mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-10-05 08:26:59 +00:00
drm: cdev lock_kernel() pushdown
Signed-off-by: Jonathan Corbet <corbet@lwn.net>
This commit is contained in:
parent
abedd296e9
commit
70ffa16e60
1 changed files with 7 additions and 2 deletions
|
@ -37,6 +37,7 @@
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
#include "drm_sarea.h"
|
#include "drm_sarea.h"
|
||||||
#include <linux/poll.h>
|
#include <linux/poll.h>
|
||||||
|
#include <linux/smp_lock.h>
|
||||||
|
|
||||||
static int drm_open_helper(struct inode *inode, struct file *filp,
|
static int drm_open_helper(struct inode *inode, struct file *filp,
|
||||||
struct drm_device * dev);
|
struct drm_device * dev);
|
||||||
|
@ -174,12 +175,14 @@ int drm_stub_open(struct inode *inode, struct file *filp)
|
||||||
|
|
||||||
DRM_DEBUG("\n");
|
DRM_DEBUG("\n");
|
||||||
|
|
||||||
|
/* BKL pushdown: note that nothing else serializes idr_find() */
|
||||||
|
lock_kernel();
|
||||||
minor = idr_find(&drm_minors_idr, minor_id);
|
minor = idr_find(&drm_minors_idr, minor_id);
|
||||||
if (!minor)
|
if (!minor)
|
||||||
return -ENODEV;
|
goto out;
|
||||||
|
|
||||||
if (!(dev = minor->dev))
|
if (!(dev = minor->dev))
|
||||||
return -ENODEV;
|
goto out;
|
||||||
|
|
||||||
old_fops = filp->f_op;
|
old_fops = filp->f_op;
|
||||||
filp->f_op = fops_get(&dev->driver->fops);
|
filp->f_op = fops_get(&dev->driver->fops);
|
||||||
|
@ -189,6 +192,8 @@ int drm_stub_open(struct inode *inode, struct file *filp)
|
||||||
}
|
}
|
||||||
fops_put(old_fops);
|
fops_put(old_fops);
|
||||||
|
|
||||||
|
out:
|
||||||
|
unlock_kernel();
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue