The ti_k3_dsp_remoteproc.c driver asserts the local reset in probe
and releases the module reset in .prepare callback. This is done to
ensure the core does not execute bogus code when module reset is
deasserted.

Put both of these operations together in .prepare callback, which is
more suitable as it ensures local reset is asserted for subsequent core
start operations from sysfs. This is done to align the .prepare callback
of DSP with the M4 driver which can be factored out at a later stage.

Signed-off-by: Beleswar Padhi <[email protected]>
Tested-by: Judith Mendez <[email protected]>
---
v11: Changelog:
1. Carried T/B tag.

Link to v10:
https://lore.kernel.org/all/[email protected]/

v10: Changelog:
1. Split [v9 15/26] into [v10 21/33] and [v10 22/33] patches. 

Link to v9:
https://lore.kernel.org/all/[email protected]/

 drivers/remoteproc/ti_k3_dsp_remoteproc.c | 30 ++++++++++++-----------
 1 file changed, 16 insertions(+), 14 deletions(-)

diff --git a/drivers/remoteproc/ti_k3_dsp_remoteproc.c 
b/drivers/remoteproc/ti_k3_dsp_remoteproc.c
index 9037e3948f4f5..a43715309eed5 100644
--- a/drivers/remoteproc/ti_k3_dsp_remoteproc.c
+++ b/drivers/remoteproc/ti_k3_dsp_remoteproc.c
@@ -44,6 +44,22 @@ static int k3_dsp_rproc_prepare(struct rproc *rproc)
        if (rproc->state == RPROC_DETACHED)
                return 0;
 
+       /*
+        * Ensure the local reset is asserted so the core doesn't
+        * execute bogus code when the module reset is released.
+        */
+       if (kproc->data->uses_lreset) {
+               ret = k3_rproc_reset(kproc);
+               if (ret)
+                       return ret;
+
+               ret = reset_control_status(kproc->reset);
+               if (ret <= 0) {
+                       dev_err(dev, "local reset still not asserted\n");
+                       return ret;
+               }
+       }
+
        ret = kproc->ti_sci->ops.dev_ops.get_device(kproc->ti_sci,
                                                    kproc->ti_sci_id);
        if (ret)
@@ -471,20 +487,6 @@ static int k3_dsp_rproc_probe(struct platform_device *pdev)
                rproc->state = RPROC_DETACHED;
        } else {
                dev_info(dev, "configured DSP for remoteproc mode\n");
-               /*
-                * ensure the DSP local reset is asserted to ensure the DSP
-                * doesn't execute bogus code in .prepare() when the module
-                * reset is released.
-                */
-               if (data->uses_lreset) {
-                       ret = reset_control_status(kproc->reset);
-                       if (ret < 0) {
-                               return dev_err_probe(dev, ret, "failed to get 
reset status\n");
-                       } else if (ret == 0) {
-                               dev_warn(dev, "local reset is deasserted for 
device\n");
-                               k3_rproc_reset(kproc);
-                       }
-               }
        }
 
        ret = devm_rproc_add(dev, rproc);
-- 
2.34.1


Reply via email to