From f370c25106d51491853019bab50a95c2e06d1ae6 Mon Sep 17 00:00:00 2001 From: Yoshihiro Shimoda Date: Thu, 30 Jun 2011 22:52:13 +0000 Subject: [PATCH] --- yaml --- r: 256033 b: refs/heads/master c: 31fcb99d9958bdf04e84224e202f69e6cdac893b h: refs/heads/master i: 256031: 0d6d99dc017c961f309831a65c1612b09b1c88ec v: v3 --- [refs] | 2 +- trunk/drivers/net/sh_eth.c | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/[refs] b/[refs] index 445458ae56f4..0b14ba8962f6 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: ee9c88f2283c80d9926f980848ae02cc3e88ee57 +refs/heads/master: 31fcb99d9958bdf04e84224e202f69e6cdac893b diff --git a/trunk/drivers/net/sh_eth.c b/trunk/drivers/net/sh_eth.c index 96a629f1678e..3da168a859ca 100644 --- a/trunk/drivers/net/sh_eth.c +++ b/trunk/drivers/net/sh_eth.c @@ -33,7 +33,6 @@ #include #include #include -#include #include "sh_eth.h" @@ -864,6 +863,8 @@ static int sh_eth_txfree(struct net_device *ndev) break; /* Free the original skb. */ if (mdp->tx_skbuff[entry]) { + dma_unmap_single(&ndev->dev, txdesc->addr, + txdesc->buffer_length, DMA_TO_DEVICE); dev_kfree_skb_irq(mdp->tx_skbuff[entry]); mdp->tx_skbuff[entry] = NULL; freeNum++; @@ -1487,13 +1488,12 @@ static int sh_eth_start_xmit(struct sk_buff *skb, struct net_device *ndev) entry = mdp->cur_tx % TX_RING_SIZE; mdp->tx_skbuff[entry] = skb; txdesc = &mdp->tx_ring[entry]; - txdesc->addr = virt_to_phys(skb->data); /* soft swap. */ if (!mdp->cd->hw_swap) sh_eth_soft_swap(phys_to_virt(ALIGN(txdesc->addr, 4)), skb->len + 2); - /* write back */ - __flush_purge_region(skb->data, skb->len); + txdesc->addr = dma_map_single(&ndev->dev, skb->data, skb->len, + DMA_TO_DEVICE); if (skb->len < ETHERSMALL) txdesc->buffer_length = ETHERSMALL; else