diff options
Diffstat (limited to 'bgpd/bgp_fsm.c')
| -rw-r--r-- | bgpd/bgp_fsm.c | 20 | 
1 files changed, 8 insertions, 12 deletions
diff --git a/bgpd/bgp_fsm.c b/bgpd/bgp_fsm.c index 74ad65f1ec..cdd9b7ae4d 100644 --- a/bgpd/bgp_fsm.c +++ b/bgpd/bgp_fsm.c @@ -1799,18 +1799,14 @@ bgp_connect_fail(struct peer_connection *connection)   */  static void bgp_connect_in_progress_update_connection(struct peer *peer)  { -	if (bgp_getsockname(peer) < 0) { -		if (!peer->su_remote && -		    !BGP_CONNECTION_SU_UNSPEC(peer->connection)) { -			/* if connect initiated, then dest port and dest addresses are well known */ -			peer->su_remote = sockunion_dup(&peer->connection->su); -			if (sockunion_family(peer->su_remote) == AF_INET) -				peer->su_remote->sin.sin_port = -					htons(peer->port); -			else if (sockunion_family(peer->su_remote) == AF_INET6) -				peer->su_remote->sin6.sin6_port = -					htons(peer->port); -		} +	bgp_updatesockname(peer); +	if (!peer->su_remote && !BGP_CONNECTION_SU_UNSPEC(peer->connection)) { +		/* if connect initiated, then dest port and dest addresses are well known */ +		peer->su_remote = sockunion_dup(&peer->connection->su); +		if (sockunion_family(peer->su_remote) == AF_INET) +			peer->su_remote->sin.sin_port = htons(peer->port); +		else if (sockunion_family(peer->su_remote) == AF_INET6) +			peer->su_remote->sin6.sin6_port = htons(peer->port);  	}  }  | 
