aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_main.c
diff options
context:
space:
mode:
authorGabor Juhos <juhosg@openwrt.org>2010-03-27 13:05:24 +0000
committerGabor Juhos <juhosg@openwrt.org>2010-03-27 13:05:24 +0000
commitf9acf8ada191798952817bf3650832b685c441ed (patch)
treed59c37fa44c9cda727f6cf405b228ddefc5f9c68 /target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_main.c
parent200db5ebb5d18509a29fca9280a16c4e72649b25 (diff)
downloadupstream-f9acf8ada191798952817bf3650832b685c441ed.tar.gz
upstream-f9acf8ada191798952817bf3650832b685c441ed.tar.bz2
upstream-f9acf8ada191798952817bf3650832b685c441ed.zip
ar71xx: ag71xx: introduce ag71xx_has_ar8216() helper
SVN-Revision: 20505
Diffstat (limited to 'target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_main.c')
-rw-r--r--target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_main.c9
1 files changed, 6 insertions, 3 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 3cf4f5eced..f4c5a12147 100644
--- a/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_main.c
+++ b/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_main.c
@@ -614,7 +614,8 @@ static netdev_tx_t ag71xx_hard_start_xmit(struct sk_buff *skb,
if (!ag71xx_desc_empty(desc))
goto err_drop;
- ag71xx_add_ar8216_header(ag, skb);
+ if (ag71xx_has_ar8216(ag))
+ ag71xx_add_ar8216_header(ag, skb);
if (skb->len <= 0) {
DBG("%s: packet len is too small\n", ag->dev->name);
@@ -772,7 +773,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;
+ int err = 0;
if (ag71xx_desc_empty(desc))
break;
@@ -795,7 +796,9 @@ static int ag71xx_rx_packets(struct ag71xx *ag, int limit)
dev->stats.rx_packets++;
dev->stats.rx_bytes += pktlen;
- err = ag71xx_remove_ar8216_header(ag, skb);
+ if (ag71xx_has_ar8216(ag))
+ err = ag71xx_remove_ar8216_header(ag, skb);
+
if (err) {
dev->stats.rx_dropped++;
kfree_skb(skb);