From nobody Fri Oct 24 09:56:15 2025 Delivered-To: importer@patchew.org Received-SPF: pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) client-ip=208.118.235.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; dkim=fail; spf=pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (lists.gnu.org [208.118.235.17]) by mx.zohomail.com with SMTPS id 1519747183496251.96561040436222; Tue, 27 Feb 2018 07:59:43 -0800 (PST) Received: from localhost ([::1]:38300 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1eqhfH-0005YR-KN for importer@patchew.org; Tue, 27 Feb 2018 10:59:39 -0500 Received: from eggs.gnu.org ([2001:4830:134:3::10]:48619) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1eqcPb-00080D-KZ for qemu-devel@nongnu.org; Tue, 27 Feb 2018 05:23:09 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1eqcPW-0000bT-Hy for qemu-devel@nongnu.org; Tue, 27 Feb 2018 05:23:07 -0500 Received: from aserp2130.oracle.com ([141.146.126.79]:45040) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1eqcPW-0000Yy-80 for qemu-devel@nongnu.org; Tue, 27 Feb 2018 05:23:02 -0500 Received: from pps.filterd (aserp2130.oracle.com [127.0.0.1]) by aserp2130.oracle.com (8.16.0.22/8.16.0.22) with SMTP id w1RAM218092105; Tue, 27 Feb 2018 10:22:59 GMT Received: from aserv0021.oracle.com (aserv0021.oracle.com [141.146.126.233]) by aserp2130.oracle.com with ESMTP id 2gd3xv0j50-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Tue, 27 Feb 2018 10:22:59 +0000 Received: from userv0121.oracle.com (userv0121.oracle.com [156.151.31.72]) by aserv0021.oracle.com (8.14.4/8.14.4) with ESMTP id w1RAMw2V026736 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=FAIL); Tue, 27 Feb 2018 10:22:59 GMT Received: from abhmp0006.oracle.com (abhmp0006.oracle.com [141.146.116.12]) by userv0121.oracle.com (8.14.4/8.13.8) with ESMTP id w1RAMwFn021813; Tue, 27 Feb 2018 10:22:58 GMT Received: from liran-pc.local.tld (/213.57.127.10) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Tue, 27 Feb 2018 02:22:57 -0800 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oracle.com; h=from : to : cc : subject : date : message-id; s=corp-2017-10-26; bh=btmhJB0vfVYkyUD3ID9TtXFGrBoWvnNAQGwQkGbI4Dw=; b=bf973Oq/a7uSWinsLybkEOXLL5MiuRfVx3c+JaCroz89lrMJeXOLTWvTej8UqKs2iDwP l5KGqAdrRcLyCBTYqOJ/mtp/FWNqLdTfAq6OoCVAJbFgqxgR2rNKDQYQG+1MIM9lag6H EPiCA5krWQD09n1E+bnpVI2yHLc4/Wtr8R3OHdj1vlAmRztZ3e5O41A44Nox32XltkzM 37goINWJKwICMXIpUC3rbEVQY3l2QpDf/9Zw8Cv5K4PBU7pAGTt2YHprEd0JlpqiD280 A0pdV3gM42rnuFOPJ/pv9GGH7Bl1gfzvrm2HDoXryoyNae25uxQL1ttng5CAcjagfLMe HQ== From: Liran Alon To: qemu-devel@nongnu.org Date: Tue, 27 Feb 2018 12:22:12 +0200 Message-Id: <1519726932-13833-1-git-send-email-liran.alon@oracle.com> X-Mailer: git-send-email 1.9.1 X-Proofpoint-Virus-Version: vendor=nai engine=5900 definitions=8816 signatures=668680 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 suspectscore=1 malwarescore=0 phishscore=0 bulkscore=0 spamscore=0 mlxscore=0 mlxlogscore=920 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1711220000 definitions=main-1802270128 X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x [generic] [fuzzy] X-Received-From: 141.146.126.79 X-Mailman-Approved-At: Tue, 27 Feb 2018 10:58:35 -0500 Subject: [Qemu-devel] [PATCH] KVM: x86: Add support for save/load MSR_SMI_COUNT X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: habkost@redhat.com, kvm@vger.kernel.org, Konrad Rzeszutek Wilk , mtosatti@redhat.com, Liran Alon , pbonzini@redhat.com, rth@twiddle.net Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: fail (Header signature does not verify) X-ZohoMail: RDKM_2 RSF_0 Z_629925259 SPT_0 Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" This MSR returns the number of #SMIs that occurred on CPU since boot. KVM commit 52797bf9a875 ("KVM: x86: Add emulation of MSR_SMI_COUNT") introduced support for emulating this MSR. This commit adds support for QEMU to save/load this MSR for migration purposes. Signed-off-by: Liran Alon Reviewed-by: Konrad Rzeszutek Wilk Signed-off-by: Konrad Rzeszutek Wilk --- target/i386/cpu.c | 1 + target/i386/cpu.h | 3 +++ target/i386/kvm.c | 13 +++++++++++++ target/i386/machine.c | 20 ++++++++++++++++++++ 4 files changed, 37 insertions(+) diff --git a/target/i386/cpu.c b/target/i386/cpu.c index b5e431e769da..ba9ec6a6116b 100644 --- a/target/i386/cpu.c +++ b/target/i386/cpu.c @@ -3645,6 +3645,7 @@ static void x86_cpu_reset(CPUState *s) cpu_x86_update_cr0(env, 0x60000010); env->a20_mask =3D ~0x0; env->smbase =3D 0x30000; + env->msr_smi_count =3D 0; =20 env->idt.limit =3D 0xffff; env->gdt.limit =3D 0xffff; diff --git a/target/i386/cpu.h b/target/i386/cpu.h index faf39ec1ce77..254e557bb8fa 100644 --- a/target/i386/cpu.h +++ b/target/i386/cpu.h @@ -1,3 +1,4 @@ + /* * i386 virtual CPU header * @@ -359,6 +360,7 @@ typedef enum X86Seg { #define MSR_P6_PERFCTR0 0xc1 =20 #define MSR_IA32_SMBASE 0x9e +#define MSR_SMI_COUNT 0x34 #define MSR_MTRRcap 0xfe #define MSR_MTRRcap_VCNT 8 #define MSR_MTRRcap_FIXRANGE_SUPPORT (1 << 8) @@ -1123,6 +1125,7 @@ typedef struct CPUX86State { =20 uint64_t pat; uint32_t smbase; + uint64_t msr_smi_count; =20 uint32_t pkru; =20 diff --git a/target/i386/kvm.c b/target/i386/kvm.c index ad4b159b28af..a53735f266c5 100644 --- a/target/i386/kvm.c +++ b/target/i386/kvm.c @@ -92,6 +92,7 @@ static bool has_msr_hv_stimer; static bool has_msr_hv_frequencies; static bool has_msr_xss; static bool has_msr_spec_ctrl; +static bool has_msr_smi_count; =20 static uint32_t has_architectural_pmu_version; static uint32_t num_architectural_pmu_gp_counters; @@ -1124,6 +1125,9 @@ static int kvm_get_supported_msrs(KVMState *s) case MSR_IA32_SMBASE: has_msr_smbase =3D true; break; + case MSR_SMI_COUNT: + has_msr_smi_count =3D true; + break; case MSR_IA32_MISC_ENABLE: has_msr_misc_enable =3D true; break; @@ -1633,6 +1637,9 @@ static int kvm_put_msrs(X86CPU *cpu, int level) if (has_msr_smbase) { kvm_msr_entry_add(cpu, MSR_IA32_SMBASE, env->smbase); } + if (has_msr_smi_count) { + kvm_msr_entry_add(cpu, MSR_SMI_COUNT, env->msr_smi_count); + } if (has_msr_bndcfgs) { kvm_msr_entry_add(cpu, MSR_IA32_BNDCFGS, env->msr_bndcfgs); } @@ -1979,6 +1986,9 @@ static int kvm_get_msrs(X86CPU *cpu) if (has_msr_smbase) { kvm_msr_entry_add(cpu, MSR_IA32_SMBASE, 0); } + if (has_msr_smi_count) { + kvm_msr_entry_add(cpu, MSR_SMI_COUNT, 0); + } if (has_msr_feature_control) { kvm_msr_entry_add(cpu, MSR_IA32_FEATURE_CONTROL, 0); } @@ -2205,6 +2215,9 @@ static int kvm_get_msrs(X86CPU *cpu) case MSR_IA32_SMBASE: env->smbase =3D msrs[i].data; break; + case MSR_SMI_COUNT: + env->msr_smi_count =3D msrs[i].data; + break; case MSR_IA32_FEATURE_CONTROL: env->msr_ia32_feature_control =3D msrs[i].data; break; diff --git a/target/i386/machine.c b/target/i386/machine.c index 361c05aedfdc..9432496cbda8 100644 --- a/target/i386/machine.c +++ b/target/i386/machine.c @@ -395,6 +395,25 @@ static const VMStateDescription vmstate_msr_tsc_adjust= =3D { } }; =20 +static bool msr_smi_count_needed(void *opaque) +{ + X86CPU *cpu =3D opaque; + CPUX86State *env =3D &cpu->env; + + return env->msr_smi_count !=3D 0; +} + +static const VMStateDescription vmstate_msr_smi_count =3D { + .name =3D "cpu/msr_smi_count", + .version_id =3D 1, + .minimum_version_id =3D 1, + .needed =3D msr_smi_count_needed, + .fields =3D (VMStateField[]) { + VMSTATE_UINT64(env.msr_smi_count, X86CPU), + VMSTATE_END_OF_LIST() + } +}; + static bool tscdeadline_needed(void *opaque) { X86CPU *cpu =3D opaque; @@ -952,6 +971,7 @@ VMStateDescription vmstate_x86_cpu =3D { &vmstate_avx512, &vmstate_xss, &vmstate_tsc_khz, + &vmstate_msr_smi_count, #ifdef TARGET_X86_64 &vmstate_pkru, #endif --=20 1.9.1