diff options
Diffstat (limited to 'arch/x86/kernel')
| -rw-r--r-- | arch/x86/kernel/amd_nb.c | 6 | ||||
| -rw-r--r-- | arch/x86/kernel/kprobes/core.c | 4 | ||||
| -rw-r--r-- | arch/x86/kernel/kvm.c | 8 | ||||
| -rw-r--r-- | arch/x86/kernel/machine_kexec_32.c | 6 | ||||
| -rw-r--r-- | arch/x86/kernel/machine_kexec_64.c | 5 | ||||
| -rw-r--r-- | arch/x86/kernel/uprobes.c | 4 | 
6 files changed, 27 insertions, 6 deletions
| diff --git a/arch/x86/kernel/amd_nb.c b/arch/x86/kernel/amd_nb.c index c88e0b127810..b481b95bd8f6 100644 --- a/arch/x86/kernel/amd_nb.c +++ b/arch/x86/kernel/amd_nb.c @@ -14,8 +14,11 @@  #include <asm/amd_nb.h>  #define PCI_DEVICE_ID_AMD_17H_ROOT	0x1450 +#define PCI_DEVICE_ID_AMD_17H_M10H_ROOT	0x15d0  #define PCI_DEVICE_ID_AMD_17H_DF_F3	0x1463  #define PCI_DEVICE_ID_AMD_17H_DF_F4	0x1464 +#define PCI_DEVICE_ID_AMD_17H_M10H_DF_F3 0x15eb +#define PCI_DEVICE_ID_AMD_17H_M10H_DF_F4 0x15ec  /* Protect the PCI config register pairs used for SMN and DF indirect access. */  static DEFINE_MUTEX(smn_mutex); @@ -24,6 +27,7 @@ static u32 *flush_words;  static const struct pci_device_id amd_root_ids[] = {  	{ PCI_DEVICE(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_17H_ROOT) }, +	{ PCI_DEVICE(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_17H_M10H_ROOT) },  	{}  }; @@ -39,6 +43,7 @@ const struct pci_device_id amd_nb_misc_ids[] = {  	{ PCI_DEVICE(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_16H_NB_F3) },  	{ PCI_DEVICE(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_16H_M30H_NB_F3) },  	{ PCI_DEVICE(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_17H_DF_F3) }, +	{ PCI_DEVICE(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_17H_M10H_DF_F3) },  	{ PCI_DEVICE(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_CNB17H_F3) },  	{}  }; @@ -51,6 +56,7 @@ static const struct pci_device_id amd_nb_link_ids[] = {  	{ PCI_DEVICE(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_16H_NB_F4) },  	{ PCI_DEVICE(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_16H_M30H_NB_F4) },  	{ PCI_DEVICE(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_17H_DF_F4) }, +	{ PCI_DEVICE(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_17H_M10H_DF_F4) },  	{ PCI_DEVICE(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_CNB17H_F4) },  	{}  }; diff --git a/arch/x86/kernel/kprobes/core.c b/arch/x86/kernel/kprobes/core.c index 0715f827607c..6f4d42377fe5 100644 --- a/arch/x86/kernel/kprobes/core.c +++ b/arch/x86/kernel/kprobes/core.c @@ -370,6 +370,10 @@ int __copy_instruction(u8 *dest, u8 *src, u8 *real, struct insn *insn)  	if (insn->opcode.bytes[0] == BREAKPOINT_INSTRUCTION)  		return 0; +	/* We should not singlestep on the exception masking instructions */ +	if (insn_masking_exception(insn)) +		return 0; +  #ifdef CONFIG_X86_64  	/* Only x86_64 has RIP relative instructions */  	if (insn_rip_relative(insn)) { diff --git a/arch/x86/kernel/kvm.c b/arch/x86/kernel/kvm.c index 7867417cfaff..5b2300b818af 100644 --- a/arch/x86/kernel/kvm.c +++ b/arch/x86/kernel/kvm.c @@ -457,7 +457,7 @@ static void __init sev_map_percpu_data(void)  static void __init kvm_smp_prepare_cpus(unsigned int max_cpus)  {  	native_smp_prepare_cpus(max_cpus); -	if (kvm_para_has_hint(KVM_HINTS_DEDICATED)) +	if (kvm_para_has_hint(KVM_HINTS_REALTIME))  		static_branch_disable(&virt_spin_lock_key);  } @@ -553,7 +553,7 @@ static void __init kvm_guest_init(void)  	}  	if (kvm_para_has_feature(KVM_FEATURE_PV_TLB_FLUSH) && -	    !kvm_para_has_hint(KVM_HINTS_DEDICATED) && +	    !kvm_para_has_hint(KVM_HINTS_REALTIME) &&  	    kvm_para_has_feature(KVM_FEATURE_STEAL_TIME))  		pv_mmu_ops.flush_tlb_others = kvm_flush_tlb_others; @@ -649,7 +649,7 @@ static __init int kvm_setup_pv_tlb_flush(void)  	int cpu;  	if (kvm_para_has_feature(KVM_FEATURE_PV_TLB_FLUSH) && -	    !kvm_para_has_hint(KVM_HINTS_DEDICATED) && +	    !kvm_para_has_hint(KVM_HINTS_REALTIME) &&  	    kvm_para_has_feature(KVM_FEATURE_STEAL_TIME)) {  		for_each_possible_cpu(cpu) {  			zalloc_cpumask_var_node(per_cpu_ptr(&__pv_tlb_mask, cpu), @@ -745,7 +745,7 @@ void __init kvm_spinlock_init(void)  	if (!kvm_para_has_feature(KVM_FEATURE_PV_UNHALT))  		return; -	if (kvm_para_has_hint(KVM_HINTS_DEDICATED)) +	if (kvm_para_has_hint(KVM_HINTS_REALTIME))  		return;  	__pv_init_lock_hash(); diff --git a/arch/x86/kernel/machine_kexec_32.c b/arch/x86/kernel/machine_kexec_32.c index 60cdec6628b0..d1ab07ec8c9a 100644 --- a/arch/x86/kernel/machine_kexec_32.c +++ b/arch/x86/kernel/machine_kexec_32.c @@ -57,12 +57,17 @@ static void load_segments(void)  static void machine_kexec_free_page_tables(struct kimage *image)  {  	free_page((unsigned long)image->arch.pgd); +	image->arch.pgd = NULL;  #ifdef CONFIG_X86_PAE  	free_page((unsigned long)image->arch.pmd0); +	image->arch.pmd0 = NULL;  	free_page((unsigned long)image->arch.pmd1); +	image->arch.pmd1 = NULL;  #endif  	free_page((unsigned long)image->arch.pte0); +	image->arch.pte0 = NULL;  	free_page((unsigned long)image->arch.pte1); +	image->arch.pte1 = NULL;  }  static int machine_kexec_alloc_page_tables(struct kimage *image) @@ -79,7 +84,6 @@ static int machine_kexec_alloc_page_tables(struct kimage *image)  	    !image->arch.pmd0 || !image->arch.pmd1 ||  #endif  	    !image->arch.pte0 || !image->arch.pte1) { -		machine_kexec_free_page_tables(image);  		return -ENOMEM;  	}  	return 0; diff --git a/arch/x86/kernel/machine_kexec_64.c b/arch/x86/kernel/machine_kexec_64.c index a5e55d832d0a..6010449ca6d2 100644 --- a/arch/x86/kernel/machine_kexec_64.c +++ b/arch/x86/kernel/machine_kexec_64.c @@ -39,9 +39,13 @@ const struct kexec_file_ops * const kexec_file_loaders[] = {  static void free_transition_pgtable(struct kimage *image)  {  	free_page((unsigned long)image->arch.p4d); +	image->arch.p4d = NULL;  	free_page((unsigned long)image->arch.pud); +	image->arch.pud = NULL;  	free_page((unsigned long)image->arch.pmd); +	image->arch.pmd = NULL;  	free_page((unsigned long)image->arch.pte); +	image->arch.pte = NULL;  }  static int init_transition_pgtable(struct kimage *image, pgd_t *pgd) @@ -91,7 +95,6 @@ static int init_transition_pgtable(struct kimage *image, pgd_t *pgd)  	set_pte(pte, pfn_pte(paddr >> PAGE_SHIFT, PAGE_KERNEL_EXEC_NOENC));  	return 0;  err: -	free_transition_pgtable(image);  	return result;  } diff --git a/arch/x86/kernel/uprobes.c b/arch/x86/kernel/uprobes.c index 85c7ef23d99f..c84bb5396958 100644 --- a/arch/x86/kernel/uprobes.c +++ b/arch/x86/kernel/uprobes.c @@ -299,6 +299,10 @@ static int uprobe_init_insn(struct arch_uprobe *auprobe, struct insn *insn, bool  	if (is_prefix_bad(insn))  		return -ENOTSUPP; +	/* We should not singlestep on the exception masking instructions */ +	if (insn_masking_exception(insn)) +		return -ENOTSUPP; +  	if (x86_64)  		good_insns = good_insns_64;  	else | 
