mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2025-01-26 15:31:06 +02:00
ramips: Don't trigger BUG_ON due to skb allocation failure
Instead just drop the rx'ed frame silently and reuse the already available buffer. Signed-off-by: Helmut Schaa <helmut.schaa@googlemail.com> git-svn-id: svn://svn.openwrt.org/openwrt/trunk@24122 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
parent
e0af17401f
commit
c523394925
@ -272,23 +272,26 @@ ramips_eth_rx_hw(unsigned long ptr)
|
||||
break;
|
||||
max_rx--;
|
||||
|
||||
rx_skb = priv->rx_skb[rx];
|
||||
skb_put(rx_skb, RX_DMA_PLEN0(priv->rx[rx].rxd2));
|
||||
rx_skb->dev = dev;
|
||||
rx_skb->protocol = eth_type_trans(rx_skb, dev);
|
||||
rx_skb->ip_summed = CHECKSUM_NONE;
|
||||
dev->stats.rx_packets++;
|
||||
dev->stats.rx_bytes += rx_skb->len;
|
||||
netif_rx(rx_skb);
|
||||
|
||||
new_skb = netdev_alloc_skb(dev, MAX_RX_LENGTH + 2);
|
||||
priv->rx_skb[rx] = new_skb;
|
||||
BUG_ON(!new_skb);
|
||||
skb_reserve(new_skb, 2);
|
||||
priv->rx[rx].rxd1 = dma_map_single(NULL,
|
||||
new_skb->data,
|
||||
MAX_RX_LENGTH + 2,
|
||||
DMA_FROM_DEVICE);
|
||||
/* Reuse the buffer on allocation failures */
|
||||
if (new_skb) {
|
||||
rx_skb = priv->rx_skb[rx];
|
||||
skb_put(rx_skb, RX_DMA_PLEN0(priv->rx[rx].rxd2));
|
||||
rx_skb->dev = dev;
|
||||
rx_skb->protocol = eth_type_trans(rx_skb, dev);
|
||||
rx_skb->ip_summed = CHECKSUM_NONE;
|
||||
dev->stats.rx_packets++;
|
||||
dev->stats.rx_bytes += rx_skb->len;
|
||||
netif_rx(rx_skb);
|
||||
|
||||
priv->rx_skb[rx] = new_skb;
|
||||
skb_reserve(new_skb, 2);
|
||||
priv->rx[rx].rxd1 = dma_map_single(NULL,
|
||||
new_skb->data,
|
||||
MAX_RX_LENGTH + 2,
|
||||
DMA_FROM_DEVICE);
|
||||
}
|
||||
|
||||
priv->rx[rx].rxd2 &= ~RX_DMA_DONE;
|
||||
wmb();
|
||||
ramips_fe_wr(rx, RAMIPS_RX_CALC_IDX0);
|
||||
|
Loading…
x
Reference in New Issue
Block a user