github.com/nicocha30/gvisor-ligolo@v0.0.0-20230726075806-989fa2c0a413/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  )