From 27eb0a30b6a6da41a05019e62d70e4a2b78bac92 Mon Sep 17 00:00:00 2001 From: Gerhard Rieger Date: Sat, 21 Jul 2012 15:42:44 +0200 Subject: [PATCH] info message during socks connect showed bad port number on little endian systems --- CHANGES | 4 ++++ xio-socks.c | 7 ++++--- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/CHANGES b/CHANGES index 6d27ccd..da78704 100644 --- a/CHANGES +++ b/CHANGES @@ -15,6 +15,10 @@ corrections: Debian bug 531078: socat execs children with SIGCHLD ignored; corrected to default. Thanks to Martin Dorey for reporting this bug. + info message during socks connect showed bad port number on little + endian systems due to wrong byte order (thanks to Peter M. Galbavy for + bug report and patch) + docu mentions option so-bindtodev but correct name is so-bindtodevice. Thanks to Jim Zimmerman for reporting. diff --git a/xio-socks.c b/xio-socks.c index f8961a2..ebc7b40 100644 --- a/xio-socks.c +++ b/xio-socks.c @@ -1,5 +1,5 @@ /* source: xio-socks.c */ -/* Copyright Gerhard Rieger 2001-2009 */ +/* Copyright Gerhard Rieger 2001-2012 */ /* Published under the GNU General Public License V.2, see file COPYING */ /* this file contains the source for opening addresses of socks4 type */ @@ -257,7 +257,8 @@ int _xioopen_socks4_prepare(const char *targetport, struct opt *opts, char **soc /* generate socks header - points to final target */ sockhead->version = 4; sockhead->action = 1; - sockhead->port = parseport(targetport, IPPROTO_TCP); + sockhead->port = parseport(targetport, IPPROTO_TCP); /* network byte + order */ if (retropt_string(opts, OPT_SOCKSPORT, socksport) < 0) { if ((se = getservbyname("socks", "tcp")) != NULL) { @@ -358,7 +359,7 @@ int _xioopen_socks4_connect(struct single *xfd, } Info11("sending socks4%s request VN=%d DC=%d DSTPORT=%d DSTIP=%d.%d.%d.%d USERID=%s%s%s", destdomname?"a":"", - sockhead->version, sockhead->action, sockhead->port, + sockhead->version, sockhead->action, ntohs(sockhead->port), ((unsigned char *)&sockhead->dest)[0], ((unsigned char *)&sockhead->dest)[1], ((unsigned char *)&sockhead->dest)[2],