]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
drm/stm: Fix an error handling path in stm_drm_platform_probe()
authorChristophe JAILLET <christophe.jaillet@wanadoo.fr>
Sat, 6 Jan 2024 16:54:32 +0000 (17:54 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 17 Oct 2024 13:07:46 +0000 (15:07 +0200)
[ Upstream commit ce7c90bfda2656418c69ba0dd8f8a7536b8928d4 ]

If drm_dev_register() fails, a call to drv_load() must be undone, as
already done in the remove function.

Fixes: b759012c5fa7 ("drm/stm: Add STM32 LTDC driver")
Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Acked-by: Raphael Gallais-Pou <raphael.gallais-pou@foss.st.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20fff7f853f20a48a96db8ff186124470ec4d976.1704560028.git.christophe.jaillet@wanadoo.fr
Signed-off-by: Raphael Gallais-Pou <raphael.gallais-pou@foss.st.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/gpu/drm/stm/drv.c

index 411103f013e2596d7de1d5c9dc1f789c847acfff..08c50e68cfca6033c1658c3e294c717ef84c1e15 100644 (file)
@@ -195,12 +195,14 @@ static int stm_drm_platform_probe(struct platform_device *pdev)
 
        ret = drm_dev_register(ddev, 0);
        if (ret)
-               goto err_put;
+               goto err_unload;
 
        drm_fbdev_generic_setup(ddev, 16);
 
        return 0;
 
+err_unload:
+       drv_unload(ddev);
 err_put:
        drm_dev_put(ddev);