mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 02:30:34 +02:00 
			
		
		
		
	KVM: arm64: vgic-v3: Add ICV_PMR_EL1 handler
Add a handler for reading/writing the guest's view of the ICC_PMR_EL1 register, which is located in the ICH_VMCR_EL2.VPMR field. Tested-by: Alexander Graf <agraf@suse.de> Acked-by: David Daney <david.daney@cavium.com> Acked-by: Christoffer Dall <cdall@linaro.org> Reviewed-by: Eric Auger <eric.auger@redhat.com> Signed-off-by: Marc Zyngier <marc.zyngier@arm.com> Signed-off-by: Christoffer Dall <cdall@linaro.org>
This commit is contained in:
		
							parent
							
								
									d840b2d37d
								
							
						
					
					
						commit
						6293d6514d
					
				
					 1 changed files with 27 additions and 0 deletions
				
			
		| 
						 | 
				
			
			@ -884,6 +884,27 @@ static void __hyp_text __vgic_v3_read_hppir(struct kvm_vcpu *vcpu,
 | 
			
		|||
	vcpu_set_reg(vcpu, rt, lr_val & ICH_LR_VIRTUAL_ID_MASK);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void __hyp_text __vgic_v3_read_pmr(struct kvm_vcpu *vcpu,
 | 
			
		||||
					  u32 vmcr, int rt)
 | 
			
		||||
{
 | 
			
		||||
	vmcr &= ICH_VMCR_PMR_MASK;
 | 
			
		||||
	vmcr >>= ICH_VMCR_PMR_SHIFT;
 | 
			
		||||
	vcpu_set_reg(vcpu, rt, vmcr);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void __hyp_text __vgic_v3_write_pmr(struct kvm_vcpu *vcpu,
 | 
			
		||||
					   u32 vmcr, int rt)
 | 
			
		||||
{
 | 
			
		||||
	u32 val = vcpu_get_reg(vcpu, rt);
 | 
			
		||||
 | 
			
		||||
	val <<= ICH_VMCR_PMR_SHIFT;
 | 
			
		||||
	val &= ICH_VMCR_PMR_MASK;
 | 
			
		||||
	vmcr &= ~ICH_VMCR_PMR_MASK;
 | 
			
		||||
	vmcr |= val;
 | 
			
		||||
 | 
			
		||||
	write_gicreg(vmcr, ICH_VMCR_EL2);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void __hyp_text __vgic_v3_read_rpr(struct kvm_vcpu *vcpu,
 | 
			
		||||
					  u32 vmcr, int rt)
 | 
			
		||||
{
 | 
			
		||||
| 
						 | 
				
			
			@ -1029,6 +1050,12 @@ int __hyp_text __vgic_v3_perform_cpuif_access(struct kvm_vcpu *vcpu)
 | 
			
		|||
		else
 | 
			
		||||
			fn = __vgic_v3_write_ctlr;
 | 
			
		||||
		break;
 | 
			
		||||
	case SYS_ICC_PMR_EL1:
 | 
			
		||||
		if (is_read)
 | 
			
		||||
			fn = __vgic_v3_read_pmr;
 | 
			
		||||
		else
 | 
			
		||||
			fn = __vgic_v3_write_pmr;
 | 
			
		||||
		break;
 | 
			
		||||
	default:
 | 
			
		||||
		return 0;
 | 
			
		||||
	}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue