Commit eaa98ba2 authored by Anup Patel's avatar Anup Patel Committed by Anup Patel
Browse files

RISC-V: KVM: Don't flush TLB when PTE is unchanged



The gstage_set_pte() and gstage_op_pte() should flush TLB only when
a leaf PTE changes so that unnecessary TLB flushes can be avoided.

Signed-off-by: default avatarAnup Patel <apatel@ventanamicro.com>
Reviewed-by: default avatarAtish Patra <atishp@rivosinc.com>
Tested-by: default avatarAtish Patra <atishp@rivosinc.com>
Reviewed-by: default avatarNutty Liu <liujingqi@lanxincomputing.com>
Link: https://lore.kernel.org/r/20250618113532.471448-6-apatel@ventanamicro.com


Signed-off-by: default avatarAnup Patel <anup@brainfault.org>
parent 7584eb61
Loading
Loading
Loading
Loading
+9 −5
Original line number Diff line number Diff line
@@ -167,9 +167,11 @@ static int gstage_set_pte(struct kvm *kvm, u32 level,
		ptep = &next_ptep[gstage_pte_index(addr, current_level)];
	}

	if (pte_val(*ptep) != pte_val(*new_pte)) {
		set_pte(ptep, *new_pte);
		if (gstage_pte_leaf(ptep))
			gstage_remote_tlb_flush(kvm, current_level, addr);
	}

	return 0;
}
@@ -229,7 +231,7 @@ static void gstage_op_pte(struct kvm *kvm, gpa_t addr,
			  pte_t *ptep, u32 ptep_level, enum gstage_op op)
{
	int i, ret;
	pte_t *next_ptep;
	pte_t old_pte, *next_ptep;
	u32 next_ptep_level;
	unsigned long next_page_size, page_size;

@@ -258,10 +260,12 @@ static void gstage_op_pte(struct kvm *kvm, gpa_t addr,
		if (op == GSTAGE_OP_CLEAR)
			put_page(virt_to_page(next_ptep));
	} else {
		old_pte = *ptep;
		if (op == GSTAGE_OP_CLEAR)
			set_pte(ptep, __pte(0));
		else if (op == GSTAGE_OP_WP)
			set_pte(ptep, __pte(pte_val(ptep_get(ptep)) & ~_PAGE_WRITE));
		if (pte_val(*ptep) != pte_val(old_pte))
			gstage_remote_tlb_flush(kvm, ptep_level, addr);
	}
}