Larry Finger
4ff61c8f7b
kaweth: Fix locking to be SMP-safe
...
On an SMP system, the following message is printed. The patch below gets
fixes the problem.
=================================
[ INFO: inconsistent lock state ]
2.6.29-Linus-05093-gc31f403 #57
---------------------------------
inconsistent {hardirq-on-W} -> {in-hardirq-W} usage.
bash/4105 [HC1[1]:SC0[0]:HE0:SE1] takes:
(&kaweth->device_lock){+...}, at: [<ffffffffa01aa286>]
kaweth_usb_receive+0x77/0x1af [kaw eth]
{hardirq-on-W} state was registered at:
[<ffffffff80260503>] __lock_acquire+0x753/0x1685
[<ffffffff8026148a>] lock_acquire+0x55/0x71
[<ffffffff80461ba6>] _spin_lock+0x31/0x3d
[<ffffffffa01aaa0c>] kaweth_start_xmit+0x2b/0x1e1 [kaweth]
[<ffffffff803eccd3>] dev_hard_start_xmit+0x22e/0x2ad
[<ffffffff803fe120>] __qdisc_run+0xf2/0x203
[<ffffffff803ed0cd>] dev_queue_xmit+0x263/0x39b
[<ffffffffa03a47cb>] packet_sendmsg_spkt+0x1c4/0x20a [af_packet]
[<ffffffff803de0c2>] sock_sendmsg+0xe4/0xfd
[<ffffffff803dec8f>] sys_sendto+0xe4/0x10c
[<ffffffff8020bccb>] system_call_fastpath+0x16/0x1b
[<ffffffffffffffff>] 0xffffffffffffffff
irq event stamp: 1280
hardirqs last enabled at (1279): [<ffffffff80461a71>]
_spin_unlock_irqrestore+0x44/0x4c
hardirqs last disabled at (1280): [<ffffffff8020bad7>]
save_args+0x67/0x70
softirqs last enabled at (660): [<ffffffff8024192c>]
__do_softirq+0x14d/0x15d
softirqs last disabled at (651): [<ffffffff8020ce9c>]
call_softirq+0x1c/0x28
Signed-off-by: Larry Finger <Larry.Finger@lwfinger.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
2009-04-02 01:09:43 -07:00
..
2009-03-27 00:46:42 -07:00
2009-02-17 17:26:05 -08:00
2009-03-28 20:29:51 +00:00
2009-03-23 01:18:58 -07:00
2009-02-17 17:26:06 -08:00
2009-02-17 17:26:07 -08:00
2009-03-27 00:25:24 -07:00
2009-03-25 17:23:38 -07:00
2008-12-17 15:37:55 -08:00
2009-02-26 23:07:38 -08:00
2008-11-06 22:43:03 -08:00
2009-03-27 00:46:59 -07:00
2009-03-26 01:00:55 -07:00
2009-03-26 01:10:00 -07:00
2009-03-24 16:38:22 -07:00
2009-02-09 23:25:33 -08:00
2009-01-21 14:33:50 -08:00
2009-03-31 14:43:54 -07:00
2009-03-21 16:50:20 -07:00
2009-04-02 00:59:08 -07:00
2009-03-28 20:29:51 +00:00
2009-03-20 01:17:24 -07:00
2009-04-02 01:02:33 -07:00
2009-01-21 14:33:50 -08:00
2009-03-26 15:54:36 -07:00
2009-03-24 16:32:13 -07:00
2009-03-17 15:01:30 -07:00
2009-03-30 20:25:13 +05:30
2009-03-26 01:22:01 -07:00
2009-03-17 15:01:30 -07:00
2009-03-31 15:07:21 -07:00
2009-02-17 17:37:59 -08:00
2009-03-31 14:43:54 -07:00
2009-03-20 02:27:41 -07:00
2009-04-02 01:09:43 -07:00
2009-04-02 00:33:46 -07:00
2009-03-27 00:46:44 -07:00
2009-03-24 16:38:23 -07:00
2009-03-29 13:52:21 -07:00
2009-02-26 22:21:54 -08:00
2009-01-21 14:02:21 -08:00
2008-12-08 01:14:16 -08:00
2009-03-27 00:46:38 -07:00
2009-02-14 23:12:00 -08:00
2008-04-29 01:55:11 -04:00
2009-01-21 14:02:23 -08:00
2009-02-07 02:52:44 -08:00
2009-01-21 14:02:24 -08:00
2009-01-21 14:02:24 -08:00
2009-01-21 14:02:25 -08:00
2008-11-03 21:11:17 -08:00
2009-03-13 11:47:48 -07:00
2009-03-13 11:48:18 -07:00
2009-01-11 00:06:36 -08:00
2008-11-25 18:12:49 -08:00
2009-01-11 00:06:36 -08:00
2009-01-21 14:02:41 -08:00
2009-03-18 18:17:48 -07:00
2009-03-27 00:46:54 -07:00
2009-02-26 22:21:58 -08:00
2009-01-04 16:10:02 -08:00
2009-01-21 14:33:50 -08:00
2008-11-25 18:25:32 -08:00
2008-11-03 21:11:17 -08:00
2009-03-27 00:46:51 -07:00
2008-11-12 23:37:49 -08:00
2009-01-07 18:10:24 -08:00
2009-03-24 16:38:22 -07:00
2008-10-08 16:29:57 -07:00
2009-03-24 23:32:03 -07:00
2009-03-01 21:35:16 -08:00
2009-01-15 15:29:35 -08:00
2009-03-24 16:38:22 -07:00
2008-10-08 16:29:57 -07:00
2009-03-24 16:38:22 -07:00
2009-02-12 16:53:48 -08:00
2009-02-12 16:53:22 -08:00
2009-03-20 02:27:41 -07:00
2009-02-12 16:54:48 -08:00
2009-03-02 22:32:48 -08:00
2009-02-15 23:32:01 -08:00
2009-02-15 23:32:01 -08:00
2009-03-22 21:24:19 -07:00
2009-03-10 04:52:03 -07:00
2009-03-02 22:32:45 -08:00
2009-02-15 23:32:01 -08:00
2009-03-10 04:52:03 -07:00
2009-03-02 22:32:43 -08:00
2009-03-10 05:04:16 -07:00
2009-02-03 00:15:35 -08:00
2008-09-22 19:27:10 -07:00
2009-03-24 16:38:22 -07:00
2009-03-27 00:46:55 -07:00
2009-01-07 17:34:36 -08:00
2009-01-07 17:34:36 -08:00
2009-03-24 16:38:22 -07:00
2009-02-10 01:56:45 -08:00
2009-03-27 00:46:52 -07:00
2008-11-21 17:31:51 -08:00
2009-03-22 21:28:39 -07:00
2008-06-24 22:57:16 -04:00
2009-03-26 01:22:01 -07:00
2009-03-11 23:26:02 -07:00
2008-11-20 20:28:00 -08:00
2009-03-21 13:25:25 -07:00
2009-02-17 17:21:08 -08:00
2009-03-27 00:46:51 -07:00
2009-03-27 00:46:50 -07:00
2008-12-29 18:42:33 -08:00
2009-01-07 17:30:09 -08:00
2009-01-21 14:33:50 -08:00
2009-03-21 19:06:53 -07:00
2008-11-25 18:23:59 -08:00
2009-03-27 00:46:55 -07:00
2009-03-27 00:16:21 -07:00
2009-03-27 00:46:52 -07:00
2009-02-26 22:21:59 -08:00
2008-12-21 02:54:30 -07:00
2009-04-02 00:57:01 -07:00
2008-05-01 11:05:58 -06:00
2009-02-26 22:42:51 -08:00
2009-02-01 00:58:26 -08:00
2009-03-10 05:29:52 -07:00
2009-03-23 15:37:09 -07:00
2009-02-04 16:42:35 -08:00
2009-02-01 00:52:34 -08:00
2009-02-04 16:43:44 -08:00
2009-03-29 01:19:37 -07:00
2009-03-18 23:28:22 -07:00
2009-02-26 22:22:02 -08:00
2009-01-07 18:13:49 -08:00
2009-02-26 21:02:19 -08:00
2008-11-25 18:24:57 -08:00
2008-06-11 21:58:32 -04:00
2009-01-11 00:06:36 -08:00
2009-03-27 00:46:49 -07:00
2009-01-21 14:33:50 -08:00
2009-01-06 10:47:44 -08:00
2008-11-20 20:14:53 -08:00
2008-11-03 21:11:17 -08:00
2009-01-07 17:26:14 -08:00
2008-08-14 04:26:38 -04:00
2008-12-03 22:19:52 -08:00
2009-01-13 14:48:00 +11:00
2009-03-24 16:38:22 -07:00
2009-03-05 02:06:47 -08:00
2009-03-02 01:55:15 -08:00
2009-04-02 00:33:46 -07:00
2009-01-21 14:33:50 -08:00
2009-03-27 00:46:48 -07:00
2008-12-15 15:14:59 -08:00
2008-11-03 21:11:17 -08:00
2008-11-25 18:24:38 -08:00
2008-11-20 20:14:53 -08:00
2009-03-27 00:46:54 -07:00
2008-12-03 22:19:52 -08:00
2009-01-11 00:06:36 -08:00
2009-03-24 16:38:22 -07:00
2008-10-08 16:29:57 -07:00
2008-11-12 23:37:49 -08:00
2008-11-03 21:11:17 -08:00
2009-03-24 16:38:22 -07:00
2009-03-13 13:16:13 -07:00
2009-04-02 00:33:46 -07:00
2008-11-03 21:11:17 -08:00
2009-03-24 16:38:25 -07:00
2009-03-24 16:38:22 -07:00
2008-11-12 23:38:14 -08:00
2009-03-23 14:29:24 -07:00
2008-08-29 02:13:32 -07:00
2009-02-26 22:21:58 -08:00
2008-11-28 15:55:00 -08:00
2009-02-26 22:21:55 -08:00
2009-02-11 21:01:33 +01:00
2009-01-11 00:06:36 -08:00
2008-12-25 23:52:57 -08:00
2009-03-28 23:55:58 -07:00
2008-12-05 22:54:40 -08:00
2009-03-27 00:46:53 -07:00
2008-03-26 00:18:00 -04:00
2009-03-27 00:46:53 -07:00
2009-03-28 23:37:27 -07:00
2009-03-29 01:39:41 -07:00
2009-02-20 00:58:45 -08:00
2009-02-26 23:07:39 -08:00
2008-11-12 23:38:14 -08:00
2009-01-21 14:33:50 -08:00
2008-12-08 01:14:16 -08:00
2009-01-21 14:33:50 -08:00
2009-01-07 17:26:48 -08:00
2009-03-13 16:09:12 -07:00
2009-03-13 16:09:12 -07:00
2008-08-14 04:26:38 -04:00
2009-03-13 16:09:12 -07:00
2009-03-10 05:22:43 -07:00
2009-02-17 17:21:12 -08:00
2009-01-21 15:55:15 -08:00
2009-02-01 00:45:17 -08:00
2008-06-03 15:00:14 -04:00
2009-02-03 00:15:35 -08:00
2008-11-10 15:11:56 -05:00
2009-01-21 14:33:50 -08:00
2008-08-07 02:11:14 -04:00
2009-03-25 17:19:34 -07:00
2009-04-02 01:06:01 -07:00
2009-02-26 23:07:31 -08:00
2008-12-03 22:19:52 -08:00
2008-05-22 06:26:21 -04:00
2009-02-17 17:21:14 -08:00
2008-09-24 18:49:04 -04:00
2009-01-07 17:56:54 -08:00
2009-03-24 16:38:22 -07:00
2009-01-21 14:03:42 -08:00
2009-03-27 00:46:46 -07:00
2008-11-12 23:38:36 -08:00
2009-03-18 23:31:49 -07:00
2009-03-18 23:31:50 -07:00
2009-01-07 17:35:41 -08:00
2009-02-26 22:21:55 -08:00
2009-01-21 14:33:50 -08:00
2009-02-03 15:08:36 -08:00
2008-08-07 01:55:50 -04:00
2009-01-07 18:09:36 -08:00
2009-01-06 11:28:06 +01:00
2009-03-24 16:38:22 -07:00
2009-03-28 20:29:51 +00:00
2009-03-24 16:38:22 -07:00
2009-03-13 21:44:51 +00:00
2009-03-27 00:46:47 -07:00
2009-01-11 00:06:36 -08:00
2009-03-27 00:46:47 -07:00
2009-03-27 00:46:48 -07:00
2009-03-27 00:46:38 -07:00
2009-03-19 23:59:27 -07:00
2009-03-24 16:38:22 -07:00
2009-02-20 00:38:51 -08:00
2008-04-25 02:08:54 -04:00
2008-11-03 21:11:17 -08:00
2008-11-12 23:38:36 -08:00
2008-11-12 23:38:36 -08:00
2009-03-23 14:42:09 -07:00
2008-04-16 20:06:50 -04:00
2009-02-26 22:22:00 -08:00
2008-11-25 18:25:49 -08:00
2008-12-08 01:14:16 -08:00
2009-02-12 16:40:20 -08:00
2009-03-23 14:29:24 -07:00
2008-08-29 02:13:33 -07:00
2009-02-26 22:22:00 -08:00
2009-02-02 23:19:50 -08:00
2009-03-23 13:35:04 -07:00
2009-03-12 09:27:53 -07:00
2008-08-29 02:14:29 -07:00
2009-03-23 14:29:24 -07:00
2009-03-23 14:29:24 -07:00
2008-08-29 02:14:43 -07:00
2009-03-20 00:51:22 -07:00
2009-03-24 16:38:22 -07:00
2009-02-26 23:20:56 -08:00
2009-02-26 23:20:56 -08:00
2009-03-29 01:39:49 -07:00
2009-02-26 23:16:40 -08:00
2009-01-07 17:27:15 -08:00
2008-05-30 22:18:02 -04:00
2009-02-03 00:15:35 -08:00
2009-02-14 20:46:39 -08:00
2009-03-02 22:15:09 -08:00
2009-01-21 14:34:08 -08:00
2009-02-04 16:42:35 -08:00
2009-03-29 01:20:18 -07:00
2009-03-23 13:35:04 -07:00
2009-03-03 23:36:04 -08:00
2009-02-26 22:21:59 -08:00
2009-03-13 13:37:46 -07:00
2009-02-01 00:45:17 -08:00
2009-03-20 02:27:41 -07:00
2009-01-11 00:06:36 -08:00
2009-03-28 13:30:43 -07:00
2009-03-24 16:38:22 -07:00
2009-02-26 22:21:57 -08:00
2009-01-21 14:02:31 -08:00
2009-01-11 00:06:36 -08:00