aboutsummaryrefslogtreecommitdiff
path: root/libbb
diff options
context:
space:
mode:
Diffstat (limited to 'libbb')
-rw-r--r--libbb/xconnect.c38
-rw-r--r--libbb/xfuncs.c9
2 files changed, 31 insertions, 16 deletions
diff --git a/libbb/xconnect.c b/libbb/xconnect.c
index b90aa9add..cb5ac2c8e 100644
--- a/libbb/xconnect.c
+++ b/libbb/xconnect.c
@@ -9,9 +9,9 @@
9#include <netinet/in.h> 9#include <netinet/in.h>
10#include "libbb.h" 10#include "libbb.h"
11 11
12int setsockopt_reuseaddr(int fd) 12void setsockopt_reuseaddr(int fd)
13{ 13{
14 return setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, &const_int_1, sizeof(const_int_1)); 14 setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, &const_int_1, sizeof(const_int_1));
15} 15}
16int setsockopt_broadcast(int fd) 16int setsockopt_broadcast(int fd)
17{ 17{
@@ -298,11 +298,21 @@ int xconnect_stream(const len_and_sockaddr *lsa)
298/* We hijack this constant to mean something else */ 298/* We hijack this constant to mean something else */
299/* It doesn't hurt because we will add this bit anyway */ 299/* It doesn't hurt because we will add this bit anyway */
300#define IGNORE_PORT NI_NUMERICSERV 300#define IGNORE_PORT NI_NUMERICSERV
301static char* sockaddr2str(const struct sockaddr *sa, socklen_t salen, int flags) 301static char* sockaddr2str(const struct sockaddr *sa, int flags)
302{ 302{
303 char host[128]; 303 char host[128];
304 char serv[16]; 304 char serv[16];
305 int rc = getnameinfo(sa, salen, 305 int rc;
306 socklen_t salen;
307
308 salen = LSA_SIZEOF_SA;
309#if ENABLE_FEATURE_IPV6
310 if (sa->sa_family == AF_INET)
311 salen = sizeof(struct sockaddr_in);
312 if (sa->sa_family == AF_INET6)
313 salen = sizeof(struct sockaddr_in6);
314#endif
315 rc = getnameinfo(sa, salen,
306 host, sizeof(host), 316 host, sizeof(host),
307 /* can do ((flags & IGNORE_PORT) ? NULL : serv) but why bother? */ 317 /* can do ((flags & IGNORE_PORT) ? NULL : serv) but why bother? */
308 serv, sizeof(serv), 318 serv, sizeof(serv),
@@ -327,26 +337,26 @@ static char* sockaddr2str(const struct sockaddr *sa, socklen_t salen, int flags)
327 /*return xstrdup(host);*/ 337 /*return xstrdup(host);*/
328} 338}
329 339
330char* xmalloc_sockaddr2host(const struct sockaddr *sa, socklen_t salen) 340char* xmalloc_sockaddr2host(const struct sockaddr *sa)
331{ 341{
332 return sockaddr2str(sa, salen, 0); 342 return sockaddr2str(sa, 0);
333} 343}
334 344
335char* xmalloc_sockaddr2host_noport(const struct sockaddr *sa, socklen_t salen) 345char* xmalloc_sockaddr2host_noport(const struct sockaddr *sa)
336{ 346{
337 return sockaddr2str(sa, salen, IGNORE_PORT); 347 return sockaddr2str(sa, IGNORE_PORT);
338} 348}
339 349
340char* xmalloc_sockaddr2hostonly_noport(const struct sockaddr *sa, socklen_t salen) 350char* xmalloc_sockaddr2hostonly_noport(const struct sockaddr *sa)
341{ 351{
342 return sockaddr2str(sa, salen, NI_NAMEREQD | IGNORE_PORT); 352 return sockaddr2str(sa, NI_NAMEREQD | IGNORE_PORT);
343} 353}
344char* xmalloc_sockaddr2dotted(const struct sockaddr *sa, socklen_t salen) 354char* xmalloc_sockaddr2dotted(const struct sockaddr *sa)
345{ 355{
346 return sockaddr2str(sa, salen, NI_NUMERICHOST); 356 return sockaddr2str(sa, NI_NUMERICHOST);
347} 357}
348 358
349char* xmalloc_sockaddr2dotted_noport(const struct sockaddr *sa, socklen_t salen) 359char* xmalloc_sockaddr2dotted_noport(const struct sockaddr *sa)
350{ 360{
351 return sockaddr2str(sa, salen, NI_NUMERICHOST | IGNORE_PORT); 361 return sockaddr2str(sa, NI_NUMERICHOST | IGNORE_PORT);
352} 362}
diff --git a/libbb/xfuncs.c b/libbb/xfuncs.c
index 64061e4f0..5a1090eaf 100644
--- a/libbb/xfuncs.c
+++ b/libbb/xfuncs.c
@@ -169,13 +169,18 @@ int ndelay_off(int fd)
169 return fcntl(fd, F_SETFL, fcntl(fd,F_GETFL,0) & ~O_NONBLOCK); 169 return fcntl(fd, F_SETFL, fcntl(fd,F_GETFL,0) & ~O_NONBLOCK);
170} 170}
171 171
172void xdup2(int from, int to)
173{
174 if (dup2(from, to) != to)
175 bb_perror_msg_and_die("can't duplicate file descriptor");
176}
177
172// "Renumber" opened fd 178// "Renumber" opened fd
173void xmove_fd(int from, int to) 179void xmove_fd(int from, int to)
174{ 180{
175 if (from == to) 181 if (from == to)
176 return; 182 return;
177 if (dup2(from, to) != to) 183 xdup2(from, to);
178 bb_perror_msg_and_die("can't duplicate file descriptor");
179 close(from); 184 close(from);
180} 185}
181 186