]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
slimbus: core: fix runtime PM imbalance on report present
authorJohan Hovold <johan@kernel.org>
Wed, 26 Nov 2025 14:53:25 +0000 (15:53 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 30 Jan 2026 09:27:39 +0000 (10:27 +0100)
commit 0eb4ff6596114aabba1070a66afa2c2f5593739f upstream.

Make sure to balance the runtime PM usage count in case slimbus device
or address allocation fails on report present, which would otherwise
prevent the controller from suspending.

Fixes: 4b14e62ad3c9 ("slimbus: Add support for 'clock-pause' feature")
Cc: stable@vger.kernel.org # 4.16
Signed-off-by: Johan Hovold <johan@kernel.org>
Link: https://patch.msgid.link/20251126145329.5022-3-johan@kernel.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/slimbus/core.c

index 01cbd462198107b2eb1de205bb7aa1d933420c93..ef3f2a53075067faea3ae926d2a381ad6b0bfc0b 100644 (file)
@@ -496,21 +496,23 @@ int slim_device_report_present(struct slim_controller *ctrl,
        if (ctrl->sched.clk_state != SLIM_CLK_ACTIVE) {
                dev_err(ctrl->dev, "slim ctrl not active,state:%d, ret:%d\n",
                                    ctrl->sched.clk_state, ret);
-               goto slimbus_not_active;
+               goto out_put_rpm;
        }
 
        sbdev = slim_get_device(ctrl, e_addr);
-       if (IS_ERR(sbdev))
-               return -ENODEV;
+       if (IS_ERR(sbdev)) {
+               ret = -ENODEV;
+               goto out_put_rpm;
+       }
 
        if (sbdev->is_laddr_valid) {
                *laddr = sbdev->laddr;
-               return 0;
+               ret = 0;
+       } else {
+               ret = slim_device_alloc_laddr(sbdev, true);
        }
 
-       ret = slim_device_alloc_laddr(sbdev, true);
-
-slimbus_not_active:
+out_put_rpm:
        pm_runtime_mark_last_busy(ctrl->dev);
        pm_runtime_put_autosuspend(ctrl->dev);
        return ret;