Mark Rustad
222a806af8
[SCSI] Fix NULL dereferences in scsi_cmd_to_driver
...
Avoid crashing if the private_data pointer happens to be NULL. This has
been seen sometimes when a host reset happens, notably when there are
many LUNs:
host3: Assigned Port ID 0c1601
scsi host3: libfc: Host reset succeeded on port (0c1601)
BUG: unable to handle kernel NULL pointer dereference at 0000000000000350
IP: [<ffffffff81352bb8>] scsi_send_eh_cmnd+0x58/0x3a0
<snip>
Process scsi_eh_3 (pid: 4144, threadinfo ffff88030920c000, task ffff880326b160c0)
Stack:
000000010372e6ba 0000000000000282 000027100920dca0 ffffffffa0038ee0
0000000000000000 0000000000030003 ffff88030920dc80 ffff88030920dc80
00000002000e0000 0000000a00004000 ffff8803242f7760 ffff88031326ed80
Call Trace:
[<ffffffff8105b590>] ? lock_timer_base+0x70/0x70
[<ffffffff81352fbe>] scsi_eh_tur+0x3e/0xc0
[<ffffffff81353a36>] scsi_eh_test_devices+0x76/0x170
[<ffffffff81354125>] scsi_eh_host_reset+0x85/0x160
[<ffffffff81354291>] scsi_eh_ready_devs+0x91/0x110
[<ffffffff813543fd>] scsi_unjam_host+0xed/0x1f0
[<ffffffff813546a8>] scsi_error_handler+0x1a8/0x200
[<ffffffff81354500>] ? scsi_unjam_host+0x1f0/0x1f0
[<ffffffff8106ec3e>] kthread+0x9e/0xb0
[<ffffffff81509264>] kernel_thread_helper+0x4/0x10
[<ffffffff8106eba0>] ? kthread_freezable_should_stop+0x70/0x70
[<ffffffff81509260>] ? gs_change+0x13/0x13
Code: 25 28 00 00 00 48 89 45 c8 31 c0 48 8b 87 80 00 00 00 48 8d b5 60 ff ff ff 89 d1 48 89 fb 41 89 d6 4c 89 fa 48 8b 80 b8 00 00 00
<48> 8b 80 50 03 00 00 48 8b 00 48 89 85 38 ff ff ff 48 8b 07 4c
RIP [<ffffffff81352bb8>] scsi_send_eh_cmnd+0x58/0x3a0
RSP <ffff88030920dc50>
CR2: 0000000000000350
Signed-off-by: Mark Rustad <mark.d.rustad@intel.com >
Tested-by: Marcus Dennis <marcusx.e.dennis@intel.com >
Cc: <stable@kernel.org >
Signed-off-by: James Bottomley <JBottomley@Parallels.com >
2012-07-08 09:40:51 +01:00
..
2012-03-22 12:55:29 -07:00
2012-02-19 08:08:58 -06:00
2011-07-28 12:08:55 +04:00
2012-05-23 09:40:09 +01:00
2012-03-27 08:26:35 +01:00
2012-04-25 09:29:35 +01:00
2010-05-02 11:45:12 -04:00
2012-02-19 08:08:58 -06:00
2012-05-23 09:43:13 +01:00
2012-02-19 08:09:00 -06:00
2012-02-19 08:09:00 -06:00
2012-04-23 12:03:39 +01:00
2009-12-30 12:23:27 -08:00
2009-06-10 08:54:07 -05:00
2011-06-24 11:18:57 +02:00
2012-03-04 17:54:34 -05:00
2010-10-26 10:42:34 -05:00
2009-03-12 12:58:06 -05:00
2009-12-04 12:01:44 -06:00
2010-10-26 10:42:34 -05:00
2012-04-23 12:11:47 +01:00
2012-05-17 12:27:11 -07:00
2010-01-17 12:36:33 -06:00
2011-08-27 08:36:21 -06:00
2012-07-08 09:40:51 +01:00
2007-10-12 14:51:56 -04:00
2012-06-22 22:05:31 -07:00
2009-12-04 12:00:46 -06:00
2012-02-19 10:14:52 -06:00
2008-07-26 15:14:56 -04:00
2012-01-08 19:14:57 -05:00
2008-10-21 07:47:28 -04:00
2006-09-02 15:35:15 -05:00
2012-03-23 16:58:31 -07:00
2009-04-13 11:37:07 -07:00
2011-05-24 13:03:56 -04:00
2007-10-12 14:37:50 -04:00
2007-10-12 14:37:50 -04:00
2012-02-19 08:08:57 -06:00
2012-02-29 16:55:59 -06:00
2012-02-29 13:01:06 -06:00
2009-06-15 10:09:35 -05:00
2007-10-12 14:38:01 -04:00
2012-03-04 17:54:34 -05:00
2012-02-25 14:37:46 -08:00
2010-03-12 15:53:10 -08:00
2010-10-22 22:19:10 -07:00