summaryrefslogtreecommitdiffstats
path: root/drivers/clk/socfpga
diff options
context:
space:
mode:
authorLeo Yan <leo.yan@linaro.org>2017-05-22 12:52:27 +0800
committerStephen Boyd <sboyd@codeaurora.org>2017-06-19 16:36:48 -0700
commita925810f6ebb89ef94977c4f499264c8fd199dff (patch)
tree353312fdc0b73264a9d8bf7d714ba5d2413e0dc2 /drivers/clk/socfpga
parent4dea04c1f113a848cec8722d2401127227623820 (diff)
downloadop-kernel-dev-a925810f6ebb89ef94977c4f499264c8fd199dff.zip
op-kernel-dev-a925810f6ebb89ef94977c4f499264c8fd199dff.tar.gz
clk: Hi3660: register fixed_rate_clks with CLK_OF_DECLARE_DRIVER
The timer will register into system at very early phase at kernel boot; if timer needs to use clock, the clock should be get ready in function of_clk_init() so later the timer driver probe can retrieve clock successfully. This is finished in below flow on arm64: start_kernel() `-> time_init() `-> of_clk_init(NULL) => register timer's clock `-> clocksource_probe() => register timer On Hi3660 the sp804 timer uses clock "osc32k", this clock is registered as platform driver rather than CLK_OF_DECLARE_DRIVER method. As result, sp804 timer probe returns failure due if cannot bind clock properly. To fix the failure, this patch is to split crgctrl clocks into two subsets. One part is for fixed_rate_clks which includes pre-defined fixed rate clocks, and "osc32k" clock is in this category; So we change their registration to CLK_OF_DECLARE_DRIVER method, as result the clocks can be registered ahead with function of_clk_init() and timer driver can bind timer clock successfully; the rest of the crgctrl clocks are still registered by the probe of the platform driver. This patch also adds checking for all crgctrl clocks registration and print out log if any clock has failure. Signed-off-by: Leo Yan <leo.yan@linaro.org> Signed-off-by: Stephen Boyd <sboyd@codeaurora.org>
Diffstat (limited to 'drivers/clk/socfpga')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud