Package arm64
Overview ▸
Index ▸
Constants
const ( NSNAME = 8 NSYM = 50 NREG = 32 /* number of general registers */ NFREG = 32 /* number of floating point registers */ )
General purpose registers, kept in the low bits of Prog.Reg.
const ( // integer REG_R0 = obj.RBaseARM64 + iota REG_R1 REG_R2 REG_R3 REG_R4 REG_R5 REG_R6 REG_R7 REG_R8 REG_R9 REG_R10 REG_R11 REG_R12 REG_R13 REG_R14 REG_R15 REG_R16 REG_R17 REG_R18 REG_R19 REG_R20 REG_R21 REG_R22 REG_R23 REG_R24 REG_R25 REG_R26 REG_R27 REG_R28 REG_R29 REG_R30 REG_R31 // scalar floating point REG_F0 REG_F1 REG_F2 REG_F3 REG_F4 REG_F5 REG_F6 REG_F7 REG_F8 REG_F9 REG_F10 REG_F11 REG_F12 REG_F13 REG_F14 REG_F15 REG_F16 REG_F17 REG_F18 REG_F19 REG_F20 REG_F21 REG_F22 REG_F23 REG_F24 REG_F25 REG_F26 REG_F27 REG_F28 REG_F29 REG_F30 REG_F31 // SIMD REG_V0 REG_V1 REG_V2 REG_V3 REG_V4 REG_V5 REG_V6 REG_V7 REG_V8 REG_V9 REG_V10 REG_V11 REG_V12 REG_V13 REG_V14 REG_V15 REG_V16 REG_V17 REG_V18 REG_V19 REG_V20 REG_V21 REG_V22 REG_V23 REG_V24 REG_V25 REG_V26 REG_V27 REG_V28 REG_V29 REG_V30 REG_V31 REG_RSP = REG_V31 + 32 // to differentiate ZR/SP, REG_RSP&0x1f = 31 )
bits 0-4 indicates register: Vn bits 5-8 indicates arrangement: <T>
const ( REG_ARNG = obj.RBaseARM64 + 1<<10 + iota<<9 // Vn.<T> REG_ELEM // Vn.<T>[index] REG_ELEM_END )
const ( REG_UXTB = REG_EXT + iota<<8 REG_UXTH REG_UXTW REG_UXTX REG_SXTB REG_SXTH REG_SXTW REG_SXTX )
Register assignments:
compiler allocates R0 up as temps compiler allocates register variables R7-R25 compiler allocates external registers R26 down
compiler allocates register variables F7-F26 compiler allocates external registers F26 down
const ( REGMIN = REG_R7 // register variables allocated from here to REGMAX REGRT1 = REG_R16 // ARM64 IP0, external linker may use as a scratch register in trampoline REGRT2 = REG_R17 // ARM64 IP1, external linker may use as a scratch register in trampoline REGPR = REG_R18 // ARM64 platform register, unused in the Go toolchain REGMAX = REG_R25 REGCTXT = REG_R26 // environment for closures REGTMP = REG_R27 // reserved for liblink REGG = REG_R28 // G REGFP = REG_R29 // frame pointer REGLINK = REG_R30 // ARM64 uses R31 as both stack pointer and zero register, // depending on the instruction. To differentiate RSP from ZR, // we use a different numeric value for REGZERO and REGSP. REGZERO = REG_R31 REGSP = REG_RSP FREGRET = REG_F0 FREGMIN = REG_F7 // first register variable FREGMAX = REG_F26 // last register variable for 7g only FREGEXT = REG_F26 // first external register )
const ( /* mark flags */ LABEL = 1 << iota LEAF FLOAT BRANCH LOAD FCMP SYNC LIST FOLL NOSCHED )
const ( // optab is sorted based on the order of these constants // and the first match is chosen. // The more specific class needs to come earlier. C_NONE = iota + 1 // starting from 1, leave unclassified Addr's class as 0 C_REG // R0..R30 C_ZREG // R0..R30, ZR C_RSP // R0..R30, RSP C_FREG // F0..F31 C_VREG // V0..V31 C_PAIR // (Rn, Rm) C_SHIFT // Rn<<2 C_EXTREG // Rn.UXTB[<<3] C_SPR // REG_NZCV C_COND // condition code, EQ, NE, etc. C_SPOP // special operand, PLDL1KEEP, VMALLE1IS, etc. C_ARNG // Vn.<T> C_ELEM // Vn.<T>[index] C_LIST // [V1, V2, V3] C_ZCON // $0 C_ABCON0 // could be C_ADDCON0 or C_BITCON C_ADDCON0 // 12-bit unsigned, unshifted C_ABCON // could be C_ADDCON or C_BITCON C_AMCON // could be C_ADDCON or C_MOVCON C_ADDCON // 12-bit unsigned, shifted left by 0 or 12 C_MBCON // could be C_MOVCON or C_BITCON C_MOVCON // generated by a 16-bit constant, optionally inverted and/or shifted by multiple of 16 C_BITCON // bitfield and logical immediate masks C_ADDCON2 // 24-bit constant C_LCON // 32-bit constant C_MOVCON2 // a constant that can be loaded with one MOVZ/MOVN and one MOVK C_MOVCON3 // a constant that can be loaded with one MOVZ/MOVN and two MOVKs C_VCON // 64-bit constant C_FCON // floating-point constant C_VCONADDR // 64-bit memory address C_AACON // ADDCON offset in auto constant $a(FP) C_AACON2 // 24-bit offset in auto constant $a(FP) C_LACON // 32-bit offset in auto constant $a(FP) C_AECON // ADDCON offset in extern constant $e(SB) // TODO(aram): only one branch class should be enough C_SBRA // for TYPE_BRANCH C_LBRA C_ZAUTO // 0(RSP) C_NSAUTO_16 // -256 <= x < 0, 0 mod 16 C_NSAUTO_8 // -256 <= x < 0, 0 mod 8 C_NSAUTO_4 // -256 <= x < 0, 0 mod 4 C_NSAUTO // -256 <= x < 0 C_NPAUTO_16 // -512 <= x < 0, 0 mod 16 C_NPAUTO // -512 <= x < 0, 0 mod 8 C_NQAUTO_16 // -1024 <= x < 0, 0 mod 16 C_NAUTO4K // -4095 <= x < 0 C_PSAUTO_16 // 0 to 255, 0 mod 16 C_PSAUTO_8 // 0 to 255, 0 mod 8 C_PSAUTO_4 // 0 to 255, 0 mod 4 C_PSAUTO // 0 to 255 C_PPAUTO_16 // 0 to 504, 0 mod 16 C_PPAUTO // 0 to 504, 0 mod 8 C_PQAUTO_16 // 0 to 1008, 0 mod 16 C_UAUTO4K_16 // 0 to 4095, 0 mod 16 C_UAUTO4K_8 // 0 to 4095, 0 mod 8 C_UAUTO4K_4 // 0 to 4095, 0 mod 4 C_UAUTO4K_2 // 0 to 4095, 0 mod 2 C_UAUTO4K // 0 to 4095 C_UAUTO8K_16 // 0 to 8190, 0 mod 16 C_UAUTO8K_8 // 0 to 8190, 0 mod 8 C_UAUTO8K_4 // 0 to 8190, 0 mod 4 C_UAUTO8K // 0 to 8190, 0 mod 2 + C_PSAUTO C_UAUTO16K_16 // 0 to 16380, 0 mod 16 C_UAUTO16K_8 // 0 to 16380, 0 mod 8 C_UAUTO16K // 0 to 16380, 0 mod 4 + C_PSAUTO C_UAUTO32K_16 // 0 to 32760, 0 mod 16 + C_PSAUTO C_UAUTO32K // 0 to 32760, 0 mod 8 + C_PSAUTO C_UAUTO64K // 0 to 65520, 0 mod 16 + C_PSAUTO C_LAUTOPOOL // any other constant up to 64 bits (needs pool literal) C_LAUTO // any other constant up to 64 bits C_SEXT1 // 0 to 4095, direct C_SEXT2 // 0 to 8190 C_SEXT4 // 0 to 16380 C_SEXT8 // 0 to 32760 C_SEXT16 // 0 to 65520 C_LEXT C_ZOREG // 0(R) C_NSOREG_16 // must mirror C_NSAUTO_16, etc C_NSOREG_8 C_NSOREG_4 C_NSOREG C_NPOREG_16 C_NPOREG C_NQOREG_16 C_NOREG4K C_PSOREG_16 C_PSOREG_8 C_PSOREG_4 C_PSOREG C_PPOREG_16 C_PPOREG C_PQOREG_16 C_UOREG4K_16 C_UOREG4K_8 C_UOREG4K_4 C_UOREG4K_2 C_UOREG4K C_UOREG8K_16 C_UOREG8K_8 C_UOREG8K_4 C_UOREG8K C_UOREG16K_16 C_UOREG16K_8 C_UOREG16K C_UOREG32K_16 C_UOREG32K C_UOREG64K C_LOREGPOOL C_LOREG C_ADDR // TODO(aram): explain difference from C_VCONADDR // The GOT slot for a symbol in -dynlink mode. C_GOTADDR // TLS "var" in local exec mode: will become a constant offset from // thread local base that is ultimately chosen by the program linker. C_TLS_LE // TLS "var" in initial exec mode: will become a memory address (chosen // by the program linker) that the dynamic linker will fill with the // offset from the thread local base. C_TLS_IE C_ROFF // register offset (including register extended) C_GOK C_TEXTSIZE C_NCLASS // must be last )
const ( C_XPRE = 1 << 6 // match arm.C_WBIT, so Prog.String know how to print it C_XPOST = 1 << 5 // match arm.C_PBIT, so Prog.String know how to print it )
const ( AADC = obj.ABaseARM64 + obj.A_ARCHSPECIFIC + iota AADCS AADCSW AADCW AADD AADDS AADDSW AADDW AADR AADRP AAESD AAESE AAESIMC AAESMC AAND AANDS AANDSW AANDW AASR AASRW AAT ABCC ABCS ABEQ ABFI ABFIW ABFM ABFMW ABFXIL ABFXILW ABGE ABGT ABHI ABHS ABIC ABICS ABICSW ABICW ABLE ABLO ABLS ABLT ABMI ABNE ABPL ABRK ABVC ABVS ACASAD ACASALB ACASALD ACASALH ACASALW ACASAW ACASB ACASD ACASH ACASLD ACASLW ACASPD ACASPW ACASW ACBNZ ACBNZW ACBZ ACBZW ACCMN ACCMNW ACCMP ACCMPW ACINC ACINCW ACINV ACINVW ACLREX ACLS ACLSW ACLZ ACLZW ACMN ACMNW ACMP ACMPW ACNEG ACNEGW ACRC32B ACRC32CB ACRC32CH ACRC32CW ACRC32CX ACRC32H ACRC32W ACRC32X ACSEL ACSELW ACSET ACSETM ACSETMW ACSETW ACSINC ACSINCW ACSINV ACSINVW ACSNEG ACSNEGW ADC ADCPS1 ADCPS2 ADCPS3 ADMB ADRPS ADSB ADWORD AEON AEONW AEOR AEORW AERET AEXTR AEXTRW AFABSD AFABSS AFADDD AFADDS AFCCMPD AFCCMPED AFCCMPES AFCCMPS AFCMPD AFCMPED AFCMPES AFCMPS AFCSELD AFCSELS AFCVTDH AFCVTDS AFCVTHD AFCVTHS AFCVTSD AFCVTSH AFCVTZSD AFCVTZSDW AFCVTZSS AFCVTZSSW AFCVTZUD AFCVTZUDW AFCVTZUS AFCVTZUSW AFDIVD AFDIVS AFLDPD AFLDPQ AFLDPS AFMADDD AFMADDS AFMAXD AFMAXNMD AFMAXNMS AFMAXS AFMIND AFMINNMD AFMINNMS AFMINS AFMOVD AFMOVQ AFMOVS AFMSUBD AFMSUBS AFMULD AFMULS AFNEGD AFNEGS AFNMADDD AFNMADDS AFNMSUBD AFNMSUBS AFNMULD AFNMULS AFRINTAD AFRINTAS AFRINTID AFRINTIS AFRINTMD AFRINTMS AFRINTND AFRINTNS AFRINTPD AFRINTPS AFRINTXD AFRINTXS AFRINTZD AFRINTZS AFSQRTD AFSQRTS AFSTPD AFSTPQ AFSTPS AFSUBD AFSUBS AHINT AHLT AHVC AIC AISB ALDADDAB ALDADDAD ALDADDAH ALDADDALB ALDADDALD ALDADDALH ALDADDALW ALDADDAW ALDADDB ALDADDD ALDADDH ALDADDLB ALDADDLD ALDADDLH ALDADDLW ALDADDW ALDAR ALDARB ALDARH ALDARW ALDAXP ALDAXPW ALDAXR ALDAXRB ALDAXRH ALDAXRW ALDCLRAB ALDCLRAD ALDCLRAH ALDCLRALB ALDCLRALD ALDCLRALH ALDCLRALW ALDCLRAW ALDCLRB ALDCLRD ALDCLRH ALDCLRLB ALDCLRLD ALDCLRLH ALDCLRLW ALDCLRW ALDEORAB ALDEORAD ALDEORAH ALDEORALB ALDEORALD ALDEORALH ALDEORALW ALDEORAW ALDEORB ALDEORD ALDEORH ALDEORLB ALDEORLD ALDEORLH ALDEORLW ALDEORW ALDORAB ALDORAD ALDORAH ALDORALB ALDORALD ALDORALH ALDORALW ALDORAW ALDORB ALDORD ALDORH ALDORLB ALDORLD ALDORLH ALDORLW ALDORW ALDP ALDPSW ALDPW ALDXP ALDXPW ALDXR ALDXRB ALDXRH ALDXRW ALSL ALSLW ALSR ALSRW AMADD AMADDW AMNEG AMNEGW AMOVB AMOVBU AMOVD AMOVH AMOVHU AMOVK AMOVKW AMOVN AMOVNW AMOVP AMOVPD AMOVPQ AMOVPS AMOVPSW AMOVPW AMOVW AMOVWU AMOVZ AMOVZW AMRS AMSR AMSUB AMSUBW AMUL AMULW AMVN AMVNW ANEG ANEGS ANEGSW ANEGW ANGC ANGCS ANGCSW ANGCW ANOOP AORN AORNW AORR AORRW APRFM APRFUM ARBIT ARBITW AREM AREMW AREV AREV16 AREV16W AREV32 AREVW AROR ARORW ASBC ASBCS ASBCSW ASBCW ASBFIZ ASBFIZW ASBFM ASBFMW ASBFX ASBFXW ASCVTFD ASCVTFS ASCVTFWD ASCVTFWS ASDIV ASDIVW ASEV ASEVL ASHA1C ASHA1H ASHA1M ASHA1P ASHA1SU0 ASHA1SU1 ASHA256H ASHA256H2 ASHA256SU0 ASHA256SU1 ASHA512H ASHA512H2 ASHA512SU0 ASHA512SU1 ASMADDL ASMC ASMNEGL ASMSUBL ASMULH ASMULL ASTLR ASTLRB ASTLRH ASTLRW ASTLXP ASTLXPW ASTLXR ASTLXRB ASTLXRH ASTLXRW ASTP ASTPW ASTXP ASTXPW ASTXR ASTXRB ASTXRH ASTXRW ASUB ASUBS ASUBSW ASUBW ASVC ASWPAB ASWPAD ASWPAH ASWPALB ASWPALD ASWPALH ASWPALW ASWPAW ASWPB ASWPD ASWPH ASWPLB ASWPLD ASWPLH ASWPLW ASWPW ASXTB ASXTBW ASXTH ASXTHW ASXTW ASYS ASYSL ATBNZ ATBZ ATLBI ATST ATSTW AUBFIZ AUBFIZW AUBFM AUBFMW AUBFX AUBFXW AUCVTFD AUCVTFS AUCVTFWD AUCVTFWS AUDIV AUDIVW AUMADDL AUMNEGL AUMSUBL AUMULH AUMULL AUREM AUREMW AUXTB AUXTBW AUXTH AUXTHW AUXTW AVADD AVADDP AVADDV AVAND AVBCAX AVBIF AVBIT AVBSL AVCMEQ AVCMTST AVCNT AVDUP AVEOR AVEOR3 AVEXT AVFMLA AVFMLS AVLD1 AVLD1R AVLD2 AVLD2R AVLD3 AVLD3R AVLD4 AVLD4R AVMOV AVMOVD AVMOVI AVMOVQ AVMOVS AVORR AVPMULL AVPMULL2 AVRAX1 AVRBIT AVREV16 AVREV32 AVREV64 AVSHL AVSLI AVSRI AVST1 AVST2 AVST3 AVST4 AVSUB AVTBL AVTBX AVTRN1 AVTRN2 AVUADDLV AVUADDW AVUADDW2 AVUMAX AVUMIN AVUSHLL AVUSHLL2 AVUSHR AVUSRA AVUXTL AVUXTL2 AVUZP1 AVUZP2 AVXAR AVZIP1 AVZIP2 AWFE AWFI AWORD AYIELD ALAST AB = obj.AJMP ABL = obj.ACALL )
const ( // shift types SHIFT_LL = 0 << 22 SHIFT_LR = 1 << 22 SHIFT_AR = 2 << 22 SHIFT_ROR = 3 << 22 )
Arrangement for ARM64 SIMD instructions
const ( // arrangement types ARNG_8B = iota ARNG_16B ARNG_1D ARNG_4H ARNG_8H ARNG_2S ARNG_4S ARNG_2D ARNG_1Q ARNG_B ARNG_H ARNG_S ARNG_D )
const ( S32 = 0 << 31 S64 = 1 << 31 Sbit = 1 << 29 LSL0_32 = 2 << 13 LSL0_64 = 3 << 13 )
const ( // Optab.flag LFROM = 1 << iota // p.From uses constant pool LTO // p.To uses constant pool NOTUSETMP // p expands to multiple instructions, but does NOT use REGTMP BRANCH14BITS // branch instruction encodes 14 bits BRANCH19BITS // branch instruction encodes 19 bits )
const ( SYSREG_BEGIN = REG_SPECIAL + iota REG_ACTLR_EL1 REG_AFSR0_EL1 REG_AFSR1_EL1 REG_AIDR_EL1 REG_AMAIR_EL1 REG_AMCFGR_EL0 REG_AMCGCR_EL0 REG_AMCNTENCLR0_EL0 REG_AMCNTENCLR1_EL0 REG_AMCNTENSET0_EL0 REG_AMCNTENSET1_EL0 REG_AMCR_EL0 REG_AMEVCNTR00_EL0 REG_AMEVCNTR01_EL0 REG_AMEVCNTR02_EL0 REG_AMEVCNTR03_EL0 REG_AMEVCNTR04_EL0 REG_AMEVCNTR05_EL0 REG_AMEVCNTR06_EL0 REG_AMEVCNTR07_EL0 REG_AMEVCNTR08_EL0 REG_AMEVCNTR09_EL0 REG_AMEVCNTR010_EL0 REG_AMEVCNTR011_EL0 REG_AMEVCNTR012_EL0 REG_AMEVCNTR013_EL0 REG_AMEVCNTR014_EL0 REG_AMEVCNTR015_EL0 REG_AMEVCNTR10_EL0 REG_AMEVCNTR11_EL0 REG_AMEVCNTR12_EL0 REG_AMEVCNTR13_EL0 REG_AMEVCNTR14_EL0 REG_AMEVCNTR15_EL0 REG_AMEVCNTR16_EL0 REG_AMEVCNTR17_EL0 REG_AMEVCNTR18_EL0 REG_AMEVCNTR19_EL0 REG_AMEVCNTR110_EL0 REG_AMEVCNTR111_EL0 REG_AMEVCNTR112_EL0 REG_AMEVCNTR113_EL0 REG_AMEVCNTR114_EL0 REG_AMEVCNTR115_EL0 REG_AMEVTYPER00_EL0 REG_AMEVTYPER01_EL0 REG_AMEVTYPER02_EL0 REG_AMEVTYPER03_EL0 REG_AMEVTYPER04_EL0 REG_AMEVTYPER05_EL0 REG_AMEVTYPER06_EL0 REG_AMEVTYPER07_EL0 REG_AMEVTYPER08_EL0 REG_AMEVTYPER09_EL0 REG_AMEVTYPER010_EL0 REG_AMEVTYPER011_EL0 REG_AMEVTYPER012_EL0 REG_AMEVTYPER013_EL0 REG_AMEVTYPER014_EL0 REG_AMEVTYPER015_EL0 REG_AMEVTYPER10_EL0 REG_AMEVTYPER11_EL0 REG_AMEVTYPER12_EL0 REG_AMEVTYPER13_EL0 REG_AMEVTYPER14_EL0 REG_AMEVTYPER15_EL0 REG_AMEVTYPER16_EL0 REG_AMEVTYPER17_EL0 REG_AMEVTYPER18_EL0 REG_AMEVTYPER19_EL0 REG_AMEVTYPER110_EL0 REG_AMEVTYPER111_EL0 REG_AMEVTYPER112_EL0 REG_AMEVTYPER113_EL0 REG_AMEVTYPER114_EL0 REG_AMEVTYPER115_EL0 REG_AMUSERENR_EL0 REG_APDAKeyHi_EL1 REG_APDAKeyLo_EL1 REG_APDBKeyHi_EL1 REG_APDBKeyLo_EL1 REG_APGAKeyHi_EL1 REG_APGAKeyLo_EL1 REG_APIAKeyHi_EL1 REG_APIAKeyLo_EL1 REG_APIBKeyHi_EL1 REG_APIBKeyLo_EL1 REG_CCSIDR2_EL1 REG_CCSIDR_EL1 REG_CLIDR_EL1 REG_CNTFRQ_EL0 REG_CNTKCTL_EL1 REG_CNTP_CTL_EL0 REG_CNTP_CVAL_EL0 REG_CNTP_TVAL_EL0 REG_CNTPCT_EL0 REG_CNTPS_CTL_EL1 REG_CNTPS_CVAL_EL1 REG_CNTPS_TVAL_EL1 REG_CNTV_CTL_EL0 REG_CNTV_CVAL_EL0 REG_CNTV_TVAL_EL0 REG_CNTVCT_EL0 REG_CONTEXTIDR_EL1 REG_CPACR_EL1 REG_CSSELR_EL1 REG_CTR_EL0 REG_CurrentEL REG_DAIF REG_DBGAUTHSTATUS_EL1 REG_DBGBCR0_EL1 REG_DBGBCR1_EL1 REG_DBGBCR2_EL1 REG_DBGBCR3_EL1 REG_DBGBCR4_EL1 REG_DBGBCR5_EL1 REG_DBGBCR6_EL1 REG_DBGBCR7_EL1 REG_DBGBCR8_EL1 REG_DBGBCR9_EL1 REG_DBGBCR10_EL1 REG_DBGBCR11_EL1 REG_DBGBCR12_EL1 REG_DBGBCR13_EL1 REG_DBGBCR14_EL1 REG_DBGBCR15_EL1 REG_DBGBVR0_EL1 REG_DBGBVR1_EL1 REG_DBGBVR2_EL1 REG_DBGBVR3_EL1 REG_DBGBVR4_EL1 REG_DBGBVR5_EL1 REG_DBGBVR6_EL1 REG_DBGBVR7_EL1 REG_DBGBVR8_EL1 REG_DBGBVR9_EL1 REG_DBGBVR10_EL1 REG_DBGBVR11_EL1 REG_DBGBVR12_EL1 REG_DBGBVR13_EL1 REG_DBGBVR14_EL1 REG_DBGBVR15_EL1 REG_DBGCLAIMCLR_EL1 REG_DBGCLAIMSET_EL1 REG_DBGDTR_EL0 REG_DBGDTRRX_EL0 REG_DBGDTRTX_EL0 REG_DBGPRCR_EL1 REG_DBGWCR0_EL1 REG_DBGWCR1_EL1 REG_DBGWCR2_EL1 REG_DBGWCR3_EL1 REG_DBGWCR4_EL1 REG_DBGWCR5_EL1 REG_DBGWCR6_EL1 REG_DBGWCR7_EL1 REG_DBGWCR8_EL1 REG_DBGWCR9_EL1 REG_DBGWCR10_EL1 REG_DBGWCR11_EL1 REG_DBGWCR12_EL1 REG_DBGWCR13_EL1 REG_DBGWCR14_EL1 REG_DBGWCR15_EL1 REG_DBGWVR0_EL1 REG_DBGWVR1_EL1 REG_DBGWVR2_EL1 REG_DBGWVR3_EL1 REG_DBGWVR4_EL1 REG_DBGWVR5_EL1 REG_DBGWVR6_EL1 REG_DBGWVR7_EL1 REG_DBGWVR8_EL1 REG_DBGWVR9_EL1 REG_DBGWVR10_EL1 REG_DBGWVR11_EL1 REG_DBGWVR12_EL1 REG_DBGWVR13_EL1 REG_DBGWVR14_EL1 REG_DBGWVR15_EL1 REG_DCZID_EL0 REG_DISR_EL1 REG_DIT REG_DLR_EL0 REG_DSPSR_EL0 REG_ELR_EL1 REG_ERRIDR_EL1 REG_ERRSELR_EL1 REG_ERXADDR_EL1 REG_ERXCTLR_EL1 REG_ERXFR_EL1 REG_ERXMISC0_EL1 REG_ERXMISC1_EL1 REG_ERXMISC2_EL1 REG_ERXMISC3_EL1 REG_ERXPFGCDN_EL1 REG_ERXPFGCTL_EL1 REG_ERXPFGF_EL1 REG_ERXSTATUS_EL1 REG_ESR_EL1 REG_FAR_EL1 REG_FPCR REG_FPSR REG_GCR_EL1 REG_GMID_EL1 REG_ICC_AP0R0_EL1 REG_ICC_AP0R1_EL1 REG_ICC_AP0R2_EL1 REG_ICC_AP0R3_EL1 REG_ICC_AP1R0_EL1 REG_ICC_AP1R1_EL1 REG_ICC_AP1R2_EL1 REG_ICC_AP1R3_EL1 REG_ICC_ASGI1R_EL1 REG_ICC_BPR0_EL1 REG_ICC_BPR1_EL1 REG_ICC_CTLR_EL1 REG_ICC_DIR_EL1 REG_ICC_EOIR0_EL1 REG_ICC_EOIR1_EL1 REG_ICC_HPPIR0_EL1 REG_ICC_HPPIR1_EL1 REG_ICC_IAR0_EL1 REG_ICC_IAR1_EL1 REG_ICC_IGRPEN0_EL1 REG_ICC_IGRPEN1_EL1 REG_ICC_PMR_EL1 REG_ICC_RPR_EL1 REG_ICC_SGI0R_EL1 REG_ICC_SGI1R_EL1 REG_ICC_SRE_EL1 REG_ICV_AP0R0_EL1 REG_ICV_AP0R1_EL1 REG_ICV_AP0R2_EL1 REG_ICV_AP0R3_EL1 REG_ICV_AP1R0_EL1 REG_ICV_AP1R1_EL1 REG_ICV_AP1R2_EL1 REG_ICV_AP1R3_EL1 REG_ICV_BPR0_EL1 REG_ICV_BPR1_EL1 REG_ICV_CTLR_EL1 REG_ICV_DIR_EL1 REG_ICV_EOIR0_EL1 REG_ICV_EOIR1_EL1 REG_ICV_HPPIR0_EL1 REG_ICV_HPPIR1_EL1 REG_ICV_IAR0_EL1 REG_ICV_IAR1_EL1 REG_ICV_IGRPEN0_EL1 REG_ICV_IGRPEN1_EL1 REG_ICV_PMR_EL1 REG_ICV_RPR_EL1 REG_ID_AA64AFR0_EL1 REG_ID_AA64AFR1_EL1 REG_ID_AA64DFR0_EL1 REG_ID_AA64DFR1_EL1 REG_ID_AA64ISAR0_EL1 REG_ID_AA64ISAR1_EL1 REG_ID_AA64MMFR0_EL1 REG_ID_AA64MMFR1_EL1 REG_ID_AA64MMFR2_EL1 REG_ID_AA64PFR0_EL1 REG_ID_AA64PFR1_EL1 REG_ID_AA64ZFR0_EL1 REG_ID_AFR0_EL1 REG_ID_DFR0_EL1 REG_ID_ISAR0_EL1 REG_ID_ISAR1_EL1 REG_ID_ISAR2_EL1 REG_ID_ISAR3_EL1 REG_ID_ISAR4_EL1 REG_ID_ISAR5_EL1 REG_ID_ISAR6_EL1 REG_ID_MMFR0_EL1 REG_ID_MMFR1_EL1 REG_ID_MMFR2_EL1 REG_ID_MMFR3_EL1 REG_ID_MMFR4_EL1 REG_ID_PFR0_EL1 REG_ID_PFR1_EL1 REG_ID_PFR2_EL1 REG_ISR_EL1 REG_LORC_EL1 REG_LOREA_EL1 REG_LORID_EL1 REG_LORN_EL1 REG_LORSA_EL1 REG_MAIR_EL1 REG_MDCCINT_EL1 REG_MDCCSR_EL0 REG_MDRAR_EL1 REG_MDSCR_EL1 REG_MIDR_EL1 REG_MPAM0_EL1 REG_MPAM1_EL1 REG_MPAMIDR_EL1 REG_MPIDR_EL1 REG_MVFR0_EL1 REG_MVFR1_EL1 REG_MVFR2_EL1 REG_NZCV REG_OSDLR_EL1 REG_OSDTRRX_EL1 REG_OSDTRTX_EL1 REG_OSECCR_EL1 REG_OSLAR_EL1 REG_OSLSR_EL1 REG_PAN REG_PAR_EL1 REG_PMBIDR_EL1 REG_PMBLIMITR_EL1 REG_PMBPTR_EL1 REG_PMBSR_EL1 REG_PMCCFILTR_EL0 REG_PMCCNTR_EL0 REG_PMCEID0_EL0 REG_PMCEID1_EL0 REG_PMCNTENCLR_EL0 REG_PMCNTENSET_EL0 REG_PMCR_EL0 REG_PMEVCNTR0_EL0 REG_PMEVCNTR1_EL0 REG_PMEVCNTR2_EL0 REG_PMEVCNTR3_EL0 REG_PMEVCNTR4_EL0 REG_PMEVCNTR5_EL0 REG_PMEVCNTR6_EL0 REG_PMEVCNTR7_EL0 REG_PMEVCNTR8_EL0 REG_PMEVCNTR9_EL0 REG_PMEVCNTR10_EL0 REG_PMEVCNTR11_EL0 REG_PMEVCNTR12_EL0 REG_PMEVCNTR13_EL0 REG_PMEVCNTR14_EL0 REG_PMEVCNTR15_EL0 REG_PMEVCNTR16_EL0 REG_PMEVCNTR17_EL0 REG_PMEVCNTR18_EL0 REG_PMEVCNTR19_EL0 REG_PMEVCNTR20_EL0 REG_PMEVCNTR21_EL0 REG_PMEVCNTR22_EL0 REG_PMEVCNTR23_EL0 REG_PMEVCNTR24_EL0 REG_PMEVCNTR25_EL0 REG_PMEVCNTR26_EL0 REG_PMEVCNTR27_EL0 REG_PMEVCNTR28_EL0 REG_PMEVCNTR29_EL0 REG_PMEVCNTR30_EL0 REG_PMEVTYPER0_EL0 REG_PMEVTYPER1_EL0 REG_PMEVTYPER2_EL0 REG_PMEVTYPER3_EL0 REG_PMEVTYPER4_EL0 REG_PMEVTYPER5_EL0 REG_PMEVTYPER6_EL0 REG_PMEVTYPER7_EL0 REG_PMEVTYPER8_EL0 REG_PMEVTYPER9_EL0 REG_PMEVTYPER10_EL0 REG_PMEVTYPER11_EL0 REG_PMEVTYPER12_EL0 REG_PMEVTYPER13_EL0 REG_PMEVTYPER14_EL0 REG_PMEVTYPER15_EL0 REG_PMEVTYPER16_EL0 REG_PMEVTYPER17_EL0 REG_PMEVTYPER18_EL0 REG_PMEVTYPER19_EL0 REG_PMEVTYPER20_EL0 REG_PMEVTYPER21_EL0 REG_PMEVTYPER22_EL0 REG_PMEVTYPER23_EL0 REG_PMEVTYPER24_EL0 REG_PMEVTYPER25_EL0 REG_PMEVTYPER26_EL0 REG_PMEVTYPER27_EL0 REG_PMEVTYPER28_EL0 REG_PMEVTYPER29_EL0 REG_PMEVTYPER30_EL0 REG_PMINTENCLR_EL1 REG_PMINTENSET_EL1 REG_PMMIR_EL1 REG_PMOVSCLR_EL0 REG_PMOVSSET_EL0 REG_PMSCR_EL1 REG_PMSELR_EL0 REG_PMSEVFR_EL1 REG_PMSFCR_EL1 REG_PMSICR_EL1 REG_PMSIDR_EL1 REG_PMSIRR_EL1 REG_PMSLATFR_EL1 REG_PMSWINC_EL0 REG_PMUSERENR_EL0 REG_PMXEVCNTR_EL0 REG_PMXEVTYPER_EL0 REG_REVIDR_EL1 REG_RGSR_EL1 REG_RMR_EL1 REG_RNDR REG_RNDRRS REG_RVBAR_EL1 REG_SCTLR_EL1 REG_SCXTNUM_EL0 REG_SCXTNUM_EL1 REG_SP_EL0 REG_SP_EL1 REG_SPSel REG_SPSR_abt REG_SPSR_EL1 REG_SPSR_fiq REG_SPSR_irq REG_SPSR_und REG_SSBS REG_TCO REG_TCR_EL1 REG_TFSR_EL1 REG_TFSRE0_EL1 REG_TPIDR_EL0 REG_TPIDR_EL1 REG_TPIDRRO_EL0 REG_TRFCR_EL1 REG_TTBR0_EL1 REG_TTBR1_EL1 REG_UAO REG_VBAR_EL1 REG_ZCR_EL1 SYSREG_END )
const ( SR_READ = 1 << iota SR_WRITE )
const (
BIG = 2048 - 8
)
Used for padding NOOP instruction
const OP_NOOP = 0xd503201f
const (
REGFROM = 1
)
const REG_EXT = obj.RBaseARM64 + 1<<11
Not registers, but flags that can be combined with regular register constants to indicate extended register conversion. When checking, you should subtract obj.RBaseARM64 first. From this difference, bit 11 indicates extended register, bits 8-10 select the conversion mode. REG_LSL is the index shift specifier, bit 9 indicates shifted offset register.
const REG_LSL = obj.RBaseARM64 + 1<<9
Special registers, after subtracting obj.RBaseARM64, bit 12 indicates a special register and the low bits select the register. SYSREG_END is the last item in the automatically generated system register declaration, and it is defined in the sysRegEnc.go file. Define the special register after REG_SPECIAL, the first value of it should be REG_{name} = SYSREG_END + iota.
const (
REG_SPECIAL = obj.RBaseARM64 + 1<<12
)
Variables
http://infocenter.arm.com/help/topic/com.arm.doc.ecm0665627/abi_sve_aadwarf_100985_0000_00_en.pdf
var ARM64DWARFRegisters = map[int16]int16{
REG_R0: 0,
REG_R1: 1,
REG_R2: 2,
REG_R3: 3,
REG_R4: 4,
REG_R5: 5,
REG_R6: 6,
REG_R7: 7,
REG_R8: 8,
REG_R9: 9,
REG_R10: 10,
REG_R11: 11,
REG_R12: 12,
REG_R13: 13,
REG_R14: 14,
REG_R15: 15,
REG_R16: 16,
REG_R17: 17,
REG_R18: 18,
REG_R19: 19,
REG_R20: 20,
REG_R21: 21,
REG_R22: 22,
REG_R23: 23,
REG_R24: 24,
REG_R25: 25,
REG_R26: 26,
REG_R27: 27,
REG_R28: 28,
REG_R29: 29,
REG_R30: 30,
REG_F0: 64,
REG_F1: 65,
REG_F2: 66,
REG_F3: 67,
REG_F4: 68,
REG_F5: 69,
REG_F6: 70,
REG_F7: 71,
REG_F8: 72,
REG_F9: 73,
REG_F10: 74,
REG_F11: 75,
REG_F12: 76,
REG_F13: 77,
REG_F14: 78,
REG_F15: 79,
REG_F16: 80,
REG_F17: 81,
REG_F18: 82,
REG_F19: 83,
REG_F20: 84,
REG_F21: 85,
REG_F22: 86,
REG_F23: 87,
REG_F24: 88,
REG_F25: 89,
REG_F26: 90,
REG_F27: 91,
REG_F28: 92,
REG_F29: 93,
REG_F30: 94,
REG_F31: 95,
REG_V0: 64,
REG_V1: 65,
REG_V2: 66,
REG_V3: 67,
REG_V4: 68,
REG_V5: 69,
REG_V6: 70,
REG_V7: 71,
REG_V8: 72,
REG_V9: 73,
REG_V10: 74,
REG_V11: 75,
REG_V12: 76,
REG_V13: 77,
REG_V14: 78,
REG_V15: 79,
REG_V16: 80,
REG_V17: 81,
REG_V18: 82,
REG_V19: 83,
REG_V20: 84,
REG_V21: 85,
REG_V22: 86,
REG_V23: 87,
REG_V24: 88,
REG_V25: 89,
REG_V26: 90,
REG_V27: 91,
REG_V28: 92,
REG_V29: 93,
REG_V30: 94,
REG_V31: 95,
}
var Anames = []string{
obj.A_ARCHSPECIFIC: "ADC",
"ADCS",
"ADCSW",
"ADCW",
"ADD",
"ADDS",
"ADDSW",
"ADDW",
"ADR",
"ADRP",
"AESD",
"AESE",
"AESIMC",
"AESMC",
"AND",
"ANDS",
"ANDSW",
"ANDW",
"ASR",
"ASRW",
"AT",
"BCC",
"BCS",
"BEQ",
"BFI",
"BFIW",
"BFM",
"BFMW",
"BFXIL",
"BFXILW",
"BGE",
"BGT",
"BHI",
"BHS",
"BIC",
"BICS",
"BICSW",
"BICW",
"BLE",
"BLO",
"BLS",
"BLT",
"BMI",
"BNE",
"BPL",
"BRK",
"BVC",
"BVS",
"CASAD",
"CASALB",
"CASALD",
"CASALH",
"CASALW",
"CASAW",
"CASB",
"CASD",
"CASH",
"CASLD",
"CASLW",
"CASPD",
"CASPW",
"CASW",
"CBNZ",
"CBNZW",
"CBZ",
"CBZW",
"CCMN",
"CCMNW",
"CCMP",
"CCMPW",
"CINC",
"CINCW",
"CINV",
"CINVW",
"CLREX",
"CLS",
"CLSW",
"CLZ",
"CLZW",
"CMN",
"CMNW",
"CMP",
"CMPW",
"CNEG",
"CNEGW",
"CRC32B",
"CRC32CB",
"CRC32CH",
"CRC32CW",
"CRC32CX",
"CRC32H",
"CRC32W",
"CRC32X",
"CSEL",
"CSELW",
"CSET",
"CSETM",
"CSETMW",
"CSETW",
"CSINC",
"CSINCW",
"CSINV",
"CSINVW",
"CSNEG",
"CSNEGW",
"DC",
"DCPS1",
"DCPS2",
"DCPS3",
"DMB",
"DRPS",
"DSB",
"DWORD",
"EON",
"EONW",
"EOR",
"EORW",
"ERET",
"EXTR",
"EXTRW",
"FABSD",
"FABSS",
"FADDD",
"FADDS",
"FCCMPD",
"FCCMPED",
"FCCMPES",
"FCCMPS",
"FCMPD",
"FCMPED",
"FCMPES",
"FCMPS",
"FCSELD",
"FCSELS",
"FCVTDH",
"FCVTDS",
"FCVTHD",
"FCVTHS",
"FCVTSD",
"FCVTSH",
"FCVTZSD",
"FCVTZSDW",
"FCVTZSS",
"FCVTZSSW",
"FCVTZUD",
"FCVTZUDW",
"FCVTZUS",
"FCVTZUSW",
"FDIVD",
"FDIVS",
"FLDPD",
"FLDPQ",
"FLDPS",
"FMADDD",
"FMADDS",
"FMAXD",
"FMAXNMD",
"FMAXNMS",
"FMAXS",
"FMIND",
"FMINNMD",
"FMINNMS",
"FMINS",
"FMOVD",
"FMOVQ",
"FMOVS",
"FMSUBD",
"FMSUBS",
"FMULD",
"FMULS",
"FNEGD",
"FNEGS",
"FNMADDD",
"FNMADDS",
"FNMSUBD",
"FNMSUBS",
"FNMULD",
"FNMULS",
"FRINTAD",
"FRINTAS",
"FRINTID",
"FRINTIS",
"FRINTMD",
"FRINTMS",
"FRINTND",
"FRINTNS",
"FRINTPD",
"FRINTPS",
"FRINTXD",
"FRINTXS",
"FRINTZD",
"FRINTZS",
"FSQRTD",
"FSQRTS",
"FSTPD",
"FSTPQ",
"FSTPS",
"FSUBD",
"FSUBS",
"HINT",
"HLT",
"HVC",
"IC",
"ISB",
"LDADDAB",
"LDADDAD",
"LDADDAH",
"LDADDALB",
"LDADDALD",
"LDADDALH",
"LDADDALW",
"LDADDAW",
"LDADDB",
"LDADDD",
"LDADDH",
"LDADDLB",
"LDADDLD",
"LDADDLH",
"LDADDLW",
"LDADDW",
"LDAR",
"LDARB",
"LDARH",
"LDARW",
"LDAXP",
"LDAXPW",
"LDAXR",
"LDAXRB",
"LDAXRH",
"LDAXRW",
"LDCLRAB",
"LDCLRAD",
"LDCLRAH",
"LDCLRALB",
"LDCLRALD",
"LDCLRALH",
"LDCLRALW",
"LDCLRAW",
"LDCLRB",
"LDCLRD",
"LDCLRH",
"LDCLRLB",
"LDCLRLD",
"LDCLRLH",
"LDCLRLW",
"LDCLRW",
"LDEORAB",
"LDEORAD",
"LDEORAH",
"LDEORALB",
"LDEORALD",
"LDEORALH",
"LDEORALW",
"LDEORAW",
"LDEORB",
"LDEORD",
"LDEORH",
"LDEORLB",
"LDEORLD",
"LDEORLH",
"LDEORLW",
"LDEORW",
"LDORAB",
"LDORAD",
"LDORAH",
"LDORALB",
"LDORALD",
"LDORALH",
"LDORALW",
"LDORAW",
"LDORB",
"LDORD",
"LDORH",
"LDORLB",
"LDORLD",
"LDORLH",
"LDORLW",
"LDORW",
"LDP",
"LDPSW",
"LDPW",
"LDXP",
"LDXPW",
"LDXR",
"LDXRB",
"LDXRH",
"LDXRW",
"LSL",
"LSLW",
"LSR",
"LSRW",
"MADD",
"MADDW",
"MNEG",
"MNEGW",
"MOVB",
"MOVBU",
"MOVD",
"MOVH",
"MOVHU",
"MOVK",
"MOVKW",
"MOVN",
"MOVNW",
"MOVP",
"MOVPD",
"MOVPQ",
"MOVPS",
"MOVPSW",
"MOVPW",
"MOVW",
"MOVWU",
"MOVZ",
"MOVZW",
"MRS",
"MSR",
"MSUB",
"MSUBW",
"MUL",
"MULW",
"MVN",
"MVNW",
"NEG",
"NEGS",
"NEGSW",
"NEGW",
"NGC",
"NGCS",
"NGCSW",
"NGCW",
"NOOP",
"ORN",
"ORNW",
"ORR",
"ORRW",
"PRFM",
"PRFUM",
"RBIT",
"RBITW",
"REM",
"REMW",
"REV",
"REV16",
"REV16W",
"REV32",
"REVW",
"ROR",
"RORW",
"SBC",
"SBCS",
"SBCSW",
"SBCW",
"SBFIZ",
"SBFIZW",
"SBFM",
"SBFMW",
"SBFX",
"SBFXW",
"SCVTFD",
"SCVTFS",
"SCVTFWD",
"SCVTFWS",
"SDIV",
"SDIVW",
"SEV",
"SEVL",
"SHA1C",
"SHA1H",
"SHA1M",
"SHA1P",
"SHA1SU0",
"SHA1SU1",
"SHA256H",
"SHA256H2",
"SHA256SU0",
"SHA256SU1",
"SHA512H",
"SHA512H2",
"SHA512SU0",
"SHA512SU1",
"SMADDL",
"SMC",
"SMNEGL",
"SMSUBL",
"SMULH",
"SMULL",
"STLR",
"STLRB",
"STLRH",
"STLRW",
"STLXP",
"STLXPW",
"STLXR",
"STLXRB",
"STLXRH",
"STLXRW",
"STP",
"STPW",
"STXP",
"STXPW",
"STXR",
"STXRB",
"STXRH",
"STXRW",
"SUB",
"SUBS",
"SUBSW",
"SUBW",
"SVC",
"SWPAB",
"SWPAD",
"SWPAH",
"SWPALB",
"SWPALD",
"SWPALH",
"SWPALW",
"SWPAW",
"SWPB",
"SWPD",
"SWPH",
"SWPLB",
"SWPLD",
"SWPLH",
"SWPLW",
"SWPW",
"SXTB",
"SXTBW",
"SXTH",
"SXTHW",
"SXTW",
"SYS",
"SYSL",
"TBNZ",
"TBZ",
"TLBI",
"TST",
"TSTW",
"UBFIZ",
"UBFIZW",
"UBFM",
"UBFMW",
"UBFX",
"UBFXW",
"UCVTFD",
"UCVTFS",
"UCVTFWD",
"UCVTFWS",
"UDIV",
"UDIVW",
"UMADDL",
"UMNEGL",
"UMSUBL",
"UMULH",
"UMULL",
"UREM",
"UREMW",
"UXTB",
"UXTBW",
"UXTH",
"UXTHW",
"UXTW",
"VADD",
"VADDP",
"VADDV",
"VAND",
"VBCAX",
"VBIF",
"VBIT",
"VBSL",
"VCMEQ",
"VCMTST",
"VCNT",
"VDUP",
"VEOR",
"VEOR3",
"VEXT",
"VFMLA",
"VFMLS",
"VLD1",
"VLD1R",
"VLD2",
"VLD2R",
"VLD3",
"VLD3R",
"VLD4",
"VLD4R",
"VMOV",
"VMOVD",
"VMOVI",
"VMOVQ",
"VMOVS",
"VORR",
"VPMULL",
"VPMULL2",
"VRAX1",
"VRBIT",
"VREV16",
"VREV32",
"VREV64",
"VSHL",
"VSLI",
"VSRI",
"VST1",
"VST2",
"VST3",
"VST4",
"VSUB",
"VTBL",
"VTBX",
"VTRN1",
"VTRN2",
"VUADDLV",
"VUADDW",
"VUADDW2",
"VUMAX",
"VUMIN",
"VUSHLL",
"VUSHLL2",
"VUSHR",
"VUSRA",
"VUXTL",
"VUXTL2",
"VUZP1",
"VUZP2",
"VXAR",
"VZIP1",
"VZIP2",
"WFE",
"WFI",
"WORD",
"YIELD",
"LAST",
}
var Linkarm64 = obj.LinkArch{
Arch: sys.ArchARM64,
Init: buildop,
Preprocess: preprocess,
Assemble: span7,
Progedit: progedit,
UnaryDst: unaryDst,
DWARFRegisters: ARM64DWARFRegisters,
}
var SystemReg = []struct { Name string Reg int16 Enc uint32 // AccessFlags is the readable and writeable property of system register. AccessFlags uint8 }{ {"ACTLR_EL1", REG_ACTLR_EL1, 0x181020, SR_READ | SR_WRITE}, {"AFSR0_EL1", REG_AFSR0_EL1, 0x185100, SR_READ | SR_WRITE}, {"AFSR1_EL1", REG_AFSR1_EL1, 0x185120, SR_READ | SR_WRITE}, {"AIDR_EL1", REG_AIDR_EL1, 0x1900e0, SR_READ}, {"AMAIR_EL1", REG_AMAIR_EL1, 0x18a300, SR_READ | SR_WRITE}, {"AMCFGR_EL0", REG_AMCFGR_EL0, 0x1bd220, SR_READ}, {"AMCGCR_EL0", REG_AMCGCR_EL0, 0x1bd240, SR_READ}, {"AMCNTENCLR0_EL0", REG_AMCNTENCLR0_EL0, 0x1bd280, SR_READ | SR_WRITE}, {"AMCNTENCLR1_EL0", REG_AMCNTENCLR1_EL0, 0x1bd300, SR_READ | SR_WRITE}, {"AMCNTENSET0_EL0", REG_AMCNTENSET0_EL0, 0x1bd2a0, SR_READ | SR_WRITE}, {"AMCNTENSET1_EL0", REG_AMCNTENSET1_EL0, 0x1bd320, SR_READ | SR_WRITE}, {"AMCR_EL0", REG_AMCR_EL0, 0x1bd200, SR_READ | SR_WRITE}, {"AMEVCNTR00_EL0", REG_AMEVCNTR00_EL0, 0x1bd400, SR_READ | SR_WRITE}, {"AMEVCNTR01_EL0", REG_AMEVCNTR01_EL0, 0x1bd420, SR_READ | SR_WRITE}, {"AMEVCNTR02_EL0", REG_AMEVCNTR02_EL0, 0x1bd440, SR_READ | SR_WRITE}, {"AMEVCNTR03_EL0", REG_AMEVCNTR03_EL0, 0x1bd460, SR_READ | SR_WRITE}, {"AMEVCNTR04_EL0", REG_AMEVCNTR04_EL0, 0x1bd480, SR_READ | SR_WRITE}, {"AMEVCNTR05_EL0", REG_AMEVCNTR05_EL0, 0x1bd4a0, SR_READ | SR_WRITE}, {"AMEVCNTR06_EL0", REG_AMEVCNTR06_EL0, 0x1bd4c0, SR_READ | SR_WRITE}, {"AMEVCNTR07_EL0", REG_AMEVCNTR07_EL0, 0x1bd4e0, SR_READ | SR_WRITE}, {"AMEVCNTR08_EL0", REG_AMEVCNTR08_EL0, 0x1bd500, SR_READ | SR_WRITE}, {"AMEVCNTR09_EL0", REG_AMEVCNTR09_EL0, 0x1bd520, SR_READ | SR_WRITE}, {"AMEVCNTR010_EL0", REG_AMEVCNTR010_EL0, 0x1bd540, SR_READ | SR_WRITE}, {"AMEVCNTR011_EL0", REG_AMEVCNTR011_EL0, 0x1bd560, SR_READ | SR_WRITE}, {"AMEVCNTR012_EL0", REG_AMEVCNTR012_EL0, 0x1bd580, SR_READ | SR_WRITE}, {"AMEVCNTR013_EL0", REG_AMEVCNTR013_EL0, 0x1bd5a0, SR_READ | SR_WRITE}, {"AMEVCNTR014_EL0", REG_AMEVCNTR014_EL0, 0x1bd5c0, SR_READ | SR_WRITE}, {"AMEVCNTR015_EL0", REG_AMEVCNTR015_EL0, 0x1bd5e0, SR_READ | SR_WRITE}, {"AMEVCNTR10_EL0", REG_AMEVCNTR10_EL0, 0x1bdc00, SR_READ | SR_WRITE}, {"AMEVCNTR11_EL0", REG_AMEVCNTR11_EL0, 0x1bdc20, SR_READ | SR_WRITE}, {"AMEVCNTR12_EL0", REG_AMEVCNTR12_EL0, 0x1bdc40, SR_READ | SR_WRITE}, {"AMEVCNTR13_EL0", REG_AMEVCNTR13_EL0, 0x1bdc60, SR_READ | SR_WRITE}, {"AMEVCNTR14_EL0", REG_AMEVCNTR14_EL0, 0x1bdc80, SR_READ | SR_WRITE}, {"AMEVCNTR15_EL0", REG_AMEVCNTR15_EL0, 0x1bdca0, SR_READ | SR_WRITE}, {"AMEVCNTR16_EL0", REG_AMEVCNTR16_EL0, 0x1bdcc0, SR_READ | SR_WRITE}, {"AMEVCNTR17_EL0", REG_AMEVCNTR17_EL0, 0x1bdce0, SR_READ | SR_WRITE}, {"AMEVCNTR18_EL0", REG_AMEVCNTR18_EL0, 0x1bdd00, SR_READ | SR_WRITE}, {"AMEVCNTR19_EL0", REG_AMEVCNTR19_EL0, 0x1bdd20, SR_READ | SR_WRITE}, {"AMEVCNTR110_EL0", REG_AMEVCNTR110_EL0, 0x1bdd40, SR_READ | SR_WRITE}, {"AMEVCNTR111_EL0", REG_AMEVCNTR111_EL0, 0x1bdd60, SR_READ | SR_WRITE}, {"AMEVCNTR112_EL0", REG_AMEVCNTR112_EL0, 0x1bdd80, SR_READ | SR_WRITE}, {"AMEVCNTR113_EL0", REG_AMEVCNTR113_EL0, 0x1bdda0, SR_READ | SR_WRITE}, {"AMEVCNTR114_EL0", REG_AMEVCNTR114_EL0, 0x1bddc0, SR_READ | SR_WRITE}, {"AMEVCNTR115_EL0", REG_AMEVCNTR115_EL0, 0x1bdde0, SR_READ | SR_WRITE}, {"AMEVTYPER00_EL0", REG_AMEVTYPER00_EL0, 0x1bd600, SR_READ}, {"AMEVTYPER01_EL0", REG_AMEVTYPER01_EL0, 0x1bd620, SR_READ}, {"AMEVTYPER02_EL0", REG_AMEVTYPER02_EL0, 0x1bd640, SR_READ}, {"AMEVTYPER03_EL0", REG_AMEVTYPER03_EL0, 0x1bd660, SR_READ}, {"AMEVTYPER04_EL0", REG_AMEVTYPER04_EL0, 0x1bd680, SR_READ}, {"AMEVTYPER05_EL0", REG_AMEVTYPER05_EL0, 0x1bd6a0, SR_READ}, {"AMEVTYPER06_EL0", REG_AMEVTYPER06_EL0, 0x1bd6c0, SR_READ}, {"AMEVTYPER07_EL0", REG_AMEVTYPER07_EL0, 0x1bd6e0, SR_READ}, {"AMEVTYPER08_EL0", REG_AMEVTYPER08_EL0, 0x1bd700, SR_READ}, {"AMEVTYPER09_EL0", REG_AMEVTYPER09_EL0, 0x1bd720, SR_READ}, {"AMEVTYPER010_EL0", REG_AMEVTYPER010_EL0, 0x1bd740, SR_READ}, {"AMEVTYPER011_EL0", REG_AMEVTYPER011_EL0, 0x1bd760, SR_READ}, {"AMEVTYPER012_EL0", REG_AMEVTYPER012_EL0, 0x1bd780, SR_READ}, {"AMEVTYPER013_EL0", REG_AMEVTYPER013_EL0, 0x1bd7a0, SR_READ}, {"AMEVTYPER014_EL0", REG_AMEVTYPER014_EL0, 0x1bd7c0, SR_READ}, {"AMEVTYPER015_EL0", REG_AMEVTYPER015_EL0, 0x1bd7e0, SR_READ}, {"AMEVTYPER10_EL0", REG_AMEVTYPER10_EL0, 0x1bde00, SR_READ | SR_WRITE}, {"AMEVTYPER11_EL0", REG_AMEVTYPER11_EL0, 0x1bde20, SR_READ | SR_WRITE}, {"AMEVTYPER12_EL0", REG_AMEVTYPER12_EL0, 0x1bde40, SR_READ | SR_WRITE}, {"AMEVTYPER13_EL0", REG_AMEVTYPER13_EL0, 0x1bde60, SR_READ | SR_WRITE}, {"AMEVTYPER14_EL0", REG_AMEVTYPER14_EL0, 0x1bde80, SR_READ | SR_WRITE}, {"AMEVTYPER15_EL0", REG_AMEVTYPER15_EL0, 0x1bdea0, SR_READ | SR_WRITE}, {"AMEVTYPER16_EL0", REG_AMEVTYPER16_EL0, 0x1bdec0, SR_READ | SR_WRITE}, {"AMEVTYPER17_EL0", REG_AMEVTYPER17_EL0, 0x1bdee0, SR_READ | SR_WRITE}, {"AMEVTYPER18_EL0", REG_AMEVTYPER18_EL0, 0x1bdf00, SR_READ | SR_WRITE}, {"AMEVTYPER19_EL0", REG_AMEVTYPER19_EL0, 0x1bdf20, SR_READ | SR_WRITE}, {"AMEVTYPER110_EL0", REG_AMEVTYPER110_EL0, 0x1bdf40, SR_READ | SR_WRITE}, {"AMEVTYPER111_EL0", REG_AMEVTYPER111_EL0, 0x1bdf60, SR_READ | SR_WRITE}, {"AMEVTYPER112_EL0", REG_AMEVTYPER112_EL0, 0x1bdf80, SR_READ | SR_WRITE}, {"AMEVTYPER113_EL0", REG_AMEVTYPER113_EL0, 0x1bdfa0, SR_READ | SR_WRITE}, {"AMEVTYPER114_EL0", REG_AMEVTYPER114_EL0, 0x1bdfc0, SR_READ | SR_WRITE}, {"AMEVTYPER115_EL0", REG_AMEVTYPER115_EL0, 0x1bdfe0, SR_READ | SR_WRITE}, {"AMUSERENR_EL0", REG_AMUSERENR_EL0, 0x1bd260, SR_READ | SR_WRITE}, {"APDAKeyHi_EL1", REG_APDAKeyHi_EL1, 0x182220, SR_READ | SR_WRITE}, {"APDAKeyLo_EL1", REG_APDAKeyLo_EL1, 0x182200, SR_READ | SR_WRITE}, {"APDBKeyHi_EL1", REG_APDBKeyHi_EL1, 0x182260, SR_READ | SR_WRITE}, {"APDBKeyLo_EL1", REG_APDBKeyLo_EL1, 0x182240, SR_READ | SR_WRITE}, {"APGAKeyHi_EL1", REG_APGAKeyHi_EL1, 0x182320, SR_READ | SR_WRITE}, {"APGAKeyLo_EL1", REG_APGAKeyLo_EL1, 0x182300, SR_READ | SR_WRITE}, {"APIAKeyHi_EL1", REG_APIAKeyHi_EL1, 0x182120, SR_READ | SR_WRITE}, {"APIAKeyLo_EL1", REG_APIAKeyLo_EL1, 0x182100, SR_READ | SR_WRITE}, {"APIBKeyHi_EL1", REG_APIBKeyHi_EL1, 0x182160, SR_READ | SR_WRITE}, {"APIBKeyLo_EL1", REG_APIBKeyLo_EL1, 0x182140, SR_READ | SR_WRITE}, {"CCSIDR2_EL1", REG_CCSIDR2_EL1, 0x190040, SR_READ}, {"CCSIDR_EL1", REG_CCSIDR_EL1, 0x190000, SR_READ}, {"CLIDR_EL1", REG_CLIDR_EL1, 0x190020, SR_READ}, {"CNTFRQ_EL0", REG_CNTFRQ_EL0, 0x1be000, SR_READ | SR_WRITE}, {"CNTKCTL_EL1", REG_CNTKCTL_EL1, 0x18e100, SR_READ | SR_WRITE}, {"CNTP_CTL_EL0", REG_CNTP_CTL_EL0, 0x1be220, SR_READ | SR_WRITE}, {"CNTP_CVAL_EL0", REG_CNTP_CVAL_EL0, 0x1be240, SR_READ | SR_WRITE}, {"CNTP_TVAL_EL0", REG_CNTP_TVAL_EL0, 0x1be200, SR_READ | SR_WRITE}, {"CNTPCT_EL0", REG_CNTPCT_EL0, 0x1be020, SR_READ}, {"CNTPS_CTL_EL1", REG_CNTPS_CTL_EL1, 0x1fe220, SR_READ | SR_WRITE}, {"CNTPS_CVAL_EL1", REG_CNTPS_CVAL_EL1, 0x1fe240, SR_READ | SR_WRITE}, {"CNTPS_TVAL_EL1", REG_CNTPS_TVAL_EL1, 0x1fe200, SR_READ | SR_WRITE}, {"CNTV_CTL_EL0", REG_CNTV_CTL_EL0, 0x1be320, SR_READ | SR_WRITE}, {"CNTV_CVAL_EL0", REG_CNTV_CVAL_EL0, 0x1be340, SR_READ | SR_WRITE}, {"CNTV_TVAL_EL0", REG_CNTV_TVAL_EL0, 0x1be300, SR_READ | SR_WRITE}, {"CNTVCT_EL0", REG_CNTVCT_EL0, 0x1be040, SR_READ}, {"CONTEXTIDR_EL1", REG_CONTEXTIDR_EL1, 0x18d020, SR_READ | SR_WRITE}, {"CPACR_EL1", REG_CPACR_EL1, 0x181040, SR_READ | SR_WRITE}, {"CSSELR_EL1", REG_CSSELR_EL1, 0x1a0000, SR_READ | SR_WRITE}, {"CTR_EL0", REG_CTR_EL0, 0x1b0020, SR_READ}, {"CurrentEL", REG_CurrentEL, 0x184240, SR_READ}, {"DAIF", REG_DAIF, 0x1b4220, SR_READ | SR_WRITE}, {"DBGAUTHSTATUS_EL1", REG_DBGAUTHSTATUS_EL1, 0x107ec0, SR_READ}, {"DBGBCR0_EL1", REG_DBGBCR0_EL1, 0x1000a0, SR_READ | SR_WRITE}, {"DBGBCR1_EL1", REG_DBGBCR1_EL1, 0x1001a0, SR_READ | SR_WRITE}, {"DBGBCR2_EL1", REG_DBGBCR2_EL1, 0x1002a0, SR_READ | SR_WRITE}, {"DBGBCR3_EL1", REG_DBGBCR3_EL1, 0x1003a0, SR_READ | SR_WRITE}, {"DBGBCR4_EL1", REG_DBGBCR4_EL1, 0x1004a0, SR_READ | SR_WRITE}, {"DBGBCR5_EL1", REG_DBGBCR5_EL1, 0x1005a0, SR_READ | SR_WRITE}, {"DBGBCR6_EL1", REG_DBGBCR6_EL1, 0x1006a0, SR_READ | SR_WRITE}, {"DBGBCR7_EL1", REG_DBGBCR7_EL1, 0x1007a0, SR_READ | SR_WRITE}, {"DBGBCR8_EL1", REG_DBGBCR8_EL1, 0x1008a0, SR_READ | SR_WRITE}, {"DBGBCR9_EL1", REG_DBGBCR9_EL1, 0x1009a0, SR_READ | SR_WRITE}, {"DBGBCR10_EL1", REG_DBGBCR10_EL1, 0x100aa0, SR_READ | SR_WRITE}, {"DBGBCR11_EL1", REG_DBGBCR11_EL1, 0x100ba0, SR_READ | SR_WRITE}, {"DBGBCR12_EL1", REG_DBGBCR12_EL1, 0x100ca0, SR_READ | SR_WRITE}, {"DBGBCR13_EL1", REG_DBGBCR13_EL1, 0x100da0, SR_READ | SR_WRITE}, {"DBGBCR14_EL1", REG_DBGBCR14_EL1, 0x100ea0, SR_READ | SR_WRITE}, {"DBGBCR15_EL1", REG_DBGBCR15_EL1, 0x100fa0, SR_READ | SR_WRITE}, {"DBGBVR0_EL1", REG_DBGBVR0_EL1, 0x100080, SR_READ | SR_WRITE}, {"DBGBVR1_EL1", REG_DBGBVR1_EL1, 0x100180, SR_READ | SR_WRITE}, {"DBGBVR2_EL1", REG_DBGBVR2_EL1, 0x100280, SR_READ | SR_WRITE}, {"DBGBVR3_EL1", REG_DBGBVR3_EL1, 0x100380, SR_READ | SR_WRITE}, {"DBGBVR4_EL1", REG_DBGBVR4_EL1, 0x100480, SR_READ | SR_WRITE}, {"DBGBVR5_EL1", REG_DBGBVR5_EL1, 0x100580, SR_READ | SR_WRITE}, {"DBGBVR6_EL1", REG_DBGBVR6_EL1, 0x100680, SR_READ | SR_WRITE}, {"DBGBVR7_EL1", REG_DBGBVR7_EL1, 0x100780, SR_READ | SR_WRITE}, {"DBGBVR8_EL1", REG_DBGBVR8_EL1, 0x100880, SR_READ | SR_WRITE}, {"DBGBVR9_EL1", REG_DBGBVR9_EL1, 0x100980, SR_READ | SR_WRITE}, {"DBGBVR10_EL1", REG_DBGBVR10_EL1, 0x100a80, SR_READ | SR_WRITE}, {"DBGBVR11_EL1", REG_DBGBVR11_EL1, 0x100b80, SR_READ | SR_WRITE}, {"DBGBVR12_EL1", REG_DBGBVR12_EL1, 0x100c80, SR_READ | SR_WRITE}, {"DBGBVR13_EL1", REG_DBGBVR13_EL1, 0x100d80, SR_READ | SR_WRITE}, {"DBGBVR14_EL1", REG_DBGBVR14_EL1, 0x100e80, SR_READ | SR_WRITE}, {"DBGBVR15_EL1", REG_DBGBVR15_EL1, 0x100f80, SR_READ | SR_WRITE}, {"DBGCLAIMCLR_EL1", REG_DBGCLAIMCLR_EL1, 0x1079c0, SR_READ | SR_WRITE}, {"DBGCLAIMSET_EL1", REG_DBGCLAIMSET_EL1, 0x1078c0, SR_READ | SR_WRITE}, {"DBGDTR_EL0", REG_DBGDTR_EL0, 0x130400, SR_READ | SR_WRITE}, {"DBGDTRRX_EL0", REG_DBGDTRRX_EL0, 0x130500, SR_READ}, {"DBGDTRTX_EL0", REG_DBGDTRTX_EL0, 0x130500, SR_WRITE}, {"DBGPRCR_EL1", REG_DBGPRCR_EL1, 0x101480, SR_READ | SR_WRITE}, {"DBGWCR0_EL1", REG_DBGWCR0_EL1, 0x1000e0, SR_READ | SR_WRITE}, {"DBGWCR1_EL1", REG_DBGWCR1_EL1, 0x1001e0, SR_READ | SR_WRITE}, {"DBGWCR2_EL1", REG_DBGWCR2_EL1, 0x1002e0, SR_READ | SR_WRITE}, {"DBGWCR3_EL1", REG_DBGWCR3_EL1, 0x1003e0, SR_READ | SR_WRITE}, {"DBGWCR4_EL1", REG_DBGWCR4_EL1, 0x1004e0, SR_READ | SR_WRITE}, {"DBGWCR5_EL1", REG_DBGWCR5_EL1, 0x1005e0, SR_READ | SR_WRITE}, {"DBGWCR6_EL1", REG_DBGWCR6_EL1, 0x1006e0, SR_READ | SR_WRITE}, {"DBGWCR7_EL1", REG_DBGWCR7_EL1, 0x1007e0, SR_READ | SR_WRITE}, {"DBGWCR8_EL1", REG_DBGWCR8_EL1, 0x1008e0, SR_READ | SR_WRITE}, {"DBGWCR9_EL1", REG_DBGWCR9_EL1, 0x1009e0, SR_READ | SR_WRITE}, {"DBGWCR10_EL1", REG_DBGWCR10_EL1, 0x100ae0, SR_READ | SR_WRITE}, {"DBGWCR11_EL1", REG_DBGWCR11_EL1, 0x100be0, SR_READ | SR_WRITE}, {"DBGWCR12_EL1", REG_DBGWCR12_EL1, 0x100ce0, SR_READ | SR_WRITE}, {"DBGWCR13_EL1", REG_DBGWCR13_EL1, 0x100de0, SR_READ | SR_WRITE}, {"DBGWCR14_EL1", REG_DBGWCR14_EL1, 0x100ee0, SR_READ | SR_WRITE}, {"DBGWCR15_EL1", REG_DBGWCR15_EL1, 0x100fe0, SR_READ | SR_WRITE}, {"DBGWVR0_EL1", REG_DBGWVR0_EL1, 0x1000c0, SR_READ | SR_WRITE}, {"DBGWVR1_EL1", REG_DBGWVR1_EL1, 0x1001c0, SR_READ | SR_WRITE}, {"DBGWVR2_EL1", REG_DBGWVR2_EL1, 0x1002c0, SR_READ | SR_WRITE}, {"DBGWVR3_EL1", REG_DBGWVR3_EL1, 0x1003c0, SR_READ | SR_WRITE}, {"DBGWVR4_EL1", REG_DBGWVR4_EL1, 0x1004c0, SR_READ | SR_WRITE}, {"DBGWVR5_EL1", REG_DBGWVR5_EL1, 0x1005c0, SR_READ | SR_WRITE}, {"DBGWVR6_EL1", REG_DBGWVR6_EL1, 0x1006c0, SR_READ | SR_WRITE}, {"DBGWVR7_EL1", REG_DBGWVR7_EL1, 0x1007c0, SR_READ | SR_WRITE}, {"DBGWVR8_EL1", REG_DBGWVR8_EL1, 0x1008c0, SR_READ | SR_WRITE}, {"DBGWVR9_EL1", REG_DBGWVR9_EL1, 0x1009c0, SR_READ | SR_WRITE}, {"DBGWVR10_EL1", REG_DBGWVR10_EL1, 0x100ac0, SR_READ | SR_WRITE}, {"DBGWVR11_EL1", REG_DBGWVR11_EL1, 0x100bc0, SR_READ | SR_WRITE}, {"DBGWVR12_EL1", REG_DBGWVR12_EL1, 0x100cc0, SR_READ | SR_WRITE}, {"DBGWVR13_EL1", REG_DBGWVR13_EL1, 0x100dc0, SR_READ | SR_WRITE}, {"DBGWVR14_EL1", REG_DBGWVR14_EL1, 0x100ec0, SR_READ | SR_WRITE}, {"DBGWVR15_EL1", REG_DBGWVR15_EL1, 0x100fc0, SR_READ | SR_WRITE}, {"DCZID_EL0", REG_DCZID_EL0, 0x1b00e0, SR_READ}, {"DISR_EL1", REG_DISR_EL1, 0x18c120, SR_READ | SR_WRITE}, {"DIT", REG_DIT, 0x1b42a0, SR_READ | SR_WRITE}, {"DLR_EL0", REG_DLR_EL0, 0x1b4520, SR_READ | SR_WRITE}, {"DSPSR_EL0", REG_DSPSR_EL0, 0x1b4500, SR_READ | SR_WRITE}, {"ELR_EL1", REG_ELR_EL1, 0x184020, SR_READ | SR_WRITE}, {"ERRIDR_EL1", REG_ERRIDR_EL1, 0x185300, SR_READ}, {"ERRSELR_EL1", REG_ERRSELR_EL1, 0x185320, SR_READ | SR_WRITE}, {"ERXADDR_EL1", REG_ERXADDR_EL1, 0x185460, SR_READ | SR_WRITE}, {"ERXCTLR_EL1", REG_ERXCTLR_EL1, 0x185420, SR_READ | SR_WRITE}, {"ERXFR_EL1", REG_ERXFR_EL1, 0x185400, SR_READ}, {"ERXMISC0_EL1", REG_ERXMISC0_EL1, 0x185500, SR_READ | SR_WRITE}, {"ERXMISC1_EL1", REG_ERXMISC1_EL1, 0x185520, SR_READ | SR_WRITE}, {"ERXMISC2_EL1", REG_ERXMISC2_EL1, 0x185540, SR_READ | SR_WRITE}, {"ERXMISC3_EL1", REG_ERXMISC3_EL1, 0x185560, SR_READ | SR_WRITE}, {"ERXPFGCDN_EL1", REG_ERXPFGCDN_EL1, 0x1854c0, SR_READ | SR_WRITE}, {"ERXPFGCTL_EL1", REG_ERXPFGCTL_EL1, 0x1854a0, SR_READ | SR_WRITE}, {"ERXPFGF_EL1", REG_ERXPFGF_EL1, 0x185480, SR_READ}, {"ERXSTATUS_EL1", REG_ERXSTATUS_EL1, 0x185440, SR_READ | SR_WRITE}, {"ESR_EL1", REG_ESR_EL1, 0x185200, SR_READ | SR_WRITE}, {"FAR_EL1", REG_FAR_EL1, 0x186000, SR_READ | SR_WRITE}, {"FPCR", REG_FPCR, 0x1b4400, SR_READ | SR_WRITE}, {"FPSR", REG_FPSR, 0x1b4420, SR_READ | SR_WRITE}, {"GCR_EL1", REG_GCR_EL1, 0x1810c0, SR_READ | SR_WRITE}, {"GMID_EL1", REG_GMID_EL1, 0x31400, SR_READ}, {"ICC_AP0R0_EL1", REG_ICC_AP0R0_EL1, 0x18c880, SR_READ | SR_WRITE}, {"ICC_AP0R1_EL1", REG_ICC_AP0R1_EL1, 0x18c8a0, SR_READ | SR_WRITE}, {"ICC_AP0R2_EL1", REG_ICC_AP0R2_EL1, 0x18c8c0, SR_READ | SR_WRITE}, {"ICC_AP0R3_EL1", REG_ICC_AP0R3_EL1, 0x18c8e0, SR_READ | SR_WRITE}, {"ICC_AP1R0_EL1", REG_ICC_AP1R0_EL1, 0x18c900, SR_READ | SR_WRITE}, {"ICC_AP1R1_EL1", REG_ICC_AP1R1_EL1, 0x18c920, SR_READ | SR_WRITE}, {"ICC_AP1R2_EL1", REG_ICC_AP1R2_EL1, 0x18c940, SR_READ | SR_WRITE}, {"ICC_AP1R3_EL1", REG_ICC_AP1R3_EL1, 0x18c960, SR_READ | SR_WRITE}, {"ICC_ASGI1R_EL1", REG_ICC_ASGI1R_EL1, 0x18cbc0, SR_WRITE}, {"ICC_BPR0_EL1", REG_ICC_BPR0_EL1, 0x18c860, SR_READ | SR_WRITE}, {"ICC_BPR1_EL1", REG_ICC_BPR1_EL1, 0x18cc60, SR_READ | SR_WRITE}, {"ICC_CTLR_EL1", REG_ICC_CTLR_EL1, 0x18cc80, SR_READ | SR_WRITE}, {"ICC_DIR_EL1", REG_ICC_DIR_EL1, 0x18cb20, SR_WRITE}, {"ICC_EOIR0_EL1", REG_ICC_EOIR0_EL1, 0x18c820, SR_WRITE}, {"ICC_EOIR1_EL1", REG_ICC_EOIR1_EL1, 0x18cc20, SR_WRITE}, {"ICC_HPPIR0_EL1", REG_ICC_HPPIR0_EL1, 0x18c840, SR_READ}, {"ICC_HPPIR1_EL1", REG_ICC_HPPIR1_EL1, 0x18cc40, SR_READ}, {"ICC_IAR0_EL1", REG_ICC_IAR0_EL1, 0x18c800, SR_READ}, {"ICC_IAR1_EL1", REG_ICC_IAR1_EL1, 0x18cc00, SR_READ}, {"ICC_IGRPEN0_EL1", REG_ICC_IGRPEN0_EL1, 0x18ccc0, SR_READ | SR_WRITE}, {"ICC_IGRPEN1_EL1", REG_ICC_IGRPEN1_EL1, 0x18cce0, SR_READ | SR_WRITE}, {"ICC_PMR_EL1", REG_ICC_PMR_EL1, 0x184600, SR_READ | SR_WRITE}, {"ICC_RPR_EL1", REG_ICC_RPR_EL1, 0x18cb60, SR_READ}, {"ICC_SGI0R_EL1", REG_ICC_SGI0R_EL1, 0x18cbe0, SR_WRITE}, {"ICC_SGI1R_EL1", REG_ICC_SGI1R_EL1, 0x18cba0, SR_WRITE}, {"ICC_SRE_EL1", REG_ICC_SRE_EL1, 0x18cca0, SR_READ | SR_WRITE}, {"ICV_AP0R0_EL1", REG_ICV_AP0R0_EL1, 0x18c880, SR_READ | SR_WRITE}, {"ICV_AP0R1_EL1", REG_ICV_AP0R1_EL1, 0x18c8a0, SR_READ | SR_WRITE}, {"ICV_AP0R2_EL1", REG_ICV_AP0R2_EL1, 0x18c8c0, SR_READ | SR_WRITE}, {"ICV_AP0R3_EL1", REG_ICV_AP0R3_EL1, 0x18c8e0, SR_READ | SR_WRITE}, {"ICV_AP1R0_EL1", REG_ICV_AP1R0_EL1, 0x18c900, SR_READ | SR_WRITE}, {"ICV_AP1R1_EL1", REG_ICV_AP1R1_EL1, 0x18c920, SR_READ | SR_WRITE}, {"ICV_AP1R2_EL1", REG_ICV_AP1R2_EL1, 0x18c940, SR_READ | SR_WRITE}, {"ICV_AP1R3_EL1", REG_ICV_AP1R3_EL1, 0x18c960, SR_READ | SR_WRITE}, {"ICV_BPR0_EL1", REG_ICV_BPR0_EL1, 0x18c860, SR_READ | SR_WRITE}, {"ICV_BPR1_EL1", REG_ICV_BPR1_EL1, 0x18cc60, SR_READ | SR_WRITE}, {"ICV_CTLR_EL1", REG_ICV_CTLR_EL1, 0x18cc80, SR_READ | SR_WRITE}, {"ICV_DIR_EL1", REG_ICV_DIR_EL1, 0x18cb20, SR_WRITE}, {"ICV_EOIR0_EL1", REG_ICV_EOIR0_EL1, 0x18c820, SR_WRITE}, {"ICV_EOIR1_EL1", REG_ICV_EOIR1_EL1, 0x18cc20, SR_WRITE}, {"ICV_HPPIR0_EL1", REG_ICV_HPPIR0_EL1, 0x18c840, SR_READ}, {"ICV_HPPIR1_EL1", REG_ICV_HPPIR1_EL1, 0x18cc40, SR_READ}, {"ICV_IAR0_EL1", REG_ICV_IAR0_EL1, 0x18c800, SR_READ}, {"ICV_IAR1_EL1", REG_ICV_IAR1_EL1, 0x18cc00, SR_READ}, {"ICV_IGRPEN0_EL1", REG_ICV_IGRPEN0_EL1, 0x18ccc0, SR_READ | SR_WRITE}, {"ICV_IGRPEN1_EL1", REG_ICV_IGRPEN1_EL1, 0x18cce0, SR_READ | SR_WRITE}, {"ICV_PMR_EL1", REG_ICV_PMR_EL1, 0x184600, SR_READ | SR_WRITE}, {"ICV_RPR_EL1", REG_ICV_RPR_EL1, 0x18cb60, SR_READ}, {"ID_AA64AFR0_EL1", REG_ID_AA64AFR0_EL1, 0x180580, SR_READ}, {"ID_AA64AFR1_EL1", REG_ID_AA64AFR1_EL1, 0x1805a0, SR_READ}, {"ID_AA64DFR0_EL1", REG_ID_AA64DFR0_EL1, 0x180500, SR_READ}, {"ID_AA64DFR1_EL1", REG_ID_AA64DFR1_EL1, 0x180520, SR_READ}, {"ID_AA64ISAR0_EL1", REG_ID_AA64ISAR0_EL1, 0x180600, SR_READ}, {"ID_AA64ISAR1_EL1", REG_ID_AA64ISAR1_EL1, 0x180620, SR_READ}, {"ID_AA64MMFR0_EL1", REG_ID_AA64MMFR0_EL1, 0x180700, SR_READ}, {"ID_AA64MMFR1_EL1", REG_ID_AA64MMFR1_EL1, 0x180720, SR_READ}, {"ID_AA64MMFR2_EL1", REG_ID_AA64MMFR2_EL1, 0x180740, SR_READ}, {"ID_AA64PFR0_EL1", REG_ID_AA64PFR0_EL1, 0x180400, SR_READ}, {"ID_AA64PFR1_EL1", REG_ID_AA64PFR1_EL1, 0x180420, SR_READ}, {"ID_AA64ZFR0_EL1", REG_ID_AA64ZFR0_EL1, 0x180480, SR_READ}, {"ID_AFR0_EL1", REG_ID_AFR0_EL1, 0x180160, SR_READ}, {"ID_DFR0_EL1", REG_ID_DFR0_EL1, 0x180140, SR_READ}, {"ID_ISAR0_EL1", REG_ID_ISAR0_EL1, 0x180200, SR_READ}, {"ID_ISAR1_EL1", REG_ID_ISAR1_EL1, 0x180220, SR_READ}, {"ID_ISAR2_EL1", REG_ID_ISAR2_EL1, 0x180240, SR_READ}, {"ID_ISAR3_EL1", REG_ID_ISAR3_EL1, 0x180260, SR_READ}, {"ID_ISAR4_EL1", REG_ID_ISAR4_EL1, 0x180280, SR_READ}, {"ID_ISAR5_EL1", REG_ID_ISAR5_EL1, 0x1802a0, SR_READ}, {"ID_ISAR6_EL1", REG_ID_ISAR6_EL1, 0x1802e0, SR_READ}, {"ID_MMFR0_EL1", REG_ID_MMFR0_EL1, 0x180180, SR_READ}, {"ID_MMFR1_EL1", REG_ID_MMFR1_EL1, 0x1801a0, SR_READ}, {"ID_MMFR2_EL1", REG_ID_MMFR2_EL1, 0x1801c0, SR_READ}, {"ID_MMFR3_EL1", REG_ID_MMFR3_EL1, 0x1801e0, SR_READ}, {"ID_MMFR4_EL1", REG_ID_MMFR4_EL1, 0x1802c0, SR_READ}, {"ID_PFR0_EL1", REG_ID_PFR0_EL1, 0x180100, SR_READ}, {"ID_PFR1_EL1", REG_ID_PFR1_EL1, 0x180120, SR_READ}, {"ID_PFR2_EL1", REG_ID_PFR2_EL1, 0x180380, SR_READ}, {"ISR_EL1", REG_ISR_EL1, 0x18c100, SR_READ}, {"LORC_EL1", REG_LORC_EL1, 0x18a460, SR_READ | SR_WRITE}, {"LOREA_EL1", REG_LOREA_EL1, 0x18a420, SR_READ | SR_WRITE}, {"LORID_EL1", REG_LORID_EL1, 0x18a4e0, SR_READ}, {"LORN_EL1", REG_LORN_EL1, 0x18a440, SR_READ | SR_WRITE}, {"LORSA_EL1", REG_LORSA_EL1, 0x18a400, SR_READ | SR_WRITE}, {"MAIR_EL1", REG_MAIR_EL1, 0x18a200, SR_READ | SR_WRITE}, {"MDCCINT_EL1", REG_MDCCINT_EL1, 0x100200, SR_READ | SR_WRITE}, {"MDCCSR_EL0", REG_MDCCSR_EL0, 0x130100, SR_READ}, {"MDRAR_EL1", REG_MDRAR_EL1, 0x101000, SR_READ}, {"MDSCR_EL1", REG_MDSCR_EL1, 0x100240, SR_READ | SR_WRITE}, {"MIDR_EL1", REG_MIDR_EL1, 0x180000, SR_READ}, {"MPAM0_EL1", REG_MPAM0_EL1, 0x18a520, SR_READ | SR_WRITE}, {"MPAM1_EL1", REG_MPAM1_EL1, 0x18a500, SR_READ | SR_WRITE}, {"MPAMIDR_EL1", REG_MPAMIDR_EL1, 0x18a480, SR_READ}, {"MPIDR_EL1", REG_MPIDR_EL1, 0x1800a0, SR_READ}, {"MVFR0_EL1", REG_MVFR0_EL1, 0x180300, SR_READ}, {"MVFR1_EL1", REG_MVFR1_EL1, 0x180320, SR_READ}, {"MVFR2_EL1", REG_MVFR2_EL1, 0x180340, SR_READ}, {"NZCV", REG_NZCV, 0x1b4200, SR_READ | SR_WRITE}, {"OSDLR_EL1", REG_OSDLR_EL1, 0x101380, SR_READ | SR_WRITE}, {"OSDTRRX_EL1", REG_OSDTRRX_EL1, 0x100040, SR_READ | SR_WRITE}, {"OSDTRTX_EL1", REG_OSDTRTX_EL1, 0x100340, SR_READ | SR_WRITE}, {"OSECCR_EL1", REG_OSECCR_EL1, 0x100640, SR_READ | SR_WRITE}, {"OSLAR_EL1", REG_OSLAR_EL1, 0x101080, SR_WRITE}, {"OSLSR_EL1", REG_OSLSR_EL1, 0x101180, SR_READ}, {"PAN", REG_PAN, 0x184260, SR_READ | SR_WRITE}, {"PAR_EL1", REG_PAR_EL1, 0x187400, SR_READ | SR_WRITE}, {"PMBIDR_EL1", REG_PMBIDR_EL1, 0x189ae0, SR_READ}, {"PMBLIMITR_EL1", REG_PMBLIMITR_EL1, 0x189a00, SR_READ | SR_WRITE}, {"PMBPTR_EL1", REG_PMBPTR_EL1, 0x189a20, SR_READ | SR_WRITE}, {"PMBSR_EL1", REG_PMBSR_EL1, 0x189a60, SR_READ | SR_WRITE}, {"PMCCFILTR_EL0", REG_PMCCFILTR_EL0, 0x1befe0, SR_READ | SR_WRITE}, {"PMCCNTR_EL0", REG_PMCCNTR_EL0, 0x1b9d00, SR_READ | SR_WRITE}, {"PMCEID0_EL0", REG_PMCEID0_EL0, 0x1b9cc0, SR_READ}, {"PMCEID1_EL0", REG_PMCEID1_EL0, 0x1b9ce0, SR_READ}, {"PMCNTENCLR_EL0", REG_PMCNTENCLR_EL0, 0x1b9c40, SR_READ | SR_WRITE}, {"PMCNTENSET_EL0", REG_PMCNTENSET_EL0, 0x1b9c20, SR_READ | SR_WRITE}, {"PMCR_EL0", REG_PMCR_EL0, 0x1b9c00, SR_READ | SR_WRITE}, {"PMEVCNTR0_EL0", REG_PMEVCNTR0_EL0, 0x1be800, SR_READ | SR_WRITE}, {"PMEVCNTR1_EL0", REG_PMEVCNTR1_EL0, 0x1be820, SR_READ | SR_WRITE}, {"PMEVCNTR2_EL0", REG_PMEVCNTR2_EL0, 0x1be840, SR_READ | SR_WRITE}, {"PMEVCNTR3_EL0", REG_PMEVCNTR3_EL0, 0x1be860, SR_READ | SR_WRITE}, {"PMEVCNTR4_EL0", REG_PMEVCNTR4_EL0, 0x1be880, SR_READ | SR_WRITE}, {"PMEVCNTR5_EL0", REG_PMEVCNTR5_EL0, 0x1be8a0, SR_READ | SR_WRITE}, {"PMEVCNTR6_EL0", REG_PMEVCNTR6_EL0, 0x1be8c0, SR_READ | SR_WRITE}, {"PMEVCNTR7_EL0", REG_PMEVCNTR7_EL0, 0x1be8e0, SR_READ | SR_WRITE}, {"PMEVCNTR8_EL0", REG_PMEVCNTR8_EL0, 0x1be900, SR_READ | SR_WRITE}, {"PMEVCNTR9_EL0", REG_PMEVCNTR9_EL0, 0x1be920, SR_READ | SR_WRITE}, {"PMEVCNTR10_EL0", REG_PMEVCNTR10_EL0, 0x1be940, SR_READ | SR_WRITE}, {"PMEVCNTR11_EL0", REG_PMEVCNTR11_EL0, 0x1be960, SR_READ | SR_WRITE}, {"PMEVCNTR12_EL0", REG_PMEVCNTR12_EL0, 0x1be980, SR_READ | SR_WRITE}, {"PMEVCNTR13_EL0", REG_PMEVCNTR13_EL0, 0x1be9a0, SR_READ | SR_WRITE}, {"PMEVCNTR14_EL0", REG_PMEVCNTR14_EL0, 0x1be9c0, SR_READ | SR_WRITE}, {"PMEVCNTR15_EL0", REG_PMEVCNTR15_EL0, 0x1be9e0, SR_READ | SR_WRITE}, {"PMEVCNTR16_EL0", REG_PMEVCNTR16_EL0, 0x1bea00, SR_READ | SR_WRITE}, {"PMEVCNTR17_EL0", REG_PMEVCNTR17_EL0, 0x1bea20, SR_READ | SR_WRITE}, {"PMEVCNTR18_EL0", REG_PMEVCNTR18_EL0, 0x1bea40, SR_READ | SR_WRITE}, {"PMEVCNTR19_EL0", REG_PMEVCNTR19_EL0, 0x1bea60, SR_READ | SR_WRITE}, {"PMEVCNTR20_EL0", REG_PMEVCNTR20_EL0, 0x1bea80, SR_READ | SR_WRITE}, {"PMEVCNTR21_EL0", REG_PMEVCNTR21_EL0, 0x1beaa0, SR_READ | SR_WRITE}, {"PMEVCNTR22_EL0", REG_PMEVCNTR22_EL0, 0x1beac0, SR_READ | SR_WRITE}, {"PMEVCNTR23_EL0", REG_PMEVCNTR23_EL0, 0x1beae0, SR_READ | SR_WRITE}, {"PMEVCNTR24_EL0", REG_PMEVCNTR24_EL0, 0x1beb00, SR_READ | SR_WRITE}, {"PMEVCNTR25_EL0", REG_PMEVCNTR25_EL0, 0x1beb20, SR_READ | SR_WRITE}, {"PMEVCNTR26_EL0", REG_PMEVCNTR26_EL0, 0x1beb40, SR_READ | SR_WRITE}, {"PMEVCNTR27_EL0", REG_PMEVCNTR27_EL0, 0x1beb60, SR_READ | SR_WRITE}, {"PMEVCNTR28_EL0", REG_PMEVCNTR28_EL0, 0x1beb80, SR_READ | SR_WRITE}, {"PMEVCNTR29_EL0", REG_PMEVCNTR29_EL0, 0x1beba0, SR_READ | SR_WRITE}, {"PMEVCNTR30_EL0", REG_PMEVCNTR30_EL0, 0x1bebc0, SR_READ | SR_WRITE}, {"PMEVTYPER0_EL0", REG_PMEVTYPER0_EL0, 0x1bec00, SR_READ | SR_WRITE}, {"PMEVTYPER1_EL0", REG_PMEVTYPER1_EL0, 0x1bec20, SR_READ | SR_WRITE}, {"PMEVTYPER2_EL0", REG_PMEVTYPER2_EL0, 0x1bec40, SR_READ | SR_WRITE}, {"PMEVTYPER3_EL0", REG_PMEVTYPER3_EL0, 0x1bec60, SR_READ | SR_WRITE}, {"PMEVTYPER4_EL0", REG_PMEVTYPER4_EL0, 0x1bec80, SR_READ | SR_WRITE}, {"PMEVTYPER5_EL0", REG_PMEVTYPER5_EL0, 0x1beca0, SR_READ | SR_WRITE}, {"PMEVTYPER6_EL0", REG_PMEVTYPER6_EL0, 0x1becc0, SR_READ | SR_WRITE}, {"PMEVTYPER7_EL0", REG_PMEVTYPER7_EL0, 0x1bece0, SR_READ | SR_WRITE}, {"PMEVTYPER8_EL0", REG_PMEVTYPER8_EL0, 0x1bed00, SR_READ | SR_WRITE}, {"PMEVTYPER9_EL0", REG_PMEVTYPER9_EL0, 0x1bed20, SR_READ | SR_WRITE}, {"PMEVTYPER10_EL0", REG_PMEVTYPER10_EL0, 0x1bed40, SR_READ | SR_WRITE}, {"PMEVTYPER11_EL0", REG_PMEVTYPER11_EL0, 0x1bed60, SR_READ | SR_WRITE}, {"PMEVTYPER12_EL0", REG_PMEVTYPER12_EL0, 0x1bed80, SR_READ | SR_WRITE}, {"PMEVTYPER13_EL0", REG_PMEVTYPER13_EL0, 0x1beda0, SR_READ | SR_WRITE}, {"PMEVTYPER14_EL0", REG_PMEVTYPER14_EL0, 0x1bedc0, SR_READ | SR_WRITE}, {"PMEVTYPER15_EL0", REG_PMEVTYPER15_EL0, 0x1bede0, SR_READ | SR_WRITE}, {"PMEVTYPER16_EL0", REG_PMEVTYPER16_EL0, 0x1bee00, SR_READ | SR_WRITE}, {"PMEVTYPER17_EL0", REG_PMEVTYPER17_EL0, 0x1bee20, SR_READ | SR_WRITE}, {"PMEVTYPER18_EL0", REG_PMEVTYPER18_EL0, 0x1bee40, SR_READ | SR_WRITE}, {"PMEVTYPER19_EL0", REG_PMEVTYPER19_EL0, 0x1bee60, SR_READ | SR_WRITE}, {"PMEVTYPER20_EL0", REG_PMEVTYPER20_EL0, 0x1bee80, SR_READ | SR_WRITE}, {"PMEVTYPER21_EL0", REG_PMEVTYPER21_EL0, 0x1beea0, SR_READ | SR_WRITE}, {"PMEVTYPER22_EL0", REG_PMEVTYPER22_EL0, 0x1beec0, SR_READ | SR_WRITE}, {"PMEVTYPER23_EL0", REG_PMEVTYPER23_EL0, 0x1beee0, SR_READ | SR_WRITE}, {"PMEVTYPER24_EL0", REG_PMEVTYPER24_EL0, 0x1bef00, SR_READ | SR_WRITE}, {"PMEVTYPER25_EL0", REG_PMEVTYPER25_EL0, 0x1bef20, SR_READ | SR_WRITE}, {"PMEVTYPER26_EL0", REG_PMEVTYPER26_EL0, 0x1bef40, SR_READ | SR_WRITE}, {"PMEVTYPER27_EL0", REG_PMEVTYPER27_EL0, 0x1bef60, SR_READ | SR_WRITE}, {"PMEVTYPER28_EL0", REG_PMEVTYPER28_EL0, 0x1bef80, SR_READ | SR_WRITE}, {"PMEVTYPER29_EL0", REG_PMEVTYPER29_EL0, 0x1befa0, SR_READ | SR_WRITE}, {"PMEVTYPER30_EL0", REG_PMEVTYPER30_EL0, 0x1befc0, SR_READ | SR_WRITE}, {"PMINTENCLR_EL1", REG_PMINTENCLR_EL1, 0x189e40, SR_READ | SR_WRITE}, {"PMINTENSET_EL1", REG_PMINTENSET_EL1, 0x189e20, SR_READ | SR_WRITE}, {"PMMIR_EL1", REG_PMMIR_EL1, 0x189ec0, SR_READ}, {"PMOVSCLR_EL0", REG_PMOVSCLR_EL0, 0x1b9c60, SR_READ | SR_WRITE}, {"PMOVSSET_EL0", REG_PMOVSSET_EL0, 0x1b9e60, SR_READ | SR_WRITE}, {"PMSCR_EL1", REG_PMSCR_EL1, 0x189900, SR_READ | SR_WRITE}, {"PMSELR_EL0", REG_PMSELR_EL0, 0x1b9ca0, SR_READ | SR_WRITE}, {"PMSEVFR_EL1", REG_PMSEVFR_EL1, 0x1899a0, SR_READ | SR_WRITE}, {"PMSFCR_EL1", REG_PMSFCR_EL1, 0x189980, SR_READ | SR_WRITE}, {"PMSICR_EL1", REG_PMSICR_EL1, 0x189940, SR_READ | SR_WRITE}, {"PMSIDR_EL1", REG_PMSIDR_EL1, 0x1899e0, SR_READ}, {"PMSIRR_EL1", REG_PMSIRR_EL1, 0x189960, SR_READ | SR_WRITE}, {"PMSLATFR_EL1", REG_PMSLATFR_EL1, 0x1899c0, SR_READ | SR_WRITE}, {"PMSWINC_EL0", REG_PMSWINC_EL0, 0x1b9c80, SR_WRITE}, {"PMUSERENR_EL0", REG_PMUSERENR_EL0, 0x1b9e00, SR_READ | SR_WRITE}, {"PMXEVCNTR_EL0", REG_PMXEVCNTR_EL0, 0x1b9d40, SR_READ | SR_WRITE}, {"PMXEVTYPER_EL0", REG_PMXEVTYPER_EL0, 0x1b9d20, SR_READ | SR_WRITE}, {"REVIDR_EL1", REG_REVIDR_EL1, 0x1800c0, SR_READ}, {"RGSR_EL1", REG_RGSR_EL1, 0x1810a0, SR_READ | SR_WRITE}, {"RMR_EL1", REG_RMR_EL1, 0x18c040, SR_READ | SR_WRITE}, {"RNDR", REG_RNDR, 0x1b2400, SR_READ}, {"RNDRRS", REG_RNDRRS, 0x1b2420, SR_READ}, {"RVBAR_EL1", REG_RVBAR_EL1, 0x18c020, SR_READ}, {"SCTLR_EL1", REG_SCTLR_EL1, 0x181000, SR_READ | SR_WRITE}, {"SCXTNUM_EL0", REG_SCXTNUM_EL0, 0x1bd0e0, SR_READ | SR_WRITE}, {"SCXTNUM_EL1", REG_SCXTNUM_EL1, 0x18d0e0, SR_READ | SR_WRITE}, {"SP_EL0", REG_SP_EL0, 0x184100, SR_READ | SR_WRITE}, {"SP_EL1", REG_SP_EL1, 0x1c4100, SR_READ | SR_WRITE}, {"SPSel", REG_SPSel, 0x184200, SR_READ | SR_WRITE}, {"SPSR_abt", REG_SPSR_abt, 0x1c4320, SR_READ | SR_WRITE}, {"SPSR_EL1", REG_SPSR_EL1, 0x184000, SR_READ | SR_WRITE}, {"SPSR_fiq", REG_SPSR_fiq, 0x1c4360, SR_READ | SR_WRITE}, {"SPSR_irq", REG_SPSR_irq, 0x1c4300, SR_READ | SR_WRITE}, {"SPSR_und", REG_SPSR_und, 0x1c4340, SR_READ | SR_WRITE}, {"SSBS", REG_SSBS, 0x1b42c0, SR_READ | SR_WRITE}, {"TCO", REG_TCO, 0x1b42e0, SR_READ | SR_WRITE}, {"TCR_EL1", REG_TCR_EL1, 0x182040, SR_READ | SR_WRITE}, {"TFSR_EL1", REG_TFSR_EL1, 0x185600, SR_READ | SR_WRITE}, {"TFSRE0_EL1", REG_TFSRE0_EL1, 0x185620, SR_READ | SR_WRITE}, {"TPIDR_EL0", REG_TPIDR_EL0, 0x1bd040, SR_READ | SR_WRITE}, {"TPIDR_EL1", REG_TPIDR_EL1, 0x18d080, SR_READ | SR_WRITE}, {"TPIDRRO_EL0", REG_TPIDRRO_EL0, 0x1bd060, SR_READ | SR_WRITE}, {"TRFCR_EL1", REG_TRFCR_EL1, 0x181220, SR_READ | SR_WRITE}, {"TTBR0_EL1", REG_TTBR0_EL1, 0x182000, SR_READ | SR_WRITE}, {"TTBR1_EL1", REG_TTBR1_EL1, 0x182020, SR_READ | SR_WRITE}, {"UAO", REG_UAO, 0x184280, SR_READ | SR_WRITE}, {"VBAR_EL1", REG_VBAR_EL1, 0x18c000, SR_READ | SR_WRITE}, {"ZCR_EL1", REG_ZCR_EL1, 0x181200, SR_READ | SR_WRITE}, }
func ADR ¶
func ADR(p uint32, o uint32, rt uint32) uint32
func DRconv ¶
func DRconv(a int) string
func FPCCMP ¶
func FPCCMP(m uint32, s uint32, type_ uint32, op uint32) uint32
func FPCMP ¶
func FPCMP(m uint32, s uint32, type_ uint32, op uint32, op2 uint32) uint32
func FPCVTI ¶
func FPCVTI(sf uint32, s uint32, type_ uint32, rmode uint32, op uint32) uint32
func FPOP1S ¶
func FPOP1S(m uint32, s uint32, type_ uint32, op uint32) uint32
func FPOP2S ¶
func FPOP2S(m uint32, s uint32, type_ uint32, op uint32) uint32
func FPOP3S ¶
func FPOP3S(m uint32, s uint32, type_ uint32, op uint32, op2 uint32) uint32
func IsAtomicInstruction ¶
func IsAtomicInstruction(as obj.As) bool
func LD2STR ¶
func LD2STR(o uint32) uint32
func LDSTR ¶
func LDSTR(sz uint32, v uint32, opc uint32) uint32
func LDSTX ¶
func LDSTX(sz uint32, o2 uint32, l uint32, o1 uint32, o0 uint32) uint32
func MOVCONST ¶
func MOVCONST(d int64, s int, rt int) uint32
func OPBIT ¶
func OPBIT(x uint32) uint32
func OPBLR ¶
func OPBLR(x uint32) uint32
func OPBcc ¶
func OPBcc(x uint32) uint32
func OPDP2 ¶
func OPDP2(x uint32) uint32
func OPDP3 ¶
func OPDP3(sf uint32, op54 uint32, op31 uint32, o0 uint32) uint32
func SPCconv ¶
func SPCconv(a int64) string
func SYSARG4 ¶
func SYSARG4(op1 int, Cn int, Cm int, op2 int) int
func SYSARG5 ¶
func SYSARG5(op0 int, op1 int, Cn int, Cm int, op2 int) int
form offset parameter to SYS; special register number
func SYSHINT ¶
func SYSHINT(x uint32) uint32
func SYSOP ¶
func SYSOP(l uint32, op0 uint32, op1 uint32, crn uint32, crm uint32, op2 uint32, rt uint32) uint32
func SysRegEnc ¶
func SysRegEnc(r int16) (string, uint32, uint8)
type Optab ¶
type Optab struct {
// contains filtered or unexported fields
}
type SpecialOperand ¶
type SpecialOperand int
const ( // PRFM SPOP_PLDL1KEEP SpecialOperand = iota // must be the first one SPOP_BEGIN SpecialOperand = iota - 1 // set as the lower bound SPOP_PLDL1STRM SPOP_PLDL2KEEP SPOP_PLDL2STRM SPOP_PLDL3KEEP SPOP_PLDL3STRM SPOP_PLIL1KEEP SPOP_PLIL1STRM SPOP_PLIL2KEEP SPOP_PLIL2STRM SPOP_PLIL3KEEP SPOP_PLIL3STRM SPOP_PSTL1KEEP SPOP_PSTL1STRM SPOP_PSTL2KEEP SPOP_PSTL2STRM SPOP_PSTL3KEEP SPOP_PSTL3STRM // TLBI SPOP_VMALLE1IS SPOP_VAE1IS SPOP_ASIDE1IS SPOP_VAAE1IS SPOP_VALE1IS SPOP_VAALE1IS SPOP_VMALLE1 SPOP_VAE1 SPOP_ASIDE1 SPOP_VAAE1 SPOP_VALE1 SPOP_VAALE1 SPOP_IPAS2E1IS SPOP_IPAS2LE1IS SPOP_ALLE2IS SPOP_VAE2IS SPOP_ALLE1IS SPOP_VALE2IS SPOP_VMALLS12E1IS SPOP_IPAS2E1 SPOP_IPAS2LE1 SPOP_ALLE2 SPOP_VAE2 SPOP_ALLE1 SPOP_VALE2 SPOP_VMALLS12E1 SPOP_ALLE3IS SPOP_VAE3IS SPOP_VALE3IS SPOP_ALLE3 SPOP_VAE3 SPOP_VALE3 SPOP_VMALLE1OS SPOP_VAE1OS SPOP_ASIDE1OS SPOP_VAAE1OS SPOP_VALE1OS SPOP_VAALE1OS SPOP_RVAE1IS SPOP_RVAAE1IS SPOP_RVALE1IS SPOP_RVAALE1IS SPOP_RVAE1OS SPOP_RVAAE1OS SPOP_RVALE1OS SPOP_RVAALE1OS SPOP_RVAE1 SPOP_RVAAE1 SPOP_RVALE1 SPOP_RVAALE1 SPOP_RIPAS2E1IS SPOP_RIPAS2LE1IS SPOP_ALLE2OS SPOP_VAE2OS SPOP_ALLE1OS SPOP_VALE2OS SPOP_VMALLS12E1OS SPOP_RVAE2IS SPOP_RVALE2IS SPOP_IPAS2E1OS SPOP_RIPAS2E1 SPOP_RIPAS2E1OS SPOP_IPAS2LE1OS SPOP_RIPAS2LE1 SPOP_RIPAS2LE1OS SPOP_RVAE2OS SPOP_RVALE2OS SPOP_RVAE2 SPOP_RVALE2 SPOP_ALLE3OS SPOP_VAE3OS SPOP_VALE3OS SPOP_RVAE3IS SPOP_RVALE3IS SPOP_RVAE3OS SPOP_RVALE3OS SPOP_RVAE3 SPOP_RVALE3 // DC SPOP_IVAC SPOP_ISW SPOP_CSW SPOP_CISW SPOP_ZVA SPOP_CVAC SPOP_CVAU SPOP_CIVAC SPOP_IGVAC SPOP_IGSW SPOP_IGDVAC SPOP_IGDSW SPOP_CGSW SPOP_CGDSW SPOP_CIGSW SPOP_CIGDSW SPOP_GVA SPOP_GZVA SPOP_CGVAC SPOP_CGDVAC SPOP_CGVAP SPOP_CGDVAP SPOP_CGVADP SPOP_CGDVADP SPOP_CIGVAC SPOP_CIGDVAC SPOP_CVAP SPOP_CVADP // PSTATE fields SPOP_DAIFSet SPOP_DAIFClr // Condition code, EQ, NE, etc. Their relative order to EQ is matter. SPOP_EQ SPOP_NE SPOP_HS SPOP_LO SPOP_MI SPOP_PL SPOP_VS SPOP_VC SPOP_HI SPOP_LS SPOP_GE SPOP_LT SPOP_GT SPOP_LE SPOP_AL SPOP_NV SPOP_END )
func (SpecialOperand) String ¶
func (i SpecialOperand) String() string