public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
From: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] [patch u-boot git arm/next] davinci: display correct	clock info
Date: Thu, 30 Apr 2009 01:17:06 +0200	[thread overview]
Message-ID: <20090429231706.GL522@game.jcrosoft.org> (raw)
In-Reply-To: <200904291538.09721.david-b@pacbell.net>

On 15:38 Wed 29 Apr     , David Brownell wrote:
> From: David Brownell <dbrownell@users.sourceforge.net>
> 
> Make the DaVinci clock display code work on the dm355 too ... there
> are pre- and post- dividers on its PLLs, which most other DaVinci
> processors don't use; and it uses different PLL dividers.  Stubbed
> in support for the DM6467 too.  Verified on dm355 and dm6446.
> 
> Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
> ---
> This should move to cpu/arm926ejs/davinci (cpuinfo.c?) someday,
> like the other SoC-specific code.  For another patch.
good idea

cpu.c will be better

btw a clock design as done for at91 & avr32 will be nice too
> 
>  board/davinci/common/misc.c |   88 +++++++++++++++++++++++++++++++++++++++---
>  1 file changed, 83 insertions(+), 5 deletions(-)
> 
> --- a/board/davinci/common/misc.c
> +++ b/board/davinci/common/misc.c
> @@ -28,6 +28,40 @@
>  #include <net.h>
>  #include <asm/arch/hardware.h>
>  
> +
> +/* offsets from PLL controller base */
> +#define PLLC_PLLCTL	0x100
> +#define PLLC_PLLM	0x110
> +#define PLLC_PREDIV	0x114
> +#define PLLC_PLLDIV1	0x118
> +#define PLLC_PLLDIV2	0x11c
> +#define PLLC_PLLDIV3	0x120
> +#define PLLC_POSTDIV	0x128
> +#define PLLC_BPDIV	0x12c
> +#define PLLC_PLLDIV4	0x160
> +#define PLLC_PLLDIV5	0x164
> +#define PLLC_PLLDIV6	0x168
> +#define PLLC_PLLDIV8	0x170
> +#define PLLC_PLLDIV9	0x174
who will init the PLL?
can we detect it if they are already init?
> +
> +#define BIT(x)		(1 << (x))
please remove
> +
> +/* SOC-specific pll info */
> +#ifdef CONFIG_SOC_DM355
> +#define ARM_PLLDIV	PLLC_PLLDIV1
> +#define DDR_PLLDIV	PLLC_PLLDIV1
> +#endif
> +
> +#ifdef CONFIG_SOC_DM644X
> +#define ARM_PLLDIV	PLLC_PLLDIV2
> +#define DDR_PLLDIV	PLLC_PLLDIV2
> +#endif
> +
> +#ifdef CONFIG_SOC_DM6447
> +#define ARM_PLLDIV	PLLC_PLLDIV2
> +#define DDR_PLLDIV	PLLC_PLLDIV1
> +#endif
> +
>  DECLARE_GLOBAL_DATA_PTR;
>  
>  int dram_init(void)
> @@ -38,16 +72,60 @@ int dram_init(void)
>  	return(0);
>  }
>  
> -static int dv_get_pllm_output(uint32_t pllm)
> +static unsigned pll_div(volatile void *pllbase, unsigned offset)
>  {
> -	return (pllm + 1) * (CONFIG_SYS_HZ_CLOCK / 1000000);
> +	u32	div;
> +
> +	div = REG(pllbase + offset);
> +	return (div & BIT(15)) ? (1 + (div & 0x1f)) : 1;
> +}
> +
> +static inline unsigned pll_prediv(volatile void *pllbase)
> +{
> +#ifdef CONFIG_SOC_DM355
> +	/* this register read seems to fail on pll0 */
maybe an errata?
> +	if (pllbase == (volatile void *)DAVINCI_PLL_CNTRL0_BASE)
> +		return 8;
> +	else
> +		return pll_div(pllbase, PLLC_PREDIV);
> +#endif
> +	return 1;
> +}
> +
> +static inline unsigned pll_postdiv(volatile void *pllbase)
> +{
> +#ifdef CONFIG_SOC_DM355
> +	return pll_div(pllbase, PLLC_POSTDIV);
> +#elif defined(CONFIG_SOC_DM6446)
> +	if (pllbase == (volatile void *)DAVINCI_PLL_CNTRL0_BASE)
> +		return pll_div(pllbase, PLLC_POSTDIV);
> +#endif
> +	return 1;
> +}
> +
> +static unsigned pll_sysclk_mhz(unsigned pll_addr, unsigned div)
> +{
> +	volatile void	*pllbase = (volatile void *) pll_addr;
> +	unsined	base = CONFIG_SYS_HZ_CLOCK / 1000;
> +
> +	/* the PLL might be bypassed */
> +	if (REG(pllbase + PLLC_PLLCTL) & BIT(0)) {
> +		base /= pll_prediv(pllbase);
> +		base *= 1 + (REG(pllbase + PLLC_PLLM) & 0x0ff);
> +		base /= pll_postdiv(pllbase);
> +	}
> +	return DIV_ROUND_UP(base, 1000 * pll_div(pllbase, div));
>  }
>  
>  void dv_display_clk_infos(void)
>  {
> -	printf("ARM Clock: %dMHz\n", dv_get_pllm_output(REG(PLL1_PLLM)) / 2);
> -	printf("DDR Clock: %dMHz\n", dv_get_pllm_output(REG(PLL2_PLLM)) /
> -	       ((REG(PLL2_DIV2) & 0x1f) + 1) / 2);
> +	printf("ARM Clock: %dMHz\n",
> +			pll_sysclk_mhz(DAVINCI_PLL_CNTRL0_BASE, ARM_PLLDIV));
> +	printf("DDR Clock: %dMHz\n",
> +			/* DDR PHY uses an x2 input clock */
> +			pll_sysclk_mhz(DAVINCI_PLL_CNTRL1_BASE, DDR_PLLDIV)
> +				/ 2);
> +	printf("\n");
puts("");

Best Regards,
J.

  reply	other threads:[~2009-04-29 23:17 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-04-29 22:38 [U-Boot] [patch u-boot git arm/next] davinci: display correct clock info David Brownell
2009-04-29 23:17 ` Jean-Christophe PLAGNIOL-VILLARD [this message]
2009-04-29 23:21   ` Ben Warren
2009-04-30  0:13   ` David Brownell
2009-04-30  6:10     ` Jean-Christophe PLAGNIOL-VILLARD
2009-04-30  6:35       ` David Brownell
2009-04-30  7:18         ` Jean-Christophe PLAGNIOL-VILLARD
2009-04-30  9:07           ` David Brownell
2009-05-01  1:23   ` David Brownell
2009-05-01 12:49     ` Jean-Christophe PLAGNIOL-VILLARD

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20090429231706.GL522@game.jcrosoft.org \
    --to=plagnioj@jcrosoft.com \
    --cc=u-boot@lists.denx.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox