[PATCH 1/2] arm: disable L2 cache in the v7 finish function

Eric Miao eric.y.miao at gmail.com
Wed Mar 24 04:27:38 EDT 2010


On Tue, Mar 23, 2010 at 5:00 AM, Tony Lindgren <tony at atomide.com> wrote:
> * Woodruff, Richard <r-woodruff2 at ti.com> [100319 12:51]:
>>
>> > From: linux-arm-kernel-bounces at lists.infradead.org [mailto:linux-arm-kernel-
>> > bounces at lists.infradead.org] On Behalf Of Tony Lindgren
>> > Sent: Wednesday, March 10, 2010 3:53 PM
>>
>> > > +#ifdef CONFIG_OUTER_CACHE
>> > > +   mrc     p15, 0, r0, c1, c0, 1
>> > > +   bic     r0, r0, #0x2
>> > > +   mcr     p15, 0, r0, c1, c0, 1           @ disable L2 cache
>> > > +#endif
>> > >     ldmfd   sp!, {pc}
>> > >  ENDPROC(cpu_v7_proc_fin)
>> >
>> > This one is a bit tricky. I know of three different ways
>> > to disable the L2 cache depending on the hardware. One of
>> > them is what you have above. The second is via SMI, and
>> > then the first one won't work. The third is via external
>> > secure monitor calls used on some omaps at least. And in
>> > the third case the first two methods won't work.
>>
>> On A8 cores with integrated L2 cache the L2EN bit is banked after r0px series (you won't find r0 systems anywhere). As such the above code is good on OMAP3 and many other A8's.  Other bits in this same register have issues which you warn of.  But not the L2EN.
>>
>> On A9 which uses outer cache the above won't work.  The external PL310 (or variant) is memory mapped.  To handle a different sequence is needed all together.
>
> Sounds like we need something like:
>
> ENTRY(cpu_v7_proc_fin)
> ...
>        mcr     p15, 0, r0, c1, c0, 0   @ disable caches
>        b       cpu_v7_arch_proc_fin    @ disable L2 cache
>        ldmfd   sp!, {pc}
> ENDPROC(cpu_v7_proc_fin)
>
> And then cpu_v7_arch_proc_fin can be implemented for the platforms
> that need special handling.
>

Yeah, sort of I agree.

For outer cache, I also doubt that we might need to flush the L2 before
disabling, though this may depend on the exact behavior of the specific
cache controller. Introduce something like outer_cache_fns.finish() may
be something feasible.


> Regards,
>
> Tony
>
> _______________________________________________
> linux-arm-kernel mailing list
> linux-arm-kernel at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
>



More information about the linux-arm-kernel mailing list