summaryrefslogtreecommitdiffstats
path: root/drivers/clk/qcom
diff options
context:
space:
mode:
authorJoachim Eastwood <manabian@gmail.com>2015-10-24 18:55:24 +0200
committerStephen Boyd <sboyd@codeaurora.org>2015-10-26 20:36:58 +0100
commitc23a5847695dbda865fdb032a25b7f95a1438042 (patch)
treefc5370c5fb1d4b89fe178addfcfc89fad5edc3ed /drivers/clk/qcom
parentclk: lpc18xx-ccu: fix potential system hang when disabling unused clocks (diff)
downloadlinux-c23a5847695dbda865fdb032a25b7f95a1438042.tar.xz
linux-c23a5847695dbda865fdb032a25b7f95a1438042.zip
clk: lpc18xx-cgu: fix potential system hang when disabling unused clocks
The clock consumer (CCU) of the CGU must be able to check if a CGU base clock is really running since access to the CCU registers requires a running base clock. Access with a disabled base clock will cause the system to hang. Fix this issue by adding code that check if the parent clock is running in the is_enabled clk_ops callback. Since certain clocks can be cascaded this must be added to all clock gates. The hang would occur if the boot ROM or boot loader didn't setup and enable the USB0 clock. Then when the clk framework tried to access the CCU register it would hang the system. Signed-off-by: Joachim Eastwood <manabian@gmail.com> Signed-off-by: Stephen Boyd <sboyd@codeaurora.org>
Diffstat (limited to 'drivers/clk/qcom')
0 files changed, 0 insertions, 0 deletions