+ -
当前位置:首页 → 问答吧 → 工作队列的效率

工作队列的效率

时间:2010-07-29

来源:互联网

先说说我的情况吧
是一个虚拟串口驱动
针对每个port,有一个advtty_struct的机构体
struct advtty_struct
{
    ...
    /*缓冲区*/
    unsigned char * xmit_buf;
    int                        xmit_head;
    int                        xmit_tail;
    int                        xmit_cnt;
#if (LINUX_VERSION_CODE < VERSION_CODE(2,6,0))
    struct tq_struct        process_to_app;
#else
    /*工作队列*/
    struct work_struct        process_to_app;
    ...
};
在虚拟串口驱动的write函数里边,先将上层传下来的数据放入缓冲区里边(缓冲区大小4k),然后,调用schedule_work(info->process_to_app);
process_to_app工作队列函数完成的任务是:将缓冲区里的数据通过netlink发送给另一个应用层程序。
现在我碰到的问题是:当我操作一个port时,发送速度还可以;但是假如我操作16个prot,那么发送数据的速度就变的很慢!
我怀疑这里的瓶颈是工作队列(假如是的话,就得考虑使用其他的机制了),不知道大伙儿有什么意见。

作者: jinxinxin163   发布时间: 2010-07-29

呵,用 kprobe 测试一下它的效率吧。

觉得不太可能由于工作队列效率导致的。

作者: linyunxian   发布时间: 2010-07-30

热门下载

更多