qemu-io: reject invalid pattern
Replace the use of atoi which is used for pattern parsing currently with strtol. Atoi won't parse sedecimal pattern values (it always returns 0), but qemu-iotests use such pattern values. Also reject every pattern that is not a unsigned char as we pass the pattern to memset which expect a bye value (despite having the pattern argument declared as int). Based on an earlier patch by Stefan Weil which did not include the error handling. Signed-off-by: Christoph Hellwig <hch@lst.de> Reported-by: Stefan Weil <weil@mail.berlios.de> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
a7824a886e
commit
cf070d7ec0
44
qemu-io.c
44
qemu-io.c
@ -25,6 +25,26 @@ static BlockDriverState *bs;
|
|||||||
|
|
||||||
static int misalign;
|
static int misalign;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Parse the pattern argument to various sub-commands.
|
||||||
|
*
|
||||||
|
* Because the pattern is used as an argument to memset it must evaluate
|
||||||
|
* to an unsigned integer that fits into a single byte.
|
||||||
|
*/
|
||||||
|
static int parse_pattern(const char *arg)
|
||||||
|
{
|
||||||
|
char *endptr = NULL;
|
||||||
|
long pattern;
|
||||||
|
|
||||||
|
pattern = strtol(arg, &endptr, 0);
|
||||||
|
if (pattern < 0 || pattern > UCHAR_MAX || *endptr != '\0') {
|
||||||
|
printf("%s is not a valid pattern byte\n", arg);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return pattern;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Memory allocation helpers.
|
* Memory allocation helpers.
|
||||||
*
|
*
|
||||||
@ -304,7 +324,9 @@ read_f(int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
case 'P':
|
case 'P':
|
||||||
Pflag = 1;
|
Pflag = 1;
|
||||||
pattern = atoi(optarg);
|
pattern = parse_pattern(optarg);
|
||||||
|
if (pattern < 0)
|
||||||
|
return 0;
|
||||||
break;
|
break;
|
||||||
case 'q':
|
case 'q':
|
||||||
qflag = 1;
|
qflag = 1;
|
||||||
@ -469,7 +491,9 @@ readv_f(int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
case 'P':
|
case 'P':
|
||||||
Pflag = 1;
|
Pflag = 1;
|
||||||
pattern = atoi(optarg);
|
pattern = parse_pattern(optarg);
|
||||||
|
if (pattern < 0)
|
||||||
|
return 0;
|
||||||
break;
|
break;
|
||||||
case 'q':
|
case 'q':
|
||||||
qflag = 1;
|
qflag = 1;
|
||||||
@ -594,7 +618,9 @@ write_f(int argc, char **argv)
|
|||||||
pflag = 1;
|
pflag = 1;
|
||||||
break;
|
break;
|
||||||
case 'P':
|
case 'P':
|
||||||
pattern = atoi(optarg);
|
pattern = parse_pattern(optarg);
|
||||||
|
if (pattern < 0)
|
||||||
|
return 0;
|
||||||
break;
|
break;
|
||||||
case 'q':
|
case 'q':
|
||||||
qflag = 1;
|
qflag = 1;
|
||||||
@ -721,7 +747,9 @@ writev_f(int argc, char **argv)
|
|||||||
qflag = 1;
|
qflag = 1;
|
||||||
break;
|
break;
|
||||||
case 'P':
|
case 'P':
|
||||||
pattern = atoi(optarg);
|
pattern = parse_pattern(optarg);
|
||||||
|
if (pattern < 0)
|
||||||
|
return 0;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
return command_usage(&writev_cmd);
|
return command_usage(&writev_cmd);
|
||||||
@ -895,7 +923,9 @@ aio_read_f(int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
case 'P':
|
case 'P':
|
||||||
ctx->Pflag = 1;
|
ctx->Pflag = 1;
|
||||||
ctx->pattern = atoi(optarg);
|
ctx->pattern = parse_pattern(optarg);
|
||||||
|
if (ctx->pattern < 0)
|
||||||
|
return 0;
|
||||||
break;
|
break;
|
||||||
case 'q':
|
case 'q':
|
||||||
ctx->qflag = 1;
|
ctx->qflag = 1;
|
||||||
@ -995,7 +1025,9 @@ aio_write_f(int argc, char **argv)
|
|||||||
ctx->qflag = 1;
|
ctx->qflag = 1;
|
||||||
break;
|
break;
|
||||||
case 'P':
|
case 'P':
|
||||||
pattern = atoi(optarg);
|
pattern = parse_pattern(optarg);
|
||||||
|
if (pattern < 0)
|
||||||
|
return 0;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
free(ctx);
|
free(ctx);
|
||||||
|
Loading…
Reference in New Issue
Block a user