[PATCH -next v7 04/10] arm: armv8: invalidate dcache entries on dcache_enable
Anshul Dalal
anshuld at ti.com
Mon Sep 15 07:05:58 CEST 2025
Hi Heinrich,
On Fri Sep 12, 2025 at 5:58 PM IST, Heinrich Schuchardt wrote:
> On 9/12/25 14:16, Anshul Dalal wrote:
>> In dcache_enable, currently the dcache entries are only invalidated when
>> the MMU is not enabled. This causes issues when dcache_enable is called
>> with the MMU already configured, in such cases the existing dcache
>> entries are not flushed which might result in un-expected behavior.
>>
>> This patch invalidates the cache entries on every call of dcache_enable
>> before enabling dcache (by setting CR_C). This makes dcache_enable
>> behave similar to icache_enable as well.
>>
>> Reviewed-by: Dhruva Gole <d-gole at ti.com>
>> Reviewed-by: Ilias Apalodimas <ilias.apalodimas at linaro.org>
>> Signed-off-by: Anshul Dalal <anshuld at ti.com>
>> Tested-by: Wadim Egorov <w.egorov at phytec.de>
>> ---
>> arch/arm/cpu/armv8/cache_v8.c | 7 +++----
>> 1 file changed, 3 insertions(+), 4 deletions(-)
>>
>> diff --git a/arch/arm/cpu/armv8/cache_v8.c b/arch/arm/cpu/armv8/cache_v8.c
>> index 1c1e33bec24..6e662395a83 100644
>> --- a/arch/arm/cpu/armv8/cache_v8.c
>> +++ b/arch/arm/cpu/armv8/cache_v8.c
>> @@ -830,16 +830,15 @@ void flush_dcache_range(unsigned long start, unsigned long stop)
>> void dcache_enable(void)
>> {
>> /* The data cache is not active unless the mmu is enabled */
>> - if (!(get_sctlr() & CR_M)) {
>> - invalidate_dcache_all();
>> - __asm_invalidate_tlb_all();
>> + if (!mmu_status())
>
> You are changing the logic here without describing why in the commit
> message:
>
> mmu_status() returns zero if CONFIG_SYS_ICACHE_OFF=y.
> Only for CONFIG_SYS_ICACHE_OFF=n it calls get_sctlr().
>
> Please, check if the logic change is intended.
> Please, update the commit message.
>
The bheaviour should be the same for all combinations of ICACHE_OFF and
DCACHE_OFF except for when ICACHE_OFF=y and DCACHE_OFF=n, in such cases
there is the concern that mmu_setup will be called everytime on
dcache_enable after my patch.
This was not an intended change, thanks for bringing it to my attention.
I think we should drop the ICACHE_OFF=y definition of mmu_setup which
was added in the commit 268f6ac1f95c ("arm64: Update memcpy_{from,
to}io() helpers"). And only keep the one that calls get_sctlr. If that's
off the table, I can respin the series without the call to mmu_status as
well.
CC+: Patrice Chotard, Patrick Delaunay (the authors of above commit)
Regards,
Anshul
>
>> mmu_setup();
>> - }
>>
>> /* Set up page tables only once (it is done also by mmu_setup()) */
>> if (!gd->arch.tlb_fillptr)
>> setup_all_pgtables();
>>
>> + invalidate_dcache_all();
>> + __asm_invalidate_tlb_all();
>> set_sctlr(get_sctlr() | CR_C);
>> }
>>
More information about the U-Boot
mailing list