免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3255 | 回复: 2
打印 上一主题 下一主题

死锁了,发生原因不明 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-05-16 10:39 |只看该作者 |倒序浏览
自己写了一个CAN驱动。fops的read如下:
static ssize_t mcp251x_read(struct file *file, char __user *buf, size_t count, loff_t *ofs)
{
    struct mcp251x *chip = file->private_data;
    struct can_frame *frame;
   
    if (count != sizeof(struct can_frame))
        return -EINVAL;
        
    if (down_interruptible(&chip->rxblock))
        return -ERESTARTSYS;
   
    while (chip->rxbin == chip->rxbout) {
        up(&chip->rxblock);
        if (file->f_flags & O_NONBLOCK)
            return -EAGAIN;
        if (wait_event_interruptible(chip->wq, (chip->rxbin != chip->rxbout)))
            return -ERESTARTSYS;
        if (down_interruptible(&chip->rxblock))
            return -ERESTARTSYS;
    }
   
    frame = &chip->rxb[chip->rxbout];
    if (copy_to_user(buf, frame, sizeof(struct can_frame))) {
        up(&chip->rxblock);
        return -EFAULT;
    }
   
    chip->rxbout++;
    if(chip->rxbout >= MCP251X_BUF_LEN)
        chip->rxbout = 0;
        
    up(&chip->rxblock);
        
    return count;
}

测试运行时没什么问题,但是如果User应用程序从运行于后台模式,当User应用程序从后台模式转为前台时就发生死锁。找了很长时间都没有找到原因。谢谢各们帮忙。

[ 本帖最后由 sleep_meng 于 2007-5-16 10:45 编辑 ]

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
2 [报告]
发表于 2007-05-29 17:11 |只看该作者
http://dev.yesky.com/336/2628336.shtml

  即交换wait_event_interruptible(outq, flag != 0)和down_interruptible(&sem)的顺序,这个驱动程序将变得不可运行。实际上,当两个可能要阻塞的事件同时出现时,即两个wait_event或down摆在一起的时候,将变得非常危险,死锁的可能性很大,这个时候我们要特别留意它们的出现顺序。当然,我们应该尽可能地避免这种情况的发生!

论坛徽章:
3
CU大牛徽章
日期:2013-03-13 15:32:35CU大牛徽章
日期:2013-03-13 15:38:15CU大牛徽章
日期:2013-03-13 15:38:52
3 [报告]
发表于 2007-05-29 18:28 |只看该作者
学习中……
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP