[PATCH v2 12/30] KVM: arm64: Hoist MTE validation check out of MMU lock path

Marc Zyngier maz at kernel.org
Tue Mar 31 11:28:14 PDT 2026


On Tue, 31 Mar 2026 07:57:48 +0100,
Anshuman Khandual <anshuman.khandual at arm.com> wrote:
> 
> On 27/03/26 5:06 PM, Marc Zyngier wrote:
> > From: Fuad Tabba <tabba at google.com>
> > 
> > Simplify the non-cacheable attributes assignment by using a ternary
> > operator. Additionally, hoist the MTE validation check (mte_allowed) out
> > of kvm_s2_fault_map() and into kvm_s2_fault_compute_prot(). This allows
> > us to fail faster and avoid acquiring the KVM MMU lock unnecessarily
> > when the VMM introduces a disallowed VMA for an MTE-enabled guest.
> > 
> > Signed-off-by: Fuad Tabba <tabba at google.com>
> > Signed-off-by: Marc Zyngier <maz at kernel.org>
> > ---
> >  arch/arm64/kvm/mmu.c | 28 ++++++++++++----------------
> >  1 file changed, 12 insertions(+), 16 deletions(-)
> > 
> > diff --git a/arch/arm64/kvm/mmu.c b/arch/arm64/kvm/mmu.c
> > index 0c71e3a9af8b0..ee2a548999b1b 100644
> > --- a/arch/arm64/kvm/mmu.c
> > +++ b/arch/arm64/kvm/mmu.c
> > @@ -1870,18 +1870,21 @@ static int kvm_s2_fault_compute_prot(struct kvm_s2_fault *fault)
> >  	if (fault->exec_fault)
> >  		fault->prot |= KVM_PGTABLE_PROT_X;
> >  
> > -	if (fault->s2_force_noncacheable) {
> > -		if (fault->vm_flags & VM_ALLOW_ANY_UNCACHED)
> > -			fault->prot |= KVM_PGTABLE_PROT_NORMAL_NC;
> > -		else
> > -			fault->prot |= KVM_PGTABLE_PROT_DEVICE;
> > -	} else if (cpus_have_final_cap(ARM64_HAS_CACHE_DIC)) {
> > +	if (fault->s2_force_noncacheable)
> > +		fault->prot |= (fault->vm_flags & VM_ALLOW_ANY_UNCACHED) ?
> > +			       KVM_PGTABLE_PROT_NORMAL_NC : KVM_PGTABLE_PROT_DEVICE;
> > +	else if (cpus_have_final_cap(ARM64_HAS_CACHE_DIC))
> >  		fault->prot |= KVM_PGTABLE_PROT_X;
> > -	}
> 
> Is not the existing code block bit more cleaner though ?

What is wrong with this? Are you stating a matter of personal taste ?

Ternary operators are great at making things more readable by reducing
the amount of nesting, and I'm all in favour of anything that makes
this $%^&*( code easier to parse.

Or are you pointing out a technical issue?

	M.

-- 
Without deviation from the norm, progress is not possible.



More information about the linux-arm-kernel mailing list