qemu-io: Use correct range limitations

create_iovec() has a comment lamenting the lack of SIZE_T_MAX. Since
there actually is a SIZE_MAX, use it.

Two places use INT_MAX for checking the upper bound of a sector count
that is used as an argument for a blk_*() function (blk_discard() and
blk_write_compressed(), respectively). BDRV_REQUEST_MAX_SECTORS should
be used instead.

And finally, do_co_pwrite_zeroes() used to similarly check that the
sector count does not exceed INT_MAX. However, this function is now
backed by blk_co_pwrite_zeroes() which takes bytes as an argument
instead of sectors. Therefore, it should be the byte count that does not
exceed INT_MAX, not the sector count.

Signed-off-by: Max Reitz <mreitz@redhat.com>
This commit is contained in:
Max Reitz 2016-06-20 16:26:22 +02:00
parent 84c26520d3
commit a367467995

View File

@ -389,9 +389,9 @@ create_iovec(BlockBackend *blk, QEMUIOVector *qiov, char **argv, int nr_iov,
goto fail; goto fail;
} }
/* should be SIZE_T_MAX, but that doesn't exist */ if (len > SIZE_MAX) {
if (len > INT_MAX) { printf("Argument '%s' exceeds maximum size %llu\n", arg,
printf("Argument '%s' exceeds maximum size %d\n", arg, INT_MAX); (unsigned long long)SIZE_MAX);
goto fail; goto fail;
} }
@ -479,7 +479,7 @@ static int do_co_pwrite_zeroes(BlockBackend *blk, int64_t offset,
.done = false, .done = false,
}; };
if (count >> BDRV_SECTOR_BITS > INT_MAX) { if (count > INT_MAX) {
return -ERANGE; return -ERANGE;
} }
@ -500,7 +500,7 @@ static int do_write_compressed(BlockBackend *blk, char *buf, int64_t offset,
{ {
int ret; int ret;
if (count >> 9 > INT_MAX) { if (count >> 9 > BDRV_REQUEST_MAX_SECTORS) {
return -ERANGE; return -ERANGE;
} }
@ -1688,9 +1688,9 @@ static int discard_f(BlockBackend *blk, int argc, char **argv)
if (count < 0) { if (count < 0) {
print_cvtnum_err(count, argv[optind]); print_cvtnum_err(count, argv[optind]);
return 0; return 0;
} else if (count >> BDRV_SECTOR_BITS > INT_MAX) { } else if (count >> BDRV_SECTOR_BITS > BDRV_REQUEST_MAX_SECTORS) {
printf("length cannot exceed %"PRIu64", given %s\n", printf("length cannot exceed %"PRIu64", given %s\n",
(uint64_t)INT_MAX << BDRV_SECTOR_BITS, (uint64_t)BDRV_REQUEST_MAX_SECTORS << BDRV_SECTOR_BITS,
argv[optind]); argv[optind]);
return 0; return 0;
} }