Skip to content

Commit 9967d8a

Browse files
ktraghavendraaxboe
authored andcommitted
null_blk: Null pointer deference problem in alloc_page_buffers
If we load the null_blk module with bs=8k we get following oops: [ 3819.812190] BUG: unable to handle kernel NULL pointer dereference at 0000000000000008 [ 3819.812387] IP: [<ffffffff81170aa5>] create_empty_buffers+0x28/0xaf [ 3819.812527] PGD 219244067 PUD 215a06067 PMD 0 [ 3819.812640] Oops: 0000 [#1] SMP [ 3819.812772] Modules linked in: null_blk(+) Fix that by resetting block size to PAGE_SIZE if it is greater than PAGE_SIZE Reported-by: Sumanth <sumantk2@linux.vnet.ibm.com> Signed-off-by: Raghavendra K T <raghavendra.kt@linux.vnet.ibm.com> Reviewed-by: Matias Bjorling <m@bjorling.me> Signed-off-by: Jens Axboe <axboe@kernel.dk>
1 parent 26d5805 commit 9967d8a

File tree

1 file changed

+5
-0
lines changed

1 file changed

+5
-0
lines changed

drivers/block/null_blk.c

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -622,6 +622,11 @@ static int __init null_init(void)
622622
irqmode = NULL_IRQ_NONE;
623623
}
624624
#endif
625+
if (bs > PAGE_SIZE) {
626+
pr_warn("null_blk: invalid block size\n");
627+
pr_warn("null_blk: defaults block size to %lu\n", PAGE_SIZE);
628+
bs = PAGE_SIZE;
629+
}
625630

626631
if (queue_mode == NULL_Q_MQ && use_per_node_hctx) {
627632
if (submit_queues < nr_online_nodes) {

0 commit comments

Comments
 (0)