Christof Schmitt
39562e7839
[SCSI] FC transport: Locking fix for common-code FC pass-through patch
...
Fix this:
------------[ cut here ]------------
Badness at block/blk-core.c:244
CPU: 0 Tainted: G W 2.6.31-rc1-00004-gd3a263a #3
Process zfcp_wq (pid: 901, task: 000000002fb7a038, ksp: 000000002f02bc78)
Krnl PSW : 0704300180000000 00000000002141ba (blk_remove_plug+0xb2/0xb8)
R:0 T:1 IO:1 EX:1 Key:0 M:1 W:0 P:0 AS:0 CC:3 PM:0 EA:3
Krnl GPRS: 0000000000000001 0000000000000001 0000000022811440 0000000022811798
000000000027ff4e 0000000000000000 0000000000000000 000000002f00f000
070000000006a0f4 000000002af70000 000000002af2a800 00000000228d1c00
0000000022811440 000000000050c708 000000002f02bca8 000000002f02bc80
Krnl Code: 00000000002141b0: b9140022 lgfr %r2,%r2
00000000002141b4: 07fe bcr 15,%r14
00000000002141b6: a7f40001 brc 15,2141b8
>00000000002141ba: a7f4ffbe brc 15,214136
00000000002141be: 0707 bcr 0,%r7
00000000002141c0: ebaff0680024 stmg %r10,%r15,104(%r15)
00000000002141c6: c0d00017c2a9 larl %r13,50c718
00000000002141cc: a7f13fc0 tmll %r15,16320
Call Trace:
([<000000000050e7d8>] C.272.16122+0x88/0x110)
[<00000000002141ec>] __blk_run_queue+0x2c/0x154
[<000000000028013a>] fc_remote_port_add+0x85e/0x95c
[<000000000037596e>] zfcp_scsi_rport_work+0xe6/0x148
[<000000000006908c>] worker_thread+0x25c/0x318
[<000000000006f10c>] kthread+0x94/0x9c
[<000000000001c2b2>] kernel_thread_starter+0x6/0xc
[<000000000001c2ac>] kernel_thread_starter+0x0/0xc
INFO: lockdep is turned off.
Last Breaking-Event-Address:
[<00000000002141b6>] blk_remove_plug+0xae/0xb8
The FC pass-through support triggers the WARN_ON(!irqs_disabled()) in
blk_plug_device. Since blk_plug_device requires being called with
disabled interrupts, use spin_lock_irqsave in fc_bsg_goose_queue to
disable the interrupts before calling into the block layer.
Signed-off-by: Christof Schmitt <christof.schmitt@de.ibm.com>
Acked-by: James Smart <james.smart@emulex.com>
Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
2009-06-26 10:29:48 -05:00
..
2009-04-13 15:04:33 -07:00
2009-06-15 10:09:35 -05:00
2009-04-07 08:31:11 -07:00
2009-04-07 08:31:11 -07:00
2009-03-28 20:30:18 +00:00
2009-06-21 11:02:59 -05:00
2009-06-21 10:52:39 -05:00
2009-05-20 17:21:14 -05:00
2009-06-12 18:01:46 +02:00
2009-06-21 11:07:06 -05:00
2009-06-25 11:08:53 -05:00
2009-06-25 11:06:41 -05:00
2009-06-21 11:07:08 -05:00
2009-05-19 11:36:08 +02:00
2009-06-17 09:50:44 -07:00
2009-06-12 18:01:45 +02:00
2009-06-12 10:02:03 -05:00
2009-05-23 15:44:13 -05:00
2009-06-12 10:02:03 -05:00
2009-06-15 10:09:31 -05:00
2009-06-21 10:52:44 -05:00
2009-04-07 08:31:11 -07:00
2009-06-21 11:12:17 -05:00
2008-01-11 18:22:30 -06:00
2009-05-15 12:23:32 -04:00
2009-03-13 15:46:42 -05:00
2009-05-15 12:24:59 -04:00
2009-05-15 12:24:59 -04:00
2008-05-02 10:18:22 -05:00
2007-06-17 16:15:56 -05:00
2009-04-07 08:31:11 -07:00
2007-06-17 16:09:29 -05:00
2009-04-03 10:17:31 -05:00
2009-04-03 10:17:31 -05:00
2009-04-03 10:17:17 -05:00
2009-04-03 10:17:17 -05:00
2009-04-22 20:39:06 +02:00
2009-04-03 09:25:23 -05:00
2008-10-16 16:52:06 +02:00
2007-08-04 09:11:06 -05:00
2008-04-27 12:19:55 -05:00
2009-06-15 21:30:27 -07:00
2008-02-06 10:41:01 -08:00
2009-03-26 21:15:29 +01:00
2009-03-26 21:15:29 +01:00
2009-04-07 08:31:11 -07:00
2009-04-07 08:31:11 -07:00
2008-04-07 12:15:44 -05:00
2009-03-24 16:38:25 -07:00
2009-03-13 15:48:43 -05:00
2009-03-12 12:58:02 -05:00
2008-04-07 12:15:40 -05:00
2009-04-07 08:31:11 -07:00
2008-05-08 10:46:56 -07:00
2007-11-25 12:19:26 +02:00
2008-12-29 11:24:12 -06:00
2009-05-11 09:50:54 +02:00
2008-12-29 11:24:14 -06:00
2008-08-29 02:13:10 -07:00
2008-01-11 18:22:35 -06:00
2008-12-29 11:24:12 -06:00
2008-04-27 12:19:55 -05:00
2007-11-25 12:19:26 +02:00
2009-06-09 10:31:46 -05:00
2008-10-09 08:56:13 +02:00
2009-04-07 08:31:11 -07:00
2008-10-09 08:56:13 +02:00
2009-01-02 12:16:18 -06:00
2009-06-21 10:52:42 -05:00
2009-04-07 08:31:11 -07:00
2008-01-11 18:28:06 -06:00
2008-12-29 11:24:12 -06:00
2008-07-27 10:31:49 -04:00
2008-12-29 11:24:12 -06:00
2009-04-07 08:31:11 -07:00
2008-12-29 11:24:12 -06:00
2009-06-21 10:52:47 -05:00
2009-06-21 10:52:47 -05:00
2009-04-07 08:31:11 -07:00
2008-08-23 12:14:12 -07:00
2009-06-21 10:52:40 -05:00
2008-12-29 11:24:22 -06:00
2008-04-27 12:33:04 -05:00
2009-06-21 11:10:41 -05:00
2009-04-07 08:31:11 -07:00
2009-06-21 10:52:39 -05:00
2009-06-21 10:52:41 -05:00
2009-06-15 21:30:27 -07:00
2008-01-30 13:14:02 -06:00
2008-12-29 11:24:19 -06:00
2008-12-28 20:00:03 +01:00
2009-06-09 10:22:45 -05:00
2009-04-07 08:31:11 -07:00
2009-06-12 18:01:45 +02:00
2008-06-05 09:23:44 -05:00
2009-03-24 16:38:25 -07:00
2008-04-07 12:19:07 -05:00
2009-06-15 10:09:30 -05:00
2007-10-12 14:51:18 -04:00
2008-01-30 13:14:02 -06:00
2008-12-29 11:24:12 -06:00
2007-10-12 14:55:07 -04:00
2009-05-23 15:44:09 -05:00
2007-07-19 10:04:50 -07:00
2008-07-27 10:31:49 -04:00
2009-04-07 08:31:11 -07:00
2008-08-23 12:14:12 -07:00
2009-03-12 12:58:10 -05:00
2009-03-12 12:58:10 -05:00
2007-11-25 12:19:26 +02:00
2008-07-27 10:31:49 -04:00
2009-06-16 14:15:46 +10:00
2009-05-20 17:21:13 -05:00
2009-05-20 17:21:13 -05:00
2008-12-29 11:24:12 -06:00
2008-01-30 13:14:02 -06:00
2009-04-03 09:25:23 -05:00
2008-08-29 02:14:46 -07:00
2009-01-02 10:22:16 -06:00
2009-06-21 11:03:54 -05:00
2009-06-21 10:52:45 -05:00
2009-06-08 12:47:40 -05:00
2009-01-02 10:22:16 -06:00
2007-07-14 19:28:10 -05:00
2009-06-21 12:01:27 -05:00
2008-10-23 11:42:17 -05:00
2009-06-21 12:01:27 -05:00
2009-03-31 01:14:44 +04:00
2008-04-19 19:10:33 -07:00
2009-05-20 17:21:13 -05:00
2007-07-18 11:16:32 -05:00
2009-06-21 12:01:27 -05:00
2008-07-02 15:06:25 -06:00
2009-05-11 09:50:55 +02:00
2008-07-27 10:31:49 -04:00
2007-10-12 14:46:58 -04:00
2009-06-26 10:29:48 -05:00
2009-06-21 11:58:11 -05:00
2009-06-21 10:52:41 -05:00
2009-06-21 10:52:46 -05:00
2007-10-12 14:38:09 -04:00
2009-01-02 10:22:16 -06:00
2009-04-21 19:40:00 -07:00
2009-06-08 12:23:35 -05:00
2008-01-11 18:22:40 -06:00
2009-05-11 09:50:54 +02:00
2009-06-21 12:01:27 -05:00
2009-06-21 10:52:37 -05:00
2009-04-03 10:17:01 -05:00
2009-06-11 11:10:35 -07:00
2009-01-02 10:58:41 -06:00
2009-01-02 10:22:16 -06:00
2009-04-07 08:31:11 -07:00
2009-04-27 09:32:30 -05:00
2008-10-20 08:52:41 -07:00
2009-06-21 12:01:27 -05:00
2008-02-07 18:02:44 -06:00
2008-04-07 12:15:39 -05:00
2009-06-12 10:02:03 -05:00
2009-01-02 12:02:25 -06:00
2009-04-07 08:31:11 -07:00
2008-01-11 18:28:57 -06:00
2008-04-16 09:28:11 -05:00
2007-11-25 12:19:26 +02:00
2008-10-23 11:42:19 -05:00
2008-08-31 01:23:17 -07:00
2008-12-29 11:24:12 -06:00
2007-11-25 12:19:26 +02:00
2008-12-29 11:24:14 -06:00
2007-07-14 18:56:33 -05:00
2009-05-11 09:50:54 +02:00
2008-04-28 17:31:13 -07:00
2008-04-07 12:19:01 -05:00
2007-10-19 23:22:55 +02:00
2008-12-29 11:24:12 -06:00
2009-06-25 11:37:23 -05:00
2007-11-29 09:24:52 -08:00