aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2021-09-09 22:00:44 +0200
committerDenys Vlasenko <vda.linux@googlemail.com>2021-09-09 22:00:44 +0200
commit7ab9cd23988b48956fcfe171d5828d61285baf40 (patch)
tree10b3d522ff45b06ac9dd9f362ddc336c5b058ee0
parent82c5eb8e4681ba345500e5c368fb54741bb0c450 (diff)
downloadbusybox-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.c20
-rw-r--r--networking/ftpgetput.c3
-rw-r--r--networking/nc.c2
-rw-r--r--networking/nc_bloaty.c7
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 */
121unsigned FAST_FUNC bb_lookup_port(const char *port, const char *protocol, unsigned default_port) 121unsigned 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 =
290int ftpgetput_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; 290int ftpgetput_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
291int ftpgetput_main(int argc UNUSED_PARAM, char **argv) 291int 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 */