[U-Boot] [PATCH v5 09/11] arm926ejs, davinci: add cpuinfo for dm365
Prabhakar Lad
prabhakar.csengg at gmail.com
Mon Oct 31 06:46:51 CET 2011
Hi Heiko,
I already see a patch for printing cpu info for dm365(rather for all
davinci family) .
Link for the patch<http://www.mail-archive.com/u-boot@lists.denx.de/msg65514.html>,
which is more cleaner.
Regards
--Prabhakar Lad
On Mon, Oct 31, 2011 at 10:23 AM, Heiko Schocher <hs at denx.de> wrote:
> Signed-off-by: Heiko Schocher <hs at denx.de>
> Cc: Albert ARIBAUD <albert.u.boot at aribaud.net>
> Cc: Sandeep Paulraj <s-paulraj at ti.com>
>
> ---
> Changes for v2:
> - rebase to TOT
>
> arch/arm/cpu/arm926ejs/davinci/cpu.c | 27
> ++++++++++++++++++++++++-
> arch/arm/include/asm/arch-davinci/pll_defs.h | 4 +++
> 2 files changed, 29 insertions(+), 2 deletions(-)
>
> diff --git a/arch/arm/cpu/arm926ejs/davinci/cpu.c
> b/arch/arm/cpu/arm926ejs/davinci/cpu.c
> index 02819f6..9ea9785 100644
> --- a/arch/arm/cpu/arm926ejs/davinci/cpu.c
> +++ b/arch/arm/cpu/arm926ejs/davinci/cpu.c
> @@ -146,13 +146,15 @@ static inline unsigned pll_prediv(volatile void
> *pllbase)
> return 8;
> else
> return pll_div(pllbase, PLLC_PREDIV);
> +#elif defined(CONFIG_SOC_DM365)
> + return pll_div(pllbase, PLLC_PREDIV);
> #endif
> return 1;
> }
>
> static inline unsigned pll_postdiv(volatile void *pllbase)
> {
> -#ifdef CONFIG_SOC_DM355
> +#if defined(CONFIG_SOC_DM355) || defined(CONFIG_SOC_DM365)
> return pll_div(pllbase, PLLC_POSTDIV);
> #elif defined(CONFIG_SOC_DM6446)
> if (pllbase == (volatile void *)DAVINCI_PLL_CNTRL0_BASE)
> @@ -171,9 +173,13 @@ static unsigned pll_sysclk_mhz(unsigned pll_addr,
> unsigned div)
> #endif
>
> /* the PLL might be bypassed */
> - if (REG(pllbase + PLLC_PLLCTL) & BIT(0)) {
> + if (readl(pllbase + PLLC_PLLCTL) & BIT(0)) {
> base /= pll_prediv(pllbase);
> +#if defined(CONFIG_SOC_DM365)
> + base *= 2 * (readl(pllbase + PLLC_PLLM) & 0x0ff);
> +#else
> base *= 1 + (REG(pllbase + PLLC_PLLM) & 0x0ff);
> +#endif
> base /= pll_postdiv(pllbase);
> }
> return DIV_ROUND_UP(base, 1000 * pll_div(pllbase, div));
> @@ -184,8 +190,13 @@ int print_cpuinfo(void)
> /* REVISIT fetch and display CPU ID and revision information
> * too ... that will matter as more revisions appear.
> */
> +#if defined(CONFIG_SOC_DM365)
> + printf("Cores: ARM %d MHz",
> + pll_sysclk_mhz(DAVINCI_PLL_CNTRL1_BASE,
> ARM_PLLDIV));
> +#else
> printf("Cores: ARM %d MHz",
> pll_sysclk_mhz(DAVINCI_PLL_CNTRL0_BASE,
> ARM_PLLDIV));
> +#endif
>
> #ifdef DSP_PLLDIV
> printf(", DSP %d MHz",
> @@ -194,8 +205,13 @@ int print_cpuinfo(void)
>
> printf("\nDDR: %d MHz\n",
> /* DDR PHY uses an x2 input clock */
> +#if defined(CONFIG_SOC_DM365)
> + pll_sysclk_mhz(DAVINCI_PLL_CNTRL0_BASE, DDR_PLLDIV)
> + / 2);
> +#else
> pll_sysclk_mhz(DAVINCI_PLL_CNTRL1_BASE, DDR_PLLDIV)
> / 2);
> +#endif
> return 0;
> }
>
> @@ -205,6 +221,13 @@ unsigned int davinci_arm_clk_get()
> return pll_sysclk_mhz(DAVINCI_PLL_CNTRL0_BASE, ARM_PLLDIV) *
> 1000000;
> }
> #endif
> +
> +#if defined(CONFIG_SOC_DM365)
> +unsigned int davinci_clk_get(unsigned int div)
> +{
> + return pll_sysclk_mhz(DAVINCI_PLL_CNTRL0_BASE, div) * 1000000;
> +}
> +#endif
> #endif /* CONFIG_DISPLAY_CPUINFO */
> #endif /* !CONFIG_SOC_DA8XX */
>
> diff --git a/arch/arm/include/asm/arch-davinci/pll_defs.h
> b/arch/arm/include/asm/arch-davinci/pll_defs.h
> index 5d37616..606ed0b 100644
> --- a/arch/arm/include/asm/arch-davinci/pll_defs.h
> +++ b/arch/arm/include/asm/arch-davinci/pll_defs.h
> @@ -76,4 +76,8 @@ struct dv_pll_regs {
> #define dv_pll0_regs ((struct dv_pll_regs *)DAVINCI_PLL_CNTRL0_BASE)
> #define dv_pll1_regs ((struct dv_pll_regs *)DAVINCI_PLL_CNTRL1_BASE)
>
> +#define ARM_PLLDIV (offsetof(struct dv_pll_regs, plldiv2))
> +#define DDR_PLLDIV (offsetof(struct dv_pll_regs, plldiv7))
> +
> +unsigned int davinci_clk_get(unsigned int div);
> #endif /* _DV_PLL_DEFS_H_ */
> --
> 1.7.6.4
>
> _______________________________________________
> U-Boot mailing list
> U-Boot at lists.denx.de
> http://lists.denx.de/mailman/listinfo/u-boot
>
More information about the U-Boot
mailing list