Re: [PATCH 3/4] Add physical count arch timer support for clocksourcein ARMv7.

From: Marc Zyngier
Date: Mon Sep 16 2013 - 04:16:16 EST


Hi Maxime,

On 14/09/13 13:05, maxime.ripard@xxxxxxxxxxxxxxxxxx wrote:
> Hi Marc, Fan,
>
> On Fri, Sep 13, 2013 at 10:30:49AM +0100, Marc Zyngier wrote:
>> On 13/09/13 09:49, cinifr wrote:
>>> On 13 September 2013 00:39, Marc Zyngier <marc.zyngier@xxxxxxx>
>>> wrote: I am wondering what is the principle between kernel
>>> and bootload? What should be done in bootloader and what should
>>> be done in kernel? As you said, If kernel boot from hyp,
>>> Kernel can set CNTVOFF to zero directly, does we add the code
>>> to set CNTVOFF in kernel? But, if kernel boot from PL1 NS=0,
>>> Does kernel need to switch hyp mode to set CNTVOFF and return
>>> PL1 NS=0 mode? Or,kernel dont care it because kernel believe
>>> bootloader have set CNTVOFF before?
>>
>> In an ideal world, the bootloader should set CNTVOFF to zero. The
>> fact that the kernel does it too when booted in HYP mode is to
>> preserve itself from from broken bootloaders.
>>
>> CNTVOFF can only be setup from either HYP or Secure Monitor mode
>> with SCR.NS == 1, so if you run your kernel in secure mode, it is
>> always best to do it in the bootloader.
>
> What would happen exactly if a kernel expects CNTVOFF to be set to
> 0, and that your bootloader don't set it?

It doesn't really matter if it is set to 0. What actually matters is
that all the CPUs have the same value. Otherwise, you will have time
reported differently depending on the CPU you're looking from.

> From what you're saying, it's will be set by the kernel if it's
> booted in hypervisor mode, but what if it's not?
>
> The ARM documentation says that the CNTVOFF register will hold an
> undefined value, how would that affect the kernel?

See above. Without a consistent view of time across CPUs, you're in
deep trouble.

M.
--
Jazz is not dead. It just smells funny...

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/