Commit 427e21fa authored by stephen hemminger's avatar stephen hemminger Committed by David S. Miller

acenic: use netdev_alloc_skb_ip_align

Take Eric's patch one step further.
Use netdev_skb_ip_align to do setup the receive skb.
Compile tested only.
Signed-off-by: default avatarStephen Hemminger <shemminger@vyatta.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 750e0699
...@@ -1502,13 +1502,13 @@ static int __devinit ace_init(struct net_device *dev) ...@@ -1502,13 +1502,13 @@ static int __devinit ace_init(struct net_device *dev)
* firmware to wipe the ring without re-initializing it. * firmware to wipe the ring without re-initializing it.
*/ */
if (!test_and_set_bit(0, &ap->std_refill_busy)) if (!test_and_set_bit(0, &ap->std_refill_busy))
ace_load_std_rx_ring(ap, RX_RING_SIZE); ace_load_std_rx_ring(dev, RX_RING_SIZE);
else else
printk(KERN_ERR "%s: Someone is busy refilling the RX ring\n", printk(KERN_ERR "%s: Someone is busy refilling the RX ring\n",
ap->name); ap->name);
if (ap->version >= 2) { if (ap->version >= 2) {
if (!test_and_set_bit(0, &ap->mini_refill_busy)) if (!test_and_set_bit(0, &ap->mini_refill_busy))
ace_load_mini_rx_ring(ap, RX_MINI_SIZE); ace_load_mini_rx_ring(dev, RX_MINI_SIZE);
else else
printk(KERN_ERR "%s: Someone is busy refilling " printk(KERN_ERR "%s: Someone is busy refilling "
"the RX mini ring\n", ap->name); "the RX mini ring\n", ap->name);
...@@ -1584,9 +1584,10 @@ static void ace_watchdog(struct net_device *data) ...@@ -1584,9 +1584,10 @@ static void ace_watchdog(struct net_device *data)
} }
static void ace_tasklet(unsigned long dev) static void ace_tasklet(unsigned long arg)
{ {
struct ace_private *ap = netdev_priv((struct net_device *)dev); struct net_device *dev = (struct net_device *) arg;
struct ace_private *ap = netdev_priv(dev);
int cur_size; int cur_size;
cur_size = atomic_read(&ap->cur_rx_bufs); cur_size = atomic_read(&ap->cur_rx_bufs);
...@@ -1595,7 +1596,7 @@ static void ace_tasklet(unsigned long dev) ...@@ -1595,7 +1596,7 @@ static void ace_tasklet(unsigned long dev)
#ifdef DEBUG #ifdef DEBUG
printk("refilling buffers (current %i)\n", cur_size); printk("refilling buffers (current %i)\n", cur_size);
#endif #endif
ace_load_std_rx_ring(ap, RX_RING_SIZE - cur_size); ace_load_std_rx_ring(dev, RX_RING_SIZE - cur_size);
} }
if (ap->version >= 2) { if (ap->version >= 2) {
...@@ -1606,7 +1607,7 @@ static void ace_tasklet(unsigned long dev) ...@@ -1606,7 +1607,7 @@ static void ace_tasklet(unsigned long dev)
printk("refilling mini buffers (current %i)\n", printk("refilling mini buffers (current %i)\n",
cur_size); cur_size);
#endif #endif
ace_load_mini_rx_ring(ap, RX_MINI_SIZE - cur_size); ace_load_mini_rx_ring(dev, RX_MINI_SIZE - cur_size);
} }
} }
...@@ -1616,7 +1617,7 @@ static void ace_tasklet(unsigned long dev) ...@@ -1616,7 +1617,7 @@ static void ace_tasklet(unsigned long dev)
#ifdef DEBUG #ifdef DEBUG
printk("refilling jumbo buffers (current %i)\n", cur_size); printk("refilling jumbo buffers (current %i)\n", cur_size);
#endif #endif
ace_load_jumbo_rx_ring(ap, RX_JUMBO_SIZE - cur_size); ace_load_jumbo_rx_ring(dev, RX_JUMBO_SIZE - cur_size);
} }
ap->tasklet_pending = 0; ap->tasklet_pending = 0;
} }
...@@ -1642,8 +1643,9 @@ static void ace_dump_trace(struct ace_private *ap) ...@@ -1642,8 +1643,9 @@ static void ace_dump_trace(struct ace_private *ap)
* done only before the device is enabled, thus no interrupts are * done only before the device is enabled, thus no interrupts are
* generated and by the interrupt handler/tasklet handler. * generated and by the interrupt handler/tasklet handler.
*/ */
static void ace_load_std_rx_ring(struct ace_private *ap, int nr_bufs) static void ace_load_std_rx_ring(struct net_device *dev, int nr_bufs)
{ {
struct ace_private *ap = netdev_priv(dev);
struct ace_regs __iomem *regs = ap->regs; struct ace_regs __iomem *regs = ap->regs;
short i, idx; short i, idx;
...@@ -1657,11 +1659,10 @@ static void ace_load_std_rx_ring(struct ace_private *ap, int nr_bufs) ...@@ -1657,11 +1659,10 @@ static void ace_load_std_rx_ring(struct ace_private *ap, int nr_bufs)
struct rx_desc *rd; struct rx_desc *rd;
dma_addr_t mapping; dma_addr_t mapping;
skb = dev_alloc_skb(ACE_STD_BUFSIZE + NET_IP_ALIGN); skb = netdev_alloc_skb_ip_align(dev, ACE_STD_BUFSIZE);
if (!skb) if (!skb)
break; break;
skb_reserve(skb, NET_IP_ALIGN);
mapping = pci_map_page(ap->pdev, virt_to_page(skb->data), mapping = pci_map_page(ap->pdev, virt_to_page(skb->data),
offset_in_page(skb->data), offset_in_page(skb->data),
ACE_STD_BUFSIZE, ACE_STD_BUFSIZE,
...@@ -1705,8 +1706,9 @@ static void ace_load_std_rx_ring(struct ace_private *ap, int nr_bufs) ...@@ -1705,8 +1706,9 @@ static void ace_load_std_rx_ring(struct ace_private *ap, int nr_bufs)
} }
static void ace_load_mini_rx_ring(struct ace_private *ap, int nr_bufs) static void ace_load_mini_rx_ring(struct net_device *dev, int nr_bufs)
{ {
struct ace_private *ap = netdev_priv(dev);
struct ace_regs __iomem *regs = ap->regs; struct ace_regs __iomem *regs = ap->regs;
short i, idx; short i, idx;
...@@ -1718,11 +1720,10 @@ static void ace_load_mini_rx_ring(struct ace_private *ap, int nr_bufs) ...@@ -1718,11 +1720,10 @@ static void ace_load_mini_rx_ring(struct ace_private *ap, int nr_bufs)
struct rx_desc *rd; struct rx_desc *rd;
dma_addr_t mapping; dma_addr_t mapping;
skb = dev_alloc_skb(ACE_MINI_BUFSIZE + NET_IP_ALIGN); skb = netdev_alloc_skb_ip_align(dev, ACE_MINI_BUFSIZE);
if (!skb) if (!skb)
break; break;
skb_reserve(skb, NET_IP_ALIGN);
mapping = pci_map_page(ap->pdev, virt_to_page(skb->data), mapping = pci_map_page(ap->pdev, virt_to_page(skb->data),
offset_in_page(skb->data), offset_in_page(skb->data),
ACE_MINI_BUFSIZE, ACE_MINI_BUFSIZE,
...@@ -1762,8 +1763,9 @@ static void ace_load_mini_rx_ring(struct ace_private *ap, int nr_bufs) ...@@ -1762,8 +1763,9 @@ static void ace_load_mini_rx_ring(struct ace_private *ap, int nr_bufs)
* Load the jumbo rx ring, this may happen at any time if the MTU * Load the jumbo rx ring, this may happen at any time if the MTU
* is changed to a value > 1500. * is changed to a value > 1500.
*/ */
static void ace_load_jumbo_rx_ring(struct ace_private *ap, int nr_bufs) static void ace_load_jumbo_rx_ring(struct net_device *dev, int nr_bufs)
{ {
struct ace_private *ap = netdev_priv(dev);
struct ace_regs __iomem *regs = ap->regs; struct ace_regs __iomem *regs = ap->regs;
short i, idx; short i, idx;
...@@ -1774,11 +1776,10 @@ static void ace_load_jumbo_rx_ring(struct ace_private *ap, int nr_bufs) ...@@ -1774,11 +1776,10 @@ static void ace_load_jumbo_rx_ring(struct ace_private *ap, int nr_bufs)
struct rx_desc *rd; struct rx_desc *rd;
dma_addr_t mapping; dma_addr_t mapping;
skb = dev_alloc_skb(ACE_JUMBO_BUFSIZE + NET_IP_ALIGN); skb = netdev_alloc_skb_ip_align(dev, ACE_JUMBO_BUFSIZE);
if (!skb) if (!skb)
break; break;
skb_reserve(skb, NET_IP_ALIGN);
mapping = pci_map_page(ap->pdev, virt_to_page(skb->data), mapping = pci_map_page(ap->pdev, virt_to_page(skb->data),
offset_in_page(skb->data), offset_in_page(skb->data),
ACE_JUMBO_BUFSIZE, ACE_JUMBO_BUFSIZE,
...@@ -2196,7 +2197,7 @@ static irqreturn_t ace_interrupt(int irq, void *dev_id) ...@@ -2196,7 +2197,7 @@ static irqreturn_t ace_interrupt(int irq, void *dev_id)
#ifdef DEBUG #ifdef DEBUG
printk("low on std buffers %i\n", cur_size); printk("low on std buffers %i\n", cur_size);
#endif #endif
ace_load_std_rx_ring(ap, ace_load_std_rx_ring(dev,
RX_RING_SIZE - cur_size); RX_RING_SIZE - cur_size);
} else } else
run_tasklet = 1; run_tasklet = 1;
...@@ -2212,7 +2213,8 @@ static irqreturn_t ace_interrupt(int irq, void *dev_id) ...@@ -2212,7 +2213,8 @@ static irqreturn_t ace_interrupt(int irq, void *dev_id)
printk("low on mini buffers %i\n", printk("low on mini buffers %i\n",
cur_size); cur_size);
#endif #endif
ace_load_mini_rx_ring(ap, RX_MINI_SIZE - cur_size); ace_load_mini_rx_ring(dev,
RX_MINI_SIZE - cur_size);
} else } else
run_tasklet = 1; run_tasklet = 1;
} }
...@@ -2228,7 +2230,8 @@ static irqreturn_t ace_interrupt(int irq, void *dev_id) ...@@ -2228,7 +2230,8 @@ static irqreturn_t ace_interrupt(int irq, void *dev_id)
printk("low on jumbo buffers %i\n", printk("low on jumbo buffers %i\n",
cur_size); cur_size);
#endif #endif
ace_load_jumbo_rx_ring(ap, RX_JUMBO_SIZE - cur_size); ace_load_jumbo_rx_ring(dev,
RX_JUMBO_SIZE - cur_size);
} else } else
run_tasklet = 1; run_tasklet = 1;
} }
...@@ -2267,7 +2270,7 @@ static int ace_open(struct net_device *dev) ...@@ -2267,7 +2270,7 @@ static int ace_open(struct net_device *dev)
if (ap->jumbo && if (ap->jumbo &&
!test_and_set_bit(0, &ap->jumbo_refill_busy)) !test_and_set_bit(0, &ap->jumbo_refill_busy))
ace_load_jumbo_rx_ring(ap, RX_JUMBO_SIZE); ace_load_jumbo_rx_ring(dev, RX_JUMBO_SIZE);
if (dev->flags & IFF_PROMISC) { if (dev->flags & IFF_PROMISC) {
cmd.evt = C_SET_PROMISC_MODE; cmd.evt = C_SET_PROMISC_MODE;
...@@ -2575,7 +2578,7 @@ static int ace_change_mtu(struct net_device *dev, int new_mtu) ...@@ -2575,7 +2578,7 @@ static int ace_change_mtu(struct net_device *dev, int new_mtu)
"support\n", dev->name); "support\n", dev->name);
ap->jumbo = 1; ap->jumbo = 1;
if (!test_and_set_bit(0, &ap->jumbo_refill_busy)) if (!test_and_set_bit(0, &ap->jumbo_refill_busy))
ace_load_jumbo_rx_ring(ap, RX_JUMBO_SIZE); ace_load_jumbo_rx_ring(dev, RX_JUMBO_SIZE);
ace_set_rxtx_parms(dev, 1); ace_set_rxtx_parms(dev, 1);
} }
} else { } else {
......
...@@ -766,9 +766,9 @@ static inline void ace_unmask_irq(struct net_device *dev) ...@@ -766,9 +766,9 @@ static inline void ace_unmask_irq(struct net_device *dev)
* Prototypes * Prototypes
*/ */
static int ace_init(struct net_device *dev); static int ace_init(struct net_device *dev);
static void ace_load_std_rx_ring(struct ace_private *ap, int nr_bufs); static void ace_load_std_rx_ring(struct net_device *dev, int nr_bufs);
static void ace_load_mini_rx_ring(struct ace_private *ap, int nr_bufs); static void ace_load_mini_rx_ring(struct net_device *dev, int nr_bufs);
static void ace_load_jumbo_rx_ring(struct ace_private *ap, int nr_bufs); static void ace_load_jumbo_rx_ring(struct net_device *dev, int nr_bufs);
static irqreturn_t ace_interrupt(int irq, void *dev_id); static irqreturn_t ace_interrupt(int irq, void *dev_id);
static int ace_load_firmware(struct net_device *dev); static int ace_load_firmware(struct net_device *dev);
static int ace_open(struct net_device *dev); static int ace_open(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