]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
media: mali-c55: Power-off the peripheral in remove()
authorDavid Carlier <devnexen@gmail.com>
Sat, 28 Mar 2026 15:14:51 +0000 (15:14 +0000)
committerHans Verkuil <hverkuil+cisco@kernel.org>
Tue, 19 May 2026 07:01:49 +0000 (09:01 +0200)
The Mali C55 driver doesn't depend on PM. For this reason, if pm_runtime
is not compiled in it is required to manually power-off the peripheral
during the driver's remove() handler.

Also pm_runtime_enable() is called during probe but mali_c55_remove()
never calls pm_runtime_disable(), leaving the device's runtime PM state
enabled after the driver is unbound.

Manually power-off the peripheral in remove() if the peripheral has not
been suspended using runtime_pm and disable runtime pm.

Cc: stable@vger.kernel.org
Fixes: d5f281f3dd29 ("media: mali-c55: Add Mali-C55 ISP driver")
Signed-off-by: David Carlier <devnexen@gmail.com>
Reviewed-by: Jacopo Mondi <jacopo.mondi+renesas@ideasonboard.com>
Signed-off-by: Jacopo Mondi <jacopo.mondi+renesas@ideasonboard.com>
Signed-off-by: Hans Verkuil <hverkuil+cisco@kernel.org>
drivers/media/platform/arm/mali-c55/mali-c55-core.c

index 305b8cbb9d1c357b7140b4b711e24664ade44d03..00aed62c63d9c19e9ba8c9b1525af87b2f0f43a2 100644 (file)
@@ -858,6 +858,11 @@ static void mali_c55_remove(struct platform_device *pdev)
        struct mali_c55 *mali_c55 = platform_get_drvdata(pdev);
 
        mali_c55_media_frameworks_deinit(mali_c55);
+       if (!pm_runtime_suspended(&pdev->dev)) {
+               __mali_c55_power_off(mali_c55);
+               pm_runtime_set_suspended(&pdev->dev);
+       }
+       pm_runtime_disable(&pdev->dev);
        kfree(mali_c55->context.registers);
        of_reserved_mem_device_release(&pdev->dev);
 }