免费注册 查看新帖 |

Chinaunix

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

一个驱动,两上设备顺序写操作时,第二个写操作进入死锁 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-09-28 22:43 |只看该作者 |倒序浏览
在写一个字符设备驱动时,注册了两个设备,在写操作前获取了信号量,在写操作结束后,释放了信号量,但是,第二个设备在写操作时,在down_interruptible()时出现了死锁的情况,如下代码:
95 static ssize_t globalmem_write(struct file *filp, const char __user *buf, size_t size, loff_t *ppos)
96 {
97     unsigned long p = *ppos;
98     int ret = 0;
99     unsigned int count = size;
100     struct globalmem_dev *dev = filp->private_data;
101   
102     if (p >= GLOBALMEM_SIZE)
103         return count ? -ENXIO : 0;
104   
105     if (count > GLOBALMEM_SIZE - p)
106         count = GLOBALMEM_SIZE - p;
107     
108     // get the semaphore  
109     if (down_interruptible(&dev->sem)) {
110         printk(KERN_ERR "-ERESTARTSYS.\n");
111         return -ERESTARTSYS;
112     }
113
114     printk(KERN_INFO "here is coming.\n");
115
116     // copy from user space
117     if (copy_from_user(dev->mem + p, buf, count))
118         return -EFAULT;
119     else {
120         *ppos += count;
121         ret = count;
122
123         printk(KERN_INFO "written %u byte(s) from %lu.\n", count, p);
124     }
125
126     // release semaphore
127     up(&dev->sem);
128
129     return ret;
130 }

加载.ko后,在/dev下面建立两个设备:
# mknod /dev/globalmem1 c 250 0
# mknod /dev/globalmem2 c 250 1
# echo "globalmem1" > /dev/globalmem1
# echo "globalmem2" > /dev/globalmem2
出现死锁。

分析:第一个设备写后,已经释放了信号量了,第二个设备再调用write时,再次获取信号量时,出现死锁,说明,第一个设备写操作后一直占用着内核中申请的空间,所以,第二个设备再次写操作时就会拿不到驱动所申请的空间,而出现死锁。。

不知道分析得对不对。。。。求解释

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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP