diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2016-11-04 13:08:05 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2016-11-04 13:08:05 -0700 | 
| commit | 66cecb67894b35c6af17eb4e6b6aaec6c8957c2e (patch) | |
| tree | c1986d590632735047174c5587d0b22b45b47a1e /arch/mips/kvm/mips.c | |
| parent | 34c510b2eecd2fb8414998f54ce12c94e16d78a0 (diff) | |
| parent | d9092f52d7e61dd1557f2db2400ddb430e85937e (diff) | |
| download | talos-op-linux-66cecb67894b35c6af17eb4e6b6aaec6c8957c2e.tar.gz talos-op-linux-66cecb67894b35c6af17eb4e6b6aaec6c8957c2e.zip | |
Merge tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm
Pull KVM updates from Paolo Bonzini:
 "One NULL pointer dereference, and two fixes for regressions introduced
  during the merge window.
  The rest are fixes for MIPS, s390 and nested VMX"
* tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm:
  kvm: x86: Check memopp before dereference (CVE-2016-8630)
  kvm: nVMX: VMCLEAR an active shadow VMCS after last use
  KVM: x86: drop TSC offsetting kvm_x86_ops to fix KVM_GET/SET_CLOCK
  KVM: x86: fix wbinvd_dirty_mask use-after-free
  kvm/x86: Show WRMSR data is in hex
  kvm: nVMX: Fix kernel panics induced by illegal INVEPT/INVVPID types
  KVM: document lock orders
  KVM: fix OOPS on flush_work
  KVM: s390: Fix STHYI buffer alignment for diag224
  KVM: MIPS: Precalculate MMIO load resume PC
  KVM: MIPS: Make ERET handle ERL before EXL
  KVM: MIPS: Fix lazy user ASID regenerate for SMP
Diffstat (limited to 'arch/mips/kvm/mips.c')
| -rw-r--r-- | arch/mips/kvm/mips.c | 5 | 
1 files changed, 4 insertions, 1 deletions
| diff --git a/arch/mips/kvm/mips.c b/arch/mips/kvm/mips.c index 622037d851a3..06a60b19acfb 100644 --- a/arch/mips/kvm/mips.c +++ b/arch/mips/kvm/mips.c @@ -426,7 +426,7 @@ int kvm_arch_vcpu_ioctl_set_guest_debug(struct kvm_vcpu *vcpu,  static void kvm_mips_check_asids(struct kvm_vcpu *vcpu)  {  	struct mips_coproc *cop0 = vcpu->arch.cop0; -	int cpu = smp_processor_id(); +	int i, cpu = smp_processor_id();  	unsigned int gasid;  	/* @@ -442,6 +442,9 @@ static void kvm_mips_check_asids(struct kvm_vcpu *vcpu)  						vcpu);  			vcpu->arch.guest_user_asid[cpu] =  				vcpu->arch.guest_user_mm.context.asid[cpu]; +			for_each_possible_cpu(i) +				if (i != cpu) +					vcpu->arch.guest_user_asid[cpu] = 0;  			vcpu->arch.last_user_gasid = gasid;  		}  	} | 

