From a8f69d4a0d1e9478b8466f09d35ab193d5f509c7 Mon Sep 17 00:00:00 2001 From: aiju Date: Fri, 22 Jul 2011 11:25:44 +0200 Subject: [PATCH] etherbcm: another try at the memleak --- sys/src/9/pc/etherbcm.c | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/sys/src/9/pc/etherbcm.c b/sys/src/9/pc/etherbcm.c index 376759aac..a82e748d8 100644 --- a/sys/src/9/pc/etherbcm.c +++ b/sys/src/9/pc/etherbcm.c @@ -358,18 +358,16 @@ bcmtransmit(Ether *edev) print("bcm: send queue full\n"); break; } - if(incr == ctlr->sendcleani) { - bcmtransclean(edev, 0); - if(incr == ctlr->sendcleani) - break; - } bp = qget(edev->oq); if(bp == nil) break; + setmalloctag(bp, (ulong)(void*)bcmtransmit); next = ctlr->sendr + ctlr->sendri * 4; next[0] = 0; next[1] = PADDR(bp->rp); next[2] = (BLEN(bp) << 16) | PacketEnd; next[3] = 0; + if(ctlr->sends[ctlr->sendri] != 0) + freeb(ctlr->sends[ctlr->sendri]); ctlr->sends[ctlr->sendri] = bp; csr32(ctlr, SendBDRingHostIndex) = ctlr->sendri = incr; }