[PATCH -next v7 04/10] arm: armv8: invalidate dcache entries on dcache_enable
Anshul Dalal
anshuld at ti.com
Tue Sep 16 13:26:27 CEST 2025
Hi all,
On Mon Sep 15, 2025 at 10:35 AM IST, Anshul Dalal wrote:
> 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.
>
I have posted the patch[1] removing ICACHE_OFF=y definition of
mmu_status, that patch along with this series should address this
unintended change.
Regards,
Anshul
[1]: https://lore.kernel.org/u-boot/20250916112205.238811-1-anshuld@ti.com/
>>
>>> 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