]> www.infradead.org Git - users/jedix/linux-maple.git/commit
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)
commit63887c9f02030afd042c125052ad60680f7c21b2
treedb54802ae1d194761849992d0fbf9d3b00aa5ec0
parent3ef938c3503563bfc2ac15083557f880d29c2e64
x86: Compare physical instead of virtual PGD addresses

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