]> asedeno.scripts.mit.edu Git - linux.git/blobdiff - drivers/remoteproc/stm32_rproc.c
Merge tag 'rtc-5.4' of git://git.kernel.org/pub/scm/linux/kernel/git/abelloni/linux
[linux.git] / drivers / remoteproc / stm32_rproc.c
index e2da7198b65f13d058ea0f304c176a943847671c..2cf4b2992bfcdfa33a9dd091a8360c1d1feecad8 100644 (file)
@@ -383,10 +383,21 @@ static void stm32_rproc_add_coredump_trace(struct rproc *rproc)
 
 static int stm32_rproc_start(struct rproc *rproc)
 {
+       struct stm32_rproc *ddata = rproc->priv;
        int err;
 
        stm32_rproc_add_coredump_trace(rproc);
 
+       /* clear remote proc Deep Sleep */
+       if (ddata->pdds.map) {
+               err = regmap_update_bits(ddata->pdds.map, ddata->pdds.reg,
+                                        ddata->pdds.mask, 0);
+               if (err) {
+                       dev_err(&rproc->dev, "failed to clear pdds\n");
+                       return err;
+               }
+       }
+
        err = stm32_rproc_set_hold_boot(rproc, false);
        if (err)
                return err;
@@ -506,6 +517,9 @@ static int stm32_rproc_parse_dt(struct platform_device *pdev)
        int err, irq;
 
        irq = platform_get_irq(pdev, 0);
+       if (irq == -EPROBE_DEFER)
+               return -EPROBE_DEFER;
+
        if (irq > 0) {
                err = devm_request_irq(dev, irq, stm32_rproc_wdg, 0,
                                       dev_name(dev), rproc);