RE: [PATCH v2 1/3] clk: renesas: rzg2l: Add support for watchdog reset selection

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Biju,

Thank you for the patch.

> -----Original Message-----
> From: Biju Das <biju.das.jz@xxxxxxxxxxxxxx>
> Sent: 11 November 2021 11:54
> To: Michael Turquette <mturquette@xxxxxxxxxxxx>; Stephen Boyd <sboyd@xxxxxxxxxx>
> Cc: Biju Das <biju.das.jz@xxxxxxxxxxxxxx>; Geert Uytterhoeven <geert+renesas@xxxxxxxxx>; linux-
> renesas-soc@xxxxxxxxxxxxxxx; linux-watchdog@xxxxxxxxxxxxxxx; linux-clk@xxxxxxxxxxxxxxx; Chris Paterson
> <Chris.Paterson2@xxxxxxxxxxx>; Biju Das <biju.das@xxxxxxxxxxxxxx>; Prabhakar Mahadev Lad
> <prabhakar.mahadev-lad.rj@xxxxxxxxxxxxxx>
> Subject: [PATCH v2 1/3] clk: renesas: rzg2l: Add support for watchdog reset selection
> 
> This patch adds support for watchdog reset selection.
> 
> Signed-off-by: Biju Das <biju.das.jz@xxxxxxxxxxxxxx>
> ---
> V1->V2:
>  * No Change
> RFC->V1:
>  * No change
> ---
>  drivers/clk/renesas/r9a07g044-cpg.c | 22 ++++++++++++++++++++++
>  drivers/clk/renesas/rzg2l-cpg.c     |  6 ++++++
>  drivers/clk/renesas/rzg2l-cpg.h     | 14 ++++++++++++++
>  3 files changed, 42 insertions(+)
> 
> diff --git a/drivers/clk/renesas/r9a07g044-cpg.c b/drivers/clk/renesas/r9a07g044-cpg.c
> index 91643b4e1c9c..0bbdc8bd6235 100644
> --- a/drivers/clk/renesas/r9a07g044-cpg.c
> +++ b/drivers/clk/renesas/r9a07g044-cpg.c
> @@ -8,6 +8,7 @@
>  #include <linux/clk-provider.h>
>  #include <linux/device.h>
>  #include <linux/init.h>
> +#include <linux/io.h>
>  #include <linux/kernel.h>
> 
>  #include <dt-bindings/clock/r9a07g044-cpg.h>
> @@ -295,7 +296,28 @@ static const unsigned int r9a07g044_crit_mod_clks[] __initconst = {
>  	MOD_CLK_BASE + R9A07G044_DMAC_ACLK,
>  };
> 
> +#define CPG_WDTRST_SEL			0xb14
> +#define CPG_WDTRST_SEL_WDTRSTSEL(n)	BIT(n)
> +
> +#define CPG_WDTRST_SEL_WDTRST	(CPG_WDTRST_SEL_WDTRSTSEL(0) | \
> +				 CPG_WDTRST_SEL_WDTRSTSEL(1) | \
> +				 CPG_WDTRST_SEL_WDTRSTSEL(2))
> +
> +int r9a07g044_wdt_rst_setect(void __iomem *base)
> +{
Can be static.

Cheers,
Prabhakar

> +	writel((CPG_WDTRST_SEL_WDTRST << 16) | CPG_WDTRST_SEL_WDTRST,
> +	       base + CPG_WDTRST_SEL);
> +
> +	return 0;
> +}
> +
> +static const struct rzg2l_cpg_soc_operations r9a07g044_cpg_ops = {
> +	.wdt_rst_setect = r9a07g044_wdt_rst_setect,
> +};
> +
>  const struct rzg2l_cpg_info r9a07g044_cpg_info = {
> +	.ops = &r9a07g044_cpg_ops,
> +
>  	/* Core Clocks */
>  	.core_clks = r9a07g044_core_clks,
>  	.num_core_clks = ARRAY_SIZE(r9a07g044_core_clks),
> diff --git a/drivers/clk/renesas/rzg2l-cpg.c b/drivers/clk/renesas/rzg2l-cpg.c
> index a77cb47b75e7..f9dfee14a33e 100644
> --- a/drivers/clk/renesas/rzg2l-cpg.c
> +++ b/drivers/clk/renesas/rzg2l-cpg.c
> @@ -932,6 +932,12 @@ static int __init rzg2l_cpg_probe(struct platform_device *pdev)
>  	if (error)
>  		return error;
> 
> +	if (info->ops && info->ops->wdt_rst_setect) {
> +		error = info->ops->wdt_rst_setect(priv->base);
> +		if (error)
> +			return error;
> +	}
> +
>  	return 0;
>  }
> 
> diff --git a/drivers/clk/renesas/rzg2l-cpg.h b/drivers/clk/renesas/rzg2l-cpg.h
> index 484c7cee2629..e1b1497002ed 100644
> --- a/drivers/clk/renesas/rzg2l-cpg.h
> +++ b/drivers/clk/renesas/rzg2l-cpg.h
> @@ -156,9 +156,20 @@ struct rzg2l_reset {
>  		.bit = (_bit) \
>  	}
> 
> +/**
> + * struct rzg2l_cpg_soc_operations - SoC-specific CPG Operations
> + *
> + * @wdt_rst_setect: WDT reset selection
> + */
> +struct rzg2l_cpg_soc_operations {
> +	int (*wdt_rst_setect)(void __iomem *base); /* Platform specific WDT reset selection */
> +};
> +
>  /**
>   * struct rzg2l_cpg_info - SoC-specific CPG Description
>   *
> + * @ops: SoC-specific CPG Operations
> + *
>   * @core_clks: Array of Core Clock definitions
>   * @num_core_clks: Number of entries in core_clks[]
>   * @last_dt_core_clk: ID of the last Core Clock exported to DT
> @@ -176,6 +187,9 @@ struct rzg2l_reset {
>   * @num_crit_mod_clks: Number of entries in crit_mod_clks[]
>   */
>  struct rzg2l_cpg_info {
> +	/* CPG Operations */
> +	const struct rzg2l_cpg_soc_operations *ops;
> +
>  	/* Core Clocks */
>  	const struct cpg_core_clk *core_clks;
>  	unsigned int num_core_clks;
> --
> 2.17.1





[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux]     [Linux OMAP]     [Linux MIPS]     [eCos]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux