Commit d5f3889a authored by Finn Thain's avatar Finn Thain Committed by David S. Miller

net/macsonic: Remove interrupt handler wrapper

On m68k, local irqs remain enabled while interrupt handlers execute.
Therefore the macsonic driver has had to disable interrupts to avoid
re-entering sonic_interrupt().

As of commit 865ad2f2 ("net/sonic: Add mutual exclusion for accessing
shared state"), sonic_interrupt() became re-entrant, and its wrapper
became redundant.
Tested-by: default avatarStan Johnson <userm57@yahoo.com>
Signed-off-by: default avatarFinn Thain <fthain@telegraphics.com.au>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 8fe676b3
...@@ -114,17 +114,6 @@ static inline void bit_reverse_addr(unsigned char addr[6]) ...@@ -114,17 +114,6 @@ static inline void bit_reverse_addr(unsigned char addr[6])
addr[i] = bitrev8(addr[i]); addr[i] = bitrev8(addr[i]);
} }
static irqreturn_t macsonic_interrupt(int irq, void *dev_id)
{
irqreturn_t result;
unsigned long flags;
local_irq_save(flags);
result = sonic_interrupt(irq, dev_id);
local_irq_restore(flags);
return result;
}
static int macsonic_open(struct net_device* dev) static int macsonic_open(struct net_device* dev)
{ {
int retval; int retval;
...@@ -135,12 +124,12 @@ static int macsonic_open(struct net_device* dev) ...@@ -135,12 +124,12 @@ static int macsonic_open(struct net_device* dev)
dev->name, dev->irq); dev->name, dev->irq);
goto err; goto err;
} }
/* Under the A/UX interrupt scheme, the onboard SONIC interrupt comes /* Under the A/UX interrupt scheme, the onboard SONIC interrupt gets
* in at priority level 3. However, we sometimes get the level 2 inter- * moved from level 2 to level 3. Unfortunately we still get some
* rupt as well, which must prevent re-entrance of the sonic handler. * level 2 interrupts so register the handler for both.
*/ */
if (dev->irq == IRQ_AUTO_3) { if (dev->irq == IRQ_AUTO_3) {
retval = request_irq(IRQ_NUBUS_9, macsonic_interrupt, 0, retval = request_irq(IRQ_NUBUS_9, sonic_interrupt, 0,
"sonic", dev); "sonic", dev);
if (retval) { if (retval) {
printk(KERN_ERR "%s: unable to get IRQ %d.\n", printk(KERN_ERR "%s: unable to get IRQ %d.\n",
......
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