[PATCH] fs: xfs: fix possible NULL pointer dereference in xfs_buf_ioapply_map()

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



In our fault-injection testing, bio_alloc() may fail with low memory and
return NULL. In this case, the variable "bio" in xfs_buf_ioapply_map()
would be NULL and then it is dereferenced by the next instruction
"bio->bi_iter.bi_sector".

The failure log is listed as follows:

[   11.929658] BUG: kernel NULL pointer dereference, address: 0000000000000015
...
[   11.932963] RIP: 0010:xfs_buf_ioapply_map+0x2cc/0x6f0 [xfs]
...
[   11.940043] Call Trace:
[   11.940247]  <TASK>
[   11.940416]  ? _raw_spin_unlock_irqrestore+0x3c/0x70
[   11.940827]  _xfs_buf_ioapply+0x134/0x4d0 [xfs]
[   11.941256]  __xfs_buf_submit+0x585/0x7a0 [xfs]
[   11.941684]  ? _xfs_buf_read+0xb7/0x120 [xfs]
[   11.942127]  _xfs_buf_read+0xb7/0x120 [xfs]
[   11.942535]  xfs_buf_read_map+0x1ba/0x650 [xfs]
[   11.942981]  ? xfs_read_agf+0x163/0x260 [xfs]
[   11.943394]  xfs_trans_read_buf_map+0x37c/0x850 [xfs]
[   11.943883]  ? xfs_read_agf+0x163/0x260 [xfs]
[   11.944306]  ? xfs_read_agf+0x163/0x260 [xfs]
[   11.944725]  xfs_read_agf+0x163/0x260 [xfs]
[   11.945141]  xfs_alloc_read_agf+0xc5/0x480 [xfs]
[   11.945574]  xfs_alloc_pagf_init+0x89/0x150 [xfs]
[   11.946037]  xfs_ag_resv_init+0x14b/0x5c0 [xfs]
[   11.946471]  xfs_fs_reserve_ag_blocks+0xf3/0x290 [xfs]
[   11.946961]  xfs_mountfs+0x2298/0x2440 [xfs]
[   11.947372]  xfs_fs_fill_super+0x1eaa/0x21e0 [xfs]
[   11.947840]  get_tree_bdev+0x3c3/0x5f0
[   11.948136]  ? xfs_fs_warn_deprecated+0x100/0x100 [xfs]
[   11.948633]  xfs_fs_get_tree+0x68/0xb0 [xfs]
[   11.949056]  vfs_get_tree+0x81/0x220
[   11.949336]  path_mount+0x1061/0x2340
[   11.949619]  ? kasan_quarantine_put+0x2c/0x1a0
[   11.949991]  ? slab_free_freelist_hook+0xde/0x160
[   11.950360]  ? mark_mounts_for_expiry+0x410/0x410
[   11.950729]  ? user_path_at_empty+0xf6/0x160
[   11.951072]  ? kmem_cache_free+0xb8/0x1a0
[   11.951384]  ? user_path_at_empty+0xf6/0x160
[   11.951717]  __se_sys_mount+0x217/0x2b0
[   11.952001]  ? __x64_sys_mount+0xd0/0xd0
[   11.952277]  ? exit_to_user_mode_prepare+0x32/0x130
[   11.952664]  do_syscall_64+0x41/0x90
[   11.952960]  entry_SYSCALL_64_after_hwframe+0x44/0xae
...
[   11.958483]  </TASK>

This patch adds a NULL check of "bio" and return immediately if it's NULL.

Reported-by: TOTE Robot <oslab@xxxxxxxxxxxxxxx>
Signed-off-by: Zixuan Fu <r33s3n6@xxxxxxxxx>
---
 fs/xfs/xfs_buf.c | 3 +++
 1 file changed, 3 insertions(+)

diff --git a/fs/xfs/xfs_buf.c b/fs/xfs/xfs_buf.c
index e1afb9e503e1..1be98503b538 100644
--- a/fs/xfs/xfs_buf.c
+++ b/fs/xfs/xfs_buf.c
@@ -1447,6 +1447,9 @@ xfs_buf_ioapply_map(
 	nr_pages = bio_max_segs(total_nr_pages);
 
 	bio = bio_alloc(bp->b_target->bt_bdev, nr_pages, op, GFP_NOIO);
+	if (!bio)
+		return;
+
 	bio->bi_iter.bi_sector = sector;
 	bio->bi_end_io = xfs_buf_bio_end_io;
 	bio->bi_private = bp;
-- 
2.25.1




[Index of Archives]     [XFS Filesystem Development (older mail)]     [Linux Filesystem Development]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux RAID]     [Linux SCSI]


  Powered by Linux