From: Florian Forster Date: Fri, 13 Feb 2015 12:46:06 +0000 (+0100) Subject: Merge branches 'mark' and 'timeout' X-Git-Url: https://git.tokkee.org/?p=liboping.git;a=commitdiff_plain;h=0a2a9fe209b27e37d15096fa730bac9520dfeced;hp=-c Merge branches 'mark' and 'timeout' --- 0a2a9fe209b27e37d15096fa730bac9520dfeced diff --combined src/oping.c index 5442d60,3ae226c..6263a4d --- a/src/oping.c +++ b/src/oping.c @@@ -192,10 -192,10 +192,11 @@@ typedef struct ping_contex } ping_context_t; static double opt_interval = 1.0; + static double opt_timeout = PING_DEF_TIMEOUT; static int opt_addrfamily = PING_DEF_AF; static char *opt_srcaddr = NULL; static char *opt_device = NULL; +static char *opt_mark = NULL; static char *opt_filename = NULL; static int opt_count = -1; static int opt_send_ttl = 64; @@@ -431,12 -431,12 +432,13 @@@ static void usage_exit (const char *nam " -4|-6 force the use of IPv4 or IPv6\n" " -c count number of ICMP packets to send\n" " -i interval interval with which to send ICMP packets\n" + " -w timeout time to wait for replies, in seconds\n" " -t ttl time to live for each ICMP packet\n" " -Q qos Quality of Service (QoS) of outgoing packets\n" " Use \"-Q help\" for a list of valid options.\n" " -I srcaddr source address\n" " -D device outgoing interface name\n" + " -m mark mark to set on outgoing packets\n" " -f filename filename to read hosts from\n" #if USE_NCURSES " -u / -U force / disable UTF-8 output\n" @@@ -647,7 -647,7 +649,7 @@@ static int read_options (int argc, cha while (1) { - optchar = getopt (argc, argv, "46c:hi:I:t:Q:f:D:Z:P:m:" - optchar = getopt (argc, argv, "46c:hi:I:t:Q:f:D:Z:P:w:" ++ optchar = getopt (argc, argv, "46c:hi:I:t:Q:f:D:Z:P:m:w:" #if USE_NCURSES "uUg:" #endif @@@ -700,6 -700,18 +702,18 @@@ } break; + case 'w': + { + char *endp = NULL; + double t = strtod (optarg, &endp); + if ((optarg[0] != 0) && (endp != NULL) && (*endp == 0)) + opt_timeout = t; + else + fprintf (stderr, "Ignoring invalid timeout: %s\n", + optarg); + } + break; + case 'I': { if (opt_srcaddr != NULL) @@@ -712,10 -724,6 +726,10 @@@ opt_device = optarg; break; + case 'm': + opt_mark = optarg; + break; + case 't': { int new_send_ttl; @@@ -1670,7 -1678,7 +1684,7 @@@ int main (int argc, char **argv) /* {{ } #endif - setlocale(LC_ALL, ""); + setlocale(LC_ALL, ""); optind = read_options (argc, argv); #if !_POSIX_SAVED_IDS @@@ -1721,6 -1729,12 +1735,12 @@@ /* printf ("ts_int = %i.%09li\n", (int) ts_int.tv_sec, ts_int.tv_nsec); */ } + if (ping_setopt (ping, PING_OPT_TIMEOUT, (void*)(&opt_timeout)) != 0) + { + fprintf (stderr, "Setting timeout failed: %s\n", + ping_get_error (ping)); + } + if (opt_addrfamily != PING_DEF_AF) ping_setopt (ping, PING_OPT_AF, (void *) &opt_addrfamily); @@@ -1742,23 -1756,6 +1762,23 @@@ } } + if(opt_mark != NULL) + { + char *endp; + int mark = strtoul(opt_mark, &endp, 0); + if(opt_mark[0] != '\0' && *endp == '\0') + { + if(ping_setopt(ping, PING_OPT_MARK, (void*)(&mark)) != 0) + { + fprintf (stderr, "Setting mark failed: %s\n", + ping_get_error (ping)); + } + } + else{ + fprintf(stderr, "Ignoring invalid mark: %s\n", optarg); + } + } + if (opt_filename != NULL) { FILE *infile;