aboutsummaryrefslogtreecommitdiffstats
path: root/target
diff options
context:
space:
mode:
authorGabor Juhos <juhosg@openwrt.org>2010-03-27 13:05:20 +0000
committerGabor Juhos <juhosg@openwrt.org>2010-03-27 13:05:20 +0000
commit200db5ebb5d18509a29fca9280a16c4e72649b25 (patch)
treecee71bafc0dab75a5f6ca4e05ca5a8ff6ea792b8 /target
parent245775a49f867b0da28b37934f9a512c1d05c054 (diff)
downloadupstream-200db5ebb5d18509a29fca9280a16c4e72649b25.tar.gz
upstream-200db5ebb5d18509a29fca9280a16c4e72649b25.tar.bz2
upstream-200db5ebb5d18509a29fca9280a16c4e72649b25.zip
ar71xx: ag71xx: reorganize ag71xx_rx_packet function
SVN-Revision: 20504
Diffstat (limited to 'target')
-rw-r--r--target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_main.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_main.c b/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_main.c
index 8244239663..3cf4f5eced 100644
--- a/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_main.c
+++ b/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_main.c
@@ -772,6 +772,7 @@ static int ag71xx_rx_packets(struct ag71xx *ag, int limit)
struct ag71xx_desc *desc = ring->buf[i].desc;
struct sk_buff *skb;
int pktlen;
+ int err;
if (ag71xx_desc_empty(desc))
break;
@@ -790,19 +791,19 @@ static int ag71xx_rx_packets(struct ag71xx *ag, int limit)
dma_unmap_single(&dev->dev, ring->buf[i].dma_addr,
AG71XX_RX_PKT_SIZE, DMA_FROM_DEVICE);
- skb_put(skb, pktlen);
-
- skb->dev = dev;
- skb->ip_summed = CHECKSUM_NONE;
-
dev->last_rx = jiffies;
dev->stats.rx_packets++;
dev->stats.rx_bytes += pktlen;
- if (ag71xx_remove_ar8216_header(ag, skb) != 0) {
+ err = ag71xx_remove_ar8216_header(ag, skb);
+ if (err) {
dev->stats.rx_dropped++;
kfree_skb(skb);
} else {
+ skb_put(skb, pktlen);
+
+ skb->dev = dev;
+ skb->ip_summed = CHECKSUM_NONE;
skb->protocol = eth_type_trans(skb, dev);
netif_receive_skb(skb);
}