Commit b1dd9ca1 authored by Dale Farnsworth's avatar Dale Farnsworth Committed by Jeff Garzik

[PATCH] mv643xx: fix skb memory leak

This patch fixes an skb memory leak under heavy receive load
(whenever the more packets have been received than the NAPI budget
allows to be processed).
Signed-off-by: default avatarDale Farnsworth <dale@farnsworth.org>
Signed-off-by: default avatarJeff Garzik <jgarzik@pobox.com>
parent e797637f
...@@ -412,15 +412,13 @@ static int mv643xx_eth_receive_queue(struct net_device *dev) ...@@ -412,15 +412,13 @@ static int mv643xx_eth_receive_queue(struct net_device *dev)
struct pkt_info pkt_info; struct pkt_info pkt_info;
#ifdef MV643XX_NAPI #ifdef MV643XX_NAPI
while (eth_port_receive(mp, &pkt_info) == ETH_OK && budget > 0) { while (budget-- > 0 && eth_port_receive(mp, &pkt_info) == ETH_OK) {
#else #else
while (eth_port_receive(mp, &pkt_info) == ETH_OK) { while (eth_port_receive(mp, &pkt_info) == ETH_OK) {
#endif #endif
mp->rx_ring_skbs--; mp->rx_ring_skbs--;
received_packets++; received_packets++;
#ifdef MV643XX_NAPI
budget--;
#endif
/* Update statistics. Note byte count includes 4 byte CRC count */ /* Update statistics. Note byte count includes 4 byte CRC count */
stats->rx_packets++; stats->rx_packets++;
stats->rx_bytes += pkt_info.byte_cnt; stats->rx_bytes += pkt_info.byte_cnt;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment