- patch from Denis Vlasenko to add bb_xbind() and bb_xlisten()
authorBernhard Reutner-Fischer <rep.dot.nop@gmail.com>
Wed, 12 Apr 2006 18:24:37 +0000 (18:24 -0000)
committerBernhard Reutner-Fischer <rep.dot.nop@gmail.com>
Wed, 12 Apr 2006 18:24:37 +0000 (18:24 -0000)
include/libbb.h
libbb/Makefile.in
libbb/bb_xbind.c [new file with mode: 0644]
libbb/bb_xlisten.c [new file with mode: 0644]
networking/dnsd.c
networking/fakeidentd.c
networking/httpd.c
networking/nc.c
networking/telnetd.c
networking/traceroute.c

index 650002b7b015d1aed12f727257525e2b3e9dc960..d70c71cc043bb52ef12bbeb75b3ed617f7c188d1 100644 (file)
@@ -147,6 +147,8 @@ extern void  bb_fflush_stdout_and_exit(int retval) ATTRIBUTE_NORETURN;
 extern void xstat(const char *filename, struct stat *buf);
 extern int  bb_xsocket(int domain, int type, int protocol);
 extern void bb_xdaemon(int nochdir, int noclose);
+extern void bb_xbind(int sockfd, struct sockaddr *my_addr, socklen_t addrlen);
+extern void bb_xlisten(int s, int backlog);
 
 #define BB_GETOPT_ERROR 0x80000000UL
 extern const char *bb_opt_complementally;
index 3fb945e31fab04519b1d46b0b440b475364485be..f05bf80ed766ee590bc5c020c314067433c5cd3f 100644 (file)
@@ -30,7 +30,7 @@ LIBBB-y:= \
        trim.c u_signal_names.c vdprintf.c verror_msg.c \
        vherror_msg.c vperror_msg.c wfopen.c xconnect.c xgetcwd.c xstat.c \
        xgethostbyname.c xgethostbyname2.c xreadlink.c xregcomp.c xgetlarg.c \
-       bb_xsocket.c bb_xdaemon.c \
+       bb_xsocket.c bb_xdaemon.c bb_xbind.c bb_xlisten.c \
        get_terminal_width_height.c fclose_nonstdin.c fflush_stdout_and_exit.c \
        getopt_ulflags.c default_error_retval.c wfopen_input.c speed_table.c \
        perror_nomsg_and_die.c perror_nomsg.c skip_whitespace.c bb_askpass.c \
diff --git a/libbb/bb_xbind.c b/libbb/bb_xbind.c
new file mode 100644 (file)
index 0000000..8a45af3
--- /dev/null
@@ -0,0 +1,18 @@
+/* vi: set sw=4 ts=4: */
+/*
+ * bb_xbind.c - a bind() which dies on failure with error message
+ *
+ * Copyright (C) 2006 Denis Vlasenko
+ *
+ * Licensed under LGPL, see file docs/lesser.txt in this tarball for details.
+ */
+#include <sys/types.h>
+#include <sys/socket.h>
+#include "libbb.h"
+
+void bb_xbind(int sockfd, struct sockaddr *my_addr, socklen_t addrlen)
+{
+       if (bind(sockfd, my_addr, addrlen))
+               bb_perror_msg_and_die("bind");
+}
+
diff --git a/libbb/bb_xlisten.c b/libbb/bb_xlisten.c
new file mode 100644 (file)
index 0000000..a42d61a
--- /dev/null
@@ -0,0 +1,17 @@
+/* vi: set sw=4 ts=4: */
+/*
+ * bb_xlisten.c - a listen() which dies on failure with error message
+ *
+ * Copyright (C) 2006 Denis Vlasenko
+ *
+ * Licensed under LGPL, see file docs/lesser.txt in this tarball for details.
+ */
+#include <sys/socket.h>
+#include "libbb.h"
+
+void bb_xlisten(int s, int backlog)
+{
+       if (listen(s, backlog))
+               bb_perror_msg_and_die("listen");
+}
+
index d78ea04c09196a23f9bdfc5e6d989dbf2ce4a127..b9d022170808f709357f01a7d7c171ec75880059 100644 (file)
@@ -216,9 +216,8 @@ listen_socket(char *iface_addr, int listen_port)
        a.sin_family = AF_INET;
        if (!inet_aton(iface_addr, &a.sin_addr))
                bb_perror_msg_and_die("bad iface address");
-       if (bind(s, (struct sockaddr *)&a, sizeof(a)) < 0)
-               bb_perror_msg_and_die("bind() failed");
-       listen(s, 50);
+       bb_xbind(s, (struct sockaddr *)&a, sizeof(a));
+       listen(s, 50); /* bb_xlisten? */
        sprintf(msg, "accepting UDP packets on addr:port %s:%d\n",
                iface_addr, (int)listen_port);
        log_message(LOG_FILE, msg);
index 26efdcb349e750671d1ec2a9fa3f357ef4f09a81..cae6b813821a790a31afe0fc2a55a088ac5e4195 100644 (file)
@@ -113,10 +113,10 @@ static void inetbind(void)
        addr.sin_family = AF_INET;
        addr.sin_port = htons(port);
 
-       if (bind(s, (struct sockaddr *)&addr, len) < 0)
+       if (bind(s, (struct sockaddr *)&addr, len) < 0) /* bb_xbind? */
                bb_perror_msg_and_die("Cannot bind() port %i", IDENT_PORT);
 
-       if (listen(s, 5) < 0)
+       if (listen(s, 5) < 0) /* bb_xlisten? */
                bb_perror_msg_and_die("Cannot listen() on port %i", IDENT_PORT);
 
        movefd(s, 0);
index 354c199e7902d28ea2b22bda989efe57bf0934bb..0f6174140828e85d5b8a06625631394609f4f314 100644 (file)
@@ -958,12 +958,9 @@ static int openServer(void)
 #else
   setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, (void *)&on, sizeof(on)) ;
 #endif
-  if (bind(fd, (struct sockaddr *)&lsocket, sizeof(lsocket)) == 0) {
-    listen(fd, 9);
-    signal(SIGCHLD, SIG_IGN);   /* prevent zombie (defunct) processes */
-  } else {
-    bb_perror_msg_and_die("bind");
-  }
+  bb_xbind(fd, (struct sockaddr *)&lsocket, sizeof(lsocket));
+  listen(fd, 9); /* bb_xlisten? */
+  signal(SIGCHLD, SIG_IGN);   /* prevent zombie (defunct) processes */
   return fd;
 }
 #endif  /* CONFIG_FEATURE_HTTPD_USAGE_FROM_INETD_ONLY */
index 86f0b99df79f53ece02e4d308636b5524f0fe02a..57b0917442d2513ffbd25f844a15fef94673fa5a 100644 (file)
@@ -90,16 +90,13 @@ int nc_main(int argc, char **argv)
                memset(&address.sin_addr, 0, sizeof(address.sin_addr));
                address.sin_port = lport;
 
-               if (bind(sfd, (struct sockaddr *) &address, sizeof(address)) < 0)
-                       bb_perror_msg_and_die("bind");
+               bb_xbind(sfd, (struct sockaddr *) &address, sizeof(address));
        }
 
        if (do_listen) {
                socklen_t addrlen = sizeof(address);
 
-               if (listen(sfd, 1) < 0)
-                       bb_perror_msg_and_die("listen");
-
+               bb_xlisten(sfd, 1);
                if ((tmpfd = accept(sfd, (struct sockaddr *) &address, &addrlen)) < 0)
                        bb_perror_msg_and_die("accept");
 
index d53f56b14edc9e92b95f82a73e5cf0d65cdc5dfa..1a53c0c0ccf3ed830fb86f6988ced32f8debee36 100644 (file)
@@ -461,14 +461,8 @@ telnetd_main(int argc, char **argv)
        sa.sin_addr = bind_addr;
 #endif
 
-       if (bind(master_fd, (struct sockaddr *) &sa, sizeof(sa)) < 0) {
-               bb_perror_msg_and_die("bind");
-       }
-
-       if (listen(master_fd, 1) < 0) {
-               bb_perror_msg_and_die("listen");
-       }
-
+       bb_xbind(master_fd, (struct sockaddr *) &sa, sizeof(sa));
+       bb_xlisten(master_fd, 1);
        bb_xdaemon(0, 0);
 
        maxfd = master_fd;
index 0abd9047d55e45088999c582b2126317e4f73e6e..4f7ebf1769e6bf3231323e83c0f71f289c086b8b 100644 (file)
@@ -1253,9 +1253,7 @@ traceroute_main(int argc, char *argv[])
 
        outip->ip_src = from->sin_addr;
 #ifndef IP_HDRINCL
-       if (bind(sndsock, (struct sockaddr *)from, sizeof(*from)) < 0) {
-               bb_perror_msg_and_die("bind");
-       }
+       bb_xbind(sndsock, (struct sockaddr *)from, sizeof(*from));
 #endif
 
        fprintf(stderr, "traceroute to %s (%s)", hostname, inet_ntoa(to->sin_addr));