drm: Make control nodes master-less v3
Like for render-nodes, there is no point in maintaining the master concept for control nodes, so set the struct drm_file::master pointer to NULL. At the same time, make sure DRM_MASTER | DRM_CONTROL_ALLOW ioctls are always allowed when called through the control node. Previously the caller also needed to be master. v2: Adapt to refactoring of ioctl permission check. v3: Formatting of logical expression. Use drm_is_control_client() instead of drm_is_control(). Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com> Reviewed-by: Brian Paul <brianp@vmware.com> Reviewed-by: David Herrmann <dh.herrmann@gmail.com>
This commit is contained in:
@@ -232,7 +232,8 @@ static int drm_open_helper(struct inode *inode, struct file *filp,
|
||||
/* if there is no current master make this fd it, but do not create
|
||||
* any master object for render clients */
|
||||
mutex_lock(&dev->struct_mutex);
|
||||
if (!priv->minor->master && !drm_is_render_client(priv)) {
|
||||
if (!priv->minor->master && !drm_is_render_client(priv) &&
|
||||
!drm_is_control_client(priv)) {
|
||||
/* create a new master */
|
||||
priv->minor->master = drm_master_create(priv->minor);
|
||||
if (!priv->minor->master) {
|
||||
@@ -270,7 +271,8 @@ static int drm_open_helper(struct inode *inode, struct file *filp,
|
||||
goto out_close;
|
||||
}
|
||||
}
|
||||
} else if (!drm_is_render_client(priv)) {
|
||||
} else if (!drm_is_render_client(priv) &&
|
||||
!drm_is_control_client(priv)) {
|
||||
/* get a reference to the master */
|
||||
priv->master = drm_master_get(priv->minor->master);
|
||||
}
|
||||
|
Reference in New Issue
Block a user