diff options
author | Denis Vlasenko <vda.linux@googlemail.com> | 2007-10-19 21:39:25 +0000 |
---|---|---|
committer | Denis Vlasenko <vda.linux@googlemail.com> | 2007-10-19 21:39:25 +0000 |
commit | 1a7afb48daf054d8cc9d57e8a569a6ac90acdd7d (patch) | |
tree | fedb7857cb41b2d1bf6c5c0c1d0ae0a7da736749 /networking | |
parent | fcc569637b85626078c9c353d5552e7847b4ca0a (diff) | |
download | busybox-1a7afb48daf054d8cc9d57e8a569a6ac90acdd7d.tar.gz |
paing: make -I ethN work too (-I addr already worked)
Diffstat (limited to 'networking')
-rw-r--r-- | networking/ping.c | 21 |
1 files changed, 15 insertions, 6 deletions
diff --git a/networking/ping.c b/networking/ping.c index 8b70d9a33..bd98a21e6 100644 --- a/networking/ping.c +++ b/networking/ping.c @@ -238,9 +238,10 @@ enum { struct globals { int pingsock; + int if_index; + char *opt_I; len_and_sockaddr *source_lsa; unsigned datalen; - int if_index; unsigned long ntransmitted, nreceived, nrepeats, pingcount; uint16_t myid; unsigned tmin, tmax; /* in us */ @@ -258,9 +259,10 @@ struct globals { }; #define G (*(struct globals*)&bb_common_bufsiz1) #define pingsock (G.pingsock ) +#define if_index (G.if_index ) #define source_lsa (G.source_lsa ) +#define opt_I (G.opt_I ) #define datalen (G.datalen ) -#define if_index (G.if_index ) #define ntransmitted (G.ntransmitted) #define nreceived (G.nreceived ) #define nrepeats (G.nrepeats ) @@ -537,6 +539,8 @@ static void ping4(len_and_sockaddr *lsa) bb_error_msg_and_die("can't set multicast source interface"); xbind(pingsock, &source_lsa->sa, source_lsa->len); } + if (opt_I) + setsockopt(pingsock, SOL_SOCKET, SO_BINDTODEVICE, device, strlen(opt_I) + 1); /* enable broadcast pings */ setsockopt_broadcast(pingsock); @@ -584,6 +588,8 @@ static void ping6(len_and_sockaddr *lsa) /* untested whether "-I addr" really works for IPv6: */ if (source_lsa) xbind(pingsock, &source_lsa->sa, source_lsa->len); + if (opt_I) + setsockopt(pingsock, SOL_SOCKET, SO_BINDTODEVICE, device, strlen(opt_I) + 1); #ifdef ICMP6_FILTER { @@ -680,23 +686,26 @@ int ping_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; int ping_main(int argc, char **argv) { len_and_sockaddr *lsa; - char *opt_c, *opt_s, *opt_I; + char *opt_c, *opt_s; USE_PING6(sa_family_t af = AF_UNSPEC;) INIT_G(); - datalen = DEFDATALEN; /* initialized here rather than in global scope to work around gcc bug */ + datalen = DEFDATALEN; /* exactly one argument needed, -v and -q don't mix */ opt_complementary = "=1:q--v:v--q"; getopt32(argv, OPT_STRING, &opt_c, &opt_s, &opt_I); - if (option_mask32 & OPT_c) pingcount = xatoul(opt_c); // -c - if (option_mask32 & OPT_s) datalen = xatou16(opt_s); // -s + if (option_mask32 & OPT_c) + pingcount = xatoul(opt_c); // -c + if (option_mask32 & OPT_s) + datalen = xatou16(opt_s); // -s if (option_mask32 & OPT_I) { // -I if_index = if_nametoindex(opt_I); if (!if_index) { /* TODO: I'm not sure it takes IPv6 unless in [XX:XX..] format */ source_lsa = xdotted2sockaddr(opt_I, 0); + opt_I = NULL; /* don't try to bind to device later */ } } myid = (uint16_t) getpid(); |