[PATCH RESEND v8 1/4] arm64: arch_timer: Add device tree binding for hisilicon-161010101 erratum

Ding Tianhong dingtianhong at huawei.com
Thu Jan 19 04:18:31 PST 2017



On 2017/1/19 20:10, Mark Rutland wrote:
> On Thu, Jan 19, 2017 at 07:46:43PM +0800, Ding Tianhong wrote:
>> This erratum describes a bug in logic outside the core, so MIDR can't be
>> used to identify its presence, and reading an SoC-specific revision
>> register from common arch timer code would be awkward.  So, describe it
>> in the device tree.
>>
>> Signed-off-by: Ding Tianhong <dingtianhong at huawei.com>
>> Acked-by: Rob Herring <robh at kernel.org>
>> ---
>>  Documentation/devicetree/bindings/arm/arch_timer.txt | 8 ++++++++
>>  1 file changed, 8 insertions(+)
>>
>> diff --git a/Documentation/devicetree/bindings/arm/arch_timer.txt b/Documentation/devicetree/bindings/arm/arch_timer.txt
>> index ad440a2..9116934 100644
>> --- a/Documentation/devicetree/bindings/arm/arch_timer.txt
>> +++ b/Documentation/devicetree/bindings/arm/arch_timer.txt
>> @@ -31,6 +31,14 @@ to deliver its interrupts via SPIs.
>>    This also affects writes to the tval register, due to the implicit
>>    counter read.
>>  
>> +- hisilicon,erratum-161010101 : A boolean property. Indicates the presence of
>> +  erratum 161010101, which says that reading the counter is unreliable unless
>> +  reading twice on the register and the value of the second read is larger
>> +  than the first by less than 32. If the verification is unsuccessful, then
>> +  discard the value of this read and repeat this procedure until the verification
>> +  is successful.  This also affects writes to the tval register, due to the
>> +  implicit counter read.
> 
> This describes the workaround, which shouldn't be necessary.
> 
> My understanding (from the cover letter) is that reads of the
> {virtual,physical} counters may return a value precisely 32 above the
> true value.
> 
> So it would be better to say:
> 
> - hisilicon,erratum-161010101 : A boolean property. Indicates the
>   presence of Hisilicon erratum 161010101, which says that reading the
>   counters is unreliable in some cases, and reads may return a value 32
>   beyond the correct value. This also affects writes to the tval
>   registers, due to the implicit counter read.
> 
> Thanks,
> Mark.

Looks more accurate.

Thanks.
Ding

> 
> .
> 




More information about the linux-arm-kernel mailing list