From mboxrd@z Thu Jan 1 00:00:00 1970 From: Lukasz Majewski Date: Sun, 8 Mar 2020 21:27:50 +0100 Subject: [PATCH 01/18] clk: imx: pllv3: add enable_bit In-Reply-To: <20200226171601.31142-2-giulio.benetti@benettiengineering.com> References: <20200226171601.31142-1-giulio.benetti@benettiengineering.com> <20200226171601.31142-2-giulio.benetti@benettiengineering.com> Message-ID: <20200308212750.6f7fea78@jawa> List-Id: MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit To: u-boot@lists.denx.de On Wed, 26 Feb 2020 18:15:44 +0100 Giulio Benetti wrote: > pllv3 PLLs have powerdown/up bits but enable bits too. Specifically > "enable bit" enable the pll output, so when dis/enabling pll by > setting/clearing power_bit we must also set/clear enable_bit. > > Signed-off-by: Giulio Benetti > --- > drivers/clk/imx/clk-pllv3.c | 9 +++++++++ > 1 file changed, 9 insertions(+) > > diff --git a/drivers/clk/imx/clk-pllv3.c b/drivers/clk/imx/clk-pllv3.c > index 525442debf..b4a9d587e1 100644 > --- a/drivers/clk/imx/clk-pllv3.c > +++ b/drivers/clk/imx/clk-pllv3.c > @@ -25,6 +25,7 @@ > #define PLL_DENOM_OFFSET 0x20 > > #define BM_PLL_POWER (0x1 << 12) > +#define BM_PLL_ENABLE (0x1 << 13) > #define BM_PLL_LOCK (0x1 << 31) > > struct clk_pllv3 { > @@ -32,6 +33,7 @@ struct clk_pllv3 { > void __iomem *base; > u32 power_bit; > bool powerup_set; > + u32 enable_bit; > u32 div_mask; > u32 div_shift; > }; > @@ -83,6 +85,9 @@ static int clk_pllv3_generic_enable(struct clk *clk) > val |= pll->power_bit; > else > val &= ~pll->power_bit; > + > + val |= pll->enable_bit; > + > writel(val, pll->base); > > return 0; > @@ -98,6 +103,9 @@ static int clk_pllv3_generic_disable(struct clk > *clk) val &= ~pll->power_bit; > else > val |= pll->power_bit; > + > + val &= ~pll->enable_bit; > + > writel(val, pll->base); > > return 0; > @@ -238,6 +246,7 @@ struct clk *imx_clk_pllv3(enum imx_pllv3_type > type, const char *name, return ERR_PTR(-ENOMEM); > > pll->power_bit = BM_PLL_POWER; > + pll->enable_bit = BM_PLL_ENABLE; > > switch (type) { > case IMX_PLLV3_GENERIC: Reviewed-by: Lukasz Majewski Best regards, Lukasz Majewski -- DENX Software Engineering GmbH, Managing Director: Wolfgang Denk HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany Phone: (+49)-8142-66989-59 Fax: (+49)-8142-66989-80 Email: lukma at denx.de -------------- next part -------------- A non-text attachment was scrubbed... Name: not available Type: application/pgp-signature Size: 488 bytes Desc: OpenPGP digital signature URL: