Commit 743115ee authored by Jonathan Corbet's avatar Jonathan Corbet

i2o: fasync BKL pushdown

This driver appears to really need the BKL to protect open_files.
Signed-off-by: default avatarJonathan Corbet <corbet@lwn.net>
parent b7e3e1fb
...@@ -1084,15 +1084,17 @@ static int cfg_fasync(int fd, struct file *fp, int on) ...@@ -1084,15 +1084,17 @@ static int cfg_fasync(int fd, struct file *fp, int on)
{ {
ulong id = (ulong) fp->private_data; ulong id = (ulong) fp->private_data;
struct i2o_cfg_info *p; struct i2o_cfg_info *p;
int ret = -EBADF;
lock_kernel();
for (p = open_files; p; p = p->next) for (p = open_files; p; p = p->next)
if (p->q_id == id) if (p->q_id == id)
break; break;
if (!p) if (p)
return -EBADF; ret = fasync_helper(fd, fp, on, &p->fasync);
unlock_kernel();
return fasync_helper(fd, fp, on, &p->fasync); return ret;
} }
static int cfg_release(struct inode *inode, struct file *file) static int cfg_release(struct inode *inode, struct file *file)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment