clk: tegra: Make clock initialization more robust

Don't abort clock initialization if we cannot match an entry in
tegra_clk_init_table to a valid entry in the clk array.

Also log a corresponding error message.

This was discovered when testing a patch that removed the EMC clock from
tegra124_clks but left a mention in tegra_clk_init_table.

Signed-off-by: Tomeu Vizoso <tomeu.vizoso@collabora.com>
Reviewed-by: Stephen Warren <swarren@nvidia.com>
This commit is contained in:
Tomeu Vizoso 2014-09-17 11:34:17 +02:00 committed by Peter De Schrijver
parent 4c495c204f
commit b9e742c316

View file

@ -207,8 +207,13 @@ void __init tegra_init_from_table(struct tegra_clk_init_table *tbl,
for (; tbl->clk_id < clk_max; tbl++) { for (; tbl->clk_id < clk_max; tbl++) {
clk = clks[tbl->clk_id]; clk = clks[tbl->clk_id];
if (IS_ERR_OR_NULL(clk)) if (IS_ERR_OR_NULL(clk)) {
return; pr_err("%s: invalid entry %ld in clks array for id %d\n",
__func__, PTR_ERR(clk), tbl->clk_id);
WARN_ON(1);
continue;
}
if (tbl->parent_id < clk_max) { if (tbl->parent_id < clk_max) {
struct clk *parent = clks[tbl->parent_id]; struct clk *parent = clks[tbl->parent_id];