[PATCH v4 2/4] LoongArch: KVM: Enable FPU with max VM supported FPU type

From: Bibo Mao

Date: Sun Jun 07 2026 - 21:34:06 EST


There are three FPU types FPU/LSX/LASX, which represents FPU64, FPU128
and FPU256, and now lazy FPU method is used with FPU enabling. There
are three different HW FPU exception code with different FPU type.

The exising method is to enable specified FPU type with responding
FPU exeception. Supposing application uses FPU64 and FPU256, there
will be FPU256 exception when FPU256 type is used.

Here enable FPU with VM supported type directly, it can avoid unnecessary
FPU exception in future if further FPU type is used.

Signed-off-by: Bibo Mao <maobibo@xxxxxxxxxxx>
---
arch/loongarch/include/asm/kvm_host.h | 1 -
arch/loongarch/kvm/exit.c | 9 ++-------
arch/loongarch/kvm/vcpu.c | 19 +++++--------------
3 files changed, 7 insertions(+), 22 deletions(-)

diff --git a/arch/loongarch/include/asm/kvm_host.h b/arch/loongarch/include/asm/kvm_host.h
index e76a49d4233b..bad16c5f963c 100644
--- a/arch/loongarch/include/asm/kvm_host.h
+++ b/arch/loongarch/include/asm/kvm_host.h
@@ -204,7 +204,6 @@ struct kvm_vcpu_arch {

/* Which auxiliary state is loaded (KVM_LARCH_*) */
unsigned int aux_inuse;
- unsigned int aux_ldtype;

/* FPU state */
struct loongarch_fpu fpu FPU_ALIGN;
diff --git a/arch/loongarch/kvm/exit.c b/arch/loongarch/kvm/exit.c
index b839c989d3dc..c8492670f169 100644
--- a/arch/loongarch/kvm/exit.c
+++ b/arch/loongarch/kvm/exit.c
@@ -755,7 +755,6 @@ static int kvm_handle_fpu_disabled(struct kvm_vcpu *vcpu, int ecode)
return RESUME_HOST;
}

- vcpu->arch.aux_ldtype = KVM_LARCH_FPU;
kvm_make_request(KVM_REQ_FPU_LOAD, vcpu);

return RESUME_GUEST;
@@ -796,10 +795,8 @@ static int kvm_handle_lsx_disabled(struct kvm_vcpu *vcpu, int ecode)
{
if (!kvm_guest_has_lsx(&vcpu->arch))
kvm_queue_exception(vcpu, EXCCODE_INE, 0);
- else {
- vcpu->arch.aux_ldtype = KVM_LARCH_LSX;
+ else
kvm_make_request(KVM_REQ_FPU_LOAD, vcpu);
- }

return RESUME_GUEST;
}
@@ -816,10 +813,8 @@ static int kvm_handle_lasx_disabled(struct kvm_vcpu *vcpu, int ecode)
{
if (!kvm_guest_has_lasx(&vcpu->arch))
kvm_queue_exception(vcpu, EXCCODE_INE, 0);
- else {
- vcpu->arch.aux_ldtype = KVM_LARCH_LASX;
+ else
kvm_make_request(KVM_REQ_FPU_LOAD, vcpu);
- }

return RESUME_GUEST;
}
diff --git a/arch/loongarch/kvm/vcpu.c b/arch/loongarch/kvm/vcpu.c
index c28aa37f37a9..7f55875d8b3b 100644
--- a/arch/loongarch/kvm/vcpu.c
+++ b/arch/loongarch/kvm/vcpu.c
@@ -240,21 +240,12 @@ static void kvm_late_check_requests(struct kvm_vcpu *vcpu)
}

if (kvm_check_request(KVM_REQ_FPU_LOAD, vcpu)) {
- switch (vcpu->arch.aux_ldtype) {
- case KVM_LARCH_FPU:
- kvm_own_fpu(vcpu);
- break;
- case KVM_LARCH_LSX:
- kvm_own_lsx(vcpu);
- break;
- case KVM_LARCH_LASX:
+ if (kvm_guest_has_lasx(&vcpu->arch))
kvm_own_lasx(vcpu);
- break;
- default:
- break;
- }
-
- vcpu->arch.aux_ldtype = 0;
+ else if (kvm_guest_has_lsx(&vcpu->arch))
+ kvm_own_lsx(vcpu);
+ else
+ kvm_own_fpu(vcpu);
}

if (kvm_check_request(KVM_REQ_LBT_LOAD, vcpu))
--
2.39.3