aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnders Roxell <anders.roxell@linaro.org>2018-03-16 07:44:42 -0400
committerSudeep Holla <sudeep.holla@arm.com>2018-03-20 08:20:27 -0400
commitb5e817dcdd556da2b74c66af1cf0f44840283102 (patch)
treee159278520aa0a7f088efcfaa13d5706fe255f9e
parentc09880cef78d0ddf149cdfeb733027a806465ba2 (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.c5
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
188err:
188 scmi_one_xfer_put(handle, t); 189 scmi_one_xfer_put(handle, t);
189 return ret; 190 return ret;
190} 191}