[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <48EC6286.1030202@cdi.cz>
Date: Wed, 08 Oct 2008 09:34:30 +0200
From: Martin Devera <devik@....cz>
To: Patrick McHardy <kaber@...sh.net>
CC: Simon Horman <horms@...ge.net.au>,
Jarek Poplawski <jarkao2@...il.com>, netdev@...r.kernel.org,
David Miller <davem@...emloft.net>
Subject: Re: Possible regression in HTB
Patrick McHardy wrote:
> Patrick McHardy wrote:
>> So what would really be useful to understand this is to make HTB
>> control the queue and see if it behaves as expected.
>
> What also might help understand this better would be some
> runtime data. An easy way to get some halfway usable data
> is to just run
>
> tc -s -d qdisc show dev ...; tc -s -d class show dev ...
>
> in a loop.
IMHO there is problem with packet hold outside of the qdisc.
HTB like other non-workconserving qdiscs rely on information
about class backlogged state.
When there is packet in a queue then the queue is active (has
a demand to send).
The algorithm samples queue states at deterministic but unregular
intervals to see whose classes wants service and whose can lend.
If you hold a packet outside, relevant class thinks that it is
not backlogged - and if sampled at this time then the algorithm
decides to lend classe's time.
And because the most active class has the biggest probability
to see its packet catched outside, as final effect all classes
will end up equalized with (almost) the same rates.
Thus, from qdisc point, it is not good to keep a packet for
more time out of the qdisc.
devik
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists