LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 1839|回复: 1

关于2.6以上版本 linux内核的一个疑问,请高手解答,谢谢!

[复制链接]
发表于 2009-8-7 11:47:09 | 显示全部楼层 |阅读模式
有一段摘自内核里的驱动代码

上面的例子代码发错了,应该是这个
static ssize_t vhci_read(struct file *file,
                                char __user *buf, size_t count, loff_t *pos)
{
        DECLARE_WAITQUEUE(wait, current);
        struct vhci_data *data = file->private_data;
        struct sk_buff *skb;
        ssize_t ret = 0;

        add_wait_queue(&data->read_wait, &wait);
        while (count) {
                set_current_state(TASK_INTERRUPTIBLE);

                skb = skb_dequeue(&data->readq);
                if (!skb) {
                        if (file->f_flags & O_NONBLOCK) {
                                ret = -EAGAIN;
                                break;
                        }

                        if (signal_pending(current)) {
                                ret = -ERESTARTSYS;
                                break;
                        }

                        schedule();
                        continue;
                }

                if (access_ok(VERIFY_WRITE, buf, count))
                        ret = vhci_put_user(data, skb, buf, count);
                else
                        ret = -EFAULT;

                kfree_skb(skb);
                break;
        }
        set_current_state(TASK_RUNNING);
        remove_wait_queue(&data->read_wait, &wait);

        return ret;
}


我的问题是,因为2.6的内核是可以被抢占的,
上面的vhci_read函数中, 如果读进程在执行set_current_state(TASK_INTERRUPTIBLE)之后
而skb = skb_dequeue(&data->readq)之前被抢占,那么是不是永远不会被唤醒呢(假设另外一个
写进程已经往data->readq放了点数据,并执行了wake_up_interruptiable操作,但读进程
还没有开始运行,错过了wake_up_interruptiable超作),
发表于 2009-10-19 15:36:04 | 显示全部楼层
读进程被抢占,不代表永远不会运行
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表