summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authoraiju <aiju@phicode.de>2011-07-22 11:28:17 +0200
committeraiju <aiju@phicode.de>2011-07-22 11:28:17 +0200
commitf542b0d027b51d60548835206a21422f31164470 (patch)
tree0f602fbff6e755e6189cc94ad3057e1d6cfe09d4 /sys
parent58e8b78ffdfaaf2e5e1abd7871e76c5427ed6c29 (diff)
parenta8f69d4a0d1e9478b8466f09d35ab193d5f509c7 (diff)
merge
Diffstat (limited to 'sys')
-rw-r--r--sys/src/9/pc/etherbcm.c8
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;
}