Commit fc547ab0 authored by Andy Shevchenko's avatar Andy Shevchenko Committed by Heiko Stuebner

clk: rockchip: Switch to use kmemdup_array()

Let the kememdup_array() take care about multiplication and possible
overflows.
Signed-off-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://lore.kernel.org/r/20240606161028.2986587-3-andriy.shevchenko@linux.intel.comSigned-off-by: default avatarHeiko Stuebner <heiko@sntech.de>
parent 5c0e997e
...@@ -369,9 +369,8 @@ struct clk *rockchip_clk_register_cpuclk(const char *name, ...@@ -369,9 +369,8 @@ struct clk *rockchip_clk_register_cpuclk(const char *name,
if (nrates > 0) { if (nrates > 0) {
cpuclk->rate_count = nrates; cpuclk->rate_count = nrates;
cpuclk->rate_table = kmemdup(rates, cpuclk->rate_table = kmemdup_array(rates, nrates, sizeof(*rates),
sizeof(*rates) * nrates, GFP_KERNEL);
GFP_KERNEL);
if (!cpuclk->rate_table) { if (!cpuclk->rate_table) {
ret = -ENOMEM; ret = -ENOMEM;
goto unregister_notifier; goto unregister_notifier;
......
...@@ -1136,10 +1136,10 @@ struct clk *rockchip_clk_register_pll(struct rockchip_clk_provider *ctx, ...@@ -1136,10 +1136,10 @@ struct clk *rockchip_clk_register_pll(struct rockchip_clk_provider *ctx,
len++; len++;
pll->rate_count = len; pll->rate_count = len;
pll->rate_table = kmemdup(rate_table, pll->rate_table = kmemdup_array(rate_table,
pll->rate_count * pll->rate_count,
sizeof(struct rockchip_pll_rate_table), sizeof(*pll->rate_table),
GFP_KERNEL); GFP_KERNEL);
WARN(!pll->rate_table, WARN(!pll->rate_table,
"%s: could not allocate rate table for %s\n", "%s: could not allocate rate table for %s\n",
__func__, name); __func__, name);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment