From b62f20a6ce179c36197a1a93d0d3a91c17a4b949 Mon Sep 17 00:00:00 2001 From: Andy Bui Date: Wed, 7 Feb 2024 13:01:32 +1100 Subject: [PATCH] elfloader: unconditionally set PTE shareability to Inner Shareable. We noticed a lot of instability with the Jetson Orin port when running in UP + HYP mode. Setting the shareability to Inner Shareable (IS) unconditionally is the fix, however, we're unable to find the exact line in Arm documentation that explains why this is the case. Potential theory: there are other agents on the Jetson Orin that require cache coherency and live in the IS domain. Being more permissive with memory resolves the prefetching and translation faults we were getting. For reference, Arm states "Arm expects operating systems to mark the majority of DRAM memory as Normal Write-back cacheable, Inner shareable" (102376_0200_01_en version 2). Signed-off-by: Andy Bui --- elfloader-tool/src/arch-arm/64/mmu.c | 2 -- 1 file changed, 2 deletions(-) diff --git a/elfloader-tool/src/arch-arm/64/mmu.c b/elfloader-tool/src/arch-arm/64/mmu.c index e45000b1..1254a729 100644 --- a/elfloader-tool/src/arch-arm/64/mmu.c +++ b/elfloader-tool/src/arch-arm/64/mmu.c @@ -156,9 +156,7 @@ static inline uint64_t make_pte(paddr_t pa, uint8_t mem_attr_index) return xn | mask_pa(pa) | BIT(10) /* access flag */ -#if CONFIG_MAX_NUM_NODES > 1 | (INNER_SHAREABLE << 8) -#endif | (mem_attr_index << 2) | BIT(0); /* valid page/block mapping */ }