[U-Boot] [PATCH 1/2 V2] arm926: Flush the data cache before disabling it.

Tom Rini tom.rini at gmail.com
Fri Jan 13 15:41:37 CET 2012


On Fri, Jan 13, 2012 at 1:26 AM, Sughosh Ganu <urwithsughosh at gmail.com> wrote:
> hi Christian,
>
> On Fri Jan 13, 2012 at 09:06:26AM +0100, Christian Riesch wrote:
>> Hi Sughosh,
>> I had a look at the patch and I tried to understand what's going on
>> here (I must confess that I didn't know anything about this cache
>> stuff).
>
>  Ok, thanks for taking time off to understand this issue.
>
>>
>> On Tue, Jan 10, 2012 at 7:12 PM, Sughosh Ganu <urwithsughosh at gmail.com> wrote:
>> > The current implementation invalidates the cache instead of flushing
>> > it. This causes problems on platforms where the spl/u-boot is already
>> > loaded to the RAM, with caches enabled by a first stage bootloader.
>> >
>> > The V bit of the cp15's control register c1 is set to the value of
>> > VINITHI on reset. Do not clear this bit by default, as there are SOC's
>> > with no valid memory region at 0x0.
>> [...]
>> > diff --git a/arch/arm/cpu/arm926ejs/start.S b/arch/arm/cpu/arm926ejs/start.S
>> > index 6a09c02..6e261c2 100644
>> > --- a/arch/arm/cpu/arm926ejs/start.S
>> > +++ b/arch/arm/cpu/arm926ejs/start.S
>> > @@ -355,17 +355,20 @@ _dynsym_start_ofs:
>> >  */
>> >  cpu_init_crit:
>> >        /*
>> > -        * flush v4 I/D caches
>> > +        * flush D cache before disabling it
>> >         */
>> >        mov     r0, #0
>> > -       mcr     p15, 0, r0, c7, c7, 0   /* flush v3/v4 cache */
>> > +flush_dcache:
>> > +       mrc     p15, 0, r15, c7, c10, 3
>> > +       bne     flush_dcache
>> > +
>>
>> Ok, instead of invalidating the D-cache you are cleaning it. From the
>> ARM926EJ-S Technical Reference Manual [1]: "To guarantee that memory
>> coherency is maintained, the DCache must be cleaned of dirty data
>> before it is disabled." So since we are disabling D-Cache a few lines
>> later (bic r0, r0, #0x00000087), this must be the right way to do it.
>
>  Right, so the problem here is that instead of flushing the cache,
>  the code currently invalidates it. This would not be a problem on
>  platforms where cache is not turned ON(which would be the majority
>  of cases), but on my board, it seems to be turned ON by the rbl,
>  due to which it does not boot.
>
>  If you check the manual, the loop that i have introduced is one for
>  "Testing and Cleaning", which means that in case the lines are not
>  dirty, it won't be flushed. So this should not break any platforms
>  where the cache isn't enabled.
>
>>
>> >        mcr     p15, 0, r0, c8, c7, 0   /* flush v4 TLB */
>> >
>> >        /*
>> >         * disable MMU stuff and caches
>> >         */
>> >        mrc     p15, 0, r0, c1, c0, 0
>> > -       bic     r0, r0, #0x00002300     /* clear bits 13, 9:8 (--V- --RS) */
>> > +       bic     r0, r0, #0x00000300     /* clear bits 9:8 ( --RS) */
>>
>> Ok, I read your comment above.
>>
>> >        bic     r0, r0, #0x00000087     /* clear bits 7, 2:0 (B--- -CAM) */
>> >        orr     r0, r0, #0x00000002     /* set bit 2 (A) Align */
>> >        orr     r0, r0, #0x00001000     /* set bit 12 (I) I-Cache */
>>
>> Although this is not changed in your patch, the last line makes me
>> wonder. The comment says "disable MMU stuff and cached", but actually
>> the last line sets bit 12 (I), which means that I-Cache gets enabled
>> according to [1].
>
>  Yeah, this seems to be copied code, with discrepancies in the code
>  and comments. You would see that the line i have removed has a
>  comment for flushing the cache, but instead it is invalidating the
>  cache. I have just fixed the comments for the lines that i made
>  changes to.

I think while we're in here and noticing these things we should fix
the comments at least.

-- 
Tom


More information about the U-Boot mailing list