diff options
author | aiju <aiju@phicode.de> | 2011-07-22 11:25:44 +0200 |
---|---|---|
committer | aiju <aiju@phicode.de> | 2011-07-22 11:25:44 +0200 |
commit | a8f69d4a0d1e9478b8466f09d35ab193d5f509c7 (patch) | |
tree | e97daab15a49c0eb813b8155a4c924547f9fcc99 /sys/src/9/pc/etherbcm.c | |
parent | 43f327485d374db949b9d83816c186371bbe4420 (diff) |
etherbcm: another try at the memleak
Diffstat (limited to 'sys/src/9/pc/etherbcm.c')
-rw-r--r-- | sys/src/9/pc/etherbcm.c | 8 |
1 files 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; } |