Path: blob/master/tools/arch/arm64/include/uapi/asm/kvm.h
26299 views
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */1/*2* Copyright (C) 2012,2013 - ARM Ltd3* Author: Marc Zyngier <[email protected]>4*5* Derived from arch/arm/include/uapi/asm/kvm.h:6* Copyright (C) 2012 - Virtual Open Systems and Columbia University7* Author: Christoffer Dall <[email protected]>8*9* This program is free software; you can redistribute it and/or modify10* it under the terms of the GNU General Public License version 2 as11* published by the Free Software Foundation.12*13* This program is distributed in the hope that it will be useful,14* but WITHOUT ANY WARRANTY; without even the implied warranty of15* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the16* GNU General Public License for more details.17*18* You should have received a copy of the GNU General Public License19* along with this program. If not, see <http://www.gnu.org/licenses/>.20*/2122#ifndef __ARM_KVM_H__23#define __ARM_KVM_H__2425#define KVM_SPSR_EL1 026#define KVM_SPSR_SVC KVM_SPSR_EL127#define KVM_SPSR_ABT 128#define KVM_SPSR_UND 229#define KVM_SPSR_IRQ 330#define KVM_SPSR_FIQ 431#define KVM_NR_SPSR 53233#ifndef __ASSEMBLY__34#include <linux/psci.h>35#include <linux/types.h>36#include <asm/ptrace.h>37#include <asm/sve_context.h>3839#define __KVM_HAVE_IRQ_LINE40#define __KVM_HAVE_VCPU_EVENTS4142#define KVM_COALESCED_MMIO_PAGE_OFFSET 143#define KVM_DIRTY_LOG_PAGE_OFFSET 644445struct kvm_regs {46struct user_pt_regs regs; /* sp = sp_el0 */4748__u64 sp_el1;49__u64 elr_el1;5051__u64 spsr[KVM_NR_SPSR];5253struct user_fpsimd_state fp_regs;54};5556/*57* Supported CPU Targets - Adding a new target type is not recommended,58* unless there are some special registers not supported by the59* genericv8 syreg table.60*/61#define KVM_ARM_TARGET_AEM_V8 062#define KVM_ARM_TARGET_FOUNDATION_V8 163#define KVM_ARM_TARGET_CORTEX_A57 264#define KVM_ARM_TARGET_XGENE_POTENZA 365#define KVM_ARM_TARGET_CORTEX_A53 466/* Generic ARM v8 target */67#define KVM_ARM_TARGET_GENERIC_V8 56869#define KVM_ARM_NUM_TARGETS 67071/* KVM_ARM_SET_DEVICE_ADDR ioctl id encoding */72#define KVM_ARM_DEVICE_TYPE_SHIFT 073#define KVM_ARM_DEVICE_TYPE_MASK __GENMASK(KVM_ARM_DEVICE_TYPE_SHIFT + 15, \74KVM_ARM_DEVICE_TYPE_SHIFT)75#define KVM_ARM_DEVICE_ID_SHIFT 1676#define KVM_ARM_DEVICE_ID_MASK __GENMASK(KVM_ARM_DEVICE_ID_SHIFT + 15, \77KVM_ARM_DEVICE_ID_SHIFT)7879/* Supported device IDs */80#define KVM_ARM_DEVICE_VGIC_V2 08182/* Supported VGIC address types */83#define KVM_VGIC_V2_ADDR_TYPE_DIST 084#define KVM_VGIC_V2_ADDR_TYPE_CPU 18586#define KVM_VGIC_V2_DIST_SIZE 0x100087#define KVM_VGIC_V2_CPU_SIZE 0x20008889/* Supported VGICv3 address types */90#define KVM_VGIC_V3_ADDR_TYPE_DIST 291#define KVM_VGIC_V3_ADDR_TYPE_REDIST 392#define KVM_VGIC_ITS_ADDR_TYPE 493#define KVM_VGIC_V3_ADDR_TYPE_REDIST_REGION 59495#define KVM_VGIC_V3_DIST_SIZE SZ_64K96#define KVM_VGIC_V3_REDIST_SIZE (2 * SZ_64K)97#define KVM_VGIC_V3_ITS_SIZE (2 * SZ_64K)9899#define KVM_ARM_VCPU_POWER_OFF 0 /* CPU is started in OFF state */100#define KVM_ARM_VCPU_EL1_32BIT 1 /* CPU running a 32bit VM */101#define KVM_ARM_VCPU_PSCI_0_2 2 /* CPU uses PSCI v0.2 */102#define KVM_ARM_VCPU_PMU_V3 3 /* Support guest PMUv3 */103#define KVM_ARM_VCPU_SVE 4 /* enable SVE for this CPU */104#define KVM_ARM_VCPU_PTRAUTH_ADDRESS 5 /* VCPU uses address authentication */105#define KVM_ARM_VCPU_PTRAUTH_GENERIC 6 /* VCPU uses generic authentication */106#define KVM_ARM_VCPU_HAS_EL2 7 /* Support nested virtualization */107#define KVM_ARM_VCPU_HAS_EL2_E2H0 8 /* Limit NV support to E2H RES0 */108109struct kvm_vcpu_init {110__u32 target;111__u32 features[7];112};113114struct kvm_sregs {115};116117struct kvm_fpu {118};119120/*121* See v8 ARM ARM D7.3: Debug Registers122*123* The architectural limit is 16 debug registers of each type although124* in practice there are usually less (see ID_AA64DFR0_EL1).125*126* Although the control registers are architecturally defined as 32127* bits wide we use a 64 bit structure here to keep parity with128* KVM_GET/SET_ONE_REG behaviour which treats all system registers as129* 64 bit values. It also allows for the possibility of the130* architecture expanding the control registers without having to131* change the userspace ABI.132*/133#define KVM_ARM_MAX_DBG_REGS 16134struct kvm_guest_debug_arch {135__u64 dbg_bcr[KVM_ARM_MAX_DBG_REGS];136__u64 dbg_bvr[KVM_ARM_MAX_DBG_REGS];137__u64 dbg_wcr[KVM_ARM_MAX_DBG_REGS];138__u64 dbg_wvr[KVM_ARM_MAX_DBG_REGS];139};140141#define KVM_DEBUG_ARCH_HSR_HIGH_VALID (1 << 0)142struct kvm_debug_exit_arch {143__u32 hsr;144__u32 hsr_high; /* ESR_EL2[61:32] */145__u64 far; /* used for watchpoints */146};147148/*149* Architecture specific defines for kvm_guest_debug->control150*/151152#define KVM_GUESTDBG_USE_SW_BP (1 << 16)153#define KVM_GUESTDBG_USE_HW (1 << 17)154155struct kvm_sync_regs {156/* Used with KVM_CAP_ARM_USER_IRQ */157__u64 device_irq_level;158};159160/* Bits for run->s.regs.device_irq_level */161#define KVM_ARM_DEV_EL1_VTIMER (1 << 0)162#define KVM_ARM_DEV_EL1_PTIMER (1 << 1)163#define KVM_ARM_DEV_PMU (1 << 2)164165/*166* PMU filter structure. Describe a range of events with a particular167* action. To be used with KVM_ARM_VCPU_PMU_V3_FILTER.168*/169struct kvm_pmu_event_filter {170__u16 base_event;171__u16 nevents;172173#define KVM_PMU_EVENT_ALLOW 0174#define KVM_PMU_EVENT_DENY 1175176__u8 action;177__u8 pad[3];178};179180/* for KVM_GET/SET_VCPU_EVENTS */181struct kvm_vcpu_events {182struct {183__u8 serror_pending;184__u8 serror_has_esr;185__u8 ext_dabt_pending;186/* Align it to 8 bytes */187__u8 pad[5];188__u64 serror_esr;189} exception;190__u32 reserved[12];191};192193struct kvm_arm_copy_mte_tags {194__u64 guest_ipa;195__u64 length;196void __user *addr;197__u64 flags;198__u64 reserved[2];199};200201/*202* Counter/Timer offset structure. Describe the virtual/physical offset.203* To be used with KVM_ARM_SET_COUNTER_OFFSET.204*/205struct kvm_arm_counter_offset {206__u64 counter_offset;207__u64 reserved;208};209210#define KVM_ARM_TAGS_TO_GUEST 0211#define KVM_ARM_TAGS_FROM_GUEST 1212213/* If you need to interpret the index values, here is the key: */214#define KVM_REG_ARM_COPROC_MASK 0x000000000FFF0000215#define KVM_REG_ARM_COPROC_SHIFT 16216217/* Normal registers are mapped as coprocessor 16. */218#define KVM_REG_ARM_CORE (0x0010 << KVM_REG_ARM_COPROC_SHIFT)219#define KVM_REG_ARM_CORE_REG(name) (offsetof(struct kvm_regs, name) / sizeof(__u32))220221/* Some registers need more space to represent values. */222#define KVM_REG_ARM_DEMUX (0x0011 << KVM_REG_ARM_COPROC_SHIFT)223#define KVM_REG_ARM_DEMUX_ID_MASK 0x000000000000FF00224#define KVM_REG_ARM_DEMUX_ID_SHIFT 8225#define KVM_REG_ARM_DEMUX_ID_CCSIDR (0x00 << KVM_REG_ARM_DEMUX_ID_SHIFT)226#define KVM_REG_ARM_DEMUX_VAL_MASK 0x00000000000000FF227#define KVM_REG_ARM_DEMUX_VAL_SHIFT 0228229/* AArch64 system registers */230#define KVM_REG_ARM64_SYSREG (0x0013 << KVM_REG_ARM_COPROC_SHIFT)231#define KVM_REG_ARM64_SYSREG_OP0_MASK 0x000000000000c000232#define KVM_REG_ARM64_SYSREG_OP0_SHIFT 14233#define KVM_REG_ARM64_SYSREG_OP1_MASK 0x0000000000003800234#define KVM_REG_ARM64_SYSREG_OP1_SHIFT 11235#define KVM_REG_ARM64_SYSREG_CRN_MASK 0x0000000000000780236#define KVM_REG_ARM64_SYSREG_CRN_SHIFT 7237#define KVM_REG_ARM64_SYSREG_CRM_MASK 0x0000000000000078238#define KVM_REG_ARM64_SYSREG_CRM_SHIFT 3239#define KVM_REG_ARM64_SYSREG_OP2_MASK 0x0000000000000007240#define KVM_REG_ARM64_SYSREG_OP2_SHIFT 0241242#define ARM64_SYS_REG_SHIFT_MASK(x,n) \243(((x) << KVM_REG_ARM64_SYSREG_ ## n ## _SHIFT) & \244KVM_REG_ARM64_SYSREG_ ## n ## _MASK)245246#define __ARM64_SYS_REG(op0,op1,crn,crm,op2) \247(KVM_REG_ARM64 | KVM_REG_ARM64_SYSREG | \248ARM64_SYS_REG_SHIFT_MASK(op0, OP0) | \249ARM64_SYS_REG_SHIFT_MASK(op1, OP1) | \250ARM64_SYS_REG_SHIFT_MASK(crn, CRN) | \251ARM64_SYS_REG_SHIFT_MASK(crm, CRM) | \252ARM64_SYS_REG_SHIFT_MASK(op2, OP2))253254#define ARM64_SYS_REG(...) (__ARM64_SYS_REG(__VA_ARGS__) | KVM_REG_SIZE_U64)255256/* Physical Timer EL0 Registers */257#define KVM_REG_ARM_PTIMER_CTL ARM64_SYS_REG(3, 3, 14, 2, 1)258#define KVM_REG_ARM_PTIMER_CVAL ARM64_SYS_REG(3, 3, 14, 2, 2)259#define KVM_REG_ARM_PTIMER_CNT ARM64_SYS_REG(3, 3, 14, 0, 1)260261/*262* EL0 Virtual Timer Registers263*264* WARNING:265* KVM_REG_ARM_TIMER_CVAL and KVM_REG_ARM_TIMER_CNT are not defined266* with the appropriate register encodings. Their values have been267* accidentally swapped. As this is set API, the definitions here268* must be used, rather than ones derived from the encodings.269*/270#define KVM_REG_ARM_TIMER_CTL ARM64_SYS_REG(3, 3, 14, 3, 1)271#define KVM_REG_ARM_TIMER_CVAL ARM64_SYS_REG(3, 3, 14, 0, 2)272#define KVM_REG_ARM_TIMER_CNT ARM64_SYS_REG(3, 3, 14, 3, 2)273274/* KVM-as-firmware specific pseudo-registers */275#define KVM_REG_ARM_FW (0x0014 << KVM_REG_ARM_COPROC_SHIFT)276#define KVM_REG_ARM_FW_REG(r) (KVM_REG_ARM64 | KVM_REG_SIZE_U64 | \277KVM_REG_ARM_FW | ((r) & 0xffff))278#define KVM_REG_ARM_PSCI_VERSION KVM_REG_ARM_FW_REG(0)279#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_1 KVM_REG_ARM_FW_REG(1)280#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_1_NOT_AVAIL 0281#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_1_AVAIL 1282#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_1_NOT_REQUIRED 2283284/*285* Only two states can be presented by the host kernel:286* - NOT_REQUIRED: the guest doesn't need to do anything287* - NOT_AVAIL: the guest isn't mitigated (it can still use SSBS if available)288*289* All the other values are deprecated. The host still accepts all290* values (they are ABI), but will narrow them to the above two.291*/292#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_2 KVM_REG_ARM_FW_REG(2)293#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_2_NOT_AVAIL 0294#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_2_UNKNOWN 1295#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_2_AVAIL 2296#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_2_NOT_REQUIRED 3297#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_2_ENABLED (1U << 4)298299#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_3 KVM_REG_ARM_FW_REG(3)300#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_3_NOT_AVAIL 0301#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_3_AVAIL 1302#define KVM_REG_ARM_SMCCC_ARCH_WORKAROUND_3_NOT_REQUIRED 2303304/* SVE registers */305#define KVM_REG_ARM64_SVE (0x15 << KVM_REG_ARM_COPROC_SHIFT)306307/* Z- and P-regs occupy blocks at the following offsets within this range: */308#define KVM_REG_ARM64_SVE_ZREG_BASE 0309#define KVM_REG_ARM64_SVE_PREG_BASE 0x400310#define KVM_REG_ARM64_SVE_FFR_BASE 0x600311312#define KVM_ARM64_SVE_NUM_ZREGS __SVE_NUM_ZREGS313#define KVM_ARM64_SVE_NUM_PREGS __SVE_NUM_PREGS314315#define KVM_ARM64_SVE_MAX_SLICES 32316317#define KVM_REG_ARM64_SVE_ZREG(n, i) \318(KVM_REG_ARM64 | KVM_REG_ARM64_SVE | KVM_REG_ARM64_SVE_ZREG_BASE | \319KVM_REG_SIZE_U2048 | \320(((n) & (KVM_ARM64_SVE_NUM_ZREGS - 1)) << 5) | \321((i) & (KVM_ARM64_SVE_MAX_SLICES - 1)))322323#define KVM_REG_ARM64_SVE_PREG(n, i) \324(KVM_REG_ARM64 | KVM_REG_ARM64_SVE | KVM_REG_ARM64_SVE_PREG_BASE | \325KVM_REG_SIZE_U256 | \326(((n) & (KVM_ARM64_SVE_NUM_PREGS - 1)) << 5) | \327((i) & (KVM_ARM64_SVE_MAX_SLICES - 1)))328329#define KVM_REG_ARM64_SVE_FFR(i) \330(KVM_REG_ARM64 | KVM_REG_ARM64_SVE | KVM_REG_ARM64_SVE_FFR_BASE | \331KVM_REG_SIZE_U256 | \332((i) & (KVM_ARM64_SVE_MAX_SLICES - 1)))333334/*335* Register values for KVM_REG_ARM64_SVE_ZREG(), KVM_REG_ARM64_SVE_PREG() and336* KVM_REG_ARM64_SVE_FFR() are represented in memory in an endianness-337* invariant layout which differs from the layout used for the FPSIMD338* V-registers on big-endian systems: see sigcontext.h for more explanation.339*/340341#define KVM_ARM64_SVE_VQ_MIN __SVE_VQ_MIN342#define KVM_ARM64_SVE_VQ_MAX __SVE_VQ_MAX343344/* Vector lengths pseudo-register: */345#define KVM_REG_ARM64_SVE_VLS (KVM_REG_ARM64 | KVM_REG_ARM64_SVE | \346KVM_REG_SIZE_U512 | 0xffff)347#define KVM_ARM64_SVE_VLS_WORDS \348((KVM_ARM64_SVE_VQ_MAX - KVM_ARM64_SVE_VQ_MIN) / 64 + 1)349350/* Bitmap feature firmware registers */351#define KVM_REG_ARM_FW_FEAT_BMAP (0x0016 << KVM_REG_ARM_COPROC_SHIFT)352#define KVM_REG_ARM_FW_FEAT_BMAP_REG(r) (KVM_REG_ARM64 | KVM_REG_SIZE_U64 | \353KVM_REG_ARM_FW_FEAT_BMAP | \354((r) & 0xffff))355356#define KVM_REG_ARM_STD_BMAP KVM_REG_ARM_FW_FEAT_BMAP_REG(0)357358enum {359KVM_REG_ARM_STD_BIT_TRNG_V1_0 = 0,360#ifdef __KERNEL__361KVM_REG_ARM_STD_BMAP_BIT_COUNT,362#endif363};364365#define KVM_REG_ARM_STD_HYP_BMAP KVM_REG_ARM_FW_FEAT_BMAP_REG(1)366367enum {368KVM_REG_ARM_STD_HYP_BIT_PV_TIME = 0,369#ifdef __KERNEL__370KVM_REG_ARM_STD_HYP_BMAP_BIT_COUNT,371#endif372};373374/* Vendor hyper call function numbers 0-63 */375#define KVM_REG_ARM_VENDOR_HYP_BMAP KVM_REG_ARM_FW_FEAT_BMAP_REG(2)376377enum {378KVM_REG_ARM_VENDOR_HYP_BIT_FUNC_FEAT = 0,379KVM_REG_ARM_VENDOR_HYP_BIT_PTP = 1,380#ifdef __KERNEL__381KVM_REG_ARM_VENDOR_HYP_BMAP_BIT_COUNT,382#endif383};384385/* Vendor hyper call function numbers 64-127 */386#define KVM_REG_ARM_VENDOR_HYP_BMAP_2 KVM_REG_ARM_FW_FEAT_BMAP_REG(3)387388enum {389KVM_REG_ARM_VENDOR_HYP_BIT_DISCOVER_IMPL_VER = 0,390KVM_REG_ARM_VENDOR_HYP_BIT_DISCOVER_IMPL_CPUS = 1,391#ifdef __KERNEL__392KVM_REG_ARM_VENDOR_HYP_BMAP_2_BIT_COUNT,393#endif394};395396/* Device Control API on vm fd */397#define KVM_ARM_VM_SMCCC_CTRL 0398#define KVM_ARM_VM_SMCCC_FILTER 0399400/* Device Control API: ARM VGIC */401#define KVM_DEV_ARM_VGIC_GRP_ADDR 0402#define KVM_DEV_ARM_VGIC_GRP_DIST_REGS 1403#define KVM_DEV_ARM_VGIC_GRP_CPU_REGS 2404#define KVM_DEV_ARM_VGIC_CPUID_SHIFT 32405#define KVM_DEV_ARM_VGIC_CPUID_MASK (0xffULL << KVM_DEV_ARM_VGIC_CPUID_SHIFT)406#define KVM_DEV_ARM_VGIC_V3_MPIDR_SHIFT 32407#define KVM_DEV_ARM_VGIC_V3_MPIDR_MASK \408(0xffffffffULL << KVM_DEV_ARM_VGIC_V3_MPIDR_SHIFT)409#define KVM_DEV_ARM_VGIC_OFFSET_SHIFT 0410#define KVM_DEV_ARM_VGIC_OFFSET_MASK (0xffffffffULL << KVM_DEV_ARM_VGIC_OFFSET_SHIFT)411#define KVM_DEV_ARM_VGIC_SYSREG_INSTR_MASK (0xffff)412#define KVM_DEV_ARM_VGIC_GRP_NR_IRQS 3413#define KVM_DEV_ARM_VGIC_GRP_CTRL 4414#define KVM_DEV_ARM_VGIC_GRP_REDIST_REGS 5415#define KVM_DEV_ARM_VGIC_GRP_CPU_SYSREGS 6416#define KVM_DEV_ARM_VGIC_GRP_LEVEL_INFO 7417#define KVM_DEV_ARM_VGIC_GRP_ITS_REGS 8418#define KVM_DEV_ARM_VGIC_GRP_MAINT_IRQ 9419#define KVM_DEV_ARM_VGIC_LINE_LEVEL_INFO_SHIFT 10420#define KVM_DEV_ARM_VGIC_LINE_LEVEL_INFO_MASK \421(0x3fffffULL << KVM_DEV_ARM_VGIC_LINE_LEVEL_INFO_SHIFT)422#define KVM_DEV_ARM_VGIC_LINE_LEVEL_INTID_MASK 0x3ff423#define VGIC_LEVEL_INFO_LINE_LEVEL 0424425#define KVM_DEV_ARM_VGIC_CTRL_INIT 0426#define KVM_DEV_ARM_ITS_SAVE_TABLES 1427#define KVM_DEV_ARM_ITS_RESTORE_TABLES 2428#define KVM_DEV_ARM_VGIC_SAVE_PENDING_TABLES 3429#define KVM_DEV_ARM_ITS_CTRL_RESET 4430431/* Device Control API on vcpu fd */432#define KVM_ARM_VCPU_PMU_V3_CTRL 0433#define KVM_ARM_VCPU_PMU_V3_IRQ 0434#define KVM_ARM_VCPU_PMU_V3_INIT 1435#define KVM_ARM_VCPU_PMU_V3_FILTER 2436#define KVM_ARM_VCPU_PMU_V3_SET_PMU 3437#define KVM_ARM_VCPU_PMU_V3_SET_NR_COUNTERS 4438#define KVM_ARM_VCPU_TIMER_CTRL 1439#define KVM_ARM_VCPU_TIMER_IRQ_VTIMER 0440#define KVM_ARM_VCPU_TIMER_IRQ_PTIMER 1441#define KVM_ARM_VCPU_TIMER_IRQ_HVTIMER 2442#define KVM_ARM_VCPU_TIMER_IRQ_HPTIMER 3443#define KVM_ARM_VCPU_PVTIME_CTRL 2444#define KVM_ARM_VCPU_PVTIME_IPA 0445446/* KVM_IRQ_LINE irq field index values */447#define KVM_ARM_IRQ_VCPU2_SHIFT 28448#define KVM_ARM_IRQ_VCPU2_MASK 0xf449#define KVM_ARM_IRQ_TYPE_SHIFT 24450#define KVM_ARM_IRQ_TYPE_MASK 0xf451#define KVM_ARM_IRQ_VCPU_SHIFT 16452#define KVM_ARM_IRQ_VCPU_MASK 0xff453#define KVM_ARM_IRQ_NUM_SHIFT 0454#define KVM_ARM_IRQ_NUM_MASK 0xffff455456/* irq_type field */457#define KVM_ARM_IRQ_TYPE_CPU 0458#define KVM_ARM_IRQ_TYPE_SPI 1459#define KVM_ARM_IRQ_TYPE_PPI 2460461/* out-of-kernel GIC cpu interrupt injection irq_number field */462#define KVM_ARM_IRQ_CPU_IRQ 0463#define KVM_ARM_IRQ_CPU_FIQ 1464465/*466* This used to hold the highest supported SPI, but it is now obsolete467* and only here to provide source code level compatibility with older468* userland. The highest SPI number can be set via KVM_DEV_ARM_VGIC_GRP_NR_IRQS.469*/470#ifndef __KERNEL__471#define KVM_ARM_IRQ_GIC_MAX 127472#endif473474/* One single KVM irqchip, ie. the VGIC */475#define KVM_NR_IRQCHIPS 1476477/* PSCI interface */478#define KVM_PSCI_FN_BASE 0x95c1ba5e479#define KVM_PSCI_FN(n) (KVM_PSCI_FN_BASE + (n))480481#define KVM_PSCI_FN_CPU_SUSPEND KVM_PSCI_FN(0)482#define KVM_PSCI_FN_CPU_OFF KVM_PSCI_FN(1)483#define KVM_PSCI_FN_CPU_ON KVM_PSCI_FN(2)484#define KVM_PSCI_FN_MIGRATE KVM_PSCI_FN(3)485486#define KVM_PSCI_RET_SUCCESS PSCI_RET_SUCCESS487#define KVM_PSCI_RET_NI PSCI_RET_NOT_SUPPORTED488#define KVM_PSCI_RET_INVAL PSCI_RET_INVALID_PARAMS489#define KVM_PSCI_RET_DENIED PSCI_RET_DENIED490491/* arm64-specific kvm_run::system_event flags */492/*493* Reset caused by a PSCI v1.1 SYSTEM_RESET2 call.494* Valid only when the system event has a type of KVM_SYSTEM_EVENT_RESET.495*/496#define KVM_SYSTEM_EVENT_RESET_FLAG_PSCI_RESET2 (1ULL << 0)497498/*499* Shutdown caused by a PSCI v1.3 SYSTEM_OFF2 call.500* Valid only when the system event has a type of KVM_SYSTEM_EVENT_SHUTDOWN.501*/502#define KVM_SYSTEM_EVENT_SHUTDOWN_FLAG_PSCI_OFF2 (1ULL << 0)503504/* run->fail_entry.hardware_entry_failure_reason codes. */505#define KVM_EXIT_FAIL_ENTRY_CPU_UNSUPPORTED (1ULL << 0)506507enum kvm_smccc_filter_action {508KVM_SMCCC_FILTER_HANDLE = 0,509KVM_SMCCC_FILTER_DENY,510KVM_SMCCC_FILTER_FWD_TO_USER,511512#ifdef __KERNEL__513NR_SMCCC_FILTER_ACTIONS514#endif515};516517struct kvm_smccc_filter {518__u32 base;519__u32 nr_functions;520__u8 action;521__u8 pad[15];522};523524/* arm64-specific KVM_EXIT_HYPERCALL flags */525#define KVM_HYPERCALL_EXIT_SMC (1U << 0)526#define KVM_HYPERCALL_EXIT_16BIT (1U << 1)527528/*529* Get feature ID registers userspace writable mask.530*531* From DDI0487J.a, D19.2.66 ("ID_AA64MMFR2_EL1, AArch64 Memory Model532* Feature Register 2"):533*534* "The Feature ID space is defined as the System register space in535* AArch64 with op0==3, op1=={0, 1, 3}, CRn==0, CRm=={0-7},536* op2=={0-7}."537*538* This covers all currently known R/O registers that indicate539* anything useful feature wise, including the ID registers.540*541* If we ever need to introduce a new range, it will be described as542* such in the range field.543*/544#define KVM_ARM_FEATURE_ID_RANGE_IDX(op0, op1, crn, crm, op2) \545({ \546__u64 __op1 = (op1) & 3; \547__op1 -= (__op1 == 3); \548(__op1 << 6 | ((crm) & 7) << 3 | (op2)); \549})550551#define KVM_ARM_FEATURE_ID_RANGE 0552#define KVM_ARM_FEATURE_ID_RANGE_SIZE (3 * 8 * 8)553554struct reg_mask_range {555__u64 addr; /* Pointer to mask array */556__u32 range; /* Requested range */557__u32 reserved[13];558};559560#endif561562#endif /* __ARM_KVM_H__ */563564565