From nobody Sat Oct 4 15:52:53 2025 Received: from mail.loongson.cn (mail.loongson.cn [114.242.206.163]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 9B0CA29B23B; Fri, 15 Aug 2025 02:26:32 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=114.242.206.163 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1755224794; cv=none; b=WDG/69iAsjxbqdQDy719u9Gq8Lonn03JLnAZSuDwfadJXuppdQyOk5EFdQKY0kKcpovEzk93/LVS1+VW3N40+nxaMS4R+axejrw44kWCX2ZkVVIddFOCtuUvPxfF/oOEGXgc/HwsAGUtJBGBEYjzD4GTArqZzBd548rmK1D+wX4= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1755224794; c=relaxed/simple; bh=PesLW11khJRpGmSVJfT+LbNggq4Xf0R0wDY67UVzXGI=; h=From:To:Cc:Subject:Date:Message-Id:In-Reply-To:References: MIME-Version; b=clLwzIG7gWjL3+bHfYfb7oMnZPdd4gwGXNJjXUcoUXzna8lyLx5BtZbLSgzgn9b6zkSylrV/U/tHDWT/BzHiJBG4dXSHB8YBzj5Ma42H+3giY1Z28bm7u2FSAMeQ2BkCtKmYjenJrn9qduksCVeVBVoxmTxzFwbz6/Qqh9SdAKY= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=loongson.cn; spf=pass smtp.mailfrom=loongson.cn; arc=none smtp.client-ip=114.242.206.163 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=loongson.cn Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=loongson.cn Received: from loongson.cn (unknown [10.2.5.213]) by gateway (Coremail) with SMTP id _____8AxQK3Ump5oUhpAAQ--.39061S3; Fri, 15 Aug 2025 10:26:28 +0800 (CST) Received: from localhost.localdomain (unknown [10.2.5.213]) by front1 (Coremail) with SMTP id qMiowJAxQMLOmp5oMPRMAA--.26771S6; Fri, 15 Aug 2025 10:26:28 +0800 (CST) From: Bibo Mao To: Tianrui Zhao , Huacai Chen , Xianglai Li Cc: kvm@vger.kernel.org, loongarch@lists.linux.dev, linux-kernel@vger.kernel.org Subject: [PATCH v3 4/4] LoongArch: KVM: Make function kvm_own_lbt() robust Date: Fri, 15 Aug 2025 10:26:21 +0800 Message-Id: <20250815022621.508174-5-maobibo@loongson.cn> X-Mailer: git-send-email 2.39.3 In-Reply-To: <20250815022621.508174-1-maobibo@loongson.cn> References: <20250815022621.508174-1-maobibo@loongson.cn> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-CM-TRANSID: qMiowJAxQMLOmp5oMPRMAA--.26771S6 X-CM-SenderInfo: xpdruxter6z05rqj20fqof0/ X-Coremail-Antispam: 1Uk129KBjDUn29KB7ZKAUJUUUUU529EdanIXcx71UUUUU7KY7 ZEXasCq-sGcSsGvfJ3UbIjqfuFe4nvWSU5nxnvy29KBjDU0xBIdaVrnUUvcSsGvfC2Kfnx nUUI43ZEXa7xR_UUUUUUUUU== Content-Type: text/plain; charset="utf-8" Add flag KVM_LARCH_LBT checking in function kvm_own_lbt(), so that it can be called safely rather than duplicated enabling again. Signed-off-by: Bibo Mao --- arch/loongarch/kvm/vcpu.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/arch/loongarch/kvm/vcpu.c b/arch/loongarch/kvm/vcpu.c index d1b8c50941ca..ce478151466c 100644 --- a/arch/loongarch/kvm/vcpu.c +++ b/arch/loongarch/kvm/vcpu.c @@ -1283,9 +1283,11 @@ int kvm_own_lbt(struct kvm_vcpu *vcpu) return -EINVAL; =20 preempt_disable(); - set_csr_euen(CSR_EUEN_LBTEN); - _restore_lbt(&vcpu->arch.lbt); - vcpu->arch.aux_inuse |=3D KVM_LARCH_LBT; + if (!(vcpu->arch.aux_inuse & KVM_LARCH_LBT)) { + set_csr_euen(CSR_EUEN_LBTEN); + _restore_lbt(&vcpu->arch.lbt); + vcpu->arch.aux_inuse |=3D KVM_LARCH_LBT; + } preempt_enable(); =20 return 0; --=20 2.39.3