[PATCH v2 1/2] ARM: topology: Use a clock if possible to get the CPU frequency
Vincent Guittot
vincent.guittot at linaro.org
Mon Jun 30 06:27:21 PDT 2014
On 30 June 2014 14:49, Maxime Ripard <maxime.ripard at free-electrons.com> wrote:
> On Mon, Jun 30, 2014 at 12:39:26PM +0200, Vincent Guittot wrote:
>> On 30 June 2014 12:29, Russell King - ARM Linux <linux at arm.linux.org.uk> wrote:
>> > On Mon, Jun 30, 2014 at 12:12:22PM +0200, Maxime Ripard wrote:
>> >> The Cortex-A7 and Cortex-A15 based SoCs need a clock-frequency property in the
>> >> topology code.
>> >>
>> >> Allow to use a clock to provide the same information.
>> >>
>> >> Signed-off-by: Maxime Ripard <maxime.ripard at free-electrons.com>
>> >
>> > This looks fine to me, but I don't know this code. Maybe Vincent Guittot
>> > should be on the To: list (added)?
>>
>> Thanks
>
> Ah, sorry for that.
>
>>
>> >
>> >> ---
>> >> arch/arm/kernel/topology.c | 25 ++++++++++++++++++-------
>> >> 1 file changed, 18 insertions(+), 7 deletions(-)
>> >>
>> >> diff --git a/arch/arm/kernel/topology.c b/arch/arm/kernel/topology.c
>> >> index 9d853189028b..268443d88094 100644
>> >> --- a/arch/arm/kernel/topology.c
>> >> +++ b/arch/arm/kernel/topology.c
>> >> @@ -11,6 +11,7 @@
>> >> * for more details.
>> >> */
>> >>
>> >> +#include <linux/clk.h>
>> >> #include <linux/cpu.h>
>> >> #include <linux/cpumask.h>
>> >> #include <linux/export.h>
>> >> @@ -100,8 +101,8 @@ static void __init parse_dt_topology(void)
>> >> GFP_NOWAIT);
>> >>
>> >> for_each_possible_cpu(cpu) {
>> >> - const u32 *rate;
>> >> - int len;
>> >> + struct clk *clk;
>> >> + u32 rate = 0;
>> >>
>> >> /* too early to use cpu->of_node */
>> >> cn = of_get_cpu_node(cpu, NULL);
>> >> @@ -117,14 +118,24 @@ static void __init parse_dt_topology(void)
>> >> if (cpu_eff->compatible == NULL)
>> >> continue;
>> >>
>> >> - rate = of_get_property(cn, "clock-frequency", &len);
>> >> - if (!rate || len != 4) {
>> >> - pr_err("%s missing clock-frequency property\n",
>> >> - cn->full_name);
>> >> + clk = of_clk_get(cn, 0);
>> >> + if (!IS_ERR(clk))
>> >> + rate = clk_get_rate(clk);
>>
>> We need the max frequency as it will be used to weight the different
>> CPUs capacity. How do you ensure that the current clock rate is the
>> max one ?
>
> Hmm, the clock-frequency attribute in the ePAPR is defined at the
> current CPU frequency, not the max one.
What means current frequency in device tree when DVFS is involved ?
Vincent
>
> Maxime
>
> --
> Maxime Ripard, Free Electrons
> Embedded Linux, Kernel and Android engineering
> http://free-electrons.com
More information about the linux-arm-kernel
mailing list