Commit 606dbf8d authored by Thomas Gleixner's avatar Thomas Gleixner Committed by David S. Miller

net: natsemi: Replace in_interrupt() usage.

The usage of in_interrupt() in drivers is phased out and Linus clearly
requested that code which changes behaviour depending on context should
either be seperated or the context be conveyed in an argument passed by the
caller, which usually knows the context.

sonic_quiesce() uses 'in_interrupt() || irqs_disabled()' to chose either
udelay() or usleep_range() in the wait loop.

In all callchains leading to it the context is well defined and known.

Add a 'may_sleep' argument and pass it through the various callchains
leading to this function.
Signed-off-by: default avatarSebastian Andrzej Siewior <bigeasy@linutronix.de>
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 85bdebd1
...@@ -143,7 +143,7 @@ static int sonic_open(struct net_device *dev) ...@@ -143,7 +143,7 @@ static int sonic_open(struct net_device *dev)
/* /*
* Initialize the SONIC * Initialize the SONIC
*/ */
sonic_init(dev); sonic_init(dev, true);
netif_start_queue(dev); netif_start_queue(dev);
...@@ -153,7 +153,7 @@ static int sonic_open(struct net_device *dev) ...@@ -153,7 +153,7 @@ static int sonic_open(struct net_device *dev)
} }
/* Wait for the SONIC to become idle. */ /* Wait for the SONIC to become idle. */
static void sonic_quiesce(struct net_device *dev, u16 mask) static void sonic_quiesce(struct net_device *dev, u16 mask, bool may_sleep)
{ {
struct sonic_local * __maybe_unused lp = netdev_priv(dev); struct sonic_local * __maybe_unused lp = netdev_priv(dev);
int i; int i;
...@@ -163,7 +163,7 @@ static void sonic_quiesce(struct net_device *dev, u16 mask) ...@@ -163,7 +163,7 @@ static void sonic_quiesce(struct net_device *dev, u16 mask)
bits = SONIC_READ(SONIC_CMD) & mask; bits = SONIC_READ(SONIC_CMD) & mask;
if (!bits) if (!bits)
return; return;
if (irqs_disabled() || in_interrupt()) if (!may_sleep)
udelay(20); udelay(20);
else else
usleep_range(100, 200); usleep_range(100, 200);
...@@ -187,7 +187,7 @@ static int sonic_close(struct net_device *dev) ...@@ -187,7 +187,7 @@ static int sonic_close(struct net_device *dev)
* stop the SONIC, disable interrupts * stop the SONIC, disable interrupts
*/ */
SONIC_WRITE(SONIC_CMD, SONIC_CR_RXDIS); SONIC_WRITE(SONIC_CMD, SONIC_CR_RXDIS);
sonic_quiesce(dev, SONIC_CR_ALL); sonic_quiesce(dev, SONIC_CR_ALL, true);
SONIC_WRITE(SONIC_IMR, 0); SONIC_WRITE(SONIC_IMR, 0);
SONIC_WRITE(SONIC_ISR, 0x7fff); SONIC_WRITE(SONIC_ISR, 0x7fff);
...@@ -229,7 +229,7 @@ static void sonic_tx_timeout(struct net_device *dev, unsigned int txqueue) ...@@ -229,7 +229,7 @@ static void sonic_tx_timeout(struct net_device *dev, unsigned int txqueue)
* disable all interrupts before releasing DMA buffers * disable all interrupts before releasing DMA buffers
*/ */
SONIC_WRITE(SONIC_CMD, SONIC_CR_RXDIS); SONIC_WRITE(SONIC_CMD, SONIC_CR_RXDIS);
sonic_quiesce(dev, SONIC_CR_ALL); sonic_quiesce(dev, SONIC_CR_ALL, false);
SONIC_WRITE(SONIC_IMR, 0); SONIC_WRITE(SONIC_IMR, 0);
SONIC_WRITE(SONIC_ISR, 0x7fff); SONIC_WRITE(SONIC_ISR, 0x7fff);
...@@ -246,7 +246,7 @@ static void sonic_tx_timeout(struct net_device *dev, unsigned int txqueue) ...@@ -246,7 +246,7 @@ static void sonic_tx_timeout(struct net_device *dev, unsigned int txqueue)
} }
} }
/* Try to restart the adaptor. */ /* Try to restart the adaptor. */
sonic_init(dev); sonic_init(dev, false);
lp->stats.tx_errors++; lp->stats.tx_errors++;
netif_trans_update(dev); /* prevent tx timeout */ netif_trans_update(dev); /* prevent tx timeout */
netif_wake_queue(dev); netif_wake_queue(dev);
...@@ -692,9 +692,9 @@ static void sonic_multicast_list(struct net_device *dev) ...@@ -692,9 +692,9 @@ static void sonic_multicast_list(struct net_device *dev)
/* LCAM and TXP commands can't be used simultaneously */ /* LCAM and TXP commands can't be used simultaneously */
spin_lock_irqsave(&lp->lock, flags); spin_lock_irqsave(&lp->lock, flags);
sonic_quiesce(dev, SONIC_CR_TXP); sonic_quiesce(dev, SONIC_CR_TXP, false);
SONIC_WRITE(SONIC_CMD, SONIC_CR_LCAM); SONIC_WRITE(SONIC_CMD, SONIC_CR_LCAM);
sonic_quiesce(dev, SONIC_CR_LCAM); sonic_quiesce(dev, SONIC_CR_LCAM, false);
spin_unlock_irqrestore(&lp->lock, flags); spin_unlock_irqrestore(&lp->lock, flags);
} }
} }
...@@ -708,7 +708,7 @@ static void sonic_multicast_list(struct net_device *dev) ...@@ -708,7 +708,7 @@ static void sonic_multicast_list(struct net_device *dev)
/* /*
* Initialize the SONIC ethernet controller. * Initialize the SONIC ethernet controller.
*/ */
static int sonic_init(struct net_device *dev) static int sonic_init(struct net_device *dev, bool may_sleep)
{ {
struct sonic_local *lp = netdev_priv(dev); struct sonic_local *lp = netdev_priv(dev);
int i; int i;
...@@ -730,7 +730,7 @@ static int sonic_init(struct net_device *dev) ...@@ -730,7 +730,7 @@ static int sonic_init(struct net_device *dev)
*/ */
SONIC_WRITE(SONIC_CMD, 0); SONIC_WRITE(SONIC_CMD, 0);
SONIC_WRITE(SONIC_CMD, SONIC_CR_RXDIS | SONIC_CR_STP); SONIC_WRITE(SONIC_CMD, SONIC_CR_RXDIS | SONIC_CR_STP);
sonic_quiesce(dev, SONIC_CR_ALL); sonic_quiesce(dev, SONIC_CR_ALL, may_sleep);
/* /*
* initialize the receive resource area * initialize the receive resource area
...@@ -759,7 +759,7 @@ static int sonic_init(struct net_device *dev) ...@@ -759,7 +759,7 @@ static int sonic_init(struct net_device *dev)
netif_dbg(lp, ifup, dev, "%s: issuing RRRA command\n", __func__); netif_dbg(lp, ifup, dev, "%s: issuing RRRA command\n", __func__);
SONIC_WRITE(SONIC_CMD, SONIC_CR_RRRA); SONIC_WRITE(SONIC_CMD, SONIC_CR_RRRA);
sonic_quiesce(dev, SONIC_CR_RRRA); sonic_quiesce(dev, SONIC_CR_RRRA, may_sleep);
/* /*
* Initialize the receive descriptors so that they * Initialize the receive descriptors so that they
...@@ -834,7 +834,7 @@ static int sonic_init(struct net_device *dev) ...@@ -834,7 +834,7 @@ static int sonic_init(struct net_device *dev)
* load the CAM * load the CAM
*/ */
SONIC_WRITE(SONIC_CMD, SONIC_CR_LCAM); SONIC_WRITE(SONIC_CMD, SONIC_CR_LCAM);
sonic_quiesce(dev, SONIC_CR_LCAM); sonic_quiesce(dev, SONIC_CR_LCAM, may_sleep);
/* /*
* enable receiver, disable loopback * enable receiver, disable loopback
......
...@@ -338,7 +338,7 @@ static void sonic_rx(struct net_device *dev); ...@@ -338,7 +338,7 @@ static void sonic_rx(struct net_device *dev);
static int sonic_close(struct net_device *dev); static int sonic_close(struct net_device *dev);
static struct net_device_stats *sonic_get_stats(struct net_device *dev); static struct net_device_stats *sonic_get_stats(struct net_device *dev);
static void sonic_multicast_list(struct net_device *dev); static void sonic_multicast_list(struct net_device *dev);
static int sonic_init(struct net_device *dev); static int sonic_init(struct net_device *dev, bool may_sleep);
static void sonic_tx_timeout(struct net_device *dev, unsigned int txqueue); static void sonic_tx_timeout(struct net_device *dev, unsigned int txqueue);
static void sonic_msg_init(struct net_device *dev); static void sonic_msg_init(struct net_device *dev);
static int sonic_alloc_descriptors(struct net_device *dev); static int sonic_alloc_descriptors(struct net_device *dev);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment