]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
x86: Compare physical instead of virtual PGD addresses
authorMaciej Wieczor-Retman <maciej.wieczor-retman@intel.com>
Tue, 4 Feb 2025 17:33:50 +0000 (18:33 +0100)
committerDave Hansen <dave.hansen@linux.intel.com>
Thu, 6 Feb 2025 00:23:17 +0000 (16:23 -0800)
This is a preparatory patch for when pointers have tags in their
upper address bits. But it's a harmless change on its own.

The mm->pgd virtual address may be tagged because it came out of
the allocator at some point. The __va(read_cr3_pa()) address will
never be tagged (the tag bits are all 1's). A direct pointer value
comparison would fail if one is tagged and the other is not.

To fix this, just compare the physical addresses which are never
affected by tagging.

[ dhansen: subject and changelog munging ]

Signed-off-by: Maciej Wieczor-Retman <maciej.wieczor-retman@intel.com>
Signed-off-by: Dave Hansen <dave.hansen@linux.intel.com>
Link: https://lore.kernel.org/all/fde443d0e67f76a51e7ab4e96647705840f53ddb.1738686764.git.maciej.wieczor-retman%40intel.com
arch/x86/mm/tlb.c

index 6cf881a942bbedc672889f2c96344980f1fd4e46..ffc25b3480415a33e538d88d602a2355d9b830b3 100644 (file)
@@ -1325,7 +1325,7 @@ bool nmi_uaccess_okay(void)
        if (loaded_mm != current_mm)
                return false;
 
-       VM_WARN_ON_ONCE(current_mm->pgd != __va(read_cr3_pa()));
+       VM_WARN_ON_ONCE(__pa(current_mm->pgd) != read_cr3_pa());
 
        return true;
 }