From 74b73a980b91799843f8004edd90387ac482af46 Mon Sep 17 00:00:00 2001 From: Matthias Schiffer Date: Fri, 2 Nov 2012 08:56:54 +0100 Subject: Keep track of corresonding peers in associated sockets --- src/peer.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) (limited to 'src/peer.c') diff --git a/src/peer.c b/src/peer.c index 9513703..cb7626f 100644 --- a/src/peer.c +++ b/src/peer.c @@ -149,6 +149,9 @@ static void on_disestablish(fastd_context *ctx, fastd_peer *peer) { static inline void free_socket(fastd_context *ctx, fastd_peer *peer) { if (peer->sock) { if (fastd_peer_is_socket_dynamic(peer)) { + if (peer->sock->peer != peer) + exit_bug(ctx, "dynamic peer socket mismatch"); + fastd_socket_close(ctx, peer->sock); free(peer->sock); } @@ -169,14 +172,14 @@ void fastd_peer_reset_socket(fastd_context *ctx, fastd_peer *peer) { if (ctx->sock_default_v4) peer->sock = ctx->sock_default_v4; else - peer->sock = fastd_socket_open(ctx, AF_INET); + peer->sock = fastd_socket_open(ctx, peer, AF_INET); break; case AF_INET6: if (ctx->sock_default_v6) peer->sock = ctx->sock_default_v6; else - peer->sock = fastd_socket_open(ctx, AF_INET6); + peer->sock = fastd_socket_open(ctx, peer, AF_INET6); } } -- cgit v1.2.3