Path: blob/master/tools/arch/arm64/include/asm/sysreg.h
26295 views
/* SPDX-License-Identifier: GPL-2.0-only */1/*2* Macros for accessing system registers with older binutils.3*4* Copyright (C) 2014 ARM Ltd.5* Author: Catalin Marinas <[email protected]>6*/78#ifndef __ASM_SYSREG_H9#define __ASM_SYSREG_H1011#include <linux/bits.h>12#include <linux/stringify.h>13#include <linux/kasan-tags.h>1415#include <asm/gpr-num.h>1617/*18* ARMv8 ARM reserves the following encoding for system registers:19* (Ref: ARMv8 ARM, Section: "System instruction class encoding overview",20* C5.2, version:ARM DDI 0487A.f)21* [20-19] : Op022* [18-16] : Op123* [15-12] : CRn24* [11-8] : CRm25* [7-5] : Op226*/27#define Op0_shift 1928#define Op0_mask 0x329#define Op1_shift 1630#define Op1_mask 0x731#define CRn_shift 1232#define CRn_mask 0xf33#define CRm_shift 834#define CRm_mask 0xf35#define Op2_shift 536#define Op2_mask 0x73738#define sys_reg(op0, op1, crn, crm, op2) \39(((op0) << Op0_shift) | ((op1) << Op1_shift) | \40((crn) << CRn_shift) | ((crm) << CRm_shift) | \41((op2) << Op2_shift))4243#define sys_insn sys_reg4445#define sys_reg_Op0(id) (((id) >> Op0_shift) & Op0_mask)46#define sys_reg_Op1(id) (((id) >> Op1_shift) & Op1_mask)47#define sys_reg_CRn(id) (((id) >> CRn_shift) & CRn_mask)48#define sys_reg_CRm(id) (((id) >> CRm_shift) & CRm_mask)49#define sys_reg_Op2(id) (((id) >> Op2_shift) & Op2_mask)5051#ifndef CONFIG_BROKEN_GAS_INST5253#ifdef __ASSEMBLY__54// The space separator is omitted so that __emit_inst(x) can be parsed as55// either an assembler directive or an assembler macro argument.56#define __emit_inst(x) .inst(x)57#else58#define __emit_inst(x) ".inst " __stringify((x)) "\n\t"59#endif6061#else /* CONFIG_BROKEN_GAS_INST */6263#ifndef CONFIG_CPU_BIG_ENDIAN64#define __INSTR_BSWAP(x) (x)65#else /* CONFIG_CPU_BIG_ENDIAN */66#define __INSTR_BSWAP(x) ((((x) << 24) & 0xff000000) | \67(((x) << 8) & 0x00ff0000) | \68(((x) >> 8) & 0x0000ff00) | \69(((x) >> 24) & 0x000000ff))70#endif /* CONFIG_CPU_BIG_ENDIAN */7172#ifdef __ASSEMBLY__73#define __emit_inst(x) .long __INSTR_BSWAP(x)74#else /* __ASSEMBLY__ */75#define __emit_inst(x) ".long " __stringify(__INSTR_BSWAP(x)) "\n\t"76#endif /* __ASSEMBLY__ */7778#endif /* CONFIG_BROKEN_GAS_INST */7980/*81* Instructions for modifying PSTATE fields.82* As per Arm ARM for v8-A, Section "C.5.1.3 op0 == 0b00, architectural hints,83* barriers and CLREX, and PSTATE access", ARM DDI 0487 C.a, system instructions84* for accessing PSTATE fields have the following encoding:85* Op0 = 0, CRn = 486* Op1, Op2 encodes the PSTATE field modified and defines the constraints.87* CRm = Imm4 for the instruction.88* Rt = 0x1f89*/90#define pstate_field(op1, op2) ((op1) << Op1_shift | (op2) << Op2_shift)91#define PSTATE_Imm_shift CRm_shift92#define SET_PSTATE(x, r) __emit_inst(0xd500401f | PSTATE_ ## r | ((!!x) << PSTATE_Imm_shift))9394#define PSTATE_PAN pstate_field(0, 4)95#define PSTATE_UAO pstate_field(0, 3)96#define PSTATE_SSBS pstate_field(3, 1)97#define PSTATE_DIT pstate_field(3, 2)98#define PSTATE_TCO pstate_field(3, 4)99100#define SET_PSTATE_PAN(x) SET_PSTATE((x), PAN)101#define SET_PSTATE_UAO(x) SET_PSTATE((x), UAO)102#define SET_PSTATE_SSBS(x) SET_PSTATE((x), SSBS)103#define SET_PSTATE_DIT(x) SET_PSTATE((x), DIT)104#define SET_PSTATE_TCO(x) SET_PSTATE((x), TCO)105106#define set_pstate_pan(x) asm volatile(SET_PSTATE_PAN(x))107#define set_pstate_uao(x) asm volatile(SET_PSTATE_UAO(x))108#define set_pstate_ssbs(x) asm volatile(SET_PSTATE_SSBS(x))109#define set_pstate_dit(x) asm volatile(SET_PSTATE_DIT(x))110111/* Register-based PAN access, for save/restore purposes */112#define SYS_PSTATE_PAN sys_reg(3, 0, 4, 2, 3)113114#define __SYS_BARRIER_INSN(CRm, op2, Rt) \115__emit_inst(0xd5000000 | sys_insn(0, 3, 3, (CRm), (op2)) | ((Rt) & 0x1f))116117#define SB_BARRIER_INSN __SYS_BARRIER_INSN(0, 7, 31)118119/* Data cache zero operations */120#define SYS_DC_ISW sys_insn(1, 0, 7, 6, 2)121#define SYS_DC_IGSW sys_insn(1, 0, 7, 6, 4)122#define SYS_DC_IGDSW sys_insn(1, 0, 7, 6, 6)123#define SYS_DC_CSW sys_insn(1, 0, 7, 10, 2)124#define SYS_DC_CGSW sys_insn(1, 0, 7, 10, 4)125#define SYS_DC_CGDSW sys_insn(1, 0, 7, 10, 6)126#define SYS_DC_CISW sys_insn(1, 0, 7, 14, 2)127#define SYS_DC_CIGSW sys_insn(1, 0, 7, 14, 4)128#define SYS_DC_CIGDSW sys_insn(1, 0, 7, 14, 6)129130#define SYS_IC_IALLUIS sys_insn(1, 0, 7, 1, 0)131#define SYS_IC_IALLU sys_insn(1, 0, 7, 5, 0)132#define SYS_IC_IVAU sys_insn(1, 3, 7, 5, 1)133134#define SYS_DC_IVAC sys_insn(1, 0, 7, 6, 1)135#define SYS_DC_IGVAC sys_insn(1, 0, 7, 6, 3)136#define SYS_DC_IGDVAC sys_insn(1, 0, 7, 6, 5)137138#define SYS_DC_CVAC sys_insn(1, 3, 7, 10, 1)139#define SYS_DC_CGVAC sys_insn(1, 3, 7, 10, 3)140#define SYS_DC_CGDVAC sys_insn(1, 3, 7, 10, 5)141142#define SYS_DC_CVAU sys_insn(1, 3, 7, 11, 1)143144#define SYS_DC_CVAP sys_insn(1, 3, 7, 12, 1)145#define SYS_DC_CGVAP sys_insn(1, 3, 7, 12, 3)146#define SYS_DC_CGDVAP sys_insn(1, 3, 7, 12, 5)147148#define SYS_DC_CVADP sys_insn(1, 3, 7, 13, 1)149#define SYS_DC_CGVADP sys_insn(1, 3, 7, 13, 3)150#define SYS_DC_CGDVADP sys_insn(1, 3, 7, 13, 5)151152#define SYS_DC_CIVAC sys_insn(1, 3, 7, 14, 1)153#define SYS_DC_CIGVAC sys_insn(1, 3, 7, 14, 3)154#define SYS_DC_CIGDVAC sys_insn(1, 3, 7, 14, 5)155156#define SYS_DC_ZVA sys_insn(1, 3, 7, 4, 1)157#define SYS_DC_GVA sys_insn(1, 3, 7, 4, 3)158#define SYS_DC_GZVA sys_insn(1, 3, 7, 4, 4)159160#define SYS_DC_CIVAPS sys_insn(1, 0, 7, 15, 1)161#define SYS_DC_CIGDVAPS sys_insn(1, 0, 7, 15, 5)162163/*164* Automatically generated definitions for system registers, the165* manual encodings below are in the process of being converted to166* come from here. The header relies on the definition of sys_reg()167* earlier in this file.168*/169#include "asm/sysreg-defs.h"170171/*172* System registers, organised loosely by encoding but grouped together173* where the architected name contains an index. e.g. ID_MMFR<n>_EL1.174*/175#define SYS_SVCR_SMSTOP_SM_EL0 sys_reg(0, 3, 4, 2, 3)176#define SYS_SVCR_SMSTART_SM_EL0 sys_reg(0, 3, 4, 3, 3)177#define SYS_SVCR_SMSTOP_SMZA_EL0 sys_reg(0, 3, 4, 6, 3)178179#define SYS_DBGBVRn_EL1(n) sys_reg(2, 0, 0, n, 4)180#define SYS_DBGBCRn_EL1(n) sys_reg(2, 0, 0, n, 5)181#define SYS_DBGWVRn_EL1(n) sys_reg(2, 0, 0, n, 6)182#define SYS_DBGWCRn_EL1(n) sys_reg(2, 0, 0, n, 7)183#define SYS_MDRAR_EL1 sys_reg(2, 0, 1, 0, 0)184185#define SYS_OSLSR_EL1 sys_reg(2, 0, 1, 1, 4)186#define OSLSR_EL1_OSLM_MASK (BIT(3) | BIT(0))187#define OSLSR_EL1_OSLM_NI 0188#define OSLSR_EL1_OSLM_IMPLEMENTED BIT(3)189#define OSLSR_EL1_OSLK BIT(1)190191#define SYS_OSDLR_EL1 sys_reg(2, 0, 1, 3, 4)192#define SYS_DBGPRCR_EL1 sys_reg(2, 0, 1, 4, 4)193#define SYS_DBGCLAIMSET_EL1 sys_reg(2, 0, 7, 8, 6)194#define SYS_DBGCLAIMCLR_EL1 sys_reg(2, 0, 7, 9, 6)195#define SYS_DBGAUTHSTATUS_EL1 sys_reg(2, 0, 7, 14, 6)196#define SYS_MDCCSR_EL0 sys_reg(2, 3, 0, 1, 0)197#define SYS_DBGDTR_EL0 sys_reg(2, 3, 0, 4, 0)198#define SYS_DBGDTRRX_EL0 sys_reg(2, 3, 0, 5, 0)199#define SYS_DBGDTRTX_EL0 sys_reg(2, 3, 0, 5, 0)200#define SYS_DBGVCR32_EL2 sys_reg(2, 4, 0, 7, 0)201202#define SYS_BRBINF_EL1(n) sys_reg(2, 1, 8, (n & 15), (((n & 16) >> 2) | 0))203#define SYS_BRBINFINJ_EL1 sys_reg(2, 1, 9, 1, 0)204#define SYS_BRBSRC_EL1(n) sys_reg(2, 1, 8, (n & 15), (((n & 16) >> 2) | 1))205#define SYS_BRBSRCINJ_EL1 sys_reg(2, 1, 9, 1, 1)206#define SYS_BRBTGT_EL1(n) sys_reg(2, 1, 8, (n & 15), (((n & 16) >> 2) | 2))207#define SYS_BRBTGTINJ_EL1 sys_reg(2, 1, 9, 1, 2)208#define SYS_BRBTS_EL1 sys_reg(2, 1, 9, 0, 2)209210#define SYS_BRBCR_EL1 sys_reg(2, 1, 9, 0, 0)211#define SYS_BRBFCR_EL1 sys_reg(2, 1, 9, 0, 1)212#define SYS_BRBIDR0_EL1 sys_reg(2, 1, 9, 2, 0)213214#define SYS_TRCITECR_EL1 sys_reg(3, 0, 1, 2, 3)215#define SYS_TRCACATR(m) sys_reg(2, 1, 2, ((m & 7) << 1), (2 | (m >> 3)))216#define SYS_TRCACVR(m) sys_reg(2, 1, 2, ((m & 7) << 1), (0 | (m >> 3)))217#define SYS_TRCAUTHSTATUS sys_reg(2, 1, 7, 14, 6)218#define SYS_TRCAUXCTLR sys_reg(2, 1, 0, 6, 0)219#define SYS_TRCBBCTLR sys_reg(2, 1, 0, 15, 0)220#define SYS_TRCCCCTLR sys_reg(2, 1, 0, 14, 0)221#define SYS_TRCCIDCCTLR0 sys_reg(2, 1, 3, 0, 2)222#define SYS_TRCCIDCCTLR1 sys_reg(2, 1, 3, 1, 2)223#define SYS_TRCCIDCVR(m) sys_reg(2, 1, 3, ((m & 7) << 1), 0)224#define SYS_TRCCLAIMCLR sys_reg(2, 1, 7, 9, 6)225#define SYS_TRCCLAIMSET sys_reg(2, 1, 7, 8, 6)226#define SYS_TRCCNTCTLR(m) sys_reg(2, 1, 0, (4 | (m & 3)), 5)227#define SYS_TRCCNTRLDVR(m) sys_reg(2, 1, 0, (0 | (m & 3)), 5)228#define SYS_TRCCNTVR(m) sys_reg(2, 1, 0, (8 | (m & 3)), 5)229#define SYS_TRCCONFIGR sys_reg(2, 1, 0, 4, 0)230#define SYS_TRCDEVARCH sys_reg(2, 1, 7, 15, 6)231#define SYS_TRCDEVID sys_reg(2, 1, 7, 2, 7)232#define SYS_TRCEVENTCTL0R sys_reg(2, 1, 0, 8, 0)233#define SYS_TRCEVENTCTL1R sys_reg(2, 1, 0, 9, 0)234#define SYS_TRCEXTINSELR(m) sys_reg(2, 1, 0, (8 | (m & 3)), 4)235#define SYS_TRCIDR0 sys_reg(2, 1, 0, 8, 7)236#define SYS_TRCIDR10 sys_reg(2, 1, 0, 2, 6)237#define SYS_TRCIDR11 sys_reg(2, 1, 0, 3, 6)238#define SYS_TRCIDR12 sys_reg(2, 1, 0, 4, 6)239#define SYS_TRCIDR13 sys_reg(2, 1, 0, 5, 6)240#define SYS_TRCIDR1 sys_reg(2, 1, 0, 9, 7)241#define SYS_TRCIDR2 sys_reg(2, 1, 0, 10, 7)242#define SYS_TRCIDR3 sys_reg(2, 1, 0, 11, 7)243#define SYS_TRCIDR4 sys_reg(2, 1, 0, 12, 7)244#define SYS_TRCIDR5 sys_reg(2, 1, 0, 13, 7)245#define SYS_TRCIDR6 sys_reg(2, 1, 0, 14, 7)246#define SYS_TRCIDR7 sys_reg(2, 1, 0, 15, 7)247#define SYS_TRCIDR8 sys_reg(2, 1, 0, 0, 6)248#define SYS_TRCIDR9 sys_reg(2, 1, 0, 1, 6)249#define SYS_TRCIMSPEC(m) sys_reg(2, 1, 0, (m & 7), 7)250#define SYS_TRCITEEDCR sys_reg(2, 1, 0, 2, 1)251#define SYS_TRCOSLSR sys_reg(2, 1, 1, 1, 4)252#define SYS_TRCPRGCTLR sys_reg(2, 1, 0, 1, 0)253#define SYS_TRCQCTLR sys_reg(2, 1, 0, 1, 1)254#define SYS_TRCRSCTLR(m) sys_reg(2, 1, 1, (m & 15), (0 | (m >> 4)))255#define SYS_TRCRSR sys_reg(2, 1, 0, 10, 0)256#define SYS_TRCSEQEVR(m) sys_reg(2, 1, 0, (m & 3), 4)257#define SYS_TRCSEQRSTEVR sys_reg(2, 1, 0, 6, 4)258#define SYS_TRCSEQSTR sys_reg(2, 1, 0, 7, 4)259#define SYS_TRCSSCCR(m) sys_reg(2, 1, 1, (m & 7), 2)260#define SYS_TRCSSCSR(m) sys_reg(2, 1, 1, (8 | (m & 7)), 2)261#define SYS_TRCSSPCICR(m) sys_reg(2, 1, 1, (m & 7), 3)262#define SYS_TRCSTALLCTLR sys_reg(2, 1, 0, 11, 0)263#define SYS_TRCSTATR sys_reg(2, 1, 0, 3, 0)264#define SYS_TRCSYNCPR sys_reg(2, 1, 0, 13, 0)265#define SYS_TRCTRACEIDR sys_reg(2, 1, 0, 0, 1)266#define SYS_TRCTSCTLR sys_reg(2, 1, 0, 12, 0)267#define SYS_TRCVICTLR sys_reg(2, 1, 0, 0, 2)268#define SYS_TRCVIIECTLR sys_reg(2, 1, 0, 1, 2)269#define SYS_TRCVIPCSSCTLR sys_reg(2, 1, 0, 3, 2)270#define SYS_TRCVISSCTLR sys_reg(2, 1, 0, 2, 2)271#define SYS_TRCVMIDCCTLR0 sys_reg(2, 1, 3, 2, 2)272#define SYS_TRCVMIDCCTLR1 sys_reg(2, 1, 3, 3, 2)273#define SYS_TRCVMIDCVR(m) sys_reg(2, 1, 3, ((m & 7) << 1), 1)274275/* ETM */276#define SYS_TRCOSLAR sys_reg(2, 1, 1, 0, 4)277278#define SYS_BRBCR_EL2 sys_reg(2, 4, 9, 0, 0)279280#define SYS_MIDR_EL1 sys_reg(3, 0, 0, 0, 0)281#define SYS_MPIDR_EL1 sys_reg(3, 0, 0, 0, 5)282#define SYS_REVIDR_EL1 sys_reg(3, 0, 0, 0, 6)283284#define SYS_ACTLR_EL1 sys_reg(3, 0, 1, 0, 1)285#define SYS_RGSR_EL1 sys_reg(3, 0, 1, 0, 5)286#define SYS_GCR_EL1 sys_reg(3, 0, 1, 0, 6)287288#define SYS_TCR_EL1 sys_reg(3, 0, 2, 0, 2)289290#define SYS_APIAKEYLO_EL1 sys_reg(3, 0, 2, 1, 0)291#define SYS_APIAKEYHI_EL1 sys_reg(3, 0, 2, 1, 1)292#define SYS_APIBKEYLO_EL1 sys_reg(3, 0, 2, 1, 2)293#define SYS_APIBKEYHI_EL1 sys_reg(3, 0, 2, 1, 3)294295#define SYS_APDAKEYLO_EL1 sys_reg(3, 0, 2, 2, 0)296#define SYS_APDAKEYHI_EL1 sys_reg(3, 0, 2, 2, 1)297#define SYS_APDBKEYLO_EL1 sys_reg(3, 0, 2, 2, 2)298#define SYS_APDBKEYHI_EL1 sys_reg(3, 0, 2, 2, 3)299300#define SYS_APGAKEYLO_EL1 sys_reg(3, 0, 2, 3, 0)301#define SYS_APGAKEYHI_EL1 sys_reg(3, 0, 2, 3, 1)302303#define SYS_SPSR_EL1 sys_reg(3, 0, 4, 0, 0)304#define SYS_ELR_EL1 sys_reg(3, 0, 4, 0, 1)305306#define SYS_ICC_PMR_EL1 sys_reg(3, 0, 4, 6, 0)307308#define SYS_AFSR0_EL1 sys_reg(3, 0, 5, 1, 0)309#define SYS_AFSR1_EL1 sys_reg(3, 0, 5, 1, 1)310#define SYS_ESR_EL1 sys_reg(3, 0, 5, 2, 0)311312#define SYS_ERRIDR_EL1 sys_reg(3, 0, 5, 3, 0)313#define SYS_ERRSELR_EL1 sys_reg(3, 0, 5, 3, 1)314#define SYS_ERXFR_EL1 sys_reg(3, 0, 5, 4, 0)315#define SYS_ERXCTLR_EL1 sys_reg(3, 0, 5, 4, 1)316#define SYS_ERXSTATUS_EL1 sys_reg(3, 0, 5, 4, 2)317#define SYS_ERXADDR_EL1 sys_reg(3, 0, 5, 4, 3)318#define SYS_ERXPFGF_EL1 sys_reg(3, 0, 5, 4, 4)319#define SYS_ERXPFGCTL_EL1 sys_reg(3, 0, 5, 4, 5)320#define SYS_ERXPFGCDN_EL1 sys_reg(3, 0, 5, 4, 6)321#define SYS_ERXMISC0_EL1 sys_reg(3, 0, 5, 5, 0)322#define SYS_ERXMISC1_EL1 sys_reg(3, 0, 5, 5, 1)323#define SYS_ERXMISC2_EL1 sys_reg(3, 0, 5, 5, 2)324#define SYS_ERXMISC3_EL1 sys_reg(3, 0, 5, 5, 3)325#define SYS_TFSR_EL1 sys_reg(3, 0, 5, 6, 0)326#define SYS_TFSRE0_EL1 sys_reg(3, 0, 5, 6, 1)327328#define SYS_PAR_EL1 sys_reg(3, 0, 7, 4, 0)329330#define SYS_PAR_EL1_F BIT(0)331/* When PAR_EL1.F == 1 */332#define SYS_PAR_EL1_FST GENMASK(6, 1)333#define SYS_PAR_EL1_PTW BIT(8)334#define SYS_PAR_EL1_S BIT(9)335#define SYS_PAR_EL1_AssuredOnly BIT(12)336#define SYS_PAR_EL1_TopLevel BIT(13)337#define SYS_PAR_EL1_Overlay BIT(14)338#define SYS_PAR_EL1_DirtyBit BIT(15)339#define SYS_PAR_EL1_F1_IMPDEF GENMASK_ULL(63, 48)340#define SYS_PAR_EL1_F1_RES0 (BIT(7) | BIT(10) | GENMASK_ULL(47, 16))341#define SYS_PAR_EL1_RES1 BIT(11)342/* When PAR_EL1.F == 0 */343#define SYS_PAR_EL1_SH GENMASK_ULL(8, 7)344#define SYS_PAR_EL1_NS BIT(9)345#define SYS_PAR_EL1_F0_IMPDEF BIT(10)346#define SYS_PAR_EL1_NSE BIT(11)347#define SYS_PAR_EL1_PA GENMASK_ULL(51, 12)348#define SYS_PAR_EL1_ATTR GENMASK_ULL(63, 56)349#define SYS_PAR_EL1_F0_RES0 (GENMASK_ULL(6, 1) | GENMASK_ULL(55, 52))350351/*** Statistical Profiling Extension ***/352#define PMSEVFR_EL1_RES0_IMP \353(GENMASK_ULL(47, 32) | GENMASK_ULL(23, 16) | GENMASK_ULL(11, 8) |\354BIT_ULL(6) | BIT_ULL(4) | BIT_ULL(2) | BIT_ULL(0))355#define PMSEVFR_EL1_RES0_V1P1 \356(PMSEVFR_EL1_RES0_IMP & ~(BIT_ULL(18) | BIT_ULL(17) | BIT_ULL(11)))357#define PMSEVFR_EL1_RES0_V1P2 \358(PMSEVFR_EL1_RES0_V1P1 & ~BIT_ULL(6))359360/* Buffer error reporting */361#define PMBSR_EL1_FAULT_FSC_SHIFT PMBSR_EL1_MSS_SHIFT362#define PMBSR_EL1_FAULT_FSC_MASK PMBSR_EL1_MSS_MASK363364#define PMBSR_EL1_BUF_BSC_SHIFT PMBSR_EL1_MSS_SHIFT365#define PMBSR_EL1_BUF_BSC_MASK PMBSR_EL1_MSS_MASK366367#define PMBSR_EL1_BUF_BSC_FULL 0x1UL368369/*** End of Statistical Profiling Extension ***/370371#define TRBSR_EL1_BSC_MASK GENMASK(5, 0)372#define TRBSR_EL1_BSC_SHIFT 0373374#define SYS_PMINTENSET_EL1 sys_reg(3, 0, 9, 14, 1)375#define SYS_PMINTENCLR_EL1 sys_reg(3, 0, 9, 14, 2)376377#define SYS_PMMIR_EL1 sys_reg(3, 0, 9, 14, 6)378379#define SYS_MAIR_EL1 sys_reg(3, 0, 10, 2, 0)380#define SYS_AMAIR_EL1 sys_reg(3, 0, 10, 3, 0)381382#define SYS_VBAR_EL1 sys_reg(3, 0, 12, 0, 0)383#define SYS_DISR_EL1 sys_reg(3, 0, 12, 1, 1)384385#define SYS_ICC_IAR0_EL1 sys_reg(3, 0, 12, 8, 0)386#define SYS_ICC_EOIR0_EL1 sys_reg(3, 0, 12, 8, 1)387#define SYS_ICC_HPPIR0_EL1 sys_reg(3, 0, 12, 8, 2)388#define SYS_ICC_BPR0_EL1 sys_reg(3, 0, 12, 8, 3)389#define SYS_ICC_AP0Rn_EL1(n) sys_reg(3, 0, 12, 8, 4 | n)390#define SYS_ICC_AP0R0_EL1 SYS_ICC_AP0Rn_EL1(0)391#define SYS_ICC_AP0R1_EL1 SYS_ICC_AP0Rn_EL1(1)392#define SYS_ICC_AP0R2_EL1 SYS_ICC_AP0Rn_EL1(2)393#define SYS_ICC_AP0R3_EL1 SYS_ICC_AP0Rn_EL1(3)394#define SYS_ICC_AP1Rn_EL1(n) sys_reg(3, 0, 12, 9, n)395#define SYS_ICC_AP1R0_EL1 SYS_ICC_AP1Rn_EL1(0)396#define SYS_ICC_AP1R1_EL1 SYS_ICC_AP1Rn_EL1(1)397#define SYS_ICC_AP1R2_EL1 SYS_ICC_AP1Rn_EL1(2)398#define SYS_ICC_AP1R3_EL1 SYS_ICC_AP1Rn_EL1(3)399#define SYS_ICC_DIR_EL1 sys_reg(3, 0, 12, 11, 1)400#define SYS_ICC_RPR_EL1 sys_reg(3, 0, 12, 11, 3)401#define SYS_ICC_SGI1R_EL1 sys_reg(3, 0, 12, 11, 5)402#define SYS_ICC_ASGI1R_EL1 sys_reg(3, 0, 12, 11, 6)403#define SYS_ICC_SGI0R_EL1 sys_reg(3, 0, 12, 11, 7)404#define SYS_ICC_IAR1_EL1 sys_reg(3, 0, 12, 12, 0)405#define SYS_ICC_EOIR1_EL1 sys_reg(3, 0, 12, 12, 1)406#define SYS_ICC_HPPIR1_EL1 sys_reg(3, 0, 12, 12, 2)407#define SYS_ICC_BPR1_EL1 sys_reg(3, 0, 12, 12, 3)408#define SYS_ICC_CTLR_EL1 sys_reg(3, 0, 12, 12, 4)409#define SYS_ICC_SRE_EL1 sys_reg(3, 0, 12, 12, 5)410#define SYS_ICC_IGRPEN0_EL1 sys_reg(3, 0, 12, 12, 6)411#define SYS_ICC_IGRPEN1_EL1 sys_reg(3, 0, 12, 12, 7)412413#define SYS_ACCDATA_EL1 sys_reg(3, 0, 13, 0, 5)414415#define SYS_CNTKCTL_EL1 sys_reg(3, 0, 14, 1, 0)416417#define SYS_AIDR_EL1 sys_reg(3, 1, 0, 0, 7)418419#define SYS_RNDR_EL0 sys_reg(3, 3, 2, 4, 0)420#define SYS_RNDRRS_EL0 sys_reg(3, 3, 2, 4, 1)421422#define SYS_PMCR_EL0 sys_reg(3, 3, 9, 12, 0)423#define SYS_PMCNTENSET_EL0 sys_reg(3, 3, 9, 12, 1)424#define SYS_PMCNTENCLR_EL0 sys_reg(3, 3, 9, 12, 2)425#define SYS_PMOVSCLR_EL0 sys_reg(3, 3, 9, 12, 3)426#define SYS_PMSWINC_EL0 sys_reg(3, 3, 9, 12, 4)427#define SYS_PMCEID0_EL0 sys_reg(3, 3, 9, 12, 6)428#define SYS_PMCEID1_EL0 sys_reg(3, 3, 9, 12, 7)429#define SYS_PMCCNTR_EL0 sys_reg(3, 3, 9, 13, 0)430#define SYS_PMXEVTYPER_EL0 sys_reg(3, 3, 9, 13, 1)431#define SYS_PMXEVCNTR_EL0 sys_reg(3, 3, 9, 13, 2)432#define SYS_PMUSERENR_EL0 sys_reg(3, 3, 9, 14, 0)433#define SYS_PMOVSSET_EL0 sys_reg(3, 3, 9, 14, 3)434435#define SYS_TPIDR_EL0 sys_reg(3, 3, 13, 0, 2)436#define SYS_TPIDRRO_EL0 sys_reg(3, 3, 13, 0, 3)437#define SYS_TPIDR2_EL0 sys_reg(3, 3, 13, 0, 5)438439#define SYS_SCXTNUM_EL0 sys_reg(3, 3, 13, 0, 7)440441/* Definitions for system register interface to AMU for ARMv8.4 onwards */442#define SYS_AM_EL0(crm, op2) sys_reg(3, 3, 13, (crm), (op2))443#define SYS_AMCR_EL0 SYS_AM_EL0(2, 0)444#define SYS_AMCFGR_EL0 SYS_AM_EL0(2, 1)445#define SYS_AMCGCR_EL0 SYS_AM_EL0(2, 2)446#define SYS_AMUSERENR_EL0 SYS_AM_EL0(2, 3)447#define SYS_AMCNTENCLR0_EL0 SYS_AM_EL0(2, 4)448#define SYS_AMCNTENSET0_EL0 SYS_AM_EL0(2, 5)449#define SYS_AMCNTENCLR1_EL0 SYS_AM_EL0(3, 0)450#define SYS_AMCNTENSET1_EL0 SYS_AM_EL0(3, 1)451452/*453* Group 0 of activity monitors (architected):454* op0 op1 CRn CRm op2455* Counter: 11 011 1101 010:n<3> n<2:0>456* Type: 11 011 1101 011:n<3> n<2:0>457* n: 0-15458*459* Group 1 of activity monitors (auxiliary):460* op0 op1 CRn CRm op2461* Counter: 11 011 1101 110:n<3> n<2:0>462* Type: 11 011 1101 111:n<3> n<2:0>463* n: 0-15464*/465466#define SYS_AMEVCNTR0_EL0(n) SYS_AM_EL0(4 + ((n) >> 3), (n) & 7)467#define SYS_AMEVTYPER0_EL0(n) SYS_AM_EL0(6 + ((n) >> 3), (n) & 7)468#define SYS_AMEVCNTR1_EL0(n) SYS_AM_EL0(12 + ((n) >> 3), (n) & 7)469#define SYS_AMEVTYPER1_EL0(n) SYS_AM_EL0(14 + ((n) >> 3), (n) & 7)470471/* AMU v1: Fixed (architecturally defined) activity monitors */472#define SYS_AMEVCNTR0_CORE_EL0 SYS_AMEVCNTR0_EL0(0)473#define SYS_AMEVCNTR0_CONST_EL0 SYS_AMEVCNTR0_EL0(1)474#define SYS_AMEVCNTR0_INST_RET_EL0 SYS_AMEVCNTR0_EL0(2)475#define SYS_AMEVCNTR0_MEM_STALL SYS_AMEVCNTR0_EL0(3)476477#define SYS_CNTFRQ_EL0 sys_reg(3, 3, 14, 0, 0)478479#define SYS_CNTPCT_EL0 sys_reg(3, 3, 14, 0, 1)480#define SYS_CNTVCT_EL0 sys_reg(3, 3, 14, 0, 2)481#define SYS_CNTPCTSS_EL0 sys_reg(3, 3, 14, 0, 5)482#define SYS_CNTVCTSS_EL0 sys_reg(3, 3, 14, 0, 6)483484#define SYS_CNTP_TVAL_EL0 sys_reg(3, 3, 14, 2, 0)485#define SYS_CNTP_CTL_EL0 sys_reg(3, 3, 14, 2, 1)486#define SYS_CNTP_CVAL_EL0 sys_reg(3, 3, 14, 2, 2)487488#define SYS_CNTV_TVAL_EL0 sys_reg(3, 3, 14, 3, 0)489#define SYS_CNTV_CTL_EL0 sys_reg(3, 3, 14, 3, 1)490#define SYS_CNTV_CVAL_EL0 sys_reg(3, 3, 14, 3, 2)491492#define SYS_AARCH32_CNTP_TVAL sys_reg(0, 0, 14, 2, 0)493#define SYS_AARCH32_CNTP_CTL sys_reg(0, 0, 14, 2, 1)494#define SYS_AARCH32_CNTPCT sys_reg(0, 0, 0, 14, 0)495#define SYS_AARCH32_CNTVCT sys_reg(0, 1, 0, 14, 0)496#define SYS_AARCH32_CNTP_CVAL sys_reg(0, 2, 0, 14, 0)497#define SYS_AARCH32_CNTPCTSS sys_reg(0, 8, 0, 14, 0)498#define SYS_AARCH32_CNTVCTSS sys_reg(0, 9, 0, 14, 0)499500#define __PMEV_op2(n) ((n) & 0x7)501#define __CNTR_CRm(n) (0x8 | (((n) >> 3) & 0x3))502#define SYS_PMEVCNTSVRn_EL1(n) sys_reg(2, 0, 14, __CNTR_CRm(n), __PMEV_op2(n))503#define SYS_PMEVCNTRn_EL0(n) sys_reg(3, 3, 14, __CNTR_CRm(n), __PMEV_op2(n))504#define __TYPER_CRm(n) (0xc | (((n) >> 3) & 0x3))505#define SYS_PMEVTYPERn_EL0(n) sys_reg(3, 3, 14, __TYPER_CRm(n), __PMEV_op2(n))506507#define SYS_PMCCFILTR_EL0 sys_reg(3, 3, 14, 15, 7)508509#define SYS_SPMCGCRn_EL1(n) sys_reg(2, 0, 9, 13, ((n) & 1))510511#define __SPMEV_op2(n) ((n) & 0x7)512#define __SPMEV_crm(p, n) ((((p) & 7) << 1) | (((n) >> 3) & 1))513#define SYS_SPMEVCNTRn_EL0(n) sys_reg(2, 3, 14, __SPMEV_crm(0b000, n), __SPMEV_op2(n))514#define SYS_SPMEVFILT2Rn_EL0(n) sys_reg(2, 3, 14, __SPMEV_crm(0b011, n), __SPMEV_op2(n))515#define SYS_SPMEVFILTRn_EL0(n) sys_reg(2, 3, 14, __SPMEV_crm(0b010, n), __SPMEV_op2(n))516#define SYS_SPMEVTYPERn_EL0(n) sys_reg(2, 3, 14, __SPMEV_crm(0b001, n), __SPMEV_op2(n))517518#define SYS_VPIDR_EL2 sys_reg(3, 4, 0, 0, 0)519#define SYS_VMPIDR_EL2 sys_reg(3, 4, 0, 0, 5)520521#define SYS_SCTLR_EL2 sys_reg(3, 4, 1, 0, 0)522#define SYS_ACTLR_EL2 sys_reg(3, 4, 1, 0, 1)523#define SYS_SCTLR2_EL2 sys_reg(3, 4, 1, 0, 3)524#define SYS_HCR_EL2 sys_reg(3, 4, 1, 1, 0)525#define SYS_MDCR_EL2 sys_reg(3, 4, 1, 1, 1)526#define SYS_CPTR_EL2 sys_reg(3, 4, 1, 1, 2)527#define SYS_HSTR_EL2 sys_reg(3, 4, 1, 1, 3)528#define SYS_HACR_EL2 sys_reg(3, 4, 1, 1, 7)529530#define SYS_TTBR0_EL2 sys_reg(3, 4, 2, 0, 0)531#define SYS_TTBR1_EL2 sys_reg(3, 4, 2, 0, 1)532#define SYS_TCR_EL2 sys_reg(3, 4, 2, 0, 2)533#define SYS_VTTBR_EL2 sys_reg(3, 4, 2, 1, 0)534#define SYS_VTCR_EL2 sys_reg(3, 4, 2, 1, 2)535536#define SYS_VNCR_EL2 sys_reg(3, 4, 2, 2, 0)537#define SYS_SPSR_EL2 sys_reg(3, 4, 4, 0, 0)538#define SYS_ELR_EL2 sys_reg(3, 4, 4, 0, 1)539#define SYS_SP_EL1 sys_reg(3, 4, 4, 1, 0)540#define SYS_SPSR_irq sys_reg(3, 4, 4, 3, 0)541#define SYS_SPSR_abt sys_reg(3, 4, 4, 3, 1)542#define SYS_SPSR_und sys_reg(3, 4, 4, 3, 2)543#define SYS_SPSR_fiq sys_reg(3, 4, 4, 3, 3)544#define SYS_IFSR32_EL2 sys_reg(3, 4, 5, 0, 1)545#define SYS_AFSR0_EL2 sys_reg(3, 4, 5, 1, 0)546#define SYS_AFSR1_EL2 sys_reg(3, 4, 5, 1, 1)547#define SYS_ESR_EL2 sys_reg(3, 4, 5, 2, 0)548#define SYS_VSESR_EL2 sys_reg(3, 4, 5, 2, 3)549#define SYS_FPEXC32_EL2 sys_reg(3, 4, 5, 3, 0)550#define SYS_TFSR_EL2 sys_reg(3, 4, 5, 6, 0)551552#define SYS_FAR_EL2 sys_reg(3, 4, 6, 0, 0)553#define SYS_HPFAR_EL2 sys_reg(3, 4, 6, 0, 4)554555#define SYS_MAIR_EL2 sys_reg(3, 4, 10, 2, 0)556#define SYS_AMAIR_EL2 sys_reg(3, 4, 10, 3, 0)557558#define SYS_VBAR_EL2 sys_reg(3, 4, 12, 0, 0)559#define SYS_RVBAR_EL2 sys_reg(3, 4, 12, 0, 1)560#define SYS_RMR_EL2 sys_reg(3, 4, 12, 0, 2)561#define SYS_VDISR_EL2 sys_reg(3, 4, 12, 1, 1)562#define __SYS__AP0Rx_EL2(x) sys_reg(3, 4, 12, 8, x)563#define SYS_ICH_AP0R0_EL2 __SYS__AP0Rx_EL2(0)564#define SYS_ICH_AP0R1_EL2 __SYS__AP0Rx_EL2(1)565#define SYS_ICH_AP0R2_EL2 __SYS__AP0Rx_EL2(2)566#define SYS_ICH_AP0R3_EL2 __SYS__AP0Rx_EL2(3)567568#define __SYS__AP1Rx_EL2(x) sys_reg(3, 4, 12, 9, x)569#define SYS_ICH_AP1R0_EL2 __SYS__AP1Rx_EL2(0)570#define SYS_ICH_AP1R1_EL2 __SYS__AP1Rx_EL2(1)571#define SYS_ICH_AP1R2_EL2 __SYS__AP1Rx_EL2(2)572#define SYS_ICH_AP1R3_EL2 __SYS__AP1Rx_EL2(3)573574#define SYS_ICH_VSEIR_EL2 sys_reg(3, 4, 12, 9, 4)575#define SYS_ICC_SRE_EL2 sys_reg(3, 4, 12, 9, 5)576#define SYS_ICH_EISR_EL2 sys_reg(3, 4, 12, 11, 3)577#define SYS_ICH_ELRSR_EL2 sys_reg(3, 4, 12, 11, 5)578#define SYS_ICH_VMCR_EL2 sys_reg(3, 4, 12, 11, 7)579580#define __SYS__LR0_EL2(x) sys_reg(3, 4, 12, 12, x)581#define SYS_ICH_LR0_EL2 __SYS__LR0_EL2(0)582#define SYS_ICH_LR1_EL2 __SYS__LR0_EL2(1)583#define SYS_ICH_LR2_EL2 __SYS__LR0_EL2(2)584#define SYS_ICH_LR3_EL2 __SYS__LR0_EL2(3)585#define SYS_ICH_LR4_EL2 __SYS__LR0_EL2(4)586#define SYS_ICH_LR5_EL2 __SYS__LR0_EL2(5)587#define SYS_ICH_LR6_EL2 __SYS__LR0_EL2(6)588#define SYS_ICH_LR7_EL2 __SYS__LR0_EL2(7)589590#define __SYS__LR8_EL2(x) sys_reg(3, 4, 12, 13, x)591#define SYS_ICH_LR8_EL2 __SYS__LR8_EL2(0)592#define SYS_ICH_LR9_EL2 __SYS__LR8_EL2(1)593#define SYS_ICH_LR10_EL2 __SYS__LR8_EL2(2)594#define SYS_ICH_LR11_EL2 __SYS__LR8_EL2(3)595#define SYS_ICH_LR12_EL2 __SYS__LR8_EL2(4)596#define SYS_ICH_LR13_EL2 __SYS__LR8_EL2(5)597#define SYS_ICH_LR14_EL2 __SYS__LR8_EL2(6)598#define SYS_ICH_LR15_EL2 __SYS__LR8_EL2(7)599600#define SYS_CONTEXTIDR_EL2 sys_reg(3, 4, 13, 0, 1)601#define SYS_TPIDR_EL2 sys_reg(3, 4, 13, 0, 2)602#define SYS_SCXTNUM_EL2 sys_reg(3, 4, 13, 0, 7)603604#define __AMEV_op2(m) (m & 0x7)605#define __AMEV_CRm(n, m) (n | ((m & 0x8) >> 3))606#define __SYS__AMEVCNTVOFF0n_EL2(m) sys_reg(3, 4, 13, __AMEV_CRm(0x8, m), __AMEV_op2(m))607#define SYS_AMEVCNTVOFF0n_EL2(m) __SYS__AMEVCNTVOFF0n_EL2(m)608#define __SYS__AMEVCNTVOFF1n_EL2(m) sys_reg(3, 4, 13, __AMEV_CRm(0xA, m), __AMEV_op2(m))609#define SYS_AMEVCNTVOFF1n_EL2(m) __SYS__AMEVCNTVOFF1n_EL2(m)610611#define SYS_CNTVOFF_EL2 sys_reg(3, 4, 14, 0, 3)612#define SYS_CNTHCTL_EL2 sys_reg(3, 4, 14, 1, 0)613#define SYS_CNTHP_TVAL_EL2 sys_reg(3, 4, 14, 2, 0)614#define SYS_CNTHP_CTL_EL2 sys_reg(3, 4, 14, 2, 1)615#define SYS_CNTHP_CVAL_EL2 sys_reg(3, 4, 14, 2, 2)616#define SYS_CNTHV_TVAL_EL2 sys_reg(3, 4, 14, 3, 0)617#define SYS_CNTHV_CTL_EL2 sys_reg(3, 4, 14, 3, 1)618#define SYS_CNTHV_CVAL_EL2 sys_reg(3, 4, 14, 3, 2)619620/* VHE encodings for architectural EL0/1 system registers */621#define SYS_BRBCR_EL12 sys_reg(2, 5, 9, 0, 0)622#define SYS_TTBR0_EL12 sys_reg(3, 5, 2, 0, 0)623#define SYS_TTBR1_EL12 sys_reg(3, 5, 2, 0, 1)624#define SYS_SPSR_EL12 sys_reg(3, 5, 4, 0, 0)625#define SYS_ELR_EL12 sys_reg(3, 5, 4, 0, 1)626#define SYS_AFSR0_EL12 sys_reg(3, 5, 5, 1, 0)627#define SYS_AFSR1_EL12 sys_reg(3, 5, 5, 1, 1)628#define SYS_ESR_EL12 sys_reg(3, 5, 5, 2, 0)629#define SYS_TFSR_EL12 sys_reg(3, 5, 5, 6, 0)630#define SYS_PMSCR_EL12 sys_reg(3, 5, 9, 9, 0)631#define SYS_MAIR_EL12 sys_reg(3, 5, 10, 2, 0)632#define SYS_AMAIR_EL12 sys_reg(3, 5, 10, 3, 0)633#define SYS_VBAR_EL12 sys_reg(3, 5, 12, 0, 0)634#define SYS_SCXTNUM_EL12 sys_reg(3, 5, 13, 0, 7)635#define SYS_CNTKCTL_EL12 sys_reg(3, 5, 14, 1, 0)636#define SYS_CNTP_TVAL_EL02 sys_reg(3, 5, 14, 2, 0)637#define SYS_CNTP_CTL_EL02 sys_reg(3, 5, 14, 2, 1)638#define SYS_CNTP_CVAL_EL02 sys_reg(3, 5, 14, 2, 2)639#define SYS_CNTV_TVAL_EL02 sys_reg(3, 5, 14, 3, 0)640#define SYS_CNTV_CTL_EL02 sys_reg(3, 5, 14, 3, 1)641#define SYS_CNTV_CVAL_EL02 sys_reg(3, 5, 14, 3, 2)642643#define SYS_SP_EL2 sys_reg(3, 6, 4, 1, 0)644645/* AT instructions */646#define AT_Op0 1647#define AT_CRn 7648649#define OP_AT_S1E1R sys_insn(AT_Op0, 0, AT_CRn, 8, 0)650#define OP_AT_S1E1W sys_insn(AT_Op0, 0, AT_CRn, 8, 1)651#define OP_AT_S1E0R sys_insn(AT_Op0, 0, AT_CRn, 8, 2)652#define OP_AT_S1E0W sys_insn(AT_Op0, 0, AT_CRn, 8, 3)653#define OP_AT_S1E1RP sys_insn(AT_Op0, 0, AT_CRn, 9, 0)654#define OP_AT_S1E1WP sys_insn(AT_Op0, 0, AT_CRn, 9, 1)655#define OP_AT_S1E1A sys_insn(AT_Op0, 0, AT_CRn, 9, 2)656#define OP_AT_S1E2R sys_insn(AT_Op0, 4, AT_CRn, 8, 0)657#define OP_AT_S1E2W sys_insn(AT_Op0, 4, AT_CRn, 8, 1)658#define OP_AT_S12E1R sys_insn(AT_Op0, 4, AT_CRn, 8, 4)659#define OP_AT_S12E1W sys_insn(AT_Op0, 4, AT_CRn, 8, 5)660#define OP_AT_S12E0R sys_insn(AT_Op0, 4, AT_CRn, 8, 6)661#define OP_AT_S12E0W sys_insn(AT_Op0, 4, AT_CRn, 8, 7)662#define OP_AT_S1E2A sys_insn(AT_Op0, 4, AT_CRn, 9, 2)663664/* TLBI instructions */665#define TLBI_Op0 1666667#define TLBI_Op1_EL1 0 /* Accessible from EL1 or higher */668#define TLBI_Op1_EL2 4 /* Accessible from EL2 or higher */669670#define TLBI_CRn_XS 8 /* Extra Slow (the common one) */671#define TLBI_CRn_nXS 9 /* not Extra Slow (which nobody uses)*/672673#define TLBI_CRm_IPAIS 0 /* S2 Inner-Shareable */674#define TLBI_CRm_nROS 1 /* non-Range, Outer-Sharable */675#define TLBI_CRm_RIS 2 /* Range, Inner-Sharable */676#define TLBI_CRm_nRIS 3 /* non-Range, Inner-Sharable */677#define TLBI_CRm_IPAONS 4 /* S2 Outer and Non-Shareable */678#define TLBI_CRm_ROS 5 /* Range, Outer-Sharable */679#define TLBI_CRm_RNS 6 /* Range, Non-Sharable */680#define TLBI_CRm_nRNS 7 /* non-Range, Non-Sharable */681682#define OP_TLBI_VMALLE1OS sys_insn(1, 0, 8, 1, 0)683#define OP_TLBI_VAE1OS sys_insn(1, 0, 8, 1, 1)684#define OP_TLBI_ASIDE1OS sys_insn(1, 0, 8, 1, 2)685#define OP_TLBI_VAAE1OS sys_insn(1, 0, 8, 1, 3)686#define OP_TLBI_VALE1OS sys_insn(1, 0, 8, 1, 5)687#define OP_TLBI_VAALE1OS sys_insn(1, 0, 8, 1, 7)688#define OP_TLBI_RVAE1IS sys_insn(1, 0, 8, 2, 1)689#define OP_TLBI_RVAAE1IS sys_insn(1, 0, 8, 2, 3)690#define OP_TLBI_RVALE1IS sys_insn(1, 0, 8, 2, 5)691#define OP_TLBI_RVAALE1IS sys_insn(1, 0, 8, 2, 7)692#define OP_TLBI_VMALLE1IS sys_insn(1, 0, 8, 3, 0)693#define OP_TLBI_VAE1IS sys_insn(1, 0, 8, 3, 1)694#define OP_TLBI_ASIDE1IS sys_insn(1, 0, 8, 3, 2)695#define OP_TLBI_VAAE1IS sys_insn(1, 0, 8, 3, 3)696#define OP_TLBI_VALE1IS sys_insn(1, 0, 8, 3, 5)697#define OP_TLBI_VAALE1IS sys_insn(1, 0, 8, 3, 7)698#define OP_TLBI_RVAE1OS sys_insn(1, 0, 8, 5, 1)699#define OP_TLBI_RVAAE1OS sys_insn(1, 0, 8, 5, 3)700#define OP_TLBI_RVALE1OS sys_insn(1, 0, 8, 5, 5)701#define OP_TLBI_RVAALE1OS sys_insn(1, 0, 8, 5, 7)702#define OP_TLBI_RVAE1 sys_insn(1, 0, 8, 6, 1)703#define OP_TLBI_RVAAE1 sys_insn(1, 0, 8, 6, 3)704#define OP_TLBI_RVALE1 sys_insn(1, 0, 8, 6, 5)705#define OP_TLBI_RVAALE1 sys_insn(1, 0, 8, 6, 7)706#define OP_TLBI_VMALLE1 sys_insn(1, 0, 8, 7, 0)707#define OP_TLBI_VAE1 sys_insn(1, 0, 8, 7, 1)708#define OP_TLBI_ASIDE1 sys_insn(1, 0, 8, 7, 2)709#define OP_TLBI_VAAE1 sys_insn(1, 0, 8, 7, 3)710#define OP_TLBI_VALE1 sys_insn(1, 0, 8, 7, 5)711#define OP_TLBI_VAALE1 sys_insn(1, 0, 8, 7, 7)712#define OP_TLBI_VMALLE1OSNXS sys_insn(1, 0, 9, 1, 0)713#define OP_TLBI_VAE1OSNXS sys_insn(1, 0, 9, 1, 1)714#define OP_TLBI_ASIDE1OSNXS sys_insn(1, 0, 9, 1, 2)715#define OP_TLBI_VAAE1OSNXS sys_insn(1, 0, 9, 1, 3)716#define OP_TLBI_VALE1OSNXS sys_insn(1, 0, 9, 1, 5)717#define OP_TLBI_VAALE1OSNXS sys_insn(1, 0, 9, 1, 7)718#define OP_TLBI_RVAE1ISNXS sys_insn(1, 0, 9, 2, 1)719#define OP_TLBI_RVAAE1ISNXS sys_insn(1, 0, 9, 2, 3)720#define OP_TLBI_RVALE1ISNXS sys_insn(1, 0, 9, 2, 5)721#define OP_TLBI_RVAALE1ISNXS sys_insn(1, 0, 9, 2, 7)722#define OP_TLBI_VMALLE1ISNXS sys_insn(1, 0, 9, 3, 0)723#define OP_TLBI_VAE1ISNXS sys_insn(1, 0, 9, 3, 1)724#define OP_TLBI_ASIDE1ISNXS sys_insn(1, 0, 9, 3, 2)725#define OP_TLBI_VAAE1ISNXS sys_insn(1, 0, 9, 3, 3)726#define OP_TLBI_VALE1ISNXS sys_insn(1, 0, 9, 3, 5)727#define OP_TLBI_VAALE1ISNXS sys_insn(1, 0, 9, 3, 7)728#define OP_TLBI_RVAE1OSNXS sys_insn(1, 0, 9, 5, 1)729#define OP_TLBI_RVAAE1OSNXS sys_insn(1, 0, 9, 5, 3)730#define OP_TLBI_RVALE1OSNXS sys_insn(1, 0, 9, 5, 5)731#define OP_TLBI_RVAALE1OSNXS sys_insn(1, 0, 9, 5, 7)732#define OP_TLBI_RVAE1NXS sys_insn(1, 0, 9, 6, 1)733#define OP_TLBI_RVAAE1NXS sys_insn(1, 0, 9, 6, 3)734#define OP_TLBI_RVALE1NXS sys_insn(1, 0, 9, 6, 5)735#define OP_TLBI_RVAALE1NXS sys_insn(1, 0, 9, 6, 7)736#define OP_TLBI_VMALLE1NXS sys_insn(1, 0, 9, 7, 0)737#define OP_TLBI_VAE1NXS sys_insn(1, 0, 9, 7, 1)738#define OP_TLBI_ASIDE1NXS sys_insn(1, 0, 9, 7, 2)739#define OP_TLBI_VAAE1NXS sys_insn(1, 0, 9, 7, 3)740#define OP_TLBI_VALE1NXS sys_insn(1, 0, 9, 7, 5)741#define OP_TLBI_VAALE1NXS sys_insn(1, 0, 9, 7, 7)742#define OP_TLBI_IPAS2E1IS sys_insn(1, 4, 8, 0, 1)743#define OP_TLBI_RIPAS2E1IS sys_insn(1, 4, 8, 0, 2)744#define OP_TLBI_IPAS2LE1IS sys_insn(1, 4, 8, 0, 5)745#define OP_TLBI_RIPAS2LE1IS sys_insn(1, 4, 8, 0, 6)746#define OP_TLBI_ALLE2OS sys_insn(1, 4, 8, 1, 0)747#define OP_TLBI_VAE2OS sys_insn(1, 4, 8, 1, 1)748#define OP_TLBI_ALLE1OS sys_insn(1, 4, 8, 1, 4)749#define OP_TLBI_VALE2OS sys_insn(1, 4, 8, 1, 5)750#define OP_TLBI_VMALLS12E1OS sys_insn(1, 4, 8, 1, 6)751#define OP_TLBI_RVAE2IS sys_insn(1, 4, 8, 2, 1)752#define OP_TLBI_RVALE2IS sys_insn(1, 4, 8, 2, 5)753#define OP_TLBI_ALLE2IS sys_insn(1, 4, 8, 3, 0)754#define OP_TLBI_VAE2IS sys_insn(1, 4, 8, 3, 1)755#define OP_TLBI_ALLE1IS sys_insn(1, 4, 8, 3, 4)756#define OP_TLBI_VALE2IS sys_insn(1, 4, 8, 3, 5)757#define OP_TLBI_VMALLS12E1IS sys_insn(1, 4, 8, 3, 6)758#define OP_TLBI_IPAS2E1OS sys_insn(1, 4, 8, 4, 0)759#define OP_TLBI_IPAS2E1 sys_insn(1, 4, 8, 4, 1)760#define OP_TLBI_RIPAS2E1 sys_insn(1, 4, 8, 4, 2)761#define OP_TLBI_RIPAS2E1OS sys_insn(1, 4, 8, 4, 3)762#define OP_TLBI_IPAS2LE1OS sys_insn(1, 4, 8, 4, 4)763#define OP_TLBI_IPAS2LE1 sys_insn(1, 4, 8, 4, 5)764#define OP_TLBI_RIPAS2LE1 sys_insn(1, 4, 8, 4, 6)765#define OP_TLBI_RIPAS2LE1OS sys_insn(1, 4, 8, 4, 7)766#define OP_TLBI_RVAE2OS sys_insn(1, 4, 8, 5, 1)767#define OP_TLBI_RVALE2OS sys_insn(1, 4, 8, 5, 5)768#define OP_TLBI_RVAE2 sys_insn(1, 4, 8, 6, 1)769#define OP_TLBI_RVALE2 sys_insn(1, 4, 8, 6, 5)770#define OP_TLBI_ALLE2 sys_insn(1, 4, 8, 7, 0)771#define OP_TLBI_VAE2 sys_insn(1, 4, 8, 7, 1)772#define OP_TLBI_ALLE1 sys_insn(1, 4, 8, 7, 4)773#define OP_TLBI_VALE2 sys_insn(1, 4, 8, 7, 5)774#define OP_TLBI_VMALLS12E1 sys_insn(1, 4, 8, 7, 6)775#define OP_TLBI_IPAS2E1ISNXS sys_insn(1, 4, 9, 0, 1)776#define OP_TLBI_RIPAS2E1ISNXS sys_insn(1, 4, 9, 0, 2)777#define OP_TLBI_IPAS2LE1ISNXS sys_insn(1, 4, 9, 0, 5)778#define OP_TLBI_RIPAS2LE1ISNXS sys_insn(1, 4, 9, 0, 6)779#define OP_TLBI_ALLE2OSNXS sys_insn(1, 4, 9, 1, 0)780#define OP_TLBI_VAE2OSNXS sys_insn(1, 4, 9, 1, 1)781#define OP_TLBI_ALLE1OSNXS sys_insn(1, 4, 9, 1, 4)782#define OP_TLBI_VALE2OSNXS sys_insn(1, 4, 9, 1, 5)783#define OP_TLBI_VMALLS12E1OSNXS sys_insn(1, 4, 9, 1, 6)784#define OP_TLBI_RVAE2ISNXS sys_insn(1, 4, 9, 2, 1)785#define OP_TLBI_RVALE2ISNXS sys_insn(1, 4, 9, 2, 5)786#define OP_TLBI_ALLE2ISNXS sys_insn(1, 4, 9, 3, 0)787#define OP_TLBI_VAE2ISNXS sys_insn(1, 4, 9, 3, 1)788#define OP_TLBI_ALLE1ISNXS sys_insn(1, 4, 9, 3, 4)789#define OP_TLBI_VALE2ISNXS sys_insn(1, 4, 9, 3, 5)790#define OP_TLBI_VMALLS12E1ISNXS sys_insn(1, 4, 9, 3, 6)791#define OP_TLBI_IPAS2E1OSNXS sys_insn(1, 4, 9, 4, 0)792#define OP_TLBI_IPAS2E1NXS sys_insn(1, 4, 9, 4, 1)793#define OP_TLBI_RIPAS2E1NXS sys_insn(1, 4, 9, 4, 2)794#define OP_TLBI_RIPAS2E1OSNXS sys_insn(1, 4, 9, 4, 3)795#define OP_TLBI_IPAS2LE1OSNXS sys_insn(1, 4, 9, 4, 4)796#define OP_TLBI_IPAS2LE1NXS sys_insn(1, 4, 9, 4, 5)797#define OP_TLBI_RIPAS2LE1NXS sys_insn(1, 4, 9, 4, 6)798#define OP_TLBI_RIPAS2LE1OSNXS sys_insn(1, 4, 9, 4, 7)799#define OP_TLBI_RVAE2OSNXS sys_insn(1, 4, 9, 5, 1)800#define OP_TLBI_RVALE2OSNXS sys_insn(1, 4, 9, 5, 5)801#define OP_TLBI_RVAE2NXS sys_insn(1, 4, 9, 6, 1)802#define OP_TLBI_RVALE2NXS sys_insn(1, 4, 9, 6, 5)803#define OP_TLBI_ALLE2NXS sys_insn(1, 4, 9, 7, 0)804#define OP_TLBI_VAE2NXS sys_insn(1, 4, 9, 7, 1)805#define OP_TLBI_ALLE1NXS sys_insn(1, 4, 9, 7, 4)806#define OP_TLBI_VALE2NXS sys_insn(1, 4, 9, 7, 5)807#define OP_TLBI_VMALLS12E1NXS sys_insn(1, 4, 9, 7, 6)808809/* Misc instructions */810#define OP_GCSPUSHX sys_insn(1, 0, 7, 7, 4)811#define OP_GCSPOPCX sys_insn(1, 0, 7, 7, 5)812#define OP_GCSPOPX sys_insn(1, 0, 7, 7, 6)813#define OP_GCSPUSHM sys_insn(1, 3, 7, 7, 0)814815#define OP_BRB_IALL sys_insn(1, 1, 7, 2, 4)816#define OP_BRB_INJ sys_insn(1, 1, 7, 2, 5)817#define OP_CFP_RCTX sys_insn(1, 3, 7, 3, 4)818#define OP_DVP_RCTX sys_insn(1, 3, 7, 3, 5)819#define OP_COSP_RCTX sys_insn(1, 3, 7, 3, 6)820#define OP_CPP_RCTX sys_insn(1, 3, 7, 3, 7)821822/* Common SCTLR_ELx flags. */823#define SCTLR_ELx_ENTP2 (BIT(60))824#define SCTLR_ELx_DSSBS (BIT(44))825#define SCTLR_ELx_ATA (BIT(43))826827#define SCTLR_ELx_EE_SHIFT 25828#define SCTLR_ELx_ENIA_SHIFT 31829830#define SCTLR_ELx_ITFSB (BIT(37))831#define SCTLR_ELx_ENIA (BIT(SCTLR_ELx_ENIA_SHIFT))832#define SCTLR_ELx_ENIB (BIT(30))833#define SCTLR_ELx_LSMAOE (BIT(29))834#define SCTLR_ELx_nTLSMD (BIT(28))835#define SCTLR_ELx_ENDA (BIT(27))836#define SCTLR_ELx_EE (BIT(SCTLR_ELx_EE_SHIFT))837#define SCTLR_ELx_EIS (BIT(22))838#define SCTLR_ELx_IESB (BIT(21))839#define SCTLR_ELx_TSCXT (BIT(20))840#define SCTLR_ELx_WXN (BIT(19))841#define SCTLR_ELx_ENDB (BIT(13))842#define SCTLR_ELx_I (BIT(12))843#define SCTLR_ELx_EOS (BIT(11))844#define SCTLR_ELx_SA (BIT(3))845#define SCTLR_ELx_C (BIT(2))846#define SCTLR_ELx_A (BIT(1))847#define SCTLR_ELx_M (BIT(0))848849/* SCTLR_EL2 specific flags. */850#define SCTLR_EL2_RES1 ((BIT(4)) | (BIT(5)) | (BIT(11)) | (BIT(16)) | \851(BIT(18)) | (BIT(22)) | (BIT(23)) | (BIT(28)) | \852(BIT(29)))853854#define SCTLR_EL2_BT (BIT(36))855#ifdef CONFIG_CPU_BIG_ENDIAN856#define ENDIAN_SET_EL2 SCTLR_ELx_EE857#else858#define ENDIAN_SET_EL2 0859#endif860861#define INIT_SCTLR_EL2_MMU_ON \862(SCTLR_ELx_M | SCTLR_ELx_C | SCTLR_ELx_SA | SCTLR_ELx_I | \863SCTLR_ELx_IESB | SCTLR_ELx_WXN | ENDIAN_SET_EL2 | \864SCTLR_ELx_ITFSB | SCTLR_EL2_RES1)865866#define INIT_SCTLR_EL2_MMU_OFF \867(SCTLR_EL2_RES1 | ENDIAN_SET_EL2)868869/* SCTLR_EL1 specific flags. */870#ifdef CONFIG_CPU_BIG_ENDIAN871#define ENDIAN_SET_EL1 (SCTLR_EL1_E0E | SCTLR_ELx_EE)872#else873#define ENDIAN_SET_EL1 0874#endif875876#define INIT_SCTLR_EL1_MMU_OFF \877(ENDIAN_SET_EL1 | SCTLR_EL1_LSMAOE | SCTLR_EL1_nTLSMD | \878SCTLR_EL1_EIS | SCTLR_EL1_TSCXT | SCTLR_EL1_EOS)879880#define INIT_SCTLR_EL1_MMU_ON \881(SCTLR_ELx_M | SCTLR_ELx_C | SCTLR_ELx_SA | \882SCTLR_EL1_SA0 | SCTLR_EL1_SED | SCTLR_ELx_I | \883SCTLR_EL1_DZE | SCTLR_EL1_UCT | SCTLR_EL1_nTWE | \884SCTLR_ELx_IESB | SCTLR_EL1_SPAN | SCTLR_ELx_ITFSB | \885ENDIAN_SET_EL1 | SCTLR_EL1_UCI | SCTLR_EL1_EPAN | \886SCTLR_EL1_LSMAOE | SCTLR_EL1_nTLSMD | SCTLR_EL1_EIS | \887SCTLR_EL1_TSCXT | SCTLR_EL1_EOS)888889/* MAIR_ELx memory attributes (used by Linux) */890#define MAIR_ATTR_DEVICE_nGnRnE UL(0x00)891#define MAIR_ATTR_DEVICE_nGnRE UL(0x04)892#define MAIR_ATTR_NORMAL_NC UL(0x44)893#define MAIR_ATTR_NORMAL_TAGGED UL(0xf0)894#define MAIR_ATTR_NORMAL UL(0xff)895#define MAIR_ATTR_MASK UL(0xff)896897/* Position the attr at the correct index */898#define MAIR_ATTRIDX(attr, idx) ((attr) << ((idx) * 8))899900/* id_aa64mmfr0 */901#define ID_AA64MMFR0_EL1_TGRAN4_SUPPORTED_MIN 0x0902#define ID_AA64MMFR0_EL1_TGRAN4_LPA2 ID_AA64MMFR0_EL1_TGRAN4_52_BIT903#define ID_AA64MMFR0_EL1_TGRAN4_SUPPORTED_MAX 0x7904#define ID_AA64MMFR0_EL1_TGRAN64_SUPPORTED_MIN 0x0905#define ID_AA64MMFR0_EL1_TGRAN64_SUPPORTED_MAX 0x7906#define ID_AA64MMFR0_EL1_TGRAN16_SUPPORTED_MIN 0x1907#define ID_AA64MMFR0_EL1_TGRAN16_LPA2 ID_AA64MMFR0_EL1_TGRAN16_52_BIT908#define ID_AA64MMFR0_EL1_TGRAN16_SUPPORTED_MAX 0xf909910#define ARM64_MIN_PARANGE_BITS 32911912#define ID_AA64MMFR0_EL1_TGRAN_2_SUPPORTED_DEFAULT 0x0913#define ID_AA64MMFR0_EL1_TGRAN_2_SUPPORTED_NONE 0x1914#define ID_AA64MMFR0_EL1_TGRAN_2_SUPPORTED_MIN 0x2915#define ID_AA64MMFR0_EL1_TGRAN_2_SUPPORTED_LPA2 0x3916#define ID_AA64MMFR0_EL1_TGRAN_2_SUPPORTED_MAX 0x7917918#ifdef CONFIG_ARM64_PA_BITS_52919#define ID_AA64MMFR0_EL1_PARANGE_MAX ID_AA64MMFR0_EL1_PARANGE_52920#else921#define ID_AA64MMFR0_EL1_PARANGE_MAX ID_AA64MMFR0_EL1_PARANGE_48922#endif923924#if defined(CONFIG_ARM64_4K_PAGES)925#define ID_AA64MMFR0_EL1_TGRAN_SHIFT ID_AA64MMFR0_EL1_TGRAN4_SHIFT926#define ID_AA64MMFR0_EL1_TGRAN_LPA2 ID_AA64MMFR0_EL1_TGRAN4_52_BIT927#define ID_AA64MMFR0_EL1_TGRAN_SUPPORTED_MIN ID_AA64MMFR0_EL1_TGRAN4_SUPPORTED_MIN928#define ID_AA64MMFR0_EL1_TGRAN_SUPPORTED_MAX ID_AA64MMFR0_EL1_TGRAN4_SUPPORTED_MAX929#define ID_AA64MMFR0_EL1_TGRAN_2_SHIFT ID_AA64MMFR0_EL1_TGRAN4_2_SHIFT930#elif defined(CONFIG_ARM64_16K_PAGES)931#define ID_AA64MMFR0_EL1_TGRAN_SHIFT ID_AA64MMFR0_EL1_TGRAN16_SHIFT932#define ID_AA64MMFR0_EL1_TGRAN_LPA2 ID_AA64MMFR0_EL1_TGRAN16_52_BIT933#define ID_AA64MMFR0_EL1_TGRAN_SUPPORTED_MIN ID_AA64MMFR0_EL1_TGRAN16_SUPPORTED_MIN934#define ID_AA64MMFR0_EL1_TGRAN_SUPPORTED_MAX ID_AA64MMFR0_EL1_TGRAN16_SUPPORTED_MAX935#define ID_AA64MMFR0_EL1_TGRAN_2_SHIFT ID_AA64MMFR0_EL1_TGRAN16_2_SHIFT936#elif defined(CONFIG_ARM64_64K_PAGES)937#define ID_AA64MMFR0_EL1_TGRAN_SHIFT ID_AA64MMFR0_EL1_TGRAN64_SHIFT938#define ID_AA64MMFR0_EL1_TGRAN_SUPPORTED_MIN ID_AA64MMFR0_EL1_TGRAN64_SUPPORTED_MIN939#define ID_AA64MMFR0_EL1_TGRAN_SUPPORTED_MAX ID_AA64MMFR0_EL1_TGRAN64_SUPPORTED_MAX940#define ID_AA64MMFR0_EL1_TGRAN_2_SHIFT ID_AA64MMFR0_EL1_TGRAN64_2_SHIFT941#endif942943#define CPACR_EL1_FPEN_EL1EN (BIT(20)) /* enable EL1 access */944#define CPACR_EL1_FPEN_EL0EN (BIT(21)) /* enable EL0 access, if EL1EN set */945946#define CPACR_EL1_SMEN_EL1EN (BIT(24)) /* enable EL1 access */947#define CPACR_EL1_SMEN_EL0EN (BIT(25)) /* enable EL0 access, if EL1EN set */948949#define CPACR_EL1_ZEN_EL1EN (BIT(16)) /* enable EL1 access */950#define CPACR_EL1_ZEN_EL0EN (BIT(17)) /* enable EL0 access, if EL1EN set */951952/* GCR_EL1 Definitions */953#define SYS_GCR_EL1_RRND (BIT(16))954#define SYS_GCR_EL1_EXCL_MASK 0xffffUL955956#ifdef CONFIG_KASAN_HW_TAGS957/*958* KASAN always uses a whole byte for its tags. With CONFIG_KASAN_HW_TAGS it959* only uses tags in the range 0xF0-0xFF, which we map to MTE tags 0x0-0xF.960*/961#define __MTE_TAG_MIN (KASAN_TAG_MIN & 0xf)962#define __MTE_TAG_MAX (KASAN_TAG_MAX & 0xf)963#define __MTE_TAG_INCL GENMASK(__MTE_TAG_MAX, __MTE_TAG_MIN)964#define KERNEL_GCR_EL1_EXCL (SYS_GCR_EL1_EXCL_MASK & ~__MTE_TAG_INCL)965#else966#define KERNEL_GCR_EL1_EXCL SYS_GCR_EL1_EXCL_MASK967#endif968969#define KERNEL_GCR_EL1 (SYS_GCR_EL1_RRND | KERNEL_GCR_EL1_EXCL)970971/* RGSR_EL1 Definitions */972#define SYS_RGSR_EL1_TAG_MASK 0xfUL973#define SYS_RGSR_EL1_SEED_SHIFT 8974#define SYS_RGSR_EL1_SEED_MASK 0xffffUL975976/* TFSR{,E0}_EL1 bit definitions */977#define SYS_TFSR_EL1_TF0_SHIFT 0978#define SYS_TFSR_EL1_TF1_SHIFT 1979#define SYS_TFSR_EL1_TF0 (UL(1) << SYS_TFSR_EL1_TF0_SHIFT)980#define SYS_TFSR_EL1_TF1 (UL(1) << SYS_TFSR_EL1_TF1_SHIFT)981982/* Safe value for MPIDR_EL1: Bit31:RES1, Bit30:U:0, Bit24:MT:0 */983#define SYS_MPIDR_SAFE_VAL (BIT(31))984985/* GIC Hypervisor interface registers */986/* ICH_LR*_EL2 bit definitions */987#define ICH_LR_VIRTUAL_ID_MASK ((1ULL << 32) - 1)988989#define ICH_LR_EOI (1ULL << 41)990#define ICH_LR_GROUP (1ULL << 60)991#define ICH_LR_HW (1ULL << 61)992#define ICH_LR_STATE (3ULL << 62)993#define ICH_LR_PENDING_BIT (1ULL << 62)994#define ICH_LR_ACTIVE_BIT (1ULL << 63)995#define ICH_LR_PHYS_ID_SHIFT 32996#define ICH_LR_PHYS_ID_MASK (0x3ffULL << ICH_LR_PHYS_ID_SHIFT)997#define ICH_LR_PRIORITY_SHIFT 48998#define ICH_LR_PRIORITY_MASK (0xffULL << ICH_LR_PRIORITY_SHIFT)9991000/* ICH_VMCR_EL2 bit definitions */1001#define ICH_VMCR_ACK_CTL_SHIFT 21002#define ICH_VMCR_ACK_CTL_MASK (1 << ICH_VMCR_ACK_CTL_SHIFT)1003#define ICH_VMCR_FIQ_EN_SHIFT 31004#define ICH_VMCR_FIQ_EN_MASK (1 << ICH_VMCR_FIQ_EN_SHIFT)1005#define ICH_VMCR_CBPR_SHIFT 41006#define ICH_VMCR_CBPR_MASK (1 << ICH_VMCR_CBPR_SHIFT)1007#define ICH_VMCR_EOIM_SHIFT 91008#define ICH_VMCR_EOIM_MASK (1 << ICH_VMCR_EOIM_SHIFT)1009#define ICH_VMCR_BPR1_SHIFT 181010#define ICH_VMCR_BPR1_MASK (7 << ICH_VMCR_BPR1_SHIFT)1011#define ICH_VMCR_BPR0_SHIFT 211012#define ICH_VMCR_BPR0_MASK (7 << ICH_VMCR_BPR0_SHIFT)1013#define ICH_VMCR_PMR_SHIFT 241014#define ICH_VMCR_PMR_MASK (0xffUL << ICH_VMCR_PMR_SHIFT)1015#define ICH_VMCR_ENG0_SHIFT 01016#define ICH_VMCR_ENG0_MASK (1 << ICH_VMCR_ENG0_SHIFT)1017#define ICH_VMCR_ENG1_SHIFT 11018#define ICH_VMCR_ENG1_MASK (1 << ICH_VMCR_ENG1_SHIFT)10191020/*1021* Permission Indirection Extension (PIE) permission encodings.1022* Encodings with the _O suffix, have overlays applied (Permission Overlay Extension).1023*/1024#define PIE_NONE_O UL(0x0)1025#define PIE_R_O UL(0x1)1026#define PIE_X_O UL(0x2)1027#define PIE_RX_O UL(0x3)1028#define PIE_RW_O UL(0x5)1029#define PIE_RWnX_O UL(0x6)1030#define PIE_RWX_O UL(0x7)1031#define PIE_R UL(0x8)1032#define PIE_GCS UL(0x9)1033#define PIE_RX UL(0xa)1034#define PIE_RW UL(0xc)1035#define PIE_RWX UL(0xe)1036#define PIE_MASK UL(0xf)10371038#define PIRx_ELx_BITS_PER_IDX 41039#define PIRx_ELx_PERM_SHIFT(idx) ((idx) * PIRx_ELx_BITS_PER_IDX)1040#define PIRx_ELx_PERM_PREP(idx, perm) (((perm) & PIE_MASK) << PIRx_ELx_PERM_SHIFT(idx))10411042/*1043* Permission Overlay Extension (POE) permission encodings.1044*/1045#define POE_NONE UL(0x0)1046#define POE_R UL(0x1)1047#define POE_X UL(0x2)1048#define POE_RX UL(0x3)1049#define POE_W UL(0x4)1050#define POE_RW UL(0x5)1051#define POE_WX UL(0x6)1052#define POE_RWX UL(0x7)1053#define POE_MASK UL(0xf)10541055#define POR_ELx_BITS_PER_IDX 41056#define POR_ELx_PERM_SHIFT(idx) ((idx) * POR_ELx_BITS_PER_IDX)1057#define POR_ELx_PERM_GET(idx, reg) (((reg) >> POR_ELx_PERM_SHIFT(idx)) & POE_MASK)1058#define POR_ELx_PERM_PREP(idx, perm) (((perm) & POE_MASK) << POR_ELx_PERM_SHIFT(idx))10591060/*1061* Definitions for Guarded Control Stack1062*/10631064#define GCS_CAP_ADDR_MASK GENMASK(63, 12)1065#define GCS_CAP_ADDR_SHIFT 121066#define GCS_CAP_ADDR_WIDTH 521067#define GCS_CAP_ADDR(x) FIELD_GET(GCS_CAP_ADDR_MASK, x)10681069#define GCS_CAP_TOKEN_MASK GENMASK(11, 0)1070#define GCS_CAP_TOKEN_SHIFT 01071#define GCS_CAP_TOKEN_WIDTH 121072#define GCS_CAP_TOKEN(x) FIELD_GET(GCS_CAP_TOKEN_MASK, x)10731074#define GCS_CAP_VALID_TOKEN 0x11075#define GCS_CAP_IN_PROGRESS_TOKEN 0x510761077#define GCS_CAP(x) ((((unsigned long)x) & GCS_CAP_ADDR_MASK) | \1078GCS_CAP_VALID_TOKEN)10791080#define ARM64_FEATURE_FIELD_BITS 410811082#ifdef __ASSEMBLY__10831084.macro mrs_s, rt, sreg1085__emit_inst(0xd5200000|(\sreg)|(.L__gpr_num_\rt))1086.endm10871088.macro msr_s, sreg, rt1089__emit_inst(0xd5000000|(\sreg)|(.L__gpr_num_\rt))1090.endm10911092#else10931094#include <linux/bitfield.h>1095#include <linux/build_bug.h>1096#include <linux/types.h>1097#include <asm/alternative.h>10981099#define DEFINE_MRS_S \1100__DEFINE_ASM_GPR_NUMS \1101" .macro mrs_s, rt, sreg\n" \1102__emit_inst(0xd5200000|(\\sreg)|(.L__gpr_num_\\rt)) \1103" .endm\n"11041105#define DEFINE_MSR_S \1106__DEFINE_ASM_GPR_NUMS \1107" .macro msr_s, sreg, rt\n" \1108__emit_inst(0xd5000000|(\\sreg)|(.L__gpr_num_\\rt)) \1109" .endm\n"11101111#define UNDEFINE_MRS_S \1112" .purgem mrs_s\n"11131114#define UNDEFINE_MSR_S \1115" .purgem msr_s\n"11161117#define __mrs_s(v, r) \1118DEFINE_MRS_S \1119" mrs_s " v ", " __stringify(r) "\n" \1120UNDEFINE_MRS_S11211122#define __msr_s(r, v) \1123DEFINE_MSR_S \1124" msr_s " __stringify(r) ", " v "\n" \1125UNDEFINE_MSR_S11261127/*1128* Unlike read_cpuid, calls to read_sysreg are never expected to be1129* optimized away or replaced with synthetic values.1130*/1131#define read_sysreg(r) ({ \1132u64 __val; \1133asm volatile("mrs %0, " __stringify(r) : "=r" (__val)); \1134__val; \1135})11361137/*1138* The "Z" constraint normally means a zero immediate, but when combined with1139* the "%x0" template means XZR.1140*/1141#define write_sysreg(v, r) do { \1142u64 __val = (u64)(v); \1143asm volatile("msr " __stringify(r) ", %x0" \1144: : "rZ" (__val)); \1145} while (0)11461147/*1148* For registers without architectural names, or simply unsupported by1149* GAS.1150*1151* __check_r forces warnings to be generated by the compiler when1152* evaluating r which wouldn't normally happen due to being passed to1153* the assembler via __stringify(r).1154*/1155#define read_sysreg_s(r) ({ \1156u64 __val; \1157u32 __maybe_unused __check_r = (u32)(r); \1158asm volatile(__mrs_s("%0", r) : "=r" (__val)); \1159__val; \1160})11611162#define write_sysreg_s(v, r) do { \1163u64 __val = (u64)(v); \1164u32 __maybe_unused __check_r = (u32)(r); \1165asm volatile(__msr_s(r, "%x0") : : "rZ" (__val)); \1166} while (0)11671168/*1169* Modify bits in a sysreg. Bits in the clear mask are zeroed, then bits in the1170* set mask are set. Other bits are left as-is.1171*/1172#define sysreg_clear_set(sysreg, clear, set) do { \1173u64 __scs_val = read_sysreg(sysreg); \1174u64 __scs_new = (__scs_val & ~(u64)(clear)) | (set); \1175if (__scs_new != __scs_val) \1176write_sysreg(__scs_new, sysreg); \1177} while (0)11781179#define sysreg_clear_set_s(sysreg, clear, set) do { \1180u64 __scs_val = read_sysreg_s(sysreg); \1181u64 __scs_new = (__scs_val & ~(u64)(clear)) | (set); \1182if (__scs_new != __scs_val) \1183write_sysreg_s(__scs_new, sysreg); \1184} while (0)11851186#define read_sysreg_par() ({ \1187u64 par; \1188asm(ALTERNATIVE("nop", "dmb sy", ARM64_WORKAROUND_1508412)); \1189par = read_sysreg(par_el1); \1190asm(ALTERNATIVE("nop", "dmb sy", ARM64_WORKAROUND_1508412)); \1191par; \1192})11931194#define SYS_FIELD_VALUE(reg, field, val) reg##_##field##_##val11951196#define SYS_FIELD_GET(reg, field, val) \1197FIELD_GET(reg##_##field##_MASK, val)11981199#define SYS_FIELD_PREP(reg, field, val) \1200FIELD_PREP(reg##_##field##_MASK, val)12011202#define SYS_FIELD_PREP_ENUM(reg, field, val) \1203FIELD_PREP(reg##_##field##_MASK, \1204SYS_FIELD_VALUE(reg, field, val))12051206#endif12071208#endif /* __ASM_SYSREG_H */120912101211