Marc Zyngier | fd9fc9f | 2012-12-10 11:16:40 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2012,2013 - ARM Ltd |
| 3 | * Author: Marc Zyngier <marc.zyngier@arm.com> |
| 4 | * |
| 5 | * This program is free software; you can redistribute it and/or modify |
| 6 | * it under the terms of the GNU General Public License version 2 as |
| 7 | * published by the Free Software Foundation. |
| 8 | * |
| 9 | * This program is distributed in the hope that it will be useful, |
| 10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 12 | * GNU General Public License for more details. |
| 13 | * |
| 14 | * You should have received a copy of the GNU General Public License |
| 15 | * along with this program. If not, see <http://www.gnu.org/licenses/>. |
| 16 | */ |
| 17 | |
| 18 | #ifndef __ARM_KVM_ASM_H__ |
| 19 | #define __ARM_KVM_ASM_H__ |
| 20 | |
Marc Zyngier | 45451914 | 2013-06-26 15:16:40 +0100 | [diff] [blame] | 21 | #include <asm/virt.h> |
| 22 | |
Marc Zyngier | 2016340 | 2016-09-06 14:02:05 +0100 | [diff] [blame] | 23 | #define ARM_EXIT_WITH_SERROR_BIT 31 |
| 24 | #define ARM_EXCEPTION_CODE(x) ((x) & ~(1U << ARM_EXIT_WITH_SERROR_BIT)) |
| 25 | #define ARM_SERROR_PENDING(x) !!((x) & (1U << ARM_EXIT_WITH_SERROR_BIT)) |
| 26 | |
Marc Zyngier | fd9fc9f | 2012-12-10 11:16:40 +0000 | [diff] [blame] | 27 | #define ARM_EXCEPTION_IRQ 0 |
Marc Zyngier | 9aecafc | 2016-09-06 14:02:02 +0100 | [diff] [blame] | 28 | #define ARM_EXCEPTION_EL1_SERROR 1 |
| 29 | #define ARM_EXCEPTION_TRAP 2 |
James Morse | c94b0cf | 2016-04-27 17:47:04 +0100 | [diff] [blame] | 30 | /* The hyp-stub will return this for any kvm_call_hyp() call */ |
Marc Zyngier | 9aecafc | 2016-09-06 14:02:02 +0100 | [diff] [blame] | 31 | #define ARM_EXCEPTION_HYP_GONE 3 |
Marc Zyngier | fd9fc9f | 2012-12-10 11:16:40 +0000 | [diff] [blame] | 32 | |
Marc Zyngier | 0c557ed | 2014-04-24 10:24:46 +0100 | [diff] [blame] | 33 | #define KVM_ARM64_DEBUG_DIRTY_SHIFT 0 |
| 34 | #define KVM_ARM64_DEBUG_DIRTY (1 << KVM_ARM64_DEBUG_DIRTY_SHIFT) |
| 35 | |
Marc Zyngier | 2510ffe | 2016-03-18 17:25:59 +0000 | [diff] [blame] | 36 | #define kvm_ksym_ref(sym) \ |
| 37 | ({ \ |
| 38 | void *val = &sym; \ |
| 39 | if (!is_kernel_in_hyp_mode()) \ |
| 40 | val = phys_to_virt((u64)&sym - kimage_voffset); \ |
| 41 | val; \ |
| 42 | }) |
Ard Biesheuvel | a0bf977 | 2016-02-16 13:52:39 +0100 | [diff] [blame] | 43 | |
Marc Zyngier | fd9fc9f | 2012-12-10 11:16:40 +0000 | [diff] [blame] | 44 | #ifndef __ASSEMBLY__ |
| 45 | struct kvm; |
| 46 | struct kvm_vcpu; |
| 47 | |
| 48 | extern char __kvm_hyp_init[]; |
| 49 | extern char __kvm_hyp_init_end[]; |
AKASHI Takahiro | 67f6919 | 2016-04-27 17:47:05 +0100 | [diff] [blame] | 50 | extern char __kvm_hyp_reset[]; |
Marc Zyngier | fd9fc9f | 2012-12-10 11:16:40 +0000 | [diff] [blame] | 51 | |
| 52 | extern char __kvm_hyp_vector[]; |
| 53 | |
Marc Zyngier | fd9fc9f | 2012-12-10 11:16:40 +0000 | [diff] [blame] | 54 | extern void __kvm_flush_vm_context(void); |
| 55 | extern void __kvm_tlb_flush_vmid_ipa(struct kvm *kvm, phys_addr_t ipa); |
Mario Smarduch | 8199ed0 | 2015-01-15 15:58:59 -0800 | [diff] [blame] | 56 | extern void __kvm_tlb_flush_vmid(struct kvm *kvm); |
Marc Zyngier | 94d0e59 | 2016-10-18 18:37:49 +0100 | [diff] [blame^] | 57 | extern void __kvm_tlb_flush_local_vmid(struct kvm_vcpu *vcpu); |
Marc Zyngier | fd9fc9f | 2012-12-10 11:16:40 +0000 | [diff] [blame] | 58 | |
| 59 | extern int __kvm_vcpu_run(struct kvm_vcpu *vcpu); |
Marc Zyngier | 1a9b130 | 2013-06-21 11:57:56 +0100 | [diff] [blame] | 60 | |
Marc Zyngier | b2fb1c0 | 2013-07-12 15:15:23 +0100 | [diff] [blame] | 61 | extern u64 __vgic_v3_get_ich_vtr_el2(void); |
Marc Zyngier | 0d98d00 | 2016-03-03 15:43:58 +0000 | [diff] [blame] | 62 | extern void __vgic_v3_init_lrs(void); |
Marc Zyngier | b2fb1c0 | 2013-07-12 15:15:23 +0100 | [diff] [blame] | 63 | |
Alex Bennée | 56c7f5e | 2015-07-07 17:29:56 +0100 | [diff] [blame] | 64 | extern u32 __kvm_get_mdcr_el2(void); |
| 65 | |
Marc Zyngier | 6141570 | 2016-04-05 16:11:47 +0100 | [diff] [blame] | 66 | extern u32 __init_stage2_translation(void); |
Marc Zyngier | 3a3604b | 2015-01-29 13:19:45 +0000 | [diff] [blame] | 67 | |
Marc Zyngier | fd9fc9f | 2012-12-10 11:16:40 +0000 | [diff] [blame] | 68 | #endif |
| 69 | |
| 70 | #endif /* __ARM_KVM_ASM_H__ */ |