clk: uniphier: fix memory overrun bug
authorMasahiro Yamada <yamada.masahiro@socionext.com>
Wed, 19 Oct 2016 11:49:39 +0000 (20:49 +0900)
committerStephen Boyd <sboyd@codeaurora.org>
Wed, 19 Oct 2016 20:14:18 +0000 (13:14 -0700)
The first loop of this "for" statement writes memory beyond the
allocated clk_hw_onecell_data.

It should be:
    for (clk_num--; clk_num >= 0; clk_num--)
            ...

Or more simply:
    while (--clk_num >= 0)
            ...

Fixes: 734d82f4a678 ("clk: uniphier: add core support code for UniPhier clock driver")
Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
Signed-off-by: Stephen Boyd <sboyd@codeaurora.org>
drivers/clk/uniphier/clk-uniphier-core.c

index f4e0f6be5f33ae6098616619ecc57e91a79a2e3d..84bc465d31aa1a660322e97a8143629370b5f095 100644 (file)
@@ -79,7 +79,7 @@ static int uniphier_clk_probe(struct platform_device *pdev)
        hw_data->num = clk_num;
 
        /* avoid returning NULL for unused idx */
-       for (; clk_num >= 0; clk_num--)
+       while (--clk_num >= 0)
                hw_data->hws[clk_num] = ERR_PTR(-EINVAL);
 
        for (p = data; p->name; p++) {