CoDel AQM discussions
 help / color / mirror / Atom feed
* [Codel] [RFC PATCH] Codel: Enable packet drop with ECN-marked packets on a threshold
@ 2012-06-17 22:30 Dave Täht
  2012-06-18  2:17 ` Eric Dumazet
  0 siblings, 1 reply; 8+ messages in thread
From: Dave Täht @ 2012-06-17 22:30 UTC (permalink / raw)
  To: codel; +Cc: Dave Täht

Lossless IP networks are not possible. Dropping packets is the
fastest way to get back to a target delay, and if that involves
dropping ECN marked packets, so be it. When a network is in a
more steady state, ECN is fine...

My choice of "2 * target" as a threshold for dropping ECN
marked packets is entirely arbitrary.
---
 include/net/codel.h |    6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)

diff --git a/include/net/codel.h b/include/net/codel.h
index 550debf..26944a0 100644
--- a/include/net/codel.h
+++ b/include/net/codel.h
@@ -280,7 +280,8 @@ static struct sk_buff *codel_dequeue(struct Qdisc *sch,
 						* since there is no more divide
 						*/
 				codel_Newton_step(vars);
-				if (params->ecn && INET_ECN_set_ce(skb)) {
+				if (params->ecn && INET_ECN_set_ce(skb) &&
+					vars->ldelay <= 2 * params->target) {
 					stats->ecn_mark++;
 					vars->drop_next =
 						codel_control_law(vars->drop_next,
@@ -305,7 +306,8 @@ static struct sk_buff *codel_dequeue(struct Qdisc *sch,
 			}
 		}
 	} else if (drop) {
-		if (params->ecn && INET_ECN_set_ce(skb)) {
+		if (params->ecn && INET_ECN_set_ce(skb) &&
+		        vars->ldelay <= 2 * params->target) {
 			stats->ecn_mark++;
 		} else {
 			qdisc_drop(skb, sch);
-- 
1.7.9.5


^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2012-06-18  3:50 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2012-06-17 22:30 [Codel] [RFC PATCH] Codel: Enable packet drop with ECN-marked packets on a threshold Dave Täht
2012-06-18  2:17 ` Eric Dumazet
2012-06-18  2:40   ` Dave Taht
2012-06-18  2:58     ` Eric Dumazet
2012-06-18  3:01       ` Dave Taht
2012-06-18  3:10     ` Eric Dumazet
2012-06-18  3:21       ` Dave Taht
2012-06-18  3:50         ` Dave Taht

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox