remoteproc: sysmon: fix shutdown_acked state
authorArnd Bergmann <arnd@arndb.de>
Fri, 4 Dec 2020 19:37:35 +0000 (20:37 +0100)
committerBjorn Andersson <bjorn.andersson@linaro.org>
Fri, 4 Dec 2020 22:40:52 +0000 (16:40 -0600)
The latest version of sysmon_stop() starts by initializing
the sysmon->shutdown_acked variable, but then overwrites it
with an uninitialized variable later:

drivers/remoteproc/qcom_sysmon.c:551:11: error: variable 'acked' is used uninitialized whenever 'if' condition is false [-Werror,-Wsometimes-uninitialized]
        else if (sysmon->ept)
                 ^~~~~~~~~~~
drivers/remoteproc/qcom_sysmon.c:554:27: note: uninitialized use occurs here
        sysmon->shutdown_acked = acked;
                                 ^~~~~

Remove the local 'acked' variable again and set the state directly.

Fixes: 5c212aaf5457 ("remoteproc: sysmon: Expose the shutdown result")
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Link: https://lore.kernel.org/r/20201204193740.3162065-1-arnd@kernel.org
Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org>
drivers/remoteproc/qcom_sysmon.c

index d01bc4bda7bfc3abfb3ca694c9a57915a8d354d3..9fca8149286350e82f7a6c44524dfde0b8941de4 100644 (file)
@@ -533,7 +533,6 @@ static void sysmon_stop(struct rproc_subdev *subdev, bool crashed)
                .subsys_name = sysmon->name,
                .ssr_event = SSCTL_SSR_EVENT_BEFORE_SHUTDOWN
        };
-       bool acked;
 
        sysmon->shutdown_acked = false;
 
@@ -547,11 +546,9 @@ static void sysmon_stop(struct rproc_subdev *subdev, bool crashed)
                return;
 
        if (sysmon->ssctl_version)
-               acked = ssctl_request_shutdown(sysmon);
+               sysmon->shutdown_acked = ssctl_request_shutdown(sysmon);
        else if (sysmon->ept)
-               acked = sysmon_request_shutdown(sysmon);
-
-       sysmon->shutdown_acked = acked;
+               sysmon->shutdown_acked = sysmon_request_shutdown(sysmon);
 }
 
 static void sysmon_unprepare(struct rproc_subdev *subdev)