int nousage = 0;
xfs_error_injection_t err_inj;
struct sigaction action;
- const char *allopts = "d:e:f:i:m:M:n:o:p:rs:S:vVwx:X:zH";
+ int loops = 1;
+ const char *allopts = "d:e:f:i:l:m:M:n:o:p:rs:S:vVwx:X:zH";
errrange = errtag = 0;
umask(0);
exit(1);
}
break;
+ case 'l':
+ loops = atoi(optarg);
+ break;
case 'n':
operations = atoi(optarg);
break;
}
}
procid = i;
- doproc();
+ for (i = 0; !loops || (i < loops); i++)
+ doproc();
return 0;
}
}
rval = stat64(".", &statbuf);
if (rval == EIO) {
fprintf(stderr, "Detected EIO\n");
- return;
+ goto errout;
}
}
}
+errout:
+ chdir("..");
}
/*
usage(void)
{
printf("Usage: %s -H or\n", myprog);
- printf(" %s [-d dir][-e errtg][-f op_name=freq][-n nops]\n",
+ printf(" %s [-d dir][-e errtg][-f op_name=freq][-l loops][-n nops]\n",
myprog);
printf(" [-p nproc][-r len][-s seed][-v][-w][-x cmd][-z][-S][-X ncmd]\n");
printf("where\n");
printf(" the valid operation names are:\n");
show_ops(-1, " ");
printf(" -i filenum get verbose output for this nth file object\n");
+ printf(" -l loops specifies the no. of times the testrun should loop.\n");
+ printf(" *use 0 for infinite (default 1)\n");
printf(" -m modulo uid/gid modulo for chown/chgrp (default 32)\n");
printf(" -n nops specifies the no. of operations per process (default 1)\n");
printf(" -o logfile specifies logfile name\n");