Fixed a bug that caused getopt not to work properly when command line arguments are given to the server.
Этот коммит содержится в:
родитель
59aaeda792
Коммит
29e3ec74c3
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
|
16
src/main.c
16
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.... */
|
/* 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:
|
||||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user