[pve-devel] r5635 - qemu-server/pve2
svn-commits at proxmox.com
svn-commits at proxmox.com
Wed Mar 2 14:17:18 CET 2011
Author: dietmar
Date: 2011-03-02 14:17:18 +0100 (Wed, 02 Mar 2011)
New Revision: 5635
Modified:
qemu-server/pve2/pve-bridge
Log:
fix tc for virtio
Modified: qemu-server/pve2/pve-bridge
===================================================================
--- qemu-server/pve2/pve-bridge 2011-03-02 12:17:29 UTC (rev 5634)
+++ qemu-server/pve2/pve-bridge 2011-03-02 13:17:18 UTC (rev 5635)
@@ -37,17 +37,29 @@
system("/sbin/tc qdisc del dev $iface root >/dev/null 2>&1");
run_command("/sbin/tc qdisc add dev $iface handle ffff: ingress");
- run_command("/sbin/tc filter add dev $iface parent ffff: protocol ip prio 50 " .
- "u32 match ip src 0.0.0.0/0 police rate ${rate}bps " .
- "burst ${burst}b drop flowid :1");
+ # this does not work wit virtio - don't know why
+ #run_command("/sbin/tc filter add dev $iface parent ffff: protocol ip prio 50 u32 match ip src 0.0.0.0/0 police rate ${rate}bps burst ${burst}b drop flowid :1");
+ # so we use avrate instead
+ run_command("/sbin/tc filter add dev $iface parent ffff: " .
+ "protocol ip prio 50 estimator 1sec 8sec " .
+ "u32 match ip src 0.0.0.0/0 police avrate ${rate}bps drop flowid :1");
+
# tbf does not work for unknown reason
#$TC qdisc add dev $DEV root tbf rate $RATE latency 100ms burst $BURST
-
+ # so we use htb instead
run_command("/sbin/tc qdisc add dev $iface root handle 1: htb default 1");
run_command("/sbin/tc class add dev $iface parent 1: classid 1:1 " .
"htb rate ${rate}bps burst ${burst}b");
+ # enable this to debug tc
+ if (0) {
+ print "DEBUG tc settings\n";
+ system("/sbin/tc qdisc ls dev $iface");
+ system("/sbin/tc class ls dev $iface");
+ system("/sbin/tc filter ls dev $iface parent ffff:");
+ }
+
}
system ("/usr/sbin/brctl addif $bridge $iface") == 0 ||
More information about the pve-devel
mailing list