summaryrefslogtreecommitdiff
path: root/drivers/net/rionet.c
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2009-06-20 09:36:54 (GMT)
committerScott Wood <scottwood@freescale.com>2014-04-10 00:18:55 (GMT)
commit5001984143b8eab3715681063220aa6f57d9ebb0 (patch)
tree2ed9c7ef93b2fc096a4781b34315e16c9731890d /drivers/net/rionet.c
parente560bacfa970cf282e62596bebaaf4d50a76714c (diff)
downloadlinux-fsl-qoriq-5001984143b8eab3715681063220aa6f57d9ebb0.tar.xz
drivers/net: fix livelock issues
Preempt-RT runs into a live lock issue with the NETDEV_TX_LOCKED micro optimization. The reason is that the softirq thread is rescheduling itself on that return value. Depending on priorities it starts to monoplize the CPU and livelock on UP systems. Remove it. Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'drivers/net/rionet.c')
-rw-r--r--drivers/net/rionet.c6
1 files changed, 1 insertions, 5 deletions
diff --git a/drivers/net/rionet.c b/drivers/net/rionet.c
index 6d1f6ed..aa9800e 100644
--- a/drivers/net/rionet.c
+++ b/drivers/net/rionet.c
@@ -174,11 +174,7 @@ static int rionet_start_xmit(struct sk_buff *skb, struct net_device *ndev)
unsigned long flags;
int add_num = 1;
- local_irq_save(flags);
- if (!spin_trylock(&rnet->tx_lock)) {
- local_irq_restore(flags);
- return NETDEV_TX_LOCKED;
- }
+ spin_lock_irqsave(&rnet->tx_lock, flags);
if (is_multicast_ether_addr(eth->h_dest))
add_num = nets[rnet->mport->id].nact;