sh: cdev lock_kernel() pushdown
Push the cdev lock_kernel() call down into the sh gio driver. Signed-off-by: Jonathan Corbet <corbet@lwn.net>
This commit is contained in:
parent
7558da942e
commit
1fa984b583
|
@ -14,6 +14,7 @@
|
||||||
*/
|
*/
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
|
#include <linux/smp_lock.h>
|
||||||
#include <linux/kdev_t.h>
|
#include <linux/kdev_t.h>
|
||||||
#include <linux/cdev.h>
|
#include <linux/cdev.h>
|
||||||
#include <linux/fs.h>
|
#include <linux/fs.h>
|
||||||
|
@ -32,17 +33,20 @@ static int openCnt;
|
||||||
static int gio_open(struct inode *inode, struct file *filp)
|
static int gio_open(struct inode *inode, struct file *filp)
|
||||||
{
|
{
|
||||||
int minor;
|
int minor;
|
||||||
|
int ret = -ENOENT;
|
||||||
|
|
||||||
|
lock_kernel();
|
||||||
minor = MINOR(inode->i_rdev);
|
minor = MINOR(inode->i_rdev);
|
||||||
if (minor < DEVCOUNT) {
|
if (minor < DEVCOUNT) {
|
||||||
if (openCnt > 0) {
|
if (openCnt > 0) {
|
||||||
return -EALREADY;
|
ret = -EALREADY;
|
||||||
} else {
|
} else {
|
||||||
openCnt++;
|
openCnt++;
|
||||||
return 0;
|
ret = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return -ENOENT;
|
unlock_kernel();
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int gio_close(struct inode *inode, struct file *filp)
|
static int gio_close(struct inode *inode, struct file *filp)
|
||||||
|
|
Loading…
Reference in a new issue