]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
remoteproc: k3-r5: Fix error handling when power-up failed
authorJan Kiszka <jan.kiszka@siemens.com>
Mon, 19 Aug 2024 15:24:51 +0000 (17:24 +0200)
committerMathieu Poirier <mathieu.poirier@linaro.org>
Wed, 28 Aug 2024 15:48:35 +0000 (09:48 -0600)
By simply bailing out, the driver was violating its rule and internal
assumptions that either both or no rproc should be initialized. E.g.,
this could cause the first core to be available but not the second one,
leading to crashes on its shutdown later on while trying to dereference
that second instance.

Fixes: 61f6f68447ab ("remoteproc: k3-r5: Wait for core0 power-up before powering up core1")
Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
Acked-by: Beleswar Padhi <b-padhi@ti.com>
Cc: stable@vger.kernel.org
Link: https://lore.kernel.org/r/9f481156-f220-4adf-b3d9-670871351e26@siemens.com
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
drivers/remoteproc/ti_k3_r5_remoteproc.c

index 60bd2042b0c60f5adb0e53ea0bafb00299beda9c..747ee467da88c97408dbf8f166d970adf1382b3d 100644 (file)
@@ -1313,7 +1313,7 @@ init_rmem:
                        dev_err(dev,
                                "Timed out waiting for %s core to power up!\n",
                                rproc->name);
-                       return ret;
+                       goto err_powerup;
                }
        }
 
@@ -1329,6 +1329,7 @@ err_split:
                }
        }
 
+err_powerup:
        rproc_del(rproc);
 err_add:
        k3_r5_reserved_mem_exit(kproc);