clk: sunxi-ng: mult: Support PLL lock detection
authorChen-Yu Tsai <wens@csie.org>
Wed, 5 Apr 2017 06:37:42 +0000 (14:37 +0800)
committerMaxime Ripard <maxime.ripard@free-electrons.com>
Wed, 5 Apr 2017 07:01:41 +0000 (09:01 +0200)
Some PLL clocks are N (multiplier) type clocks, or can be simplified
as such. An example of the former is the DDR1 PLL clock on the A33.
An example of the latter is the CPU PLL clock on the A80, in which
the P divider is only used for low frequencies that are of little
use. Both clocks support PLL lock detection.

The mult clock macro implies support for this, but that is not true.
The field is simply discarded. This patch adds proper support for it.

Signed-off-by: Chen-Yu Tsai <wens@csie.org>
Signed-off-by: Maxime Ripard <maxime.ripard@free-electrons.com>
drivers/clk/sunxi-ng/ccu_mult.c
drivers/clk/sunxi-ng/ccu_mult.h

index 8724c01171b1758f00d1151a55e86ffea593c344..671141359895290a9dc6d6ea20efa9e8347eb421 100644 (file)
@@ -137,6 +137,8 @@ static int ccu_mult_set_rate(struct clk_hw *hw, unsigned long rate,
 
        spin_unlock_irqrestore(cm->common.lock, flags);
 
+       ccu_helper_wait_for_lock(&cm->common, cm->lock);
+
        return 0;
 }
 
index 524acddfcb2eaf480b992b4f9761ad9b46fb8d70..f9c37b987d72b560d096faf7b24356863fd17cbc 100644 (file)
@@ -33,6 +33,7 @@ struct ccu_mult_internal {
 
 struct ccu_mult {
        u32                     enable;
+       u32                     lock;
 
        struct ccu_frac_internal        frac;
        struct ccu_mult_internal        mult;
@@ -45,6 +46,7 @@ struct ccu_mult {
                                   _flags)                              \
        struct ccu_mult _struct = {                                     \
                .enable = _gate,                                        \
+               .lock   = _lock,                                        \
                .mult   = _SUNXI_CCU_MULT(_mshift, _mwidth),            \
                .common = {                                             \
                        .reg            = _reg,                         \