[U-Boot] [PATCH 1/2] ARM: MX31: print WRSR to indicate the source of the last reset
Anatolij Gustschin
agust at denx.de
Sat Mar 12 14:15:39 CET 2011
On Thu, 10 Mar 2011 16:07:49 +0100
Stefano Babic <sbabic at denx.de> wrote:
> On 03/10/2011 11:53 AM, Anatolij Gustschin wrote:
> > Add output of the WRSR register content while booting so that
> > we can see the source of the last reset.
> >
> > Signed-off-by: Anatolij Gustschin <agust at denx.de>
>
> Hi Antolij,
Hi Stefano,
...
> > + printf("CPU: Freescale i.MX31 at %d MHz (WRSR=0x%04x)\n",
> > + mx31_get_mcu_main_clk() / 1000000, wdog->wrsr);
>
> Why is it better to use the wrsr register instead of the rcsr register ?
> We are actually using the rcsr register for other i.MX processors
> (MX51/MX53/MX35). And if we want to print the reset cause, I think it
> should be better to write directly the cause as string instead of the
> register value.
The reason for using wrsr register is that when reading this register,
we can also recognize the software reset cause (SWFT, bit 0 is set).
In our use case we have this requirement. U-Boot and Linux for iMX31
assert system reset by clearing SRS bit in wcr. This software reset
is reported by SWFT in the wrsr register. When I read rcsr after a
software reset, I always get watchdog timeout reset cause (probably
because the reset was performed by writing to the watchdog module
register wcr). But actually this reset was a software reset.
I'm fine with using strings for reset cause if there is no objection.
> I do not think printing the reset cause should be implemented in
> print_cpuinfo(), because it manages a different issue (reset cause
> against CPU information). The print_cpuinfo() should have only CPU
> related values, as clock values, and so on, as it is implemented now for
> this and other processors. Better to add a different function for the
> reset cause.
Were should we call this different function? Should be put it
into init_sequence[]?
Best regards,
Anatolij
More information about the U-Boot
mailing list