aboutsummaryrefslogtreecommitdiffstats
path: root/block/bio.c
diff options
context:
space:
mode:
authorGustavo A. R. Silva <gustavoars@kernel.org>2020-06-19 19:49:49 -0500
committerJens Axboe <axboe@kernel.dk>2020-06-24 09:15:58 -0600
commit1f4fe21cf45c799a2fef41ae23dd2a8a8dbb93b7 (patch)
treeb76203bdf8e91805a2515cf1ccbca8e63c57d965 /block/bio.c
parentblock: create the request_queue debugfs_dir on registration (diff)
downloadlinux-dev-1f4fe21cf45c799a2fef41ae23dd2a8a8dbb93b7.tar.xz
linux-dev-1f4fe21cf45c799a2fef41ae23dd2a8a8dbb93b7.zip
block: bio: Use struct_size() in kmalloc()
Make use of the struct_size() helper instead of an open-coded version in order to avoid any potential type mistakes. This code was detected with the help of Coccinelle and, audited and fixed manually. Signed-off-by: Gustavo A. R. Silva <gustavoars@kernel.org> Addresses-KSPP-ID: https://github.com/KSPP/linux/issues/83 Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'block/bio.c')
-rw-r--r--block/bio.c4
1 files changed, 1 insertions, 3 deletions
diff --git a/block/bio.c b/block/bio.c
index a7366c02c9b5..fb5533416fa6 100644
--- a/block/bio.c
+++ b/block/bio.c
@@ -444,9 +444,7 @@ struct bio *bio_alloc_bioset(gfp_t gfp_mask, unsigned int nr_iovecs,
if (nr_iovecs > UIO_MAXIOV)
return NULL;
- p = kmalloc(sizeof(struct bio) +
- nr_iovecs * sizeof(struct bio_vec),
- gfp_mask);
+ p = kmalloc(struct_size(bio, bi_inline_vecs, nr_iovecs), gfp_mask);
front_pad = 0;
inline_vecs = nr_iovecs;
} else {