From 29e3ec74c3a7554bcc3100ac96198374f33cfd97 Mon Sep 17 00:00:00 2001 From: sethdelliott Date: Thu, 24 Jun 2010 22:02:24 +0000 Subject: [PATCH] Fixed a bug that caused getopt not to work properly when command line arguments are given to the server. --- src/iperf_api.c | 15 +++++++-------- src/main.c | 16 ++++++---------- 2 files changed, 13 insertions(+), 18 deletions(-) diff --git a/src/iperf_api.c b/src/iperf_api.c index 68c3e26..18d6ae7 100644 --- a/src/iperf_api.c +++ b/src/iperf_api.c @@ -270,7 +270,7 @@ int parse_parameters(struct iperf_test *test) { int n; - char *arg, **args; + char *param, **params; char len, ch; char pstring[256]; char readbuf[256]; @@ -291,16 +291,16 @@ parse_parameters(struct iperf_test *test) strcat(pstring, readbuf); } - for (arg = strtok(pstring, " "), n = 0, args = NULL; arg; arg = strtok(NULL, " ")) { - if ((args = realloc(args, (n+1)*sizeof(char *))) == NULL) { + for (param = strtok(pstring, " "), n = 0, params = NULL; param; param = strtok(NULL, " ")) { + if ((params = realloc(params, (n+1)*sizeof(char *))) == NULL) { perror("realloc"); return -1; } - args[n] = arg; + params[n] = param; n++; } - while ((ch = getopt(n, args, "puP:Rw:f:C:")) != -1) { + while ((ch = getopt(n, params, "puP:Rw:f:C:")) != -1) { switch (ch) { case 'p': test->protocol = Ptcp; @@ -321,13 +321,12 @@ parse_parameters(struct iperf_test *test) test->default_settings->unit_format = *optarg; break; case 'C': - memset(test->default_settings->cookie, 0, COOKIE_SIZE); memcpy(test->default_settings->cookie, optarg, COOKIE_SIZE); break; } } - free(args); + free(params); return 0; } @@ -557,7 +556,7 @@ iperf_defaults(struct iperf_test * testp) testp->default_settings->state = TEST_START; testp->default_settings->mss = 0; testp->default_settings->bytes = 0; - memset(testp->default_settings->cookie, '\0', COOKIE_SIZE); + memset(testp->default_settings->cookie, 0, COOKIE_SIZE); } /**************************************************************************/ diff --git a/src/main.c b/src/main.c index b6198eb..a6cb899 100644 --- a/src/main.c +++ b/src/main.c @@ -229,6 +229,11 @@ main(int argc, char **argv) } } + /* For subsequent calls to getopt */ + optreset = 1; + optind = 0; + + /* exit until this is done.... */ if (test->protocol == Pudp) { printf("UDP mode not yet supported. Exiting. \n"); @@ -252,18 +257,9 @@ main(int argc, char **argv) int iperf_run(struct iperf_test * test) { - - test->default_settings->state = TEST_RUNNING; - switch (test->role) { case 's': -// The following lines are commented out until I fix the bind issue with porting -// while (1) { - iperf_run_server(test); -// test->streams = NULL; -// sleep(1); -// } - return 0; + return iperf_run_server(test); case 'c': return iperf_run_client(test); default: