github.com/ttpreport/gvisor-ligolo@v0.0.0-20240123134145-a858404967ba/pkg/sentry/platform/kvm/kvm_const_arm64.go (about) 1 // Copyright 2019 The gVisor Authors. 2 // 3 // Licensed under the Apache License, Version 2.0 (the "License"); 4 // you may not use this file except in compliance with the License. 5 // You may obtain a copy of the License at 6 // 7 // http://www.apache.org/licenses/LICENSE-2.0 8 // 9 // Unless required by applicable law or agreed to in writing, software 10 // distributed under the License is distributed on an "AS IS" BASIS, 11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 // See the License for the specific language governing permissions and 13 // limitations under the License. 14 15 package kvm 16 17 // KVM ioctls for Arm64. 18 const ( 19 _KVM_GET_ONE_REG = 0x4010aeab 20 _KVM_SET_ONE_REG = 0x4010aeac 21 22 _KVM_ARM_TARGET_GENERIC_V8 = 5 23 _KVM_ARM_PREFERRED_TARGET = 0x8020aeaf 24 _KVM_ARM_VCPU_INIT = 0x4020aeae 25 _KVM_ARM64_REGS_PSTATE = 0x6030000000100042 26 _KVM_ARM64_REGS_SP_EL1 = 0x6030000000100044 27 _KVM_ARM64_REGS_R0 = 0x6030000000100000 28 _KVM_ARM64_REGS_R1 = 0x6030000000100002 29 _KVM_ARM64_REGS_R2 = 0x6030000000100004 30 _KVM_ARM64_REGS_R3 = 0x6030000000100006 31 _KVM_ARM64_REGS_R8 = 0x6030000000100010 32 _KVM_ARM64_REGS_R18 = 0x6030000000100024 33 _KVM_ARM64_REGS_PC = 0x6030000000100040 34 _KVM_ARM64_REGS_MAIR_EL1 = 0x603000000013c510 35 _KVM_ARM64_REGS_TCR_EL1 = 0x603000000013c102 36 _KVM_ARM64_REGS_TTBR0_EL1 = 0x603000000013c100 37 _KVM_ARM64_REGS_TTBR1_EL1 = 0x603000000013c101 38 _KVM_ARM64_REGS_SCTLR_EL1 = 0x603000000013c080 39 _KVM_ARM64_REGS_CPACR_EL1 = 0x603000000013c082 40 _KVM_ARM64_REGS_VBAR_EL1 = 0x603000000013c600 41 _KVM_ARM64_REGS_TIMER_CNT = 0x603000000013df1a 42 _KVM_ARM64_REGS_CNTFRQ_EL0 = 0x603000000013df00 43 44 _KVM_ARM64_REGS_MDSCR_EL1 = 0x6030000000138012 45 _KVM_ARM64_REGS_CNTKCTL_EL1 = 0x603000000013c708 46 _KVM_ARM64_REGS_TPIDR_EL1 = 0x603000000013c684 47 ) 48 49 // Arm64: Architectural Feature Access Control Register EL1. 50 const ( 51 _FPEN_NOTRAP = 3 52 _FPEN_SHIFT = 20 53 ) 54 55 // Arm64: System Control Register EL1. 56 const ( 57 _SCTLR_M = 1 << 0 58 _SCTLR_C = 1 << 2 59 _SCTLR_I = 1 << 12 60 _SCTLR_DZE = 1 << 14 61 _SCTLR_UCT = 1 << 15 62 _SCTLR_UCI = 1 << 26 63 _SCTLR_EL1_DEFAULT = _SCTLR_M | _SCTLR_C | _SCTLR_I | _SCTLR_UCT | _SCTLR_UCI | _SCTLR_DZE 64 ) 65 66 // Arm64: Counter-timer Kernel Control Register el1. 67 const ( 68 _CNTKCTL_EL0PCTEN = 1 << 0 69 _CNTKCTL_EL0VCTEN = 1 << 1 70 71 _CNTKCTL_EL1_DEFAULT = _CNTKCTL_EL0PCTEN | _CNTKCTL_EL0VCTEN 72 ) 73 74 // Arm64: Translation Control Register EL1. 75 const ( 76 _TCR_IPS_40BITS = 2 << 32 // PA=40 77 _TCR_IPS_48BITS = 5 << 32 // PA=48 78 79 _TCR_T0SZ_OFFSET = 0 80 _TCR_T1SZ_OFFSET = 16 81 _TCR_IRGN0_SHIFT = 8 82 _TCR_IRGN1_SHIFT = 24 83 _TCR_ORGN0_SHIFT = 10 84 _TCR_ORGN1_SHIFT = 26 85 _TCR_SH0_SHIFT = 12 86 _TCR_SH1_SHIFT = 28 87 _TCR_TG0_SHIFT = 14 88 _TCR_TG1_SHIFT = 30 89 90 _TCR_T0SZ_VA48 = 64 - 48 // VA=48 91 _TCR_T1SZ_VA48 = 64 - 48 // VA=48 92 93 _TCR_A1 = 1 << 22 94 _TCR_ASID16 = 1 << 36 95 _TCR_TBI0 = 1 << 37 96 97 _TCR_TXSZ_VA48 = (_TCR_T0SZ_VA48 << _TCR_T0SZ_OFFSET) | (_TCR_T1SZ_VA48 << _TCR_T1SZ_OFFSET) 98 99 _TCR_TG0_4K = 0 << _TCR_TG0_SHIFT // 4K 100 _TCR_TG0_64K = 1 << _TCR_TG0_SHIFT // 64K 101 102 _TCR_TG1_4K = 2 << _TCR_TG1_SHIFT 103 104 _TCR_TG_FLAGS = _TCR_TG0_4K | _TCR_TG1_4K 105 106 _TCR_IRGN0_WBWA = 1 << _TCR_IRGN0_SHIFT 107 _TCR_IRGN1_WBWA = 1 << _TCR_IRGN1_SHIFT 108 _TCR_IRGN_WBWA = _TCR_IRGN0_WBWA | _TCR_IRGN1_WBWA 109 110 _TCR_ORGN0_WBWA = 1 << _TCR_ORGN0_SHIFT 111 _TCR_ORGN1_WBWA = 1 << _TCR_ORGN1_SHIFT 112 113 _TCR_ORGN_WBWA = _TCR_ORGN0_WBWA | _TCR_ORGN1_WBWA 114 115 _TCR_SHARED = (3 << _TCR_SH0_SHIFT) | (3 << _TCR_SH1_SHIFT) 116 117 _TCR_CACHE_FLAGS = _TCR_IRGN_WBWA | _TCR_ORGN_WBWA 118 ) 119 120 // Arm64: Memory Attribute Indirection Register EL1. 121 const ( 122 _MT_DEVICE_nGnRnE = 0 123 _MT_DEVICE_nGnRE = 1 124 _MT_DEVICE_GRE = 2 125 _MT_NORMAL_NC = 3 126 _MT_NORMAL = 4 127 _MT_NORMAL_WT = 5 128 _MT_ATTR_DEVICE_nGnRnE = 0x00 129 _MT_ATTR_DEVICE_nGnRE = 0x04 130 _MT_ATTR_DEVICE_GRE = 0x0c 131 _MT_ATTR_NORMAL_NC = 0x44 132 _MT_ATTR_NORMAL_WT = 0xbb 133 _MT_ATTR_NORMAL = 0xff 134 _MT_ATTR_MASK = 0xff 135 _MT_EL1_INIT = (_MT_ATTR_DEVICE_nGnRnE << (_MT_DEVICE_nGnRnE * 8)) | (_MT_ATTR_DEVICE_nGnRE << (_MT_DEVICE_nGnRE * 8)) | (_MT_ATTR_DEVICE_GRE << (_MT_DEVICE_GRE * 8)) | (_MT_ATTR_NORMAL_NC << (_MT_NORMAL_NC * 8)) | (_MT_ATTR_NORMAL << (_MT_NORMAL * 8)) | (_MT_ATTR_NORMAL_WT << (_MT_NORMAL_WT * 8)) 136 ) 137 138 const ( 139 _KVM_ARM_VCPU_POWER_OFF = 0 // CPU is started in OFF state 140 _KVM_ARM_VCPU_PSCI_0_2 = 2 // CPU uses PSCI v0.2 141 ) 142 143 // Arm64: Exception Syndrome Register EL1. 144 const ( 145 _ESR_ELx_EC_SHIFT = 26 146 _ESR_ELx_EC_MASK = 0x3F << _ESR_ELx_EC_SHIFT 147 148 _ESR_ELx_EC_IMP_DEF = 0x1f 149 _ESR_ELx_EC_IABT_LOW = 0x20 150 _ESR_ELx_EC_IABT_CUR = 0x21 151 _ESR_ELx_EC_PC_ALIGN = 0x22 152 153 _ESR_ELx_CM = 1 << 8 154 _ESR_ELx_WNR = 1 << 6 155 156 _ESR_ELx_FSC = 0x3F 157 158 _ESR_SEGV_MAPERR_L0 = 0x4 159 _ESR_SEGV_MAPERR_L1 = 0x5 160 _ESR_SEGV_MAPERR_L2 = 0x6 161 _ESR_SEGV_MAPERR_L3 = 0x7 162 163 _ESR_SEGV_ACCERR_L1 = 0x9 164 _ESR_SEGV_ACCERR_L2 = 0xa 165 _ESR_SEGV_ACCERR_L3 = 0xb 166 167 _ESR_SEGV_PEMERR_L1 = 0xd 168 _ESR_SEGV_PEMERR_L2 = 0xe 169 _ESR_SEGV_PEMERR_L3 = 0xf 170 171 // Custom ISS field definitions for system error. 172 _ESR_ELx_SERR_NMI = 0x1 173 ) 174 175 // Arm64: MMIO base address used to dispatch hypercalls. 176 const ( 177 // on Arm64, the MMIO address must be 64-bit aligned. 178 // Currently, we only need 1 hypercall: hypercall_vmexit. 179 _AARCH64_HYPERCALL_MMIO_SIZE = 1 << 3 180 )