git: 9front

Download patch

ref: 893a75e0fd8492652cf41de48e428e0e045ee8a4
parent: e079db54c40742878e3d0198b9fa88d9d075e1e2
parent: e1d7a7e32618b0eeed605fb8fa87852c4829b763
author: aiju <aiju@phicode.de>
date: Fri Jul 22 07:28:17 EDT 2011

merge

--- a/sys/src/9/pc/etherbcm.c
+++ b/sys/src/9/pc/etherbcm.c
@@ -358,18 +358,16 @@
 			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;
 	}
--