1
1

Fixed a bug that caused getopt not to work properly when command line arguments are given to the server.

Этот коммит содержится в:
sethdelliott 2010-06-24 22:02:24 +00:00
родитель 59aaeda792
Коммит 29e3ec74c3
2 изменённых файлов: 13 добавлений и 18 удалений

Просмотреть файл

@ -270,7 +270,7 @@ int
parse_parameters(struct iperf_test *test) parse_parameters(struct iperf_test *test)
{ {
int n; int n;
char *arg, **args; char *param, **params;
char len, ch; char len, ch;
char pstring[256]; char pstring[256];
char readbuf[256]; char readbuf[256];
@ -291,16 +291,16 @@ parse_parameters(struct iperf_test *test)
strcat(pstring, readbuf); strcat(pstring, readbuf);
} }
for (arg = strtok(pstring, " "), n = 0, args = NULL; arg; arg = strtok(NULL, " ")) { for (param = strtok(pstring, " "), n = 0, params = NULL; param; param = strtok(NULL, " ")) {
if ((args = realloc(args, (n+1)*sizeof(char *))) == NULL) { if ((params = realloc(params, (n+1)*sizeof(char *))) == NULL) {
perror("realloc"); perror("realloc");
return -1; return -1;
} }
args[n] = arg; params[n] = param;
n++; n++;
} }
while ((ch = getopt(n, args, "puP:Rw:f:C:")) != -1) { while ((ch = getopt(n, params, "puP:Rw:f:C:")) != -1) {
switch (ch) { switch (ch) {
case 'p': case 'p':
test->protocol = Ptcp; test->protocol = Ptcp;
@ -321,13 +321,12 @@ parse_parameters(struct iperf_test *test)
test->default_settings->unit_format = *optarg; test->default_settings->unit_format = *optarg;
break; break;
case 'C': case 'C':
memset(test->default_settings->cookie, 0, COOKIE_SIZE);
memcpy(test->default_settings->cookie, optarg, COOKIE_SIZE); memcpy(test->default_settings->cookie, optarg, COOKIE_SIZE);
break; break;
} }
} }
free(args); free(params);
return 0; return 0;
} }
@ -557,7 +556,7 @@ iperf_defaults(struct iperf_test * testp)
testp->default_settings->state = TEST_START; testp->default_settings->state = TEST_START;
testp->default_settings->mss = 0; testp->default_settings->mss = 0;
testp->default_settings->bytes = 0; testp->default_settings->bytes = 0;
memset(testp->default_settings->cookie, '\0', COOKIE_SIZE); memset(testp->default_settings->cookie, 0, COOKIE_SIZE);
} }
/**************************************************************************/ /**************************************************************************/

Просмотреть файл

@ -229,6 +229,11 @@ main(int argc, char **argv)
} }
} }
/* For subsequent calls to getopt */
optreset = 1;
optind = 0;
/* exit until this is done.... */ /* exit until this is done.... */
if (test->protocol == Pudp) { if (test->protocol == Pudp) {
printf("UDP mode not yet supported. Exiting. \n"); printf("UDP mode not yet supported. Exiting. \n");
@ -252,18 +257,9 @@ main(int argc, char **argv)
int int
iperf_run(struct iperf_test * test) iperf_run(struct iperf_test * test)
{ {
test->default_settings->state = TEST_RUNNING;
switch (test->role) { switch (test->role) {
case 's': case 's':
// The following lines are commented out until I fix the bind issue with porting return iperf_run_server(test);
// while (1) {
iperf_run_server(test);
// test->streams = NULL;
// sleep(1);
// }
return 0;
case 'c': case 'c':
return iperf_run_client(test); return iperf_run_client(test);
default: default: