aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThierry Reding <[email protected]>2015-03-23 10:57:46 +0100
committerThierry Reding <[email protected]>2015-04-10 16:04:18 +0200
commit5e43e259171e1eee8bc074d9c44be434e685087b (patch)
treeaf36d43870e098bfea1b3a8b1e9a22c8dd93832a
parent44a6f3dbf1ac63b4d689cf081a3540cde03aa5d5 (diff)
clk: tegra: Register the proper number of resets
The number of resets controls is 32 times the number of peripheral register banks rather than 32 times the number of clocks. This reduces (drastically) the number of reset controls registered from 10080 (315 clocks * 32) to 224 (6 peripheral register banks * 32). This also fixes a potential crash because trying to use any of the excess reset controls (224-10079) would have caused accesses beyond the array bounds of the peripheral register banks definition array. Cc: Peter De Schrijver <[email protected]> Cc: Prashant Gaikwad <[email protected]> Fixes: 6d5b988e7dc5 ("clk: tegra: implement a reset driver") Cc: [email protected] # 3.14+ Signed-off-by: Thierry Reding <[email protected]>
-rw-r--r--drivers/clk/tegra/clk.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/clk/tegra/clk.c b/drivers/clk/tegra/clk.c
index 9ddb7547cb43..7a1df61847fc 100644
--- a/drivers/clk/tegra/clk.c
+++ b/drivers/clk/tegra/clk.c
@@ -272,7 +272,7 @@ void __init tegra_add_of_provider(struct device_node *np)
of_clk_add_provider(np, of_clk_src_onecell_get, &clk_data);
rst_ctlr.of_node = np;
- rst_ctlr.nr_resets = clk_num * 32;
+ rst_ctlr.nr_resets = periph_banks * 32;
reset_controller_register(&rst_ctlr);
}