diff options
| author | Paolo Bonzini <pbonzini@redhat.com> | 2016-02-25 09:53:55 +0100 | 
|---|---|---|
| committer | Paolo Bonzini <pbonzini@redhat.com> | 2016-02-25 09:53:55 +0100 | 
| commit | 0fb00d326ffc36844fac0bfefd8644585a86d4a6 (patch) | |
| tree | 7fa63f85f0b8485081e3f26c2a808ccc6949885c /arch | |
| parent | 17e4bce0ae63c7e03f3c7fa8d80890e7af3d4971 (diff) | |
| parent | fd451b90e78c4178bcfc5072f2b2b637500c109a (diff) | |
Merge tag 'kvm-arm-for-4.5-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/kvmarm/kvmarm into kvm-master
KVM/ARM fixes for 4.5-rc6
- Fix per-vcpu vgic bitmap allocation
- Do not give copy random memory on MMIO read
- Fix GICv3 APR register restore order
Diffstat (limited to 'arch')
| -rw-r--r-- | arch/arm/kvm/mmio.c | 3 | ||||
| -rw-r--r-- | arch/arm64/kvm/hyp/vgic-v3-sr.c | 20 | 
2 files changed, 12 insertions, 11 deletions
diff --git a/arch/arm/kvm/mmio.c b/arch/arm/kvm/mmio.c index 7f33b2056ae6..0f6600f05137 100644 --- a/arch/arm/kvm/mmio.c +++ b/arch/arm/kvm/mmio.c @@ -206,7 +206,8 @@ int io_mem_abort(struct kvm_vcpu *vcpu, struct kvm_run *run,  	run->mmio.is_write	= is_write;  	run->mmio.phys_addr	= fault_ipa;  	run->mmio.len		= len; -	memcpy(run->mmio.data, data_buf, len); +	if (is_write) +		memcpy(run->mmio.data, data_buf, len);  	if (!ret) {  		/* We handled the access successfully in the kernel. */ diff --git a/arch/arm64/kvm/hyp/vgic-v3-sr.c b/arch/arm64/kvm/hyp/vgic-v3-sr.c index 9142e082f5f3..5dd2a26444ec 100644 --- a/arch/arm64/kvm/hyp/vgic-v3-sr.c +++ b/arch/arm64/kvm/hyp/vgic-v3-sr.c @@ -149,16 +149,6 @@ void __hyp_text __vgic_v3_restore_state(struct kvm_vcpu *vcpu)  	switch (nr_pri_bits) {  	case 7: -		 write_gicreg(cpu_if->vgic_ap1r[3], ICH_AP1R3_EL2); -		 write_gicreg(cpu_if->vgic_ap1r[2], ICH_AP1R2_EL2); -	case 6: -		 write_gicreg(cpu_if->vgic_ap1r[1], ICH_AP1R1_EL2); -	default: -		 write_gicreg(cpu_if->vgic_ap1r[0], ICH_AP1R0_EL2); -	}	 	                            -		 	                            -	switch (nr_pri_bits) { -	case 7:  		 write_gicreg(cpu_if->vgic_ap0r[3], ICH_AP0R3_EL2);  		 write_gicreg(cpu_if->vgic_ap0r[2], ICH_AP0R2_EL2);  	case 6: @@ -167,6 +157,16 @@ void __hyp_text __vgic_v3_restore_state(struct kvm_vcpu *vcpu)  		 write_gicreg(cpu_if->vgic_ap0r[0], ICH_AP0R0_EL2);  	} +	switch (nr_pri_bits) { +	case 7: +		 write_gicreg(cpu_if->vgic_ap1r[3], ICH_AP1R3_EL2); +		 write_gicreg(cpu_if->vgic_ap1r[2], ICH_AP1R2_EL2); +	case 6: +		 write_gicreg(cpu_if->vgic_ap1r[1], ICH_AP1R1_EL2); +	default: +		 write_gicreg(cpu_if->vgic_ap1r[0], ICH_AP1R0_EL2); +	} +  	switch (max_lr_idx) {  	case 15:  		write_gicreg(cpu_if->vgic_lr[VGIC_V3_LR_INDEX(15)], ICH_LR15_EL2);  | 
