base: Fix forcing loopback only binding for listeners.
authorGabe Black <gabeblack@google.com>
Sat, 28 Oct 2017 07:36:13 +0000 (00:36 -0700)
committerGabe Black <gabeblack@google.com>
Mon, 30 Oct 2017 22:15:45 +0000 (22:15 +0000)
Despite online documentation, the type used for sin_addr.s_addr is not
actually an unsigned long, it is an in_addr_t. When an unsigned long is a 64
bit value, the endian conversion moves the relevant bits of the 32 bit
in_addr_t to positions which are truncated away. This forces the value to 0
which means to bind to any interface, the opposite of the intended effect.

Change-Id: I53c63dea6bd88144dfef1a9a49b478fab30a8ba2
Reviewed-on: https://gem5-review.googlesource.com/5301
Reviewed-by: Andreas Sandberg <andreas.sandberg@arm.com>
Maintainer: Andreas Sandberg <andreas.sandberg@arm.com>

src/base/socket.cc

index 5ef0f4b9eddcbd7e416c023786d1a2e9797bbe4a..a09b51fb274124e5c919188e87f569285a1737e4 100644 (file)
@@ -106,7 +106,7 @@ ListenSocket::listen(int port, bool reuse)
     struct sockaddr_in sockaddr;
     sockaddr.sin_family = PF_INET;
     sockaddr.sin_addr.s_addr =
-        htobe<unsigned long>(bindToLoopback ? INADDR_LOOPBACK : INADDR_ANY);
+        htobe<in_addr_t>(bindToLoopback ? INADDR_LOOPBACK : INADDR_ANY);
     sockaddr.sin_port = htons(port);
     // finally clear sin_zero
     memset(&sockaddr.sin_zero, 0, sizeof(sockaddr.sin_zero));