]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
media: vidtv: fix reference leak on failed device registration
authorGuangshuo Li <lgs201920130244@gmail.com>
Wed, 15 Apr 2026 15:28:26 +0000 (23:28 +0800)
committerHans Verkuil <hverkuil+cisco@kernel.org>
Tue, 5 May 2026 14:57:02 +0000 (16:57 +0200)
When platform_device_register() fails in vidtv_bridge_init(), the
embedded struct device in vidtv_bridge_dev has already been initialized
by device_initialize(), but the failure path returns the error without
dropping the device reference for the current platform device:

  vidtv_bridge_init()
    -> platform_device_register(&vidtv_bridge_dev)
       -> device_initialize(&vidtv_bridge_dev.dev)
       -> setup_pdev_dma_masks(&vidtv_bridge_dev)
       -> platform_device_add(&vidtv_bridge_dev)

This leads to a reference leak when platform_device_register() fails.
Fix this by calling platform_device_put() before returning the error.

The issue was identified by a static analysis tool I developed and
confirmed by manual review.

Fixes: f90cf6079bf67 ("media: vidtv: add a bridge driver")
Cc: stable@vger.kernel.org
Signed-off-by: Guangshuo Li <lgs201920130244@gmail.com>
Signed-off-by: Hans Verkuil <hverkuil+cisco@kernel.org>
drivers/media/test-drivers/vidtv/vidtv_bridge.c

index a8a76434989c2ce12a9a098e6df23e267c42a7b3..fd69b4ee16f4bd8171805d046d7bdacdcbc4950a 100644 (file)
@@ -594,8 +594,10 @@ static int __init vidtv_bridge_init(void)
        int ret;
 
        ret = platform_device_register(&vidtv_bridge_dev);
-       if (ret)
+       if (ret) {
+               platform_device_put(&vidtv_bridge_dev);
                return ret;
+       }
 
        ret = platform_driver_register(&vidtv_bridge_driver);
        if (ret)