MQ Patch.
Adrian Chadd
adrian at freebsd.org
Wed Oct 30 17:48:33 UTC 2013
On 30 October 2013 04:44, Andre Oppermann <andre at freebsd.org> wrote:
>> We can't assume the hardware has deep queues _and_ we can't just hand
>> packets to the DMA engine.
>
>>
>>
>> Why?
>>
>> Because once you've pushed it into the transmit ring, you can't
>> guarantee / impose any ordering on things. You can't guarantee that
>> you can abort a frame that has been queued because it now breaks the
>> queue rules.
>>
>> That's why we don't want to just have a light wrapper around hardware
>> transmit queues. We give up way too much useful control.
>
>
> The stack can't possibly know about all these differences in current
> and future technologies and requirements. That's why this decision
> should be pushed into the L3/L2 mapping/encapsulation and driver layer.
That's why you split it.
You allow the upper layers (things like altq) to track things like
per-IP, per-traffic-class traffic and tag things appropriate.
You then let some software queue implement the queue discipline and
only drain frames to the hardware at a rate that's fast enough to keep
up with the hardware, and no faster.
Why?
Because if you have new traffic come along from a new client, it may
be higher priority than the traffic queued to the hardware. But it's
at the same QoS level as what's currently queued to the hardware, or
map to the same physical queue.
So yes, we do need that split for a lot of cases. There will be
bare-metal cases for highly low latency but if we implement the
correct queue API here it'll just collapse down to either NULL, or
just the existing software queue in front of the DMA rings to avoid
locking overhead.
Thanks,
-adrian
More information about the freebsd-net
mailing list