[PATCH v6 1/7] drm/client: Do not acquire module reference

Thomas Zimmermann tzimmermann at suse.de
Wed Nov 15 13:07:17 UTC 2023



Am 02.11.23 um 14:08 schrieb Thomas Zimmermann:
> Do not acquire a reference on the module that provides a client's
> callback functions in drm_client_init(). The additional reference
> prevents the user from unloading the callback functions' module and
> thus creating dangling pointers.
> 
> This is only necessary if there is no direct dependency between the
> caller of drm_client_init() and the provider of the callbacks in
> struct drm_client_funcs. If this case ever existed, it has been
> removed from the DRM code. Callers of drm_client_init() also provide
> the callback implementation. The lifetime of the clients is tied to
> the dependency chain's outer-most module, which is the hardware's
> DRM driver. Before client helpers could be unloaded, the driver module
> would have to be unloaded, which also unregisters all clients.
> 
> Driver modules that set up DRM clients can now be unloaded.
> 
> Signed-off-by: Thomas Zimmermann <tzimmermann at suse.de>
> Acked-by: Javier Martinez Canillas <javierm at redhat.com>

I've added this patch to drm-misc-next.

> ---
>   drivers/gpu/drm/drm_client.c | 12 +-----------
>   1 file changed, 1 insertion(+), 11 deletions(-)
> 
> diff --git a/drivers/gpu/drm/drm_client.c b/drivers/gpu/drm/drm_client.c
> index c3027115d0552..9403b3f576f7b 100644
> --- a/drivers/gpu/drm/drm_client.c
> +++ b/drivers/gpu/drm/drm_client.c
> @@ -5,7 +5,6 @@
>   
>   #include <linux/iosys-map.h>
>   #include <linux/list.h>
> -#include <linux/module.h>
>   #include <linux/mutex.h>
>   #include <linux/seq_file.h>
>   #include <linux/slab.h>
> @@ -84,16 +83,13 @@ int drm_client_init(struct drm_device *dev, struct drm_client_dev *client,
>   	if (!drm_core_check_feature(dev, DRIVER_MODESET) || !dev->driver->dumb_create)
>   		return -EOPNOTSUPP;
>   
> -	if (funcs && !try_module_get(funcs->owner))
> -		return -ENODEV;
> -
>   	client->dev = dev;
>   	client->name = name;
>   	client->funcs = funcs;
>   
>   	ret = drm_client_modeset_create(client);
>   	if (ret)
> -		goto err_put_module;
> +		return ret;
>   
>   	ret = drm_client_open(client);
>   	if (ret)
> @@ -105,10 +101,6 @@ int drm_client_init(struct drm_device *dev, struct drm_client_dev *client,
>   
>   err_free:
>   	drm_client_modeset_free(client);
> -err_put_module:
> -	if (funcs)
> -		module_put(funcs->owner);
> -
>   	return ret;
>   }
>   EXPORT_SYMBOL(drm_client_init);
> @@ -177,8 +169,6 @@ void drm_client_release(struct drm_client_dev *client)
>   	drm_client_modeset_free(client);
>   	drm_client_close(client);
>   	drm_dev_put(dev);
> -	if (client->funcs)
> -		module_put(client->funcs->owner);
>   }
>   EXPORT_SYMBOL(drm_client_release);
>   

-- 
Thomas Zimmermann
Graphics Driver Developer
SUSE Software Solutions Germany GmbH
Frankenstrasse 146, 90461 Nuernberg, Germany
GF: Ivo Totev, Andrew Myers, Andrew McDonald, Boudien Moerman
HRB 36809 (AG Nuernberg)
-------------- next part --------------
A non-text attachment was scrubbed...
Name: OpenPGP_signature.asc
Type: application/pgp-signature
Size: 840 bytes
Desc: OpenPGP digital signature
URL: <https://lists.freedesktop.org/archives/dri-devel/attachments/20231115/e30a6e40/attachment.sig>


More information about the dri-devel mailing list