diff options
author | Anders Roxell <anders.roxell@linaro.org> | 2018-03-16 07:44:42 -0400 |
---|---|---|
committer | Sudeep Holla <sudeep.holla@arm.com> | 2018-03-20 08:20:27 -0400 |
commit | b5e817dcdd556da2b74c66af1cf0f44840283102 (patch) | |
tree | e159278520aa0a7f088efcfaa13d5706fe255f9e | |
parent | c09880cef78d0ddf149cdfeb733027a806465ba2 (diff) |
firmware: arm_scmi: prevent accessing rate_discrete uninitialized
gcc-5.3 and earlier warns that rate_discrete maybe-uninitialized
../drivers/firmware/arm_scmi/clock.c:185:5: warning: 'rate_discrete'
may be used uninitialized in this function [-Wmaybe-uninitialized]
if (rate_discrete)
^
../drivers/firmware/arm_scmi/clock.c:128:7: note:
'rate_discrete' was declared here
bool rate_discrete;
^
This patch fixing the warning by initialising rate_discrete and also using
goto label for the error path.
Fixes: 5f6c6430e904 ("firmware: arm_scmi: add initial support for clock protocol")
Suggested-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Anders Roxell <anders.roxell@linaro.org>
[sudeep.holla: added one line description to the commit message]
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
-rw-r--r-- | drivers/firmware/arm_scmi/clock.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/firmware/arm_scmi/clock.c b/drivers/firmware/arm_scmi/clock.c index e8ffad33a0ff..e6f17825db79 100644 --- a/drivers/firmware/arm_scmi/clock.c +++ b/drivers/firmware/arm_scmi/clock.c | |||
@@ -125,7 +125,7 @@ scmi_clock_describe_rates_get(const struct scmi_handle *handle, u32 clk_id, | |||
125 | { | 125 | { |
126 | u64 *rate; | 126 | u64 *rate; |
127 | int ret, cnt; | 127 | int ret, cnt; |
128 | bool rate_discrete; | 128 | bool rate_discrete = false; |
129 | u32 tot_rate_cnt = 0, rates_flag; | 129 | u32 tot_rate_cnt = 0, rates_flag; |
130 | u16 num_returned, num_remaining; | 130 | u16 num_returned, num_remaining; |
131 | struct scmi_xfer *t; | 131 | struct scmi_xfer *t; |
@@ -147,7 +147,7 @@ scmi_clock_describe_rates_get(const struct scmi_handle *handle, u32 clk_id, | |||
147 | 147 | ||
148 | ret = scmi_do_xfer(handle, t); | 148 | ret = scmi_do_xfer(handle, t); |
149 | if (ret) | 149 | if (ret) |
150 | break; | 150 | goto err; |
151 | 151 | ||
152 | rates_flag = le32_to_cpu(rlist->num_rates_flags); | 152 | rates_flag = le32_to_cpu(rlist->num_rates_flags); |
153 | num_remaining = NUM_REMAINING(rates_flag); | 153 | num_remaining = NUM_REMAINING(rates_flag); |
@@ -185,6 +185,7 @@ scmi_clock_describe_rates_get(const struct scmi_handle *handle, u32 clk_id, | |||
185 | if (rate_discrete) | 185 | if (rate_discrete) |
186 | clk->list.num_rates = tot_rate_cnt; | 186 | clk->list.num_rates = tot_rate_cnt; |
187 | 187 | ||
188 | err: | ||
188 | scmi_one_xfer_put(handle, t); | 189 | scmi_one_xfer_put(handle, t); |
189 | return ret; | 190 | return ret; |
190 | } | 191 | } |