|  | @@ -1260,12 +1260,15 @@ connection_listener_new(const struct sockaddr *listensockaddr,
 | 
	
		
			
				|  |  |        gotPort = usePort;
 | 
	
		
			
				|  |  |      } else {
 | 
	
		
			
				|  |  |        tor_addr_t addr2;
 | 
	
		
			
				|  |  | -      if (tor_addr_from_getsockname(&addr2, s)<0) {
 | 
	
		
			
				|  |  | +      struct sockaddr_storage ss;
 | 
	
		
			
				|  |  | +      socklen_t ss_len=sizeof(ss);
 | 
	
		
			
				|  |  | +      if (getsockname(s, (struct sockaddr*)&ss, &ss_len)<0) {
 | 
	
		
			
				|  |  |          log_warn(LD_NET, "getsockname() couldn't learn address for %s: %s",
 | 
	
		
			
				|  |  |                   conn_type_to_string(type),
 | 
	
		
			
				|  |  |                   tor_socket_strerror(tor_socket_errno(s)));
 | 
	
		
			
				|  |  |          gotPort = 0;
 | 
	
		
			
				|  |  |        }
 | 
	
		
			
				|  |  | +      tor_addr_from_sockaddr(&addr2, (struct sockaddr*)&ss, &gotPort);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  #ifdef HAVE_SYS_UN_H
 | 
	
		
			
				|  |  |    /*
 |