rebase patches on top of Ubuntu-5.15.0-88.98
(generated with debian/scripts/import-upstream-tag) Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
This commit is contained in:
		
							parent
							
								
									65409d8b4f
								
							
						
					
					
						commit
						689d5e3eb2
					
				| @ -19,10 +19,10 @@ Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com> | ||||
|  1 file changed, 1 insertion(+), 4 deletions(-) | ||||
| 
 | ||||
| diff --git a/net/bridge/br_stp_if.c b/net/bridge/br_stp_if.c
 | ||||
| index ba55851fe132..82675e1ecfb8 100644
 | ||||
| index 3326dfced68a..3f1604948ace 100644
 | ||||
| --- a/net/bridge/br_stp_if.c
 | ||||
| +++ b/net/bridge/br_stp_if.c
 | ||||
| @@ -265,10 +265,7 @@ bool br_stp_recalculate_bridge_id(struct net_bridge *br)
 | ||||
| @@ -268,10 +268,7 @@ bool br_stp_recalculate_bridge_id(struct net_bridge *br)
 | ||||
|  		return false; | ||||
|   | ||||
|  	list_for_each_entry(p, &br->port_list, list) { | ||||
|  | ||||
| @ -55,10 +55,10 @@ Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com> | ||||
|  2 files changed, 111 insertions(+) | ||||
| 
 | ||||
| diff --git a/Documentation/admin-guide/kernel-parameters.txt b/Documentation/admin-guide/kernel-parameters.txt
 | ||||
| index b9de8d4360d8..025280c92779 100644
 | ||||
| index ec75dbe3e930..4607674a9a32 100644
 | ||||
| --- a/Documentation/admin-guide/kernel-parameters.txt
 | ||||
| +++ b/Documentation/admin-guide/kernel-parameters.txt
 | ||||
| @@ -4004,6 +4004,15 @@
 | ||||
| @@ -4000,6 +4000,15 @@
 | ||||
|  				Also, it enforces the PCI Local Bus spec | ||||
|  				rule that those bits should be 0 in system reset | ||||
|  				events (useful for kexec/kdump cases). | ||||
| @ -75,7 +75,7 @@ index b9de8d4360d8..025280c92779 100644 | ||||
|  				Safety option to keep boot IRQs enabled. This | ||||
|  				should never be necessary. | ||||
| diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c
 | ||||
| index 07a187a67982..d0ab14a33378 100644
 | ||||
| index c50eb9cb78d6..057f21de9ae9 100644
 | ||||
| --- a/drivers/pci/quirks.c
 | ||||
| +++ b/drivers/pci/quirks.c
 | ||||
| @@ -193,6 +193,106 @@ static int __init pci_apply_final_quirks(void)
 | ||||
| @ -185,7 +185,7 @@ index 07a187a67982..d0ab14a33378 100644 | ||||
|  /* | ||||
|   * Decoding should be disabled for a PCI device during BAR sizing to avoid | ||||
|   * conflict. But doing so may cause problems on host bridge and perhaps other | ||||
| @@ -4947,6 +5047,8 @@ static const struct pci_dev_acs_enabled {
 | ||||
| @@ -4949,6 +5049,8 @@ static const struct pci_dev_acs_enabled {
 | ||||
|  	{ PCI_VENDOR_ID_CAVIUM, 0xA060, pci_quirk_mf_endpoint_acs }, | ||||
|  	/* APM X-Gene */ | ||||
|  	{ PCI_VENDOR_ID_AMCC, 0xE004, pci_quirk_xgene_acs }, | ||||
|  | ||||
| @ -13,7 +13,7 @@ Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com> | ||||
|  1 file changed, 1 insertion(+), 1 deletion(-) | ||||
| 
 | ||||
| diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c
 | ||||
| index 1cb2530831f4..db159be9d5b8 100644
 | ||||
| index d11c581ce9b9..0b0ce6979370 100644
 | ||||
| --- a/virt/kvm/kvm_main.c
 | ||||
| +++ b/virt/kvm/kvm_main.c
 | ||||
| @@ -79,7 +79,7 @@ module_param(halt_poll_ns, uint, 0644);
 | ||||
|  | ||||
| @ -10,10 +10,10 @@ Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com> | ||||
|  1 file changed, 1 insertion(+), 1 deletion(-) | ||||
| 
 | ||||
| diff --git a/net/core/dev.c b/net/core/dev.c
 | ||||
| index 56a3bff7249d..7d74d0a30094 100644
 | ||||
| index 4d698ccf4172..776144daf79f 100644
 | ||||
| --- a/net/core/dev.c
 | ||||
| +++ b/net/core/dev.c
 | ||||
| @@ -10534,7 +10534,7 @@ static void netdev_wait_allrefs(struct net_device *dev)
 | ||||
| @@ -10536,7 +10536,7 @@ static void netdev_wait_allrefs(struct net_device *dev)
 | ||||
|  		if (refcnt != 1 && | ||||
|  		    time_after(jiffies, warning_time + | ||||
|  			       netdev_unregister_timeout_secs * HZ)) { | ||||
|  | ||||
| @ -64,10 +64,10 @@ index 3ee4c1217b63..0e15a9345966 100644 | ||||
|   | ||||
|  static int blkcg_print_stat(struct seq_file *sf, void *v) | ||||
| diff --git a/block/blk-iocost.c b/block/blk-iocost.c
 | ||||
| index 1717841196d2..7ac50eb46f2b 100644
 | ||||
| index f95feabb3ca8..94d1824906c7 100644
 | ||||
| --- a/block/blk-iocost.c
 | ||||
| +++ b/block/blk-iocost.c
 | ||||
| @@ -3018,13 +3018,13 @@ static void ioc_pd_free(struct blkg_policy_data *pd)
 | ||||
| @@ -3021,13 +3021,13 @@ static void ioc_pd_free(struct blkg_policy_data *pd)
 | ||||
|  	kfree(iocg); | ||||
|  } | ||||
|   | ||||
| @ -83,7 +83,7 @@ index 1717841196d2..7ac50eb46f2b 100644 | ||||
|   | ||||
|  	if (iocg->level == 0) { | ||||
|  		unsigned vp10k = DIV64_U64_ROUND_CLOSEST( | ||||
| @@ -3040,7 +3040,6 @@ static bool ioc_pd_stat(struct blkg_policy_data *pd, struct seq_file *s)
 | ||||
| @@ -3043,7 +3043,6 @@ static bool ioc_pd_stat(struct blkg_policy_data *pd, struct seq_file *s)
 | ||||
|  			iocg->last_stat.wait_us, | ||||
|  			iocg->last_stat.indebt_us, | ||||
|  			iocg->last_stat.indelay_us); | ||||
|  | ||||
| @ -267,10 +267,10 @@ index fb09cd22cb7f..0b2bbcce321a 100644 | ||||
|  #if defined(CONFIG_X86_32) | ||||
|  #define X86EMUL_MODE_HOST X86EMUL_MODE_PROT32 | ||||
| diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
 | ||||
| index 59b2df71cd49..66ef3e1b32c5 100644
 | ||||
| index 092aad38762e..137da3a91d13 100644
 | ||||
| --- a/arch/x86/kvm/x86.c
 | ||||
| +++ b/arch/x86/kvm/x86.c
 | ||||
| @@ -12650,6 +12650,7 @@ EXPORT_TRACEPOINT_SYMBOL_GPL(kvm_vmgexit_msr_protocol_exit);
 | ||||
| @@ -12660,6 +12660,7 @@ EXPORT_TRACEPOINT_SYMBOL_GPL(kvm_vmgexit_msr_protocol_exit);
 | ||||
|  static int __init kvm_x86_init(void) | ||||
|  { | ||||
|  	kvm_mmu_x86_module_init(); | ||||
|  | ||||
| @ -17,7 +17,7 @@ Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com> | ||||
|  6 files changed, 28 insertions(+), 20 deletions(-) | ||||
| 
 | ||||
| diff --git a/arch/x86/include/asm/kvm_host.h b/arch/x86/include/asm/kvm_host.h
 | ||||
| index 55d791ad4787..e05a22527585 100644
 | ||||
| index ba9fac12562a..3c97449cd652 100644
 | ||||
| --- a/arch/x86/include/asm/kvm_host.h
 | ||||
| +++ b/arch/x86/include/asm/kvm_host.h
 | ||||
| @@ -200,6 +200,7 @@ typedef enum exit_fastpath_completion fastpath_t;
 | ||||
| @ -28,7 +28,7 @@ index 55d791ad4787..e05a22527585 100644 | ||||
|  enum x86_intercept; | ||||
|  enum x86_intercept_stage; | ||||
|   | ||||
| @@ -1467,8 +1468,8 @@ struct kvm_x86_ops {
 | ||||
| @@ -1463,8 +1464,8 @@ struct kvm_x86_ops {
 | ||||
|  	void (*setup_mce)(struct kvm_vcpu *vcpu); | ||||
|   | ||||
|  	int (*smi_allowed)(struct kvm_vcpu *vcpu, bool for_injection); | ||||
| @ -105,10 +105,10 @@ index 0b2bbcce321a..3b37b3e17379 100644 | ||||
|  	int (*set_xcr)(struct x86_emulate_ctxt *ctxt, u32 index, u64 xcr); | ||||
|  }; | ||||
| diff --git a/arch/x86/kvm/svm/svm.c b/arch/x86/kvm/svm/svm.c
 | ||||
| index b0b87c36be3d..545e321998d3 100644
 | ||||
| index 7c7aef30db04..5ad5882c5ddf 100644
 | ||||
| --- a/arch/x86/kvm/svm/svm.c
 | ||||
| +++ b/arch/x86/kvm/svm/svm.c
 | ||||
| @@ -4317,12 +4317,14 @@ static int svm_smi_allowed(struct kvm_vcpu *vcpu, bool for_injection)
 | ||||
| @@ -4326,12 +4326,14 @@ static int svm_smi_allowed(struct kvm_vcpu *vcpu, bool for_injection)
 | ||||
|  	return !svm_smi_blocked(vcpu); | ||||
|  } | ||||
|   | ||||
| @ -124,7 +124,7 @@ index b0b87c36be3d..545e321998d3 100644 | ||||
|  	if (!is_guest_mode(vcpu)) | ||||
|  		return 0; | ||||
|   | ||||
| @@ -4364,7 +4366,7 @@ static int svm_enter_smm(struct kvm_vcpu *vcpu, char *smstate)
 | ||||
| @@ -4373,7 +4375,7 @@ static int svm_enter_smm(struct kvm_vcpu *vcpu, char *smstate)
 | ||||
|  	return 0; | ||||
|  } | ||||
|   | ||||
| @ -133,7 +133,7 @@ index b0b87c36be3d..545e321998d3 100644 | ||||
|  { | ||||
|  	struct vcpu_svm *svm = to_svm(vcpu); | ||||
|  	struct kvm_host_map map, map_save; | ||||
| @@ -4372,6 +4374,8 @@ static int svm_leave_smm(struct kvm_vcpu *vcpu, const char *smstate)
 | ||||
| @@ -4381,6 +4383,8 @@ static int svm_leave_smm(struct kvm_vcpu *vcpu, const char *smstate)
 | ||||
|  	struct vmcb *vmcb12; | ||||
|  	int ret; | ||||
|   | ||||
| @ -143,10 +143,10 @@ index b0b87c36be3d..545e321998d3 100644 | ||||
|  		return 0; | ||||
|   | ||||
| diff --git a/arch/x86/kvm/vmx/vmx.c b/arch/x86/kvm/vmx/vmx.c
 | ||||
| index c3382549fdf2..68a3b2844aed 100644
 | ||||
| index 076779033165..95c9ae69fbe7 100644
 | ||||
| --- a/arch/x86/kvm/vmx/vmx.c
 | ||||
| +++ b/arch/x86/kvm/vmx/vmx.c
 | ||||
| @@ -7630,7 +7630,7 @@ static int vmx_smi_allowed(struct kvm_vcpu *vcpu, bool for_injection)
 | ||||
| @@ -7648,7 +7648,7 @@ static int vmx_smi_allowed(struct kvm_vcpu *vcpu, bool for_injection)
 | ||||
|  	return !is_smm(vcpu); | ||||
|  } | ||||
|   | ||||
| @ -155,7 +155,7 @@ index c3382549fdf2..68a3b2844aed 100644 | ||||
|  { | ||||
|  	struct vcpu_vmx *vmx = to_vmx(vcpu); | ||||
|   | ||||
| @@ -7644,7 +7644,7 @@ static int vmx_enter_smm(struct kvm_vcpu *vcpu, char *smstate)
 | ||||
| @@ -7662,7 +7662,7 @@ static int vmx_enter_smm(struct kvm_vcpu *vcpu, char *smstate)
 | ||||
|  	return 0; | ||||
|  } | ||||
|   | ||||
| @ -165,10 +165,10 @@ index c3382549fdf2..68a3b2844aed 100644 | ||||
|  	struct vcpu_vmx *vmx = to_vmx(vcpu); | ||||
|  	int ret; | ||||
| diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
 | ||||
| index 66ef3e1b32c5..31424def8a03 100644
 | ||||
| index 137da3a91d13..e8a86fc933f4 100644
 | ||||
| --- a/arch/x86/kvm/x86.c
 | ||||
| +++ b/arch/x86/kvm/x86.c
 | ||||
| @@ -7445,9 +7445,9 @@ static void emulator_exiting_smm(struct x86_emulate_ctxt *ctxt)
 | ||||
| @@ -7454,9 +7454,9 @@ static void emulator_exiting_smm(struct x86_emulate_ctxt *ctxt)
 | ||||
|  } | ||||
|   | ||||
|  static int emulator_leave_smm(struct x86_emulate_ctxt *ctxt, | ||||
| @ -180,7 +180,7 @@ index 66ef3e1b32c5..31424def8a03 100644 | ||||
|  } | ||||
|   | ||||
|  static void emulator_triple_fault(struct x86_emulate_ctxt *ctxt) | ||||
| @@ -9326,25 +9326,25 @@ static void enter_smm(struct kvm_vcpu *vcpu)
 | ||||
| @@ -9335,25 +9335,25 @@ static void enter_smm(struct kvm_vcpu *vcpu)
 | ||||
|  	struct kvm_segment cs, ds; | ||||
|  	struct desc_ptr dt; | ||||
|  	unsigned long cr0; | ||||
|  | ||||
| @ -145,10 +145,10 @@ index d3cc1b8e2ea6..0dd18d66f3b7 100644 | ||||
|  	if (ret != X86EMUL_CONTINUE) | ||||
|  		goto emulate_shutdown; | ||||
| diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
 | ||||
| index 31424def8a03..804895afc119 100644
 | ||||
| index e8a86fc933f4..cebe7406d9b8 100644
 | ||||
| --- a/arch/x86/kvm/x86.c
 | ||||
| +++ b/arch/x86/kvm/x86.c
 | ||||
| @@ -9180,22 +9180,18 @@ static u32 enter_smm_get_segment_flags(struct kvm_segment *seg)
 | ||||
| @@ -9189,22 +9189,18 @@ static u32 enter_smm_get_segment_flags(struct kvm_segment *seg)
 | ||||
|  	return flags; | ||||
|  } | ||||
|   | ||||
| @ -179,7 +179,7 @@ index 31424def8a03..804895afc119 100644 | ||||
|  } | ||||
|   | ||||
|  #ifdef CONFIG_X86_64 | ||||
| @@ -9216,54 +9212,47 @@ static void enter_smm_save_seg_64(struct kvm_vcpu *vcpu, char *buf, int n)
 | ||||
| @@ -9225,54 +9221,47 @@ static void enter_smm_save_seg_64(struct kvm_vcpu *vcpu, char *buf, int n)
 | ||||
|  } | ||||
|  #endif | ||||
|   | ||||
| @ -257,7 +257,7 @@ index 31424def8a03..804895afc119 100644 | ||||
|  } | ||||
|   | ||||
|  #ifdef CONFIG_X86_64 | ||||
| @@ -9334,7 +9323,7 @@ static void enter_smm(struct kvm_vcpu *vcpu)
 | ||||
| @@ -9343,7 +9332,7 @@ static void enter_smm(struct kvm_vcpu *vcpu)
 | ||||
|  		enter_smm_save_state_64(vcpu, (char *)&smram); | ||||
|  	else | ||||
|  #endif | ||||
|  | ||||
| @ -154,10 +154,10 @@ index 0dd18d66f3b7..37c1662b5508 100644 | ||||
|  #endif | ||||
|  		ret = rsm_load_state_32(ctxt, &smram.smram32); | ||||
| diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
 | ||||
| index 804895afc119..8173c46d76f1 100644
 | ||||
| index cebe7406d9b8..88d78b9bfd43 100644
 | ||||
| --- a/arch/x86/kvm/x86.c
 | ||||
| +++ b/arch/x86/kvm/x86.c
 | ||||
| @@ -9195,20 +9195,17 @@ static void enter_smm_save_seg_32(struct kvm_vcpu *vcpu,
 | ||||
| @@ -9204,20 +9204,17 @@ static void enter_smm_save_seg_32(struct kvm_vcpu *vcpu,
 | ||||
|  } | ||||
|   | ||||
|  #ifdef CONFIG_X86_64 | ||||
| @ -185,7 +185,7 @@ index 804895afc119..8173c46d76f1 100644 | ||||
|  } | ||||
|  #endif | ||||
|   | ||||
| @@ -9256,57 +9253,51 @@ static void enter_smm_save_state_32(struct kvm_vcpu *vcpu, struct kvm_smram_stat
 | ||||
| @@ -9265,57 +9262,51 @@ static void enter_smm_save_state_32(struct kvm_vcpu *vcpu, struct kvm_smram_stat
 | ||||
|  } | ||||
|   | ||||
|  #ifdef CONFIG_X86_64 | ||||
| @ -268,7 +268,7 @@ index 804895afc119..8173c46d76f1 100644 | ||||
|  } | ||||
|  #endif | ||||
|   | ||||
| @@ -9320,7 +9311,7 @@ static void enter_smm(struct kvm_vcpu *vcpu)
 | ||||
| @@ -9329,7 +9320,7 @@ static void enter_smm(struct kvm_vcpu *vcpu)
 | ||||
|  	memset(smram.bytes, 0, sizeof(smram.bytes)); | ||||
|  #ifdef CONFIG_X86_64 | ||||
|  	if (guest_cpuid_has(vcpu, X86_FEATURE_LM)) | ||||
|  | ||||
| @ -17,10 +17,10 @@ Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com> | ||||
|  2 files changed, 6 insertions(+), 21 deletions(-) | ||||
| 
 | ||||
| diff --git a/arch/x86/include/asm/kvm_host.h b/arch/x86/include/asm/kvm_host.h
 | ||||
| index e05a22527585..457071be1f76 100644
 | ||||
| index 3c97449cd652..f71db6a29835 100644
 | ||||
| --- a/arch/x86/include/asm/kvm_host.h
 | ||||
| +++ b/arch/x86/include/asm/kvm_host.h
 | ||||
| @@ -1939,12 +1939,6 @@ static inline int kvm_cpu_get_apicid(int mps_cpu)
 | ||||
| @@ -1935,12 +1935,6 @@ static inline int kvm_cpu_get_apicid(int mps_cpu)
 | ||||
|  #endif | ||||
|  } | ||||
|   | ||||
| @ -34,10 +34,10 @@ index e05a22527585..457071be1f76 100644 | ||||
|   | ||||
|  int alloc_all_memslots_rmaps(struct kvm *kvm); | ||||
| diff --git a/arch/x86/kvm/svm/svm.c b/arch/x86/kvm/svm/svm.c
 | ||||
| index 545e321998d3..fe340de913b2 100644
 | ||||
| index 5ad5882c5ddf..b03bbe3383fe 100644
 | ||||
| --- a/arch/x86/kvm/svm/svm.c
 | ||||
| +++ b/arch/x86/kvm/svm/svm.c
 | ||||
| @@ -4323,15 +4323,11 @@ static int svm_enter_smm(struct kvm_vcpu *vcpu, union kvm_smram *smram)
 | ||||
| @@ -4332,15 +4332,11 @@ static int svm_enter_smm(struct kvm_vcpu *vcpu, union kvm_smram *smram)
 | ||||
|  	struct kvm_host_map map_save; | ||||
|  	int ret; | ||||
|   | ||||
| @ -55,7 +55,7 @@ index 545e321998d3..fe340de913b2 100644 | ||||
|   | ||||
|  	svm->vmcb->save.rax = vcpu->arch.regs[VCPU_REGS_RAX]; | ||||
|  	svm->vmcb->save.rsp = vcpu->arch.regs[VCPU_REGS_RSP]; | ||||
| @@ -4370,28 +4366,23 @@ static int svm_leave_smm(struct kvm_vcpu *vcpu, const union kvm_smram *smram)
 | ||||
| @@ -4379,28 +4375,23 @@ static int svm_leave_smm(struct kvm_vcpu *vcpu, const union kvm_smram *smram)
 | ||||
|  { | ||||
|  	struct vcpu_svm *svm = to_svm(vcpu); | ||||
|  	struct kvm_host_map map, map_save; | ||||
| @ -87,7 +87,7 @@ index 545e321998d3..fe340de913b2 100644 | ||||
|  		return 1; | ||||
|   | ||||
|  	ret = 1; | ||||
| @@ -4416,7 +4407,7 @@ static int svm_leave_smm(struct kvm_vcpu *vcpu, const union kvm_smram *smram)
 | ||||
| @@ -4425,7 +4416,7 @@ static int svm_leave_smm(struct kvm_vcpu *vcpu, const union kvm_smram *smram)
 | ||||
|   | ||||
|  	vmcb12 = map.hva; | ||||
|  	nested_load_control_from_vmcb12(svm, &vmcb12->control); | ||||
|  | ||||
| @ -19,10 +19,10 @@ Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com> | ||||
|  1 file changed, 9 insertions(+) | ||||
| 
 | ||||
| diff --git a/arch/x86/kvm/svm/svm.c b/arch/x86/kvm/svm/svm.c
 | ||||
| index fe340de913b2..9d65aaa6dd76 100644
 | ||||
| index b03bbe3383fe..9c50feb642e2 100644
 | ||||
| --- a/arch/x86/kvm/svm/svm.c
 | ||||
| +++ b/arch/x86/kvm/svm/svm.c
 | ||||
| @@ -4326,6 +4326,15 @@ static int svm_enter_smm(struct kvm_vcpu *vcpu, union kvm_smram *smram)
 | ||||
| @@ -4335,6 +4335,15 @@ static int svm_enter_smm(struct kvm_vcpu *vcpu, union kvm_smram *smram)
 | ||||
|  	if (!is_guest_mode(vcpu)) | ||||
|  		return 0; | ||||
|   | ||||
|  | ||||
| @ -128,10 +128,10 @@ index 3b37b3e17379..a64c190abf28 100644 | ||||
|  	__CHECK_SMRAM64_OFFSET(auto_hlt_restart,	0xFEC9); | ||||
|  	__CHECK_SMRAM64_OFFSET(reserved2,		0xFECA); | ||||
| diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
 | ||||
| index 8173c46d76f1..9c78d980757a 100644
 | ||||
| index 88d78b9bfd43..93fff459b95b 100644
 | ||||
| --- a/arch/x86/kvm/x86.c
 | ||||
| +++ b/arch/x86/kvm/x86.c
 | ||||
| @@ -7432,6 +7432,11 @@ static void emulator_set_nmi_mask(struct x86_emulate_ctxt *ctxt, bool masked)
 | ||||
| @@ -7441,6 +7441,11 @@ static void emulator_set_nmi_mask(struct x86_emulate_ctxt *ctxt, bool masked)
 | ||||
|  	static_call(kvm_x86_set_nmi_mask)(emul_to_vcpu(ctxt), masked); | ||||
|  } | ||||
|   | ||||
| @ -143,7 +143,7 @@ index 8173c46d76f1..9c78d980757a 100644 | ||||
|  static unsigned emulator_get_hflags(struct x86_emulate_ctxt *ctxt) | ||||
|  { | ||||
|  	return emul_to_vcpu(ctxt)->arch.hflags; | ||||
| @@ -7501,6 +7506,7 @@ static const struct x86_emulate_ops emulate_ops = {
 | ||||
| @@ -7510,6 +7515,7 @@ static const struct x86_emulate_ops emulate_ops = {
 | ||||
|  	.guest_has_fxsr      = emulator_guest_has_fxsr, | ||||
|  	.guest_has_rdpid     = emulator_guest_has_rdpid, | ||||
|  	.set_nmi_mask        = emulator_set_nmi_mask, | ||||
| @ -151,7 +151,7 @@ index 8173c46d76f1..9c78d980757a 100644 | ||||
|  	.get_hflags          = emulator_get_hflags, | ||||
|  	.exiting_smm         = emulator_exiting_smm, | ||||
|  	.leave_smm           = emulator_leave_smm, | ||||
| @@ -9250,6 +9256,8 @@ static void enter_smm_save_state_32(struct kvm_vcpu *vcpu, struct kvm_smram_stat
 | ||||
| @@ -9259,6 +9265,8 @@ static void enter_smm_save_state_32(struct kvm_vcpu *vcpu, struct kvm_smram_stat
 | ||||
|  	smram->cr4 = kvm_read_cr4(vcpu); | ||||
|  	smram->smm_revision = 0x00020000; | ||||
|  	smram->smbase = vcpu->arch.smbase; | ||||
| @ -160,7 +160,7 @@ index 8173c46d76f1..9c78d980757a 100644 | ||||
|  } | ||||
|   | ||||
|  #ifdef CONFIG_X86_64 | ||||
| @@ -9298,6 +9306,8 @@ static void enter_smm_save_state_64(struct kvm_vcpu *vcpu, struct kvm_smram_stat
 | ||||
| @@ -9307,6 +9315,8 @@ static void enter_smm_save_state_64(struct kvm_vcpu *vcpu, struct kvm_smram_stat
 | ||||
|  	enter_smm_save_seg_64(vcpu, &smram->ds, VCPU_SREG_DS); | ||||
|  	enter_smm_save_seg_64(vcpu, &smram->fs, VCPU_SREG_FS); | ||||
|  	enter_smm_save_seg_64(vcpu, &smram->gs, VCPU_SREG_GS); | ||||
| @ -169,7 +169,7 @@ index 8173c46d76f1..9c78d980757a 100644 | ||||
|  } | ||||
|  #endif | ||||
|   | ||||
| @@ -9334,6 +9344,8 @@ static void enter_smm(struct kvm_vcpu *vcpu)
 | ||||
| @@ -9343,6 +9353,8 @@ static void enter_smm(struct kvm_vcpu *vcpu)
 | ||||
|  	kvm_set_rflags(vcpu, X86_EFLAGS_FIXED); | ||||
|  	kvm_rip_write(vcpu, 0x8000); | ||||
|   | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Thomas Lamprecht
						Thomas Lamprecht