Re: [U-Boot] [PATCH v2 1/4] clk: aspeed: Add support for SD clock

2019-08-14 Thread Cédric Le Goater
On 13/08/2019 21:31, Eddie James wrote:
> Add code to enable the SD clock on the ast2500 SoC.
> 
> Signed-off-by: Eddie James 

Reviewed-by: Cédric Le Goater 

Thanks,

C.

> ---
>  arch/arm/include/asm/arch-aspeed/scu_ast2500.h |  3 +++
>  drivers/clk/aspeed/clk_ast2500.c   | 27 
> ++
>  drivers/pinctrl/aspeed/pinctrl_ast2500.c   |  2 ++
>  3 files changed, 32 insertions(+)
> 
> diff --git a/arch/arm/include/asm/arch-aspeed/scu_ast2500.h 
> b/arch/arm/include/asm/arch-aspeed/scu_ast2500.h
> index 4988ced..8db4901 100644
> --- a/arch/arm/include/asm/arch-aspeed/scu_ast2500.h
> +++ b/arch/arm/include/asm/arch-aspeed/scu_ast2500.h
> @@ -22,6 +22,8 @@
>  #define SCU_MPLL_POST_MASK   (0x3f << SCU_MPLL_POST_SHIFT)
>  #define SCU_PCLK_DIV_SHIFT   23
>  #define SCU_PCLK_DIV_MASK(7 << SCU_PCLK_DIV_SHIFT)
> +#define SCU_SDCLK_DIV_SHIFT  12
> +#define SCU_SDCLK_DIV_MASK   (7 << SCU_SDCLK_DIV_SHIFT)
>  #define SCU_HPLL_DENUM_SHIFT 0
>  #define SCU_HPLL_DENUM_MASK  0x1f
>  #define SCU_HPLL_NUM_SHIFT   5
> @@ -107,6 +109,7 @@
>  
>  #define SCU_CLKSTOP_MAC1 (1 << 20)
>  #define SCU_CLKSTOP_MAC2 (1 << 21)
> +#define SCU_CLKSTOP_SDCLK(1 << 27)
>  
>  #define SCU_D2PLL_EXT1_OFF   (1 << 0)
>  #define SCU_D2PLL_EXT1_BYPASS(1 << 1)
> diff --git a/drivers/clk/aspeed/clk_ast2500.c 
> b/drivers/clk/aspeed/clk_ast2500.c
> index dbee13a..9249cf9 100644
> --- a/drivers/clk/aspeed/clk_ast2500.c
> +++ b/drivers/clk/aspeed/clk_ast2500.c
> @@ -143,6 +143,17 @@ static ulong ast2500_clk_get_rate(struct clk *clk)
>   rate = rate / apb_div;
>   }
>   break;
> + case BCLK_SDCLK:
> + {
> + ulong apb_div = 4 + 4 * ((readl(>scu->clk_sel1)
> +   & SCU_SDCLK_DIV_MASK)
> +  >> SCU_SDCLK_DIV_SHIFT);
> + rate = ast2500_get_hpll_rate(clkin,
> +  readl(>
> +scu->h_pll_param));
> + rate = rate / apb_div;
> + }
> + break;
>   case PCLK_UART1:
>   rate = ast2500_get_uart_clk_rate(priv->scu, 1);
>   break;
> @@ -436,6 +447,22 @@ static int ast2500_clk_enable(struct clk *clk)
>   struct ast2500_clk_priv *priv = dev_get_priv(clk->dev);
>  
>   switch (clk->id) {
> + case BCLK_SDCLK:
> + if (readl(>scu->clk_stop_ctrl1) & SCU_CLKSTOP_SDCLK) {
> + ast_scu_unlock(priv->scu);
> +
> + setbits_le32(>scu->sysreset_ctrl1,
> +  SCU_SYSRESET_SDIO);
> + udelay(100);
> + clrbits_le32(>scu->clk_stop_ctrl1,
> +  SCU_CLKSTOP_SDCLK);
> + mdelay(10);
> + clrbits_le32(>scu->sysreset_ctrl1,
> +  SCU_SYSRESET_SDIO);
> +
> + ast_scu_lock(priv->scu);
> + }
> + break;
>   /*
>* For MAC clocks the clock rate is
>* configured based on whether RGMII or RMII mode has been selected
> diff --git a/drivers/pinctrl/aspeed/pinctrl_ast2500.c 
> b/drivers/pinctrl/aspeed/pinctrl_ast2500.c
> index ed333b9..a6e9c0d 100644
> --- a/drivers/pinctrl/aspeed/pinctrl_ast2500.c
> +++ b/drivers/pinctrl/aspeed/pinctrl_ast2500.c
> @@ -58,6 +58,8 @@ static const struct ast2500_group_config ast2500_groups[] = 
> {
>   { "MDIO1", 3, (1 << 31) | (1 << 30) },
>   { "MAC2LINK", 1, (1 << 1) },
>   { "MDIO2", 5, (1 << 2) },
> + { "SD1", 5, (1 << 0) },
> + { "SD2", 5, (1 << 1) },
>  };
>  
>  static int ast2500_pinctrl_get_groups_count(struct udevice *dev)
> 

___
U-Boot mailing list
U-Boot@lists.denx.de
https://lists.denx.de/listinfo/u-boot


[U-Boot] [PATCH v2 1/4] clk: aspeed: Add support for SD clock

2019-08-13 Thread Eddie James
Add code to enable the SD clock on the ast2500 SoC.

Signed-off-by: Eddie James 
---
 arch/arm/include/asm/arch-aspeed/scu_ast2500.h |  3 +++
 drivers/clk/aspeed/clk_ast2500.c   | 27 ++
 drivers/pinctrl/aspeed/pinctrl_ast2500.c   |  2 ++
 3 files changed, 32 insertions(+)

diff --git a/arch/arm/include/asm/arch-aspeed/scu_ast2500.h 
b/arch/arm/include/asm/arch-aspeed/scu_ast2500.h
index 4988ced..8db4901 100644
--- a/arch/arm/include/asm/arch-aspeed/scu_ast2500.h
+++ b/arch/arm/include/asm/arch-aspeed/scu_ast2500.h
@@ -22,6 +22,8 @@
 #define SCU_MPLL_POST_MASK (0x3f << SCU_MPLL_POST_SHIFT)
 #define SCU_PCLK_DIV_SHIFT 23
 #define SCU_PCLK_DIV_MASK  (7 << SCU_PCLK_DIV_SHIFT)
+#define SCU_SDCLK_DIV_SHIFT12
+#define SCU_SDCLK_DIV_MASK (7 << SCU_SDCLK_DIV_SHIFT)
 #define SCU_HPLL_DENUM_SHIFT   0
 #define SCU_HPLL_DENUM_MASK0x1f
 #define SCU_HPLL_NUM_SHIFT 5
@@ -107,6 +109,7 @@
 
 #define SCU_CLKSTOP_MAC1   (1 << 20)
 #define SCU_CLKSTOP_MAC2   (1 << 21)
+#define SCU_CLKSTOP_SDCLK  (1 << 27)
 
 #define SCU_D2PLL_EXT1_OFF (1 << 0)
 #define SCU_D2PLL_EXT1_BYPASS  (1 << 1)
diff --git a/drivers/clk/aspeed/clk_ast2500.c b/drivers/clk/aspeed/clk_ast2500.c
index dbee13a..9249cf9 100644
--- a/drivers/clk/aspeed/clk_ast2500.c
+++ b/drivers/clk/aspeed/clk_ast2500.c
@@ -143,6 +143,17 @@ static ulong ast2500_clk_get_rate(struct clk *clk)
rate = rate / apb_div;
}
break;
+   case BCLK_SDCLK:
+   {
+   ulong apb_div = 4 + 4 * ((readl(>scu->clk_sel1)
+ & SCU_SDCLK_DIV_MASK)
+>> SCU_SDCLK_DIV_SHIFT);
+   rate = ast2500_get_hpll_rate(clkin,
+readl(>
+  scu->h_pll_param));
+   rate = rate / apb_div;
+   }
+   break;
case PCLK_UART1:
rate = ast2500_get_uart_clk_rate(priv->scu, 1);
break;
@@ -436,6 +447,22 @@ static int ast2500_clk_enable(struct clk *clk)
struct ast2500_clk_priv *priv = dev_get_priv(clk->dev);
 
switch (clk->id) {
+   case BCLK_SDCLK:
+   if (readl(>scu->clk_stop_ctrl1) & SCU_CLKSTOP_SDCLK) {
+   ast_scu_unlock(priv->scu);
+
+   setbits_le32(>scu->sysreset_ctrl1,
+SCU_SYSRESET_SDIO);
+   udelay(100);
+   clrbits_le32(>scu->clk_stop_ctrl1,
+SCU_CLKSTOP_SDCLK);
+   mdelay(10);
+   clrbits_le32(>scu->sysreset_ctrl1,
+SCU_SYSRESET_SDIO);
+
+   ast_scu_lock(priv->scu);
+   }
+   break;
/*
 * For MAC clocks the clock rate is
 * configured based on whether RGMII or RMII mode has been selected
diff --git a/drivers/pinctrl/aspeed/pinctrl_ast2500.c 
b/drivers/pinctrl/aspeed/pinctrl_ast2500.c
index ed333b9..a6e9c0d 100644
--- a/drivers/pinctrl/aspeed/pinctrl_ast2500.c
+++ b/drivers/pinctrl/aspeed/pinctrl_ast2500.c
@@ -58,6 +58,8 @@ static const struct ast2500_group_config ast2500_groups[] = {
{ "MDIO1", 3, (1 << 31) | (1 << 30) },
{ "MAC2LINK", 1, (1 << 1) },
{ "MDIO2", 5, (1 << 2) },
+   { "SD1", 5, (1 << 0) },
+   { "SD2", 5, (1 << 1) },
 };
 
 static int ast2500_pinctrl_get_groups_count(struct udevice *dev)
-- 
1.8.3.1

___
U-Boot mailing list
U-Boot@lists.denx.de
https://lists.denx.de/listinfo/u-boot