Jarek Poplawski wrote: >> The main difference results from the fact that higher priority >> packets can't preempt "peeked" lower priority packets anymore. >> The difference this causes obviously depends on the bandwidth, >> but in my opinion the impact (as mentioned. 12ms delay for >> 1500b, 1mbit, rises linearly with bigger packets/less bandwidth) >> is large enough to speak against these changes. > > Actually, I think I had similar doubts one or two months ago, but I > can remember mainly your discussion on peek with Herbert, and not > much about something like above, but probably I didn't pay enough > attention. > > Anyway, the main source of my misleading seems to be HFSC... So do you > mean it's OK to use this kind of requeuing in hfsc_requeue(), but not > elsewhere? Maybe I miss something, but if some other qdisc is used as > a parent of HFSC, and does something like qdisc_peek_len(), it gets > just what you're against above? I think we really need a peek operation since most qdiscs do have some internal priorization. The question is whether all qdiscs need it; I tend to think no. Plugging two non-work-conserving qdiscs together doesn't make much sense, so we could just prevent this. This means we would only need to add ->peek support to the work-conserving qdiscs, which looks pretty easy in all cases. We actually don't even have to prevent plugging two non-work-conserving qdiscs, the ones that need the peek operation could just check whether the inner qdisc supports it. Just as a demonstration how easy adding a peek operation to the work-conserving qdiscs actually is. It doesn't need to keep or change any internal state in many cases thanks to the guarantee that the packet will either be dequeued or, if another packet arrives, the upper qdisc will immediately ->peek again to reevaluate the state.