Apenper 发表于 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时,再次获取信号量时,出现死锁,说明,第一个设备写操作后一直占用着内核中申请的空间,所以,第二个设备再次写操作时就会拿不到驱动所申请的空间,而出现死锁。。

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

页: [1]
查看完整版本: 一个驱动,两上设备顺序写操作时,第二个写操作进入死锁