[PATCH v6 6/8] drm: writeback: Add missing cleanup in case of initialization failure
Maxime Ripard
mripard at kernel.org
Mon Jan 6 12:58:39 UTC 2025
On Mon, Dec 30, 2024 at 07:37:36PM +0100, Louis Chauvet wrote:
> The current implementation of drm_writeback_connector initialization does
> not properly clean up all resources in case of failure (allocated
> properties and possible_encoders). Add this cleaning in case of failure.
>
> Signed-off-by: Louis Chauvet <louis.chauvet at bootlin.com>
> ---
> drivers/gpu/drm/drm_writeback.c | 15 +++++++++++----
> 1 file changed, 11 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/gpu/drm/drm_writeback.c b/drivers/gpu/drm/drm_writeback.c
> index 494400b09796d37ed89145da45d5f1e029632de5..9c69f7181e02c23dabce488405608c40d4184af5 100644
> --- a/drivers/gpu/drm/drm_writeback.c
> +++ b/drivers/gpu/drm/drm_writeback.c
> @@ -247,18 +247,20 @@ static int __drm_writeback_connector_init(struct drm_device *dev,
> int ret = create_writeback_properties(dev);
>
> if (ret != 0)
> - return ret;
> + goto failed_properties;
>
> connector->interlace_allowed = 0;
>
> ret = drm_connector_attach_encoder(connector, enc);
> if (ret)
> - return ret;
> + goto failed_properties;
>
> blob = drm_property_create_blob(dev, n_formats * sizeof(*formats),
> formats);
> - if (IS_ERR(blob))
> - return PTR_ERR(blob);
> + if (IS_ERR(blob)) {
> + ret = PTR_ERR(blob);
> + goto failed_blob;
> + }
>
> INIT_LIST_HEAD(&wb_connector->job_queue);
> spin_lock_init(&wb_connector->job_lock);
> @@ -281,6 +283,11 @@ static int __drm_writeback_connector_init(struct drm_device *dev,
> wb_connector->pixel_formats_blob_ptr = blob;
>
> return 0;
> +failed_blob:
> + connector->possible_encoders &= ~drm_encoder_mask(enc);
I don't think it's worth it to uninitialize that particular field. All
the structure fields are going to be in an undefined state, and
shouldn't be used anymore.
Maxime
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 273 bytes
Desc: not available
URL: <https://lists.freedesktop.org/archives/dri-devel/attachments/20250106/50728831/attachment.sig>
More information about the dri-devel
mailing list