George Kennedy
dfc3fff637
scsi: scsi_debug: Sanity check block descriptor length in resp_mode_select()
...
commit e0a2c28da11e2c2b963fc01d50acbf03045ac732 upstream.
In resp_mode_select() sanity check the block descriptor len to avoid UAF.
BUG: KASAN: use-after-free in resp_mode_select+0xa4c/0xb40 drivers/scsi/scsi_debug.c:2509
Read of size 1 at addr ffff888026670f50 by task scsicmd/15032
CPU: 1 PID: 15032 Comm: scsicmd Not tainted 5.15.0-01d0625 #15
Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS
Call Trace:
<TASK>
dump_stack_lvl+0x89/0xb5 lib/dump_stack.c:107
print_address_description.constprop.9+0x28/0x160 mm/kasan/report.c:257
kasan_report.cold.14+0x7d/0x117 mm/kasan/report.c:443
__asan_report_load1_noabort+0x14/0x20 mm/kasan/report_generic.c:306
resp_mode_select+0xa4c/0xb40 drivers/scsi/scsi_debug.c:2509
schedule_resp+0x4af/0x1a10 drivers/scsi/scsi_debug.c:5483
scsi_debug_queuecommand+0x8c9/0x1e70 drivers/scsi/scsi_debug.c:7537
scsi_queue_rq+0x16b4/0x2d10 drivers/scsi/scsi_lib.c:1521
blk_mq_dispatch_rq_list+0xb9b/0x2700 block/blk-mq.c:1640
__blk_mq_sched_dispatch_requests+0x28f/0x590 block/blk-mq-sched.c:325
blk_mq_sched_dispatch_requests+0x105/0x190 block/blk-mq-sched.c:358
__blk_mq_run_hw_queue+0xe5/0x150 block/blk-mq.c:1762
__blk_mq_delay_run_hw_queue+0x4f8/0x5c0 block/blk-mq.c:1839
blk_mq_run_hw_queue+0x18d/0x350 block/blk-mq.c:1891
blk_mq_sched_insert_request+0x3db/0x4e0 block/blk-mq-sched.c:474
blk_execute_rq_nowait+0x16b/0x1c0 block/blk-exec.c:63
sg_common_write.isra.18+0xeb3/0x2000 drivers/scsi/sg.c:837
sg_new_write.isra.19+0x570/0x8c0 drivers/scsi/sg.c:775
sg_ioctl_common+0x14d6/0x2710 drivers/scsi/sg.c:941
sg_ioctl+0xa2/0x180 drivers/scsi/sg.c:1166
__x64_sys_ioctl+0x19d/0x220 fs/ioctl.c:52
do_syscall_64+0x3a/0x80 arch/x86/entry/common.c:50
entry_SYSCALL_64_after_hwframe+0x44/0xae arch/x86/entry/entry_64.S:113
Link: https://lore.kernel.org/r/1637262208-28850-1-git-send-email-george.kennedy@oracle.com
Reported-by: syzkaller <syzkaller@googlegroups.com>
Acked-by: Douglas Gilbert <dgilbert@interlog.com>
Signed-off-by: George Kennedy <george.kennedy@oracle.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2021-12-22 09:32:51 +01:00
..
2021-08-11 22:25:38 -04:00
2021-07-11 10:59:53 -07:00
2021-07-11 10:59:53 -07:00
2021-06-18 23:26:33 -04:00
2021-10-04 21:54:18 -04:00
2021-07-18 21:19:14 -04:00
2021-05-21 17:01:18 -04:00
2021-07-11 10:59:53 -07:00
2021-08-11 22:25:38 -04:00
2021-11-18 19:16:52 +01:00
2021-08-13 17:49:05 -07:00
2021-09-07 19:13:42 -07:00
2021-07-29 21:58:35 -04:00
2020-03-11 23:07:59 -04:00
2021-10-04 23:33:31 -04:00
2021-06-02 01:37:04 -04:00
2021-06-07 21:30:09 -04:00
2021-08-16 13:33:24 -04:00
2021-08-11 22:25:39 -04:00
2021-10-20 22:59:45 -04:00
2021-06-10 13:09:16 +01:00
2021-08-11 22:25:43 -04:00
2021-06-28 22:31:16 -04:00
2021-08-11 22:25:39 -04:00
2021-12-08 09:04:42 +01:00
2021-11-18 19:16:50 +01:00
2021-10-16 22:16:37 -04:00
2021-12-01 09:04:47 +01:00
2021-06-22 23:00:02 -04:00
2021-08-09 23:30:25 -04:00
2021-12-14 10:57:16 +01:00
2021-11-18 19:16:25 +01:00
2021-08-16 13:27:57 -04:00
2021-12-14 10:57:12 +01:00
2021-08-11 22:25:41 -04:00
2021-11-25 09:48:27 +01:00
2021-08-24 22:56:32 -04:00
2021-08-11 22:25:42 -04:00
2021-12-22 09:32:37 +01:00
2020-03-25 11:50:48 +01:00
2021-05-31 23:59:18 -04:00
2021-05-15 18:01:34 -04:00
2021-03-18 22:18:09 -04:00
2021-01-22 21:14:08 -05:00
2021-05-31 23:59:18 -04:00
2021-01-22 21:14:07 -05:00
2021-08-11 22:25:38 -04:00
2021-05-07 00:26:34 -07:00
2021-03-29 23:33:06 -04:00
2020-06-09 09:39:13 -07:00
2020-06-09 09:39:13 -07:00
2019-05-21 10:50:45 +02:00
2021-11-25 09:48:27 +01:00
2021-05-31 22:48:23 -04:00
2021-08-11 22:25:38 -04:00
2021-01-13 00:14:07 -05:00
2021-06-18 23:27:04 -04:00
2019-05-21 10:50:45 +02:00
2020-11-23 22:12:09 -05:00
2021-03-15 22:29:00 -04:00
2021-01-22 21:14:08 -05:00
2021-08-01 13:27:46 -04:00
2021-05-14 22:19:04 -04:00
2019-05-21 10:50:45 +02:00
2021-07-28 22:24:25 -04:00
2021-06-02 23:09:39 -04:00
2021-11-18 19:16:48 +01:00
2021-01-22 21:14:10 -05:00
2019-05-24 17:36:45 +02:00
2021-08-11 22:25:38 -04:00
2020-03-11 23:07:59 -04:00
2021-05-31 22:48:21 -04:00
2019-12-19 22:08:51 -05:00
2021-01-26 07:42:27 +01:00
2019-06-18 19:46:18 -04:00
2021-05-31 22:48:24 -04:00
2020-07-08 01:12:44 -04:00
2021-06-02 01:37:04 -04:00
2021-01-26 07:42:27 +01:00
2020-06-09 09:39:13 -07:00
2021-11-18 19:15:51 +01:00
2021-04-01 22:52:40 -04:00
2021-08-11 22:25:39 -04:00
2020-09-02 22:49:06 -04:00
2021-05-31 22:48:21 -04:00
2019-06-05 17:36:37 +02:00
2021-06-18 23:01:03 -04:00
2021-03-18 23:35:55 -04:00
2021-01-22 21:14:10 -05:00
2021-06-29 16:46:08 -04:00
2021-06-29 16:46:08 -04:00
2021-08-11 22:25:39 -04:00
2021-05-07 00:26:34 -07:00
2020-06-02 21:23:47 -04:00
2021-06-02 01:28:20 -04:00
2019-05-30 11:26:37 -07:00
2021-04-13 00:20:48 -04:00
2021-07-28 22:24:27 -04:00
2021-08-30 10:18:25 +02:00
2021-02-08 22:39:03 -05:00
2021-10-04 23:40:11 -04:00
2021-03-24 22:16:12 -04:00
2020-10-02 21:52:53 -04:00
2020-12-07 20:24:09 -05:00
2021-08-23 23:07:05 -04:00
2021-05-31 23:59:18 -04:00
2021-05-31 22:48:23 -04:00
2019-05-21 10:50:45 +02:00
2020-06-09 09:39:13 -07:00
2021-08-11 22:25:40 -04:00
2020-03-11 23:07:56 -04:00
2021-08-11 22:25:40 -04:00
2020-01-02 21:57:44 -05:00
2021-08-11 22:25:40 -04:00
2020-01-02 21:57:44 -05:00
2021-09-13 22:15:47 -04:00
2021-01-22 21:14:12 -05:00
2021-08-11 22:25:38 -04:00
2020-12-07 20:24:09 -05:00
2021-05-31 22:48:23 -04:00
2019-05-24 17:39:02 +02:00
2021-03-18 23:35:55 -04:00
2021-05-21 16:59:33 -04:00
2021-06-18 23:01:03 -04:00
2021-05-31 22:48:21 -04:00
2021-08-23 23:06:56 -04:00
2020-01-15 23:09:11 -05:00
2021-05-31 22:48:23 -04:00
2021-08-11 22:25:41 -04:00
2019-06-05 17:37:17 +02:00
2019-05-24 17:36:45 +02:00
2021-08-01 13:21:40 -04:00
2021-07-28 22:24:27 -04:00
2021-12-22 09:32:51 +01:00
2021-04-06 09:28:17 -06:00
2019-05-21 06:16:21 -04:00
2021-07-21 23:49:02 -04:00
2021-03-24 23:03:43 -04:00
2021-11-18 19:15:51 +01:00
2021-11-18 19:15:51 +01:00
2021-11-25 09:48:26 +01:00
2021-08-11 22:25:37 -04:00
2019-12-19 22:08:54 -05:00
2019-05-30 11:26:35 -07:00
2020-07-24 22:09:55 -04:00
2021-07-30 22:22:36 -04:00
2020-02-04 03:05:26 +00:00
2021-08-11 22:37:22 -04:00
2019-05-30 11:29:53 -07:00
2021-12-01 09:04:50 +01:00
2020-03-16 22:08:36 -04:00
2021-08-11 22:25:37 -04:00
2021-12-08 09:04:39 +01:00
2021-05-31 22:48:20 -04:00
2021-08-11 22:25:37 -04:00
2021-04-05 23:14:53 -04:00
2021-10-12 22:08:23 -04:00
2021-05-06 19:24:11 -07:00
2019-06-05 17:37:14 +02:00
2021-09-21 23:52:55 -04:00
2021-12-01 09:04:38 +01:00
2020-10-14 15:15:35 -07:00
2020-09-15 20:28:06 -04:00
2021-09-28 22:42:06 -04:00
2021-09-02 15:09:46 -07:00
2020-09-25 06:20:44 +02:00
2021-03-18 22:52:29 -04:00
2021-05-07 00:26:34 -07:00
2021-09-13 22:15:49 -04:00
2020-02-24 14:59:01 -05:00
2021-09-02 15:09:46 -07:00
2020-02-24 15:01:57 -05:00
2021-09-13 22:15:39 -04:00
2021-08-23 12:54:30 -06:00
2021-08-11 22:25:41 -04:00
2021-10-12 21:59:50 -04:00
2021-08-11 22:25:41 -04:00
2021-04-13 00:20:48 -04:00
2020-10-02 21:52:55 -04:00
2021-09-28 22:47:28 -04:00
2021-07-02 15:14:36 -07:00
2021-03-04 17:21:25 -05:00
2021-05-31 22:48:23 -04:00
2019-05-24 17:39:02 +02:00
2021-08-16 13:33:24 -04:00
2021-08-11 22:25:42 -04:00
2021-08-30 10:18:25 +02:00
2019-05-21 10:50:45 +02:00
2020-06-09 09:39:13 -07:00