* [U-Boot] [PATCH] powerpc/85xx: Change timebase divisor to be defined per processor
@ 2011-04-21 18:59 Kumar Gala
2011-04-22 11:50 ` Tabi Timur-B04825
0 siblings, 1 reply; 9+ messages in thread
From: Kumar Gala @ 2011-04-21 18:59 UTC (permalink / raw)
To: u-boot
Introduce new CONFIG_SYS_FSL_TBCLK_DIV on 85xx platforms because
different SoCs have different divisor amounts. All the PQ3 parts are
/8, the P4080/P4080 is /16, and P2040/P3041/P5020 are /32.
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
---
arch/powerpc/cpu/mpc85xx/cpu.c | 11 ++++++-----
arch/powerpc/include/asm/config_mpc85xx.h | 6 ++++++
2 files changed, 12 insertions(+), 5 deletions(-)
diff --git a/arch/powerpc/cpu/mpc85xx/cpu.c b/arch/powerpc/cpu/mpc85xx/cpu.c
index f5b39c0..f863f4a 100644
--- a/arch/powerpc/cpu/mpc85xx/cpu.c
+++ b/arch/powerpc/cpu/mpc85xx/cpu.c
@@ -234,13 +234,14 @@ int do_reset (cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
/*
* Get timebase clock frequency
*/
+#ifndef CONFIG_SYS_FSL_TBCLK_DIV
+#define CONFIG_SYS_FSL_TBCLK_DIV 8
+#endif
unsigned long get_tbclk (void)
{
-#ifdef CONFIG_FSL_CORENET
- return (gd->bus_clk + 8) / 16;
-#else
- return (gd->bus_clk + 4UL)/8UL;
-#endif
+ unsigned long tbclk_div = CONFIG_SYS_FSL_TBCLK_DIV;
+
+ return (gd->bus_clk + (tbclk_div >> 1)) / tbclk_div;
}
diff --git a/arch/powerpc/include/asm/config_mpc85xx.h b/arch/powerpc/include/asm/config_mpc85xx.h
index da2e998..d71c3fc 100644
--- a/arch/powerpc/include/asm/config_mpc85xx.h
+++ b/arch/powerpc/include/asm/config_mpc85xx.h
@@ -264,6 +264,7 @@
#define CONFIG_SYS_NUM_FM1_DTSEC 5
#define CONFIG_NUM_DDR_CONTROLLERS 1
#define CONFIG_SYS_FM_MURAM_SIZE 0x28000
+#define CONFIG_SYS_FSL_TBCLK_DIV 32
#define CONFIG_SYS_FSL_USB1_PHY_ENABLE
#define CONFIG_SYS_FSL_USB2_PHY_ENABLE
#define CONFIG_SYS_FSL_ERRATUM_ESDHC111
@@ -278,6 +279,7 @@
#define CONFIG_SYS_NUM_FM1_10GEC 1
#define CONFIG_NUM_DDR_CONTROLLERS 1
#define CONFIG_SYS_FM_MURAM_SIZE 0x28000
+#define CONFIG_SYS_FSL_TBCLK_DIV 32
#define CONFIG_SYS_FSL_USB1_PHY_ENABLE
#define CONFIG_SYS_FSL_USB2_PHY_ENABLE
#define CONFIG_SYS_FSL_ERRATUM_ESDHC111
@@ -288,6 +290,7 @@
#define CONFIG_SYS_FSL_NUM_LAWS 32
#define CONFIG_SYS_FSL_SEC_COMPAT 4
#define CONFIG_SYS_FM_MURAM_SIZE 0x28000
+#define CONFIG_SYS_FSL_TBCLK_DIV 16
#elif defined(CONFIG_PPC_P4080)
#define CONFIG_MAX_CPUS 8
@@ -301,6 +304,7 @@
#define CONFIG_SYS_NUM_FM2_10GEC 1
#define CONFIG_NUM_DDR_CONTROLLERS 2
#define CONFIG_SYS_FM_MURAM_SIZE 0x28000
+#define CONFIG_SYS_FSL_TBCLK_DIV 16
#define CONFIG_SYS_FSL_ERRATUM_CPC_A002
#define CONFIG_SYS_FSL_ERRATUM_CPC_A003
#define CONFIG_SYS_FSL_ERRATUM_DDR_A003
@@ -323,6 +327,7 @@
#define CONFIG_SYS_NUM_FM1_10GEC 1
#define CONFIG_NUM_DDR_CONTROLLERS 1
#define CONFIG_SYS_FM_MURAM_SIZE 0x28000
+#define CONFIG_SYS_FSL_TBCLK_DIV 32
#define CONFIG_SYS_FSL_USB1_PHY_ENABLE
#define CONFIG_SYS_FSL_USB2_PHY_ENABLE
#define CONFIG_SYS_FSL_ERRATUM_ESDHC111
@@ -337,6 +342,7 @@
#define CONFIG_SYS_NUM_FM1_10GEC 1
#define CONFIG_NUM_DDR_CONTROLLERS 2
#define CONFIG_SYS_FM_MURAM_SIZE 0x28000
+#define CONFIG_SYS_FSL_TBCLK_DIV 32
#define CONFIG_SYS_FSL_USB1_PHY_ENABLE
#define CONFIG_SYS_FSL_USB2_PHY_ENABLE
#define CONFIG_SYS_FSL_ERRATUM_ESDHC111
--
1.7.3.4
^ permalink raw reply related [flat|nested] 9+ messages in thread* [U-Boot] [PATCH] powerpc/85xx: Change timebase divisor to be defined per processor
2011-04-21 18:59 [U-Boot] [PATCH] powerpc/85xx: Change timebase divisor to be defined per processor Kumar Gala
@ 2011-04-22 11:50 ` Tabi Timur-B04825
2011-04-22 13:26 ` Kumar Gala
0 siblings, 1 reply; 9+ messages in thread
From: Tabi Timur-B04825 @ 2011-04-22 11:50 UTC (permalink / raw)
To: u-boot
On Thu, Apr 21, 2011 at 1:59 PM, Kumar Gala <galak@kernel.crashing.org> wrote:
> Introduce new CONFIG_SYS_FSL_TBCLK_DIV on 85xx platforms because
> different SoCs have different divisor amounts. ?All the PQ3 parts are
> /8, the P4080/P4080 is /16, and P2040/P3041/P5020 are /32.
Shouldn't there also be a README update to document this option?
> + ? ? ? unsigned long tbclk_div = CONFIG_SYS_FSL_TBCLK_DIV;
> +
> + ? ? ? return (gd->bus_clk + (tbclk_div >> 1)) / tbclk_div;
Why not just:
return (gd->bus_clk + (CONFIG_SYS_FSL_TBCLK_DIV / 2)) /
CONFIG_SYS_FSL_TBCLK_DIV;
--
Timur Tabi
Linux kernel developer at Freescale
^ permalink raw reply [flat|nested] 9+ messages in thread
* [U-Boot] [PATCH] powerpc/85xx: Change timebase divisor to be defined per processor
2011-04-22 11:50 ` Tabi Timur-B04825
@ 2011-04-22 13:26 ` Kumar Gala
2011-04-22 15:42 ` Scott Wood
` (3 more replies)
0 siblings, 4 replies; 9+ messages in thread
From: Kumar Gala @ 2011-04-22 13:26 UTC (permalink / raw)
To: u-boot
On Apr 22, 2011, at 6:50 AM, Tabi Timur-B04825 wrote:
> On Thu, Apr 21, 2011 at 1:59 PM, Kumar Gala <galak@kernel.crashing.org> wrote:
>> Introduce new CONFIG_SYS_FSL_TBCLK_DIV on 85xx platforms because
>> different SoCs have different divisor amounts. All the PQ3 parts are
>> /8, the P4080/P4080 is /16, and P2040/P3041/P5020 are /32.
>
> Shouldn't there also be a README update to document this option?
I think its self evident what it is.
>> + unsigned long tbclk_div = CONFIG_SYS_FSL_TBCLK_DIV;
>> +
>> + return (gd->bus_clk + (tbclk_div >> 1)) / tbclk_div;
>
> Why not just:
>
> return (gd->bus_clk + (CONFIG_SYS_FSL_TBCLK_DIV / 2)) /
> CONFIG_SYS_FSL_TBCLK_DIV;
It was done this way to deal w/line wrapping.
- k
^ permalink raw reply [flat|nested] 9+ messages in thread* [U-Boot] [PATCH] powerpc/85xx: Change timebase divisor to be defined per processor
2011-04-22 13:26 ` Kumar Gala
@ 2011-04-22 15:42 ` Scott Wood
2011-04-22 19:46 ` Tabi Timur-B04825
` (2 subsequent siblings)
3 siblings, 0 replies; 9+ messages in thread
From: Scott Wood @ 2011-04-22 15:42 UTC (permalink / raw)
To: u-boot
On Fri, 22 Apr 2011 08:26:55 -0500
Kumar Gala <galak@kernel.crashing.org> wrote:
>
> On Apr 22, 2011, at 6:50 AM, Tabi Timur-B04825 wrote:
>
> > On Thu, Apr 21, 2011 at 1:59 PM, Kumar Gala <galak@kernel.crashing.org> wrote:
> >> Introduce new CONFIG_SYS_FSL_TBCLK_DIV on 85xx platforms because
> >> different SoCs have different divisor amounts. All the PQ3 parts are
> >> /8, the P4080/P4080 is /16, and P2040/P3041/P5020 are /32.
> >
> > Shouldn't there also be a README update to document this option?
>
> I think its self evident what it is.
Without commenting on whether this one is or isn't self-explanatory, there
are enough CONFIG symbols that are used without documentation that are not
self-explanatory (sometimes the purpose is clear, but the exact semantics
aren't), that it's better to just document all of them.
-Scott
^ permalink raw reply [flat|nested] 9+ messages in thread* [U-Boot] [PATCH] powerpc/85xx: Change timebase divisor to be defined per processor
2011-04-22 13:26 ` Kumar Gala
2011-04-22 15:42 ` Scott Wood
@ 2011-04-22 19:46 ` Tabi Timur-B04825
2011-04-23 18:45 ` Wolfgang Denk
2011-04-28 3:39 ` [U-Boot] [PATCH v2] " Kumar Gala
3 siblings, 0 replies; 9+ messages in thread
From: Tabi Timur-B04825 @ 2011-04-22 19:46 UTC (permalink / raw)
To: u-boot
On Fri, Apr 22, 2011 at 8:26 AM, Kumar Gala <galak@kernel.crashing.org> wrote:
>> Shouldn't there also be a README update to document this option?
>
> I think its self evident what it is.
I have to disagree. Without reading the patch description, it's hard
to know what value to choose for this macro. Besides, Wolfgang is
already annoyed with the number of CONFIG_ options that are not
documented, so I can't imagine he would accept another one.
--
Timur Tabi
Linux kernel developer at Freescale
^ permalink raw reply [flat|nested] 9+ messages in thread
* [U-Boot] [PATCH] powerpc/85xx: Change timebase divisor to be defined per processor
2011-04-22 13:26 ` Kumar Gala
2011-04-22 15:42 ` Scott Wood
2011-04-22 19:46 ` Tabi Timur-B04825
@ 2011-04-23 18:45 ` Wolfgang Denk
2011-04-28 3:38 ` Kumar Gala
2011-04-28 3:39 ` [U-Boot] [PATCH v2] " Kumar Gala
3 siblings, 1 reply; 9+ messages in thread
From: Wolfgang Denk @ 2011-04-23 18:45 UTC (permalink / raw)
To: u-boot
Dear Kumar Gala,
In message <54CE1181-5449-4FBF-9402-DF5D4E99E4CE@kernel.crashing.org> you wrote:
>
> On Apr 22, 2011, at 6:50 AM, Tabi Timur-B04825 wrote:
>
> > On Thu, Apr 21, 2011 at 1:59 PM, Kumar Gala <galak@kernel.crashing.org> wrote:
> >> Introduce new CONFIG_SYS_FSL_TBCLK_DIV on 85xx platforms because
> >> different SoCs have different divisor amounts. All the PQ3 parts are
> >> /8, the P4080/P4080 is /16, and P2040/P3041/P5020 are /32.
> >
> > Shouldn't there also be a README update to document this option?
>
> I think its self evident what it is.
Please fix it.
> >> + unsigned long tbclk_div = CONFIG_SYS_FSL_TBCLK_DIV;
> >> +
> >> + return (gd->bus_clk + (tbclk_div >> 1)) / tbclk_div;
> >
> > Why not just:
> >
> > return (gd->bus_clk + (CONFIG_SYS_FSL_TBCLK_DIV / 2)) /
> > CONFIG_SYS_FSL_TBCLK_DIV;
>
> It was done this way to deal w/line wrapping.
Now this is really a _very_ strange argument. Please fix as well.
Best regards,
Wolfgang Denk
--
DENX Software Engineering GmbH, MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: (+49)-8142-66989-10 Fax: (+49)-8142-66989-80 Email: wd at denx.de
"The best index to a person's character is a) how he treats people
who can't do him any good and b) how he treats people who can't fight
back." - Abigail Van Buren
^ permalink raw reply [flat|nested] 9+ messages in thread
* [U-Boot] [PATCH] powerpc/85xx: Change timebase divisor to be defined per processor
2011-04-23 18:45 ` Wolfgang Denk
@ 2011-04-28 3:38 ` Kumar Gala
0 siblings, 0 replies; 9+ messages in thread
From: Kumar Gala @ 2011-04-28 3:38 UTC (permalink / raw)
To: u-boot
On Apr 23, 2011, at 1:45 PM, Wolfgang Denk wrote:
> Dear Kumar Gala,
>
> In message <54CE1181-5449-4FBF-9402-DF5D4E99E4CE@kernel.crashing.org> you wrote:
>>
>> On Apr 22, 2011, at 6:50 AM, Tabi Timur-B04825 wrote:
>>
>>> On Thu, Apr 21, 2011 at 1:59 PM, Kumar Gala <galak@kernel.crashing.org> wrote:
>>>> Introduce new CONFIG_SYS_FSL_TBCLK_DIV on 85xx platforms because
>>>> different SoCs have different divisor amounts. All the PQ3 parts are
>>>> /8, the P4080/P4080 is /16, and P2040/P3041/P5020 are /32.
>>>
>>> Shouldn't there also be a README update to document this option?
>>
>> I think its self evident what it is.
>
> Please fix it.
>
>>>> + unsigned long tbclk_div = CONFIG_SYS_FSL_TBCLK_DIV;
>>>> +
>>>> + return (gd->bus_clk + (tbclk_div >> 1)) / tbclk_div;
>>>
>>> Why not just:
>>>
>>> return (gd->bus_clk + (CONFIG_SYS_FSL_TBCLK_DIV / 2)) /
>>> CONFIG_SYS_FSL_TBCLK_DIV;
>>
>> It was done this way to deal w/line wrapping.
>
> Now this is really a _very_ strange argument. Please fix as well.
I consider it more readable as it stands. I'm not changing this.
- k
^ permalink raw reply [flat|nested] 9+ messages in thread
* [U-Boot] [PATCH v2] powerpc/85xx: Change timebase divisor to be defined per processor
2011-04-22 13:26 ` Kumar Gala
` (2 preceding siblings ...)
2011-04-23 18:45 ` Wolfgang Denk
@ 2011-04-28 3:39 ` Kumar Gala
2011-04-29 12:49 ` Kumar Gala
3 siblings, 1 reply; 9+ messages in thread
From: Kumar Gala @ 2011-04-28 3:39 UTC (permalink / raw)
To: u-boot
Introduce new CONFIG_SYS_FSL_TBCLK_DIV on 85xx platforms because
different SoCs have different divisor amounts. All the PQ3 parts are
/8, the P4080/P4080 is /16, and P2040/P3041/P5020 are /32.
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
---
* Added README update
README | 7 +++++++
arch/powerpc/cpu/mpc85xx/cpu.c | 11 ++++++-----
arch/powerpc/include/asm/config_mpc85xx.h | 6 ++++++
3 files changed, 19 insertions(+), 5 deletions(-)
diff --git a/README b/README
index 157cc9e..2754d1e 100644
--- a/README
+++ b/README
@@ -356,6 +356,13 @@ The following options need to be configured:
Define this option if you want to enable the
ICache only when Code runs from RAM.
+- 85xx CPU Options:
+ CONFIG_SYS_FSL_TBCLK_DIV
+
+ Defines the core time base clock divider ratio compared to the
+ system clock. On most PQ3 devices this is 8, on newer QorIQ
+ devices it can be 16 or 32. The ratio varies from SoC to Soc.
+
- Intel Monahans options:
CONFIG_SYS_MONAHANS_RUN_MODE_OSC_RATIO
diff --git a/arch/powerpc/cpu/mpc85xx/cpu.c b/arch/powerpc/cpu/mpc85xx/cpu.c
index f5b39c0..f863f4a 100644
--- a/arch/powerpc/cpu/mpc85xx/cpu.c
+++ b/arch/powerpc/cpu/mpc85xx/cpu.c
@@ -234,13 +234,14 @@ int do_reset (cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
/*
* Get timebase clock frequency
*/
+#ifndef CONFIG_SYS_FSL_TBCLK_DIV
+#define CONFIG_SYS_FSL_TBCLK_DIV 8
+#endif
unsigned long get_tbclk (void)
{
-#ifdef CONFIG_FSL_CORENET
- return (gd->bus_clk + 8) / 16;
-#else
- return (gd->bus_clk + 4UL)/8UL;
-#endif
+ unsigned long tbclk_div = CONFIG_SYS_FSL_TBCLK_DIV;
+
+ return (gd->bus_clk + (tbclk_div >> 1)) / tbclk_div;
}
diff --git a/arch/powerpc/include/asm/config_mpc85xx.h b/arch/powerpc/include/asm/config_mpc85xx.h
index da2e998..d71c3fc 100644
--- a/arch/powerpc/include/asm/config_mpc85xx.h
+++ b/arch/powerpc/include/asm/config_mpc85xx.h
@@ -264,6 +264,7 @@
#define CONFIG_SYS_NUM_FM1_DTSEC 5
#define CONFIG_NUM_DDR_CONTROLLERS 1
#define CONFIG_SYS_FM_MURAM_SIZE 0x28000
+#define CONFIG_SYS_FSL_TBCLK_DIV 32
#define CONFIG_SYS_FSL_USB1_PHY_ENABLE
#define CONFIG_SYS_FSL_USB2_PHY_ENABLE
#define CONFIG_SYS_FSL_ERRATUM_ESDHC111
@@ -278,6 +279,7 @@
#define CONFIG_SYS_NUM_FM1_10GEC 1
#define CONFIG_NUM_DDR_CONTROLLERS 1
#define CONFIG_SYS_FM_MURAM_SIZE 0x28000
+#define CONFIG_SYS_FSL_TBCLK_DIV 32
#define CONFIG_SYS_FSL_USB1_PHY_ENABLE
#define CONFIG_SYS_FSL_USB2_PHY_ENABLE
#define CONFIG_SYS_FSL_ERRATUM_ESDHC111
@@ -288,6 +290,7 @@
#define CONFIG_SYS_FSL_NUM_LAWS 32
#define CONFIG_SYS_FSL_SEC_COMPAT 4
#define CONFIG_SYS_FM_MURAM_SIZE 0x28000
+#define CONFIG_SYS_FSL_TBCLK_DIV 16
#elif defined(CONFIG_PPC_P4080)
#define CONFIG_MAX_CPUS 8
@@ -301,6 +304,7 @@
#define CONFIG_SYS_NUM_FM2_10GEC 1
#define CONFIG_NUM_DDR_CONTROLLERS 2
#define CONFIG_SYS_FM_MURAM_SIZE 0x28000
+#define CONFIG_SYS_FSL_TBCLK_DIV 16
#define CONFIG_SYS_FSL_ERRATUM_CPC_A002
#define CONFIG_SYS_FSL_ERRATUM_CPC_A003
#define CONFIG_SYS_FSL_ERRATUM_DDR_A003
@@ -323,6 +327,7 @@
#define CONFIG_SYS_NUM_FM1_10GEC 1
#define CONFIG_NUM_DDR_CONTROLLERS 1
#define CONFIG_SYS_FM_MURAM_SIZE 0x28000
+#define CONFIG_SYS_FSL_TBCLK_DIV 32
#define CONFIG_SYS_FSL_USB1_PHY_ENABLE
#define CONFIG_SYS_FSL_USB2_PHY_ENABLE
#define CONFIG_SYS_FSL_ERRATUM_ESDHC111
@@ -337,6 +342,7 @@
#define CONFIG_SYS_NUM_FM1_10GEC 1
#define CONFIG_NUM_DDR_CONTROLLERS 2
#define CONFIG_SYS_FM_MURAM_SIZE 0x28000
+#define CONFIG_SYS_FSL_TBCLK_DIV 32
#define CONFIG_SYS_FSL_USB1_PHY_ENABLE
#define CONFIG_SYS_FSL_USB2_PHY_ENABLE
#define CONFIG_SYS_FSL_ERRATUM_ESDHC111
--
1.7.3.4
^ permalink raw reply related [flat|nested] 9+ messages in thread* [U-Boot] [PATCH v2] powerpc/85xx: Change timebase divisor to be defined per processor
2011-04-28 3:39 ` [U-Boot] [PATCH v2] " Kumar Gala
@ 2011-04-29 12:49 ` Kumar Gala
0 siblings, 0 replies; 9+ messages in thread
From: Kumar Gala @ 2011-04-29 12:49 UTC (permalink / raw)
To: u-boot
On Apr 27, 2011, at 10:39 PM, Kumar Gala wrote:
> Introduce new CONFIG_SYS_FSL_TBCLK_DIV on 85xx platforms because
> different SoCs have different divisor amounts. All the PQ3 parts are
> /8, the P4080/P4080 is /16, and P2040/P3041/P5020 are /32.
>
> Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
> ---
> * Added README update
>
> README | 7 +++++++
> arch/powerpc/cpu/mpc85xx/cpu.c | 11 ++++++-----
> arch/powerpc/include/asm/config_mpc85xx.h | 6 ++++++
> 3 files changed, 19 insertions(+), 5 deletions(-)
applied to 85xx
- k
^ permalink raw reply [flat|nested] 9+ messages in thread
end of thread, other threads:[~2011-04-29 12:49 UTC | newest]
Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-04-21 18:59 [U-Boot] [PATCH] powerpc/85xx: Change timebase divisor to be defined per processor Kumar Gala
2011-04-22 11:50 ` Tabi Timur-B04825
2011-04-22 13:26 ` Kumar Gala
2011-04-22 15:42 ` Scott Wood
2011-04-22 19:46 ` Tabi Timur-B04825
2011-04-23 18:45 ` Wolfgang Denk
2011-04-28 3:38 ` Kumar Gala
2011-04-28 3:39 ` [U-Boot] [PATCH v2] " Kumar Gala
2011-04-29 12:49 ` Kumar Gala
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox