drm: remove all control node code
authorDaniel Vetter <daniel.vetter@ffwll.ch>
Fri, 20 Apr 2018 06:51:59 +0000 (08:51 +0200)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Thu, 3 May 2018 19:26:32 +0000 (21:26 +0200)
With the ioctl and driver prep done, we can remove everything else.

Reviewed-by: Sean Paul <seanpaul@chromium.org>
Signed-off-by: Daniel Vetter <daniel.vetter@intel.com>
Cc: Gustavo Padovan <gustavo@padovan.org>
Cc: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>
Cc: Sean Paul <seanpaul@chromium.org>
Cc: David Airlie <airlied@linux.ie>
Link: https://patchwork.freedesktop.org/patch/msgid/20180420065159.4531-4-daniel.vetter@ffwll.ch
drivers/gpu/drm/drm_drv.c
drivers/gpu/drm/drm_framebuffer.c
drivers/gpu/drm/drm_ioctl.c
drivers/gpu/drm/drm_sysfs.c
include/drm/drm_device.h
include/drm/drm_file.h
include/drm/drm_ioctl.h

index 32a83b41ab61ea00a014d8abc5624c55a817094f..f6910ebe4d0eda25ad6a78222cf1be2016873278 100644 (file)
@@ -99,8 +99,6 @@ static struct drm_minor **drm_minor_get_slot(struct drm_device *dev,
                return &dev->primary;
        case DRM_MINOR_RENDER:
                return &dev->render;
-       case DRM_MINOR_CONTROL:
-               return &dev->control;
        default:
                BUG();
        }
@@ -567,7 +565,6 @@ err_ctxbitmap:
 err_minors:
        drm_minor_free(dev, DRM_MINOR_PRIMARY);
        drm_minor_free(dev, DRM_MINOR_RENDER);
-       drm_minor_free(dev, DRM_MINOR_CONTROL);
        drm_fs_inode_free(dev->anon_inode);
 err_free:
        mutex_destroy(&dev->master_mutex);
@@ -603,7 +600,6 @@ void drm_dev_fini(struct drm_device *dev)
 
        drm_minor_free(dev, DRM_MINOR_PRIMARY);
        drm_minor_free(dev, DRM_MINOR_RENDER);
-       drm_minor_free(dev, DRM_MINOR_CONTROL);
 
        mutex_destroy(&dev->master_mutex);
        mutex_destroy(&dev->ctxlist_mutex);
@@ -796,10 +792,6 @@ int drm_dev_register(struct drm_device *dev, unsigned long flags)
 
        mutex_lock(&drm_global_mutex);
 
-       ret = drm_minor_register(dev, DRM_MINOR_CONTROL);
-       if (ret)
-               goto err_minors;
-
        ret = drm_minor_register(dev, DRM_MINOR_RENDER);
        if (ret)
                goto err_minors;
@@ -837,7 +829,6 @@ err_minors:
        remove_compat_control_link(dev);
        drm_minor_unregister(dev, DRM_MINOR_PRIMARY);
        drm_minor_unregister(dev, DRM_MINOR_RENDER);
-       drm_minor_unregister(dev, DRM_MINOR_CONTROL);
 out_unlock:
        mutex_unlock(&drm_global_mutex);
        return ret;
@@ -882,7 +873,6 @@ void drm_dev_unregister(struct drm_device *dev)
        remove_compat_control_link(dev);
        drm_minor_unregister(dev, DRM_MINOR_PRIMARY);
        drm_minor_unregister(dev, DRM_MINOR_RENDER);
-       drm_minor_unregister(dev, DRM_MINOR_CONTROL);
 }
 EXPORT_SYMBOL(drm_dev_unregister);
 
index 8c4d32adcc1787d682b17d72b70b5a07aacdef81..bfedceff87bba8101ff51d18e68e4e0c9d107182 100644 (file)
@@ -484,8 +484,7 @@ int drm_mode_getfb(struct drm_device *dev,
         * backwards-compatibility reasons, we cannot make GET_FB() privileged,
         * so just return an invalid handle for non-masters.
         */
-       if (!drm_is_current_master(file_priv) && !capable(CAP_SYS_ADMIN) &&
-           !drm_is_control_client(file_priv)) {
+       if (!drm_is_current_master(file_priv) && !capable(CAP_SYS_ADMIN)) {
                r->handle = 0;
                ret = 0;
                goto out;
index 43f7e2e812948a83a336f8ee3cff139f4a1eb68d..eadeabc393f0e13d08b5cf385960b4aaf0e0783a 100644 (file)
@@ -510,13 +510,7 @@ int drm_ioctl_permit(u32 flags, struct drm_file *file_priv)
 
        /* MASTER is only for master or control clients */
        if (unlikely((flags & DRM_MASTER) &&
-                    !drm_is_current_master(file_priv) &&
-                    !drm_is_control_client(file_priv)))
-               return -EACCES;
-
-       /* Control clients must be explicitly allowed */
-       if (unlikely(!(flags & DRM_CONTROL_ALLOW) &&
-                    drm_is_control_client(file_priv)))
+                    !drm_is_current_master(file_priv)))
                return -EACCES;
 
        /* Render clients must be explicitly allowed */
index 1c5b5ce1fd7f4861f40064cfcaf73963ebd0fcee..b3c1daad1169b806271691c7e373900ef6b27e5e 100644 (file)
@@ -331,9 +331,7 @@ struct device *drm_sysfs_minor_alloc(struct drm_minor *minor)
        struct device *kdev;
        int r;
 
-       if (minor->type == DRM_MINOR_CONTROL)
-               minor_str = "controlD%d";
-       else if (minor->type == DRM_MINOR_RENDER)
+       if (minor->type == DRM_MINOR_RENDER)
                minor_str = "renderD%d";
        else
                minor_str = "card%d";
index 3a0eac2885b795f9bcad8c6cd90ddd087b573a91..858ba19a3e2937ecc9c493670e0ec7092e4f8e7e 100644 (file)
@@ -38,7 +38,6 @@ struct drm_device {
        struct device *dev;             /**< Device structure of bus-device */
        struct drm_driver *driver;      /**< DRM driver managing the device */
        void *dev_private;              /**< DRM driver private data */
-       struct drm_minor *control;              /**< Control node */
        struct drm_minor *primary;              /**< Primary node */
        struct drm_minor *render;               /**< Render node */
        bool registered;
index 5176c3797680cb83c0b3599d14d91550c1cd4f06..99ab50cbab00f3bfb23de79a2656a376d603459a 100644 (file)
@@ -49,7 +49,6 @@ struct device;
 
 enum drm_minor_type {
        DRM_MINOR_PRIMARY,
-       DRM_MINOR_CONTROL,
        DRM_MINOR_RENDER,
 };
 
@@ -348,18 +347,6 @@ static inline bool drm_is_render_client(const struct drm_file *file_priv)
        return file_priv->minor->type == DRM_MINOR_RENDER;
 }
 
-/**
- * drm_is_control_client - is this an open file of the control node
- * @file_priv: DRM file
- *
- * Control nodes are deprecated and in the process of getting removed from the
- * DRM userspace API. Do not ever use!
- */
-static inline bool drm_is_control_client(const struct drm_file *file_priv)
-{
-       return file_priv->minor->type == DRM_MINOR_CONTROL;
-}
-
 int drm_open(struct inode *inode, struct file *filp);
 ssize_t drm_read(struct file *filp, char __user *buffer,
                 size_t count, loff_t *offset);
index add42809642ae382c013dc67b1ae7f21a787070d..fafb6f592c4b97f0567947dc4ed8cffe15f8554f 100644 (file)
@@ -108,13 +108,6 @@ enum drm_ioctl_flags {
         * This is equivalent to callers with the SYSADMIN capability.
         */
        DRM_ROOT_ONLY           = BIT(2),
-       /**
-        * @DRM_CONTROL_ALLOW:
-        *
-        * Deprecated, do not use. Control nodes are in the process of getting
-        * removed.
-        */
-       DRM_CONTROL_ALLOW       = BIT(3),
        /**
         * @DRM_UNLOCKED:
         *