diff options
author | Erik Andersen | 2000-01-29 06:29:32 +0000 |
---|---|---|
committer | Erik Andersen | 2000-01-29 06:29:32 +0000 |
commit | a6d0dbc86fd8a84f9c2a05f77013bd3eb5efa697 (patch) | |
tree | 084110d01c73b978088256492695d90fb7d52ef0 | |
parent | 8e759aa31fa3f0dea6686cb7194398e68ff76696 (diff) | |
download | busybox-a6d0dbc86fd8a84f9c2a05f77013bd3eb5efa697.zip busybox-a6d0dbc86fd8a84f9c2a05f77013bd3eb5efa697.tar.gz |
Minor change. init now uses dup2.
-Erik
-rw-r--r-- | init.c | 5 | ||||
-rw-r--r-- | init/init.c | 5 | ||||
-rw-r--r-- | networking/ping.c | 9 | ||||
-rw-r--r-- | ping.c | 9 |
4 files changed, 18 insertions, 10 deletions
@@ -366,8 +366,9 @@ static pid_t run(char* command, message(LOG|CONSOLE, "Bummer, can't open %s\r\n", terminal); exit(1); } - dup(fd); - dup(fd); + dup2(fd, 0); + dup2(fd, 1); + dup2(fd, 2); tcsetpgrp (0, getpgrp()); set_term(0); diff --git a/init/init.c b/init/init.c index dd92854..722ccd2 100644 --- a/init/init.c +++ b/init/init.c @@ -366,8 +366,9 @@ static pid_t run(char* command, message(LOG|CONSOLE, "Bummer, can't open %s\r\n", terminal); exit(1); } - dup(fd); - dup(fd); + dup2(fd, 0); + dup2(fd, 1); + dup2(fd, 2); tcsetpgrp (0, getpgrp()); set_term(0); diff --git a/networking/ping.c b/networking/ping.c index 5cadac3..5b68019 100644 --- a/networking/ping.c +++ b/networking/ping.c @@ -1,5 +1,5 @@ /* - * $Id: ping.c,v 1.8 2000/01/29 05:52:40 erik Exp $ + * $Id: ping.c,v 1.9 2000/01/29 06:29:32 erik Exp $ * Mini ping implementation for busybox * * Copyright (C) 1999 by Randolph Chung <tausq@debian.org> @@ -312,14 +312,17 @@ static void unpack(char *buf, int sz, struct sockaddr_in *from) static void ping(char *host) { - struct protoent *proto=NULL; + struct protoent *proto; struct hostent *h; char buf[MAXHOSTNAMELEN]; char packet[DEFDATALEN + MAXIPLEN + MAXICMPLEN]; int sockopt; proto = getprotobyname("icmp"); - if ((pingsock = socket(AF_INET, SOCK_RAW, (proto)? proto->p_proto : 1 )) < 0) { /* 1 == ICMP */ + /* if getprotobyname failed, just silently force + * proto->p_proto to have the correct value for "icmp" */ + if ((pingsock = socket(AF_INET, SOCK_RAW, + (proto ? proto->p_proto : 1))) < 0) { /* 1 == ICMP */ if (errno == EPERM) { fprintf(stderr, "ping: permission denied. (are you root?)\n"); } else { @@ -1,5 +1,5 @@ /* - * $Id: ping.c,v 1.8 2000/01/29 05:52:40 erik Exp $ + * $Id: ping.c,v 1.9 2000/01/29 06:29:32 erik Exp $ * Mini ping implementation for busybox * * Copyright (C) 1999 by Randolph Chung <tausq@debian.org> @@ -312,14 +312,17 @@ static void unpack(char *buf, int sz, struct sockaddr_in *from) static void ping(char *host) { - struct protoent *proto=NULL; + struct protoent *proto; struct hostent *h; char buf[MAXHOSTNAMELEN]; char packet[DEFDATALEN + MAXIPLEN + MAXICMPLEN]; int sockopt; proto = getprotobyname("icmp"); - if ((pingsock = socket(AF_INET, SOCK_RAW, (proto)? proto->p_proto : 1 )) < 0) { /* 1 == ICMP */ + /* if getprotobyname failed, just silently force + * proto->p_proto to have the correct value for "icmp" */ + if ((pingsock = socket(AF_INET, SOCK_RAW, + (proto ? proto->p_proto : 1))) < 0) { /* 1 == ICMP */ if (errno == EPERM) { fprintf(stderr, "ping: permission denied. (are you root?)\n"); } else { |