Asier Llano
1e4e0767ec
net/mpc5200: Fix locking on fec_mpc52xx driver
...
Fix the locking scheme on the fec_mpc52xx driver. This device can
receive IRQs from three sources; the FEC itself, the tx DMA, and the
rx DMA. Mutual exclusion was handled by taking a spin_lock() in the
critical regions, but because the handlers are run with IRQs enabled,
spin_lock() is insufficient and the driver can end up interrupting
a critical region anyway from another IRQ.
Asier Llano discovered that this occurs when an error IRQ is raised
in the middle of handling rx irqs which resulted in an sk_buff memory
leak.
In addition, locking is spotty at best in the driver and inspection
revealed quite a few places with insufficient locking.
This patch is based on Asier's initial work, but reworks a number of
things so that locks are held for as short a time as possible, so
that spin_lock_irqsave() is used everywhere, and so the locks are
dropped when calling into the network stack (because the lock only
protects the hardware interface; not the network stack).
Boot tested on a lite5200 with an NFS root. Has not been performance
tested.
Signed-off-by: Asier Llano <a.llano@ziv.es >
Signed-off-by: Grant Likely <grant.likely@secretlab.ca >
Signed-off-by: David S. Miller <davem@davemloft.net >
2009-12-08 20:29:10 -08:00
..
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-01 22:13:38 -08:00
2009-11-18 10:47:03 -08:00
2009-12-02 22:10:16 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 16:15:52 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-09-24 17:08:56 -07:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-08 20:10:12 -08:00
2009-12-03 13:18:01 -08:00
2009-10-13 11:48:18 -07:00
2009-10-14 14:54:52 -07:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-02 19:57:11 -08:00
2009-12-08 20:10:13 -08:00
2009-10-13 12:55:20 -07:00
2009-10-14 10:52:40 -07:00
2009-12-08 20:24:35 -08:00
2009-12-03 13:18:01 -08:00
2009-12-05 15:22:26 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-11-29 17:23:58 -08:00
2009-10-11 11:20:58 -07:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 15:31:18 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-11-06 05:01:54 -08:00
2009-12-07 16:59:23 -05:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-10-12 04:18:48 -07:00
2009-09-03 20:02:11 -07:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-11-29 00:57:15 -08:00
2009-11-30 00:13:28 -08:00
2009-10-13 11:48:18 -07:00
2009-09-17 20:07:53 +02:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 15:58:00 -08:00
2009-12-03 13:18:11 -08:00
2009-11-05 20:00:41 -08:00
2009-12-03 13:18:01 -08:00
2009-11-05 20:00:29 -08:00
2009-11-18 05:03:14 -08:00
2009-11-05 20:00:48 -08:00
2009-11-17 04:08:48 -08:00
2009-11-06 20:26:09 -08:00
2009-10-11 23:30:16 -07:00
2009-10-11 23:30:14 -07:00
2009-12-02 19:57:22 -08:00
2009-10-11 23:30:16 -07:00
2009-10-13 11:48:18 -07:00
2009-11-18 23:29:17 -08:00
2009-11-20 13:57:54 -08:00
2009-11-18 23:29:17 -08:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-11-11 19:22:21 -08:00
2009-12-01 22:13:38 -08:00
2009-12-03 13:18:01 -08:00
2009-11-18 23:29:17 -08:00
2009-11-18 23:29:17 -08:00
2009-09-23 07:39:43 -07:00
2009-12-03 13:18:01 -08:00
2009-10-11 11:20:58 -07:00
2009-11-18 22:19:03 -08:00
2009-10-11 11:20:58 -07:00
2009-12-03 13:18:01 -08:00
2009-10-14 14:54:52 -07:00
2009-12-08 20:29:10 -08:00
2009-10-20 18:51:37 -07:00
2009-11-18 23:29:17 -08:00
2009-11-08 23:00:54 -08:00
2009-11-02 23:40:57 -08:00
2009-11-02 23:40:59 -08:00
2009-12-03 13:18:01 -08:00
2009-11-11 19:03:36 -08:00
2009-11-08 00:43:17 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-09-07 01:56:52 -07:00
2009-11-18 23:29:17 -08:00
2009-11-20 15:35:04 -08:00
2009-11-18 10:48:39 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-11-29 00:57:15 -08:00
2009-11-18 23:29:17 -08:00
2009-10-13 11:48:18 -07:00
2009-11-20 13:53:36 -08:00
2009-12-03 16:04:25 -08:00
2009-10-20 19:11:06 -07:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-12-01 16:15:52 -08:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-09-21 15:14:56 +02:00
2009-12-03 13:18:01 -08:00
2009-11-18 23:29:17 -08:00
2009-12-03 15:59:22 -08:00
2009-10-14 15:13:45 -07:00
2009-10-12 23:59:08 -07:00
2009-10-01 14:34:40 -07:00
2009-09-03 20:02:11 -07:00
2009-11-18 23:29:17 -08:00
2009-11-29 17:04:31 -08:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-11-18 23:29:17 -08:00
2009-11-18 23:29:17 -08:00
2009-11-13 14:07:30 -08:00
2009-12-03 13:18:01 -08:00
2009-10-12 13:26:39 -07:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-01 16:15:57 -08:00
2009-11-05 22:18:14 -08:00
2009-12-02 00:52:31 -08:00
2009-12-02 00:52:31 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-09-21 15:14:54 +02:00
2009-11-13 19:56:53 -08:00
2009-12-03 13:18:01 -08:00
2009-11-18 23:29:17 -08:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-11-18 23:29:17 -08:00
2009-10-13 11:48:18 -07:00
2009-11-18 23:29:17 -08:00
2009-10-13 03:44:05 -07:00
2009-10-13 11:48:18 -07:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-10-01 15:14:54 -07:00
2009-12-03 13:18:01 -08:00
2009-10-29 22:57:27 -07:00
2009-12-03 13:18:01 -08:00
2009-12-01 22:13:38 -08:00
2009-12-03 13:18:01 -08:00
2009-11-18 23:29:17 -08:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-12-01 22:13:38 -08:00
2009-11-10 20:28:52 -08:00
2009-12-03 13:18:01 -08:00
2009-11-18 23:29:17 -08:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-11-18 22:19:03 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-11-18 23:29:17 -08:00
2009-11-18 23:29:17 -08:00
2009-09-22 14:00:09 -07:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-11-04 05:06:24 -08:00
2009-12-03 13:18:08 -08:00
2009-12-03 13:18:04 -08:00
2009-12-03 13:18:01 -08:00
2009-10-13 11:48:18 -07:00
2009-11-06 22:52:32 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-11-29 00:57:15 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00
2009-11-26 15:51:29 -08:00
2009-12-03 13:18:01 -08:00
2009-11-18 23:29:17 -08:00
2009-11-18 23:29:17 -08:00
2009-12-03 13:18:01 -08:00
2009-12-03 13:18:01 -08:00