CVE-2022-49217 Information
Description
In the Linux kernel the following vulnerability has been resolved:
scsi: pm8001: Fix abort all task initialization
In pm80xx_send_abort_all() the n_elem field of the ccb used is not initialized to 0. This missing initialization sometimes lead to the task completion path seeing the ccb with a non-zero n_elem resulting in the execution of invalid dma_unmap_sg() calls in pm8001_ccb_task_free() causing a crash such as:
[ 197.676341] RIP: 0010:iommu_dma_unmap_sg+0x6d/0x280
[ 197.700204] RSP: 0018:ffff889bbcf89c88 EFLAGS: 00010012
[ 197.705485] RAX: dffffc0000000000 RBX: 0000000000000000 RCX: ffffffff83d0bda0
[ 197.712687] RDX: 0000000000000002 RSI: 0000000000000000 RDI: ffff88810dffc0d0
[ 197.719887] RBP: 0000000000000000 R08: 0000000000000000 R09: ffff8881c790098b
[ 197.727089] R10: ffffed1038f20131 R11: 0000000000000001 R12: 0000000000000000
[ 197.734296] R13: ffff88810dffc0d0 R14: 0000000000000010 R15: 0000000000000000
[ 197.741493] FS: 0000000000000000(0000) GS:ffff889bbcf80000(0000) knlGS:0000000000000000
[ 197.749659] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
[ 197.755459] CR2: 00007f16c1b42734 CR3: 0000000004814000 CR4: 0000000000350ee0
[ 197.762656] Call Trace:
[ 197.765127]
Avoid this issue by always initializing the ccb n_elem field to 0 in pm8001_send_abort_all() pm8001_send_read_log() and pm80xx_send_abort_all().
Reference
https://git.kernel.org/stable/c/16cd02e0951b520bef324adb9a35afcc92501caf https://git.kernel.org/stable/c/1824a21b2cedc5774a5adfa74f5f7b90472d8677 https://git.kernel.org/stable/c/279f318bd7d6e04e6e0bc7b8cd8e190da8fa37a4 https://git.kernel.org/stable/c/326d894adf89f3c707b7784becbe241830daaab6 https://git.kernel.org/stable/c/765674e3b30121782a2b792684554baa48c61f5e https://git.kernel.org/stable/c/7f12845c8389855dbcc67baa068b6832dc4a396e https://git.kernel.org/stable/c/9914461db82caee6c519acfbe10a86fe11bcdeca https://git.kernel.org/stable/c/c8db786858d895ac58342f67767b4999ae6538fa https://git.kernel.org/stable/c/d6ec4471550cc53e96485a7124c5891e6a38d1c3
Share on: