diff options
| author | Andrew Goodbody <andrew.goodbody@linaro.org> | 2025-07-23 15:13:49 +0100 | 
|---|---|---|
| committer | Eugen Hristev <eugen.hristev@linaro.org> | 2025-08-13 12:59:36 +0300 | 
| commit | da13ce8a6b1a37c49d2215ef78ee7984bae1c068 (patch) | |
| tree | 8ef8b052c24b68c380dc503a6ad6567051c50231 /drivers/clk | |
| parent | 29ea990a1c4a2455f432d5e71b217e93b406fc12 (diff) | |
clk: at91: Fix use of unsigned loop index
The use of the unsigned variable 'i' as a loop index leads to the test
for i being non-negative always being true. Instead declare 'i' as an
int so that the for loop will terminate as expected.
If the original for loop completes 'i' will be 1 past the end of the
array so decrement it in the subsequent error path to prevent an out of
bounds access occurring.
This issue was found by Smatch.
Signed-off-by: Andrew Goodbody <andrew.goodbody@linaro.org>
Diffstat (limited to 'drivers/clk')
| -rw-r--r-- | drivers/clk/at91/sckc.c | 8 | 
1 files changed, 5 insertions, 3 deletions
| diff --git a/drivers/clk/at91/sckc.c b/drivers/clk/at91/sckc.c index 6d6f12578db..3fde8ea7138 100644 --- a/drivers/clk/at91/sckc.c +++ b/drivers/clk/at91/sckc.c @@ -74,8 +74,8 @@ static struct clk *at91_sam9x60_clk_register_td_slck(struct sam9x60_sckc *sckc,  		int num_parents)  {  	struct clk *clk; -	int ret = -ENOMEM; -	u32 val, i; +	int ret = -ENOMEM, i; +	u32 val;  	if (!sckc || !name || !parent_names || num_parents != 2)  		return ERR_PTR(-EINVAL); @@ -99,8 +99,10 @@ static struct clk *at91_sam9x60_clk_register_td_slck(struct sam9x60_sckc *sckc,  	clk = &sckc->clk;  	ret = clk_register(clk, UBOOT_DM_CLK_AT91_SAM9X60_TD_SLCK, name,  			   parent_names[val]); -	if (ret) +	if (ret) { +		i--;  		goto free; +	}  	return clk; | 
