diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2021-09-09 22:00:44 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2021-09-09 22:00:44 +0200 |
commit | 7ab9cd23988b48956fcfe171d5828d61285baf40 (patch) | |
tree | 10b3d522ff45b06ac9dd9f362ddc336c5b058ee0 | |
parent | 82c5eb8e4681ba345500e5c368fb54741bb0c450 (diff) | |
download | busybox-w32-7ab9cd23988b48956fcfe171d5828d61285baf40.tar.gz busybox-w32-7ab9cd23988b48956fcfe171d5828d61285baf40.tar.bz2 busybox-w32-7ab9cd23988b48956fcfe171d5828d61285baf40.zip |
libbb: make bb_lookup_port() abort on bad port names
Also, no need to preserve errno
function old new delta
.rodata 104247 104241 -6
bb_lookup_port 97 83 -14
nc_main 1039 1018 -21
------------------------------------------------------------------------------
(add/remove: 0/0 grow/shrink: 0/3 up/down: 0/-41) Total: -41 bytes
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r-- | libbb/xconnect.c | 20 | ||||
-rw-r--r-- | networking/ftpgetput.c | 3 | ||||
-rw-r--r-- | networking/nc.c | 2 | ||||
-rw-r--r-- | networking/nc_bloaty.c | 7 |
4 files changed, 10 insertions, 22 deletions
diff --git a/libbb/xconnect.c b/libbb/xconnect.c index 5dd9cfd28..f1983a68b 100644 --- a/libbb/xconnect.c +++ b/libbb/xconnect.c | |||
@@ -115,27 +115,19 @@ void FAST_FUNC xconnect(int s, const struct sockaddr *s_addr, socklen_t addrlen) | |||
115 | 115 | ||
116 | /* Return port number for a service. | 116 | /* Return port number for a service. |
117 | * If "port" is a number use it as the port. | 117 | * If "port" is a number use it as the port. |
118 | * If "port" is a name it is looked up in /etc/services, | 118 | * If "port" is a name it is looked up in /etc/services. |
119 | * if it isnt found return default_port | 119 | * if NULL, return default_port |
120 | */ | 120 | */ |
121 | unsigned FAST_FUNC bb_lookup_port(const char *port, const char *protocol, unsigned default_port) | 121 | unsigned FAST_FUNC bb_lookup_port(const char *port, const char *protocol, unsigned port_nr) |
122 | { | 122 | { |
123 | unsigned port_nr = default_port; | ||
124 | if (port) { | 123 | if (port) { |
125 | int old_errno; | ||
126 | |||
127 | /* Since this is a lib function, we're not allowed to reset errno to 0. | ||
128 | * Doing so could break an app that is deferring checking of errno. */ | ||
129 | old_errno = errno; | ||
130 | port_nr = bb_strtou(port, NULL, 10); | 124 | port_nr = bb_strtou(port, NULL, 10); |
131 | if (errno || port_nr > 65535) { | 125 | if (errno || port_nr > 65535) { |
132 | struct servent *tserv = getservbyname(port, protocol); | 126 | struct servent *tserv = getservbyname(port, protocol); |
133 | port_nr = default_port; | 127 | if (!tserv) |
134 | if (tserv) | 128 | bb_error_msg_and_die("bad port '%s'", port); |
135 | port_nr = ntohs(tserv->s_port); | 129 | port_nr = ntohs(tserv->s_port); |
136 | //FIXME: else: port string was garbage, but we don't report that??? | ||
137 | } | 130 | } |
138 | errno = old_errno; | ||
139 | } | 131 | } |
140 | return (uint16_t)port_nr; | 132 | return (uint16_t)port_nr; |
141 | } | 133 | } |
diff --git a/networking/ftpgetput.c b/networking/ftpgetput.c index 30b3dabd1..4c92f34a1 100644 --- a/networking/ftpgetput.c +++ b/networking/ftpgetput.c | |||
@@ -290,8 +290,7 @@ static const char ftpgetput_longopts[] ALIGN1 = | |||
290 | int ftpgetput_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; | 290 | int ftpgetput_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; |
291 | int ftpgetput_main(int argc UNUSED_PARAM, char **argv) | 291 | int ftpgetput_main(int argc UNUSED_PARAM, char **argv) |
292 | { | 292 | { |
293 | const char *port = "ftp"; | 293 | const char *port = NULL; |
294 | /* socket to ftp server */ | ||
295 | 294 | ||
296 | #if ENABLE_FTPPUT && !ENABLE_FTPGET | 295 | #if ENABLE_FTPPUT && !ENABLE_FTPGET |
297 | # define ftp_action ftp_send | 296 | # define ftp_action ftp_send |
diff --git a/networking/nc.c b/networking/nc.c index 705b7356a..d351bf72a 100644 --- a/networking/nc.c +++ b/networking/nc.c | |||
@@ -216,7 +216,7 @@ int nc_main(int argc, char **argv) | |||
216 | close(sfd); | 216 | close(sfd); |
217 | } else { | 217 | } else { |
218 | cfd = create_and_connect_stream_or_die(argv[0], | 218 | cfd = create_and_connect_stream_or_die(argv[0], |
219 | argv[1] ? bb_lookup_port(argv[1], "tcp", 0) : 0); | 219 | bb_lookup_port(argv[1], "tcp", 0)); |
220 | } | 220 | } |
221 | } | 221 | } |
222 | 222 | ||
diff --git a/networking/nc_bloaty.c b/networking/nc_bloaty.c index 25b95246f..cfa133eae 100644 --- a/networking/nc_bloaty.c +++ b/networking/nc_bloaty.c | |||
@@ -813,8 +813,6 @@ int nc_main(int argc UNUSED_PARAM, char **argv) | |||
813 | //if (option_mask32 & OPT_o) /* hexdump log */ | 813 | //if (option_mask32 & OPT_o) /* hexdump log */ |
814 | if (option_mask32 & OPT_p) { /* local source port */ | 814 | if (option_mask32 & OPT_p) { /* local source port */ |
815 | o_lport = bb_lookup_port(str_p, o_udpmode ? "udp" : "tcp", 0); | 815 | o_lport = bb_lookup_port(str_p, o_udpmode ? "udp" : "tcp", 0); |
816 | if (!o_lport) | ||
817 | bb_error_msg_and_die("bad local port '%s'", str_p); | ||
818 | } | 816 | } |
819 | //if (option_mask32 & OPT_r) /* randomize various things */ | 817 | //if (option_mask32 & OPT_r) /* randomize various things */ |
820 | //if (option_mask32 & OPT_u) /* use UDP */ | 818 | //if (option_mask32 & OPT_u) /* use UDP */ |
@@ -827,9 +825,8 @@ int nc_main(int argc UNUSED_PARAM, char **argv) | |||
827 | 825 | ||
828 | if (argv[0]) { | 826 | if (argv[0]) { |
829 | themaddr = xhost2sockaddr(argv[0], | 827 | themaddr = xhost2sockaddr(argv[0], |
830 | argv[1] | 828 | bb_lookup_port(argv[1], o_udpmode ? "udp" : "tcp", 0) |
831 | ? bb_lookup_port(argv[1], o_udpmode ? "udp" : "tcp", 0) | 829 | ); |
832 | : 0); | ||
833 | } | 830 | } |
834 | 831 | ||
835 | /* create & bind network socket */ | 832 | /* create & bind network socket */ |