]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
arm64: realm: Fix PTE_NS_SHARED for 52bit PA support
authorSuzuki K Poulose <suzuki.poulose@arm.com>
Mon, 16 Mar 2026 16:19:01 +0000 (16:19 +0000)
committerWill Deacon <will@kernel.org>
Thu, 19 Mar 2026 12:46:05 +0000 (12:46 +0000)
With LPA/LPA2, the top bits of the PFN (Bits[51:48]) end up in the lower bits
of the PTE. So, simply creating a mask of the "top IPA bit" doesn't work well
for these configurations to set the "top" bit at the output of Stage1
translation.

Fix this by using the __phys_to_pte_val() to do the right thing for all
configurations.

Tested using, kvmtool, placing the memory at a higher address (-m <size>@<Addr>).

 e.g:
 # lkvm run --realm -c 4 -m 512M@@128T -k Image --console serial

 sh-5.0# dmesg | grep "LPA2\|RSI"
[    0.000000] RME: Using RSI version 1.0
[    0.000000] CPU features: detected: 52-bit Virtual Addressing (LPA2)
[    0.777354] CPU features: detected: 52-bit Virtual Addressing for KVM (LPA2)

Fixes: 399306954996 ("arm64: realm: Query IPA size from the RMM")
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Steven Price <steven.price@arm.com>
Cc: Will Deacon <will@kernel.org>
Signed-off-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Reviewed-by: Steven Price <steven.price@arm.com>
Reviewed-by: Catalin Marinas <catalin.marinas@arm.com>
Signed-off-by: Will Deacon <will@kernel.org>
arch/arm64/kernel/rsi.c

index c64a06f58c0bc0d1e9e95d5a489d9f65c0e037c7..9e846ce4ef9ca7c3781d9e98224647494f478713 100644 (file)
@@ -12,6 +12,7 @@
 
 #include <asm/io.h>
 #include <asm/mem_encrypt.h>
+#include <asm/pgtable.h>
 #include <asm/rsi.h>
 
 static struct realm_config config;
@@ -146,7 +147,7 @@ void __init arm64_rsi_init(void)
                return;
        if (WARN_ON(rsi_get_realm_config(&config)))
                return;
-       prot_ns_shared = BIT(config.ipa_bits - 1);
+       prot_ns_shared = __phys_to_pte_val(BIT(config.ipa_bits - 1));
 
        if (arm64_ioremap_prot_hook_register(realm_ioremap_hook))
                return;