+ -
当前位置:首页 → 问答吧 → Linux的QOS的出口部分(EGress)数据包调度的入队列和出队列操作是并行还是串行的?

Linux的QOS的出口部分(EGress)数据包调度的入队列和出队列操作是并行还是串行的?

时间:2010-09-01

来源:互联网

本帖最后由 iiiyyyhhhsss 于 2010-09-01 23:26 编辑

看了CU网友的<<Linux QOS实现框架分析>>,很不错.

不过还是有一个问题,<<Linux QOS实现框架分析>>里面提到:
数据包入队操作完成后,接下来在dev_queue_xmit函数中会调用qdisc_run函数进行队列调度和出队列操作,在该函数中会调用__qdisc_run函数.


这句话的意思是说,数据包入队操作和出队操作是串行的..

我觉得奇怪,为什么不是并行的呢?我的理解是,入队列和出队列,应该是分开不同线程操作的吧?难道不是?


按照我的理解,如果是串行的,那么:
入队列-->出队列(直到队列为空)-->入队列-->出队列(直到队列为空)-->入队列-->.....

这样如此下去,每次都能把队列清空,也即每次都能把所有优先级的数据发送出去.
那么,prio的优先级又有何用?

作者: iiiyyyhhhsss   发布时间: 2010-09-01

其实我就是想问,到底入队列和出队列两个操作是并行的还是串行的呢?


入队列-->出队列-->入队列-->出队列-->入队列-->.....


还是
入队列-->入队列-->入队列-->.....
出队列-->出队列-->出队列-->.....

???

作者: iiiyyyhhhsss   发布时间: 2010-09-02