Commit dfe22676 authored by François Romieu's avatar François Romieu Committed by Jeff Garzik

[PATCH] epic100: spin_unlock_irqrestore avoidance

This patch avoids to duplicate a spin_unlock:
- it is mostly an artifact due to wild goto;
- it makes the generated code smaller.
parent 07fe9727
...@@ -632,7 +632,8 @@ static inline void __epic_pci_commit(long ioaddr) ...@@ -632,7 +632,8 @@ static inline void __epic_pci_commit(long ioaddr)
#endif #endif
} }
static void epic_napi_irq_off(struct net_device *dev, struct epic_private *ep) static inline void epic_napi_irq_off(struct net_device *dev,
struct epic_private *ep)
{ {
long ioaddr = dev->base_addr; long ioaddr = dev->base_addr;
...@@ -640,7 +641,8 @@ static void epic_napi_irq_off(struct net_device *dev, struct epic_private *ep) ...@@ -640,7 +641,8 @@ static void epic_napi_irq_off(struct net_device *dev, struct epic_private *ep)
__epic_pci_commit(ioaddr); __epic_pci_commit(ioaddr);
} }
static void epic_napi_irq_on(struct net_device *dev, struct epic_private *ep) static inline void epic_napi_irq_on(struct net_device *dev,
struct epic_private *ep)
{ {
long ioaddr = dev->base_addr; long ioaddr = dev->base_addr;
...@@ -1370,20 +1372,24 @@ static int epic_poll(struct net_device *dev, int *budget) ...@@ -1370,20 +1372,24 @@ static int epic_poll(struct net_device *dev, int *budget)
if (netif_running(dev) && (work_done < orig_budget)) { if (netif_running(dev) && (work_done < orig_budget)) {
unsigned long flags; unsigned long flags;
int more;
/* A bit baroque but it avoids a (space hungry) spin_unlock */
spin_lock_irqsave(&ep->napi_lock, flags); spin_lock_irqsave(&ep->napi_lock, flags);
if (ep->reschedule_in_poll) { more = ep->reschedule_in_poll;
if (!more) {
__netif_rx_complete(dev);
outl(EpicNapiEvent, ioaddr + INTSTAT);
epic_napi_irq_on(dev, ep);
} else
ep->reschedule_in_poll--; ep->reschedule_in_poll--;
spin_unlock_irqrestore(&ep->napi_lock, flags);
goto rx_action;
}
outl(EpicNapiEvent, ioaddr + INTSTAT);
epic_napi_irq_on(dev, ep);
__netif_rx_complete(dev);
spin_unlock_irqrestore(&ep->napi_lock, flags); spin_unlock_irqrestore(&ep->napi_lock, flags);
if (more)
goto rx_action;
} }
return (work_done >= orig_budget); return (work_done >= orig_budget);
......
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