[U-Boot] [PATCH] imx: don't clobber reset cause
Eric Nelson
eric.nelson at boundarydevices.com
Thu Feb 5 19:22:32 CET 2015
Hi Stefano,
On 02/05/2015 10:52 AM, Stefano Babic wrote:
> Hi Eric,
>
> On 05/02/2015 18:22, Eric Nelson wrote:
>
>>>> There is very similar code in 'arch/arm/cpu/armv7/vf610/generic.c'. The
>>>> write is for a hard power on case where these reason registers are full
>>>> of weird bogus values (at least on Vybrid; I suspect on iMx). In the
>>>> case of a non-POR, the register bits are good. However, if you don't
>>>> clear the status, on the next reset it may have multiple registers bits
>>>> even though you really want to know the last reason (bit).
>>>>
>>>> Another option would be to clear the value and store the 'cause'
>>>> somewhere for other U-Boot users. Unless you wanted to read this from
>>>> an OS? I think both files should behave the same, all else equal.
>>>>
>>>
>>> I have assumed (maybe wrong ?) that the reason for the patch is to let
>>> the OS reading these bits.
>>>
>>
>> In some cases (Windows Embedded), yes.
>>
>> In the Linux case, we'll likely pass the value to the kernel through
>> the kernel command-line, so it's available to userspace.
>>
>> I'm not aware of any kernel functionality for this at the moment.
>>
>
> It remains the issue raised by Bill (thanks for that). If the bits are
> not reset, we can determine the cause only after POR, but not anymore
> after a warm start. Can you maybe use the IRAM to pass the information
> to Windows ?
>
Certainly, but it seems wrong to make a decision about where and how
this might get passed to an O/S in code.
If we want to generalize it, I'd be inclined to add commands to
query (into a variable) and clear the reset cause.
That would still require this patch though.
Regards,
Eric
More information about the U-Boot
mailing list