mirror of https://gitee.com/openkylin/linux.git
clk: check ops pointer on clock register
Nothing really prevents a provider from (trying to) register a clock without providing the clock ops structure. We do check the individual fields before using them, but not the structure pointer itself. This may have the usual nasty consequences when the pointer is dereferenced, most likely when checking one the field during the initialization. This is fixed by returning an error on clock register if the ops pointer is NULL. Signed-off-by: Jerome Brunet <jbrunet@baylibre.com> Signed-off-by: Michael Turquette <mturquette@baylibre.com> Link: lkml.kernel.org/r/20171219083329.24746-1-jbrunet@baylibre.com
This commit is contained in:
parent
4fbd8d194f
commit
29fd2a34ef
|
@ -2678,7 +2678,13 @@ struct clk *clk_register(struct device *dev, struct clk_hw *hw)
|
||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
goto fail_name;
|
goto fail_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (WARN_ON(!hw->init->ops)) {
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto fail_ops;
|
||||||
|
}
|
||||||
core->ops = hw->init->ops;
|
core->ops = hw->init->ops;
|
||||||
|
|
||||||
if (dev && pm_runtime_enabled(dev))
|
if (dev && pm_runtime_enabled(dev))
|
||||||
core->dev = dev;
|
core->dev = dev;
|
||||||
if (dev && dev->driver)
|
if (dev && dev->driver)
|
||||||
|
@ -2740,6 +2746,7 @@ struct clk *clk_register(struct device *dev, struct clk_hw *hw)
|
||||||
kfree_const(core->parent_names[i]);
|
kfree_const(core->parent_names[i]);
|
||||||
kfree(core->parent_names);
|
kfree(core->parent_names);
|
||||||
fail_parent_names:
|
fail_parent_names:
|
||||||
|
fail_ops:
|
||||||
kfree_const(core->name);
|
kfree_const(core->name);
|
||||||
fail_name:
|
fail_name:
|
||||||
kfree(core);
|
kfree(core);
|
||||||
|
|
Loading…
Reference in New Issue