From: Sathya Narayanan <[EMAIL PROTECTED]>

This patch addresses the memory leak happenning in drivers transmit queue
under heavy load condition. Once the transmit queue becomes full, driver
does an automatic wrapup of queue. During which the untransmitted SKB's are
lost without getting freed up.

Signed-off-by: Sathya Narayanan <[EMAIL PROTECTED]>
Signed-off-by: Stefan Roese <[EMAIL PROTECTED]>
---
 drivers/net/ibm_newemac/core.c |    7 +++++++
 1 files changed, 7 insertions(+), 0 deletions(-)

diff --git a/drivers/net/ibm_newemac/core.c b/drivers/net/ibm_newemac/core.c
index aa407b2..ee868b6 100644
--- a/drivers/net/ibm_newemac/core.c
+++ b/drivers/net/ibm_newemac/core.c
@@ -1328,6 +1328,13 @@ static int emac_start_xmit(struct sk_buff *skb, struct 
net_device *ndev)
 
        DBG2(dev, "xmit(%u) %d" NL, len, slot);
 
+       if (dev->tx_skb[slot] && dev->tx_desc[slot].data_ptr) {
+               dev_kfree_skb(dev->tx_skb[slot]);
+               dev->tx_skb[slot] = NULL;
+               dev->tx_cnt--;
+               ++dev->estats.tx_dropped;
+       }
+
        dev->tx_skb[slot] = skb;
        dev->tx_desc[slot].data_ptr = dma_map_single(&dev->ofdev->dev,
                                                     skb->data, len,
-- 
1.5.6

_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@ozlabs.org
https://ozlabs.org/mailman/listinfo/linuxppc-dev

Reply via email to