mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-18 22:14:16 +00:00 
			
		
		
		
	 55009c6ed2
			
		
	
	
		55009c6ed2
		
	
	
	
	
		
			
			We currently intertwine the KVM PSCI implementation with the general dispatch of hypercall handling, which makes perfect sense because PSCI is the only category of hypercalls we support. However, as we are about to support additional hypercalls, factor out this functionality into a separate hypercall handler file. Signed-off-by: Christoffer Dall <christoffer.dall@arm.com> [steven.price@arm.com: rebased] Reviewed-by: Andrew Jones <drjones@redhat.com> Signed-off-by: Steven Price <steven.price@arm.com> Signed-off-by: Marc Zyngier <maz@kernel.org>
		
			
				
	
	
		
			43 lines
		
	
	
	
		
			906 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
	
		
			906 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /* Copyright (C) 2019 Arm Ltd. */
 | |
| 
 | |
| #ifndef __KVM_ARM_HYPERCALLS_H
 | |
| #define __KVM_ARM_HYPERCALLS_H
 | |
| 
 | |
| #include <asm/kvm_emulate.h>
 | |
| 
 | |
| int kvm_hvc_call_handler(struct kvm_vcpu *vcpu);
 | |
| 
 | |
| static inline u32 smccc_get_function(struct kvm_vcpu *vcpu)
 | |
| {
 | |
| 	return vcpu_get_reg(vcpu, 0);
 | |
| }
 | |
| 
 | |
| static inline unsigned long smccc_get_arg1(struct kvm_vcpu *vcpu)
 | |
| {
 | |
| 	return vcpu_get_reg(vcpu, 1);
 | |
| }
 | |
| 
 | |
| static inline unsigned long smccc_get_arg2(struct kvm_vcpu *vcpu)
 | |
| {
 | |
| 	return vcpu_get_reg(vcpu, 2);
 | |
| }
 | |
| 
 | |
| static inline unsigned long smccc_get_arg3(struct kvm_vcpu *vcpu)
 | |
| {
 | |
| 	return vcpu_get_reg(vcpu, 3);
 | |
| }
 | |
| 
 | |
| static inline void smccc_set_retval(struct kvm_vcpu *vcpu,
 | |
| 				    unsigned long a0,
 | |
| 				    unsigned long a1,
 | |
| 				    unsigned long a2,
 | |
| 				    unsigned long a3)
 | |
| {
 | |
| 	vcpu_set_reg(vcpu, 0, a0);
 | |
| 	vcpu_set_reg(vcpu, 1, a1);
 | |
| 	vcpu_set_reg(vcpu, 2, a2);
 | |
| 	vcpu_set_reg(vcpu, 3, a3);
 | |
| }
 | |
| 
 | |
| #endif
 |