aboutsummaryrefslogtreecommitdiff
path: root/drivers/usb/cdns3/cdns3-plat.c
diff options
context:
space:
mode:
authorStephen Boyd <sboyd@kernel.org>2021-12-07 20:15:33 -0800
committerStephen Boyd <sboyd@kernel.org>2021-12-09 17:15:47 -0800
commit5c1c42c49b8a74ecd6de289ff13c033979501cce (patch)
tree0e395c30ff024020c7bca082bc520bb9406202db /drivers/usb/cdns3/cdns3-plat.c
parent9259228037cb614ac31a18557fee62976f873a49 (diff)
clk: clk_core_get() can also return NULL
Nothing stops a clk controller from registering an OF clk provider before registering those clks with the clk framework. This is not great but we deal with it in the clk framework by refusing to hand out struct clk pointers when 'hw->core' is NULL, the indication that clk_register() has been called. Within clk_core_fill_parent_index() we considered this case when a clk_hw pointer is referenced directly by filling in the parent cache with an -EPROBE_DEFER pointer when the core pointer is NULL. When we lookup a parent with clk_core_get() we don't care about the return value being NULL though, because that was considered largely impossible, but it's been proven now that it can be NULL if two clk providers are probing in parallel and the parent provider has been registered before the clk has. Let's check for NULL here as well and treat it the same as direct clk_hw references. Signed-off-by: Stephen Boyd <sboyd@kernel.org> Link: https://lore.kernel.org/r/20211208041534.3928718-1-sboyd@kernel.org
Diffstat (limited to 'drivers/usb/cdns3/cdns3-plat.c')
0 files changed, 0 insertions, 0 deletions