]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
aarch64: Remove F_ARCHEXT flag
authorAlice Carlotti <alice.carlotti@arm.com>
Tue, 2 Sep 2025 14:11:24 +0000 (15:11 +0100)
committerAlice Carlotti <alice.carlotti@arm.com>
Tue, 23 Sep 2025 18:42:43 +0000 (19:42 +0100)
The flag is unnecessary, because we can just unconditionally check the
features field every time.  Having the information duplicated in two
separate fields makes it harder to maintain, particularly in the context
of the upcoming regating patch.

The reg_flags parameter of aarch64_sys_ins_reg_supported_p is now
unused, so remove that as well.

gas/config/tc-aarch64.c
include/opcode/aarch64.h
opcodes/aarch64-opc.c
opcodes/aarch64-opc.h
opcodes/aarch64-sys-regs.def

index 974951cef25d084e871e78fc7184ef311838aad1..677bcfb797e368d56de80228b269e178b8f2ae88 100644 (file)
@@ -5029,7 +5029,7 @@ parse_sys_reg (char **str, htab_t sys_regs,
                  "name '%s'"), buf);
       if (!pstatefield_p && sysreg_checking_p
          && !aarch64_sys_ins_reg_supported_p (cpu_variant, o->name,
-                                              o->flags, &o->features))
+                                              &o->features))
        as_bad (_("selected processor does not support system register "
                  "name '%s'"), buf);
       if (sysreg128_p && !aarch64_sys_reg_128bit_p (o->flags))
@@ -5073,8 +5073,7 @@ parse_sys_ins_reg (char **str, htab_t sys_ins_regs, bool sysreg128_p)
   if (!o || (sysreg128_p && !aarch64_sys_reg_128bit_p (o->flags)))
     return NULL;
 
-  if (!aarch64_sys_ins_reg_supported_p (cpu_variant,
-                                       o->name, o->flags, &o->features))
+  if (!aarch64_sys_ins_reg_supported_p (cpu_variant, o->name, &o->features))
     as_bad (_("selected processor does not support system register "
              "name '%s'"), buf);
   if (aarch64_sys_reg_deprecated_p (o->flags))
index 4425dd46a4555a633a300b8d8d971a462ccc9359..1eeefe0ab9a3c35909fdc2741c814ef849ad7d1c 100644 (file)
@@ -1703,7 +1703,7 @@ extern bool aarch64_sys_ins_reg_has_xt (const aarch64_sys_ins_reg *);
 extern bool
 aarch64_sys_ins_reg_supported_p (const aarch64_feature_set,
                                 const char *reg_name,
-                                uint32_t, const aarch64_feature_set *);
+                                const aarch64_feature_set *);
 
 extern const aarch64_sys_ins_reg aarch64_sys_regs_ic [];
 extern const aarch64_sys_ins_reg aarch64_sys_regs_dc [];
index 5980841c3947fdd1011b8a3b511bf2daeb247f62..4b173201e92bc7fd5c6d4e306e1f8fb332b0e041 100644 (file)
@@ -5196,18 +5196,18 @@ const aarch64_sys_reg aarch64_pstatefields [] =
   { "spsel",   0x05, F_REG_MAX_VALUE (1), AARCH64_NO_FEATURES },
   { "daifset", 0x1e, F_REG_MAX_VALUE (15), AARCH64_NO_FEATURES },
   { "daifclr", 0x1f, F_REG_MAX_VALUE (15), AARCH64_NO_FEATURES },
-  { "pan",     0x04, F_REG_MAX_VALUE (1) | F_ARCHEXT, AARCH64_FEATURE (PAN) },
-  { "uao",     0x03, F_REG_MAX_VALUE (1) | F_ARCHEXT, AARCH64_FEATURE (V8_2A) },
-  { "ssbs",    0x19, F_REG_MAX_VALUE (1) | F_ARCHEXT, AARCH64_FEATURE (SSBS) },
-  { "dit",     0x1a, F_REG_MAX_VALUE (1) | F_ARCHEXT, AARCH64_FEATURE (V8_4A) },
-  { "tco",     0x1c, F_REG_MAX_VALUE (1) | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-  { "svcrsm",  0x1b, PSTATE_ENCODE_CRM_AND_IMM (0x2,0x1) | F_REG_MAX_VALUE (1)
-                     | F_ARCHEXT, AARCH64_FEATURE (SME) },
-  { "svcrza",  0x1b, PSTATE_ENCODE_CRM_AND_IMM (0x4,0x1) | F_REG_MAX_VALUE (1)
-                     | F_ARCHEXT, AARCH64_FEATURE (SME) },
-  { "svcrsmza",        0x1b, PSTATE_ENCODE_CRM_AND_IMM (0x6,0x1) | F_REG_MAX_VALUE (1)
-                     | F_ARCHEXT, AARCH64_FEATURE (SME) },
-  { "allint",  0x08, F_REG_MAX_VALUE (1) | F_ARCHEXT, AARCH64_FEATURE (V8_8A) },
+  { "pan",     0x04, F_REG_MAX_VALUE (1), AARCH64_FEATURE (PAN) },
+  { "uao",     0x03, F_REG_MAX_VALUE (1), AARCH64_FEATURE (V8_2A) },
+  { "ssbs",    0x19, F_REG_MAX_VALUE (1), AARCH64_FEATURE (SSBS) },
+  { "dit",     0x1a, F_REG_MAX_VALUE (1), AARCH64_FEATURE (V8_4A) },
+  { "tco",     0x1c, F_REG_MAX_VALUE (1), AARCH64_FEATURE (MEMTAG) },
+  { "svcrsm",  0x1b, PSTATE_ENCODE_CRM_AND_IMM (0x2,0x1) | F_REG_MAX_VALUE (1),
+    AARCH64_FEATURE (SME) },
+  { "svcrza",  0x1b, PSTATE_ENCODE_CRM_AND_IMM (0x4,0x1) | F_REG_MAX_VALUE (1),
+    AARCH64_FEATURE (SME) },
+  { "svcrsmza",        0x1b, PSTATE_ENCODE_CRM_AND_IMM (0x6,0x1) | F_REG_MAX_VALUE (1),
+    AARCH64_FEATURE (SME) },
+  { "allint",  0x08, F_REG_MAX_VALUE (1), AARCH64_FEATURE (V8_8A) },
   { 0, CPENC (0,0,0,0,0), 0, AARCH64_NO_FEATURES },
 };
 
@@ -5215,9 +5215,6 @@ bool
 aarch64_pstatefield_supported_p (const aarch64_feature_set features,
                                 const aarch64_sys_reg *reg)
 {
-  if (!(reg->flags & F_ARCHEXT))
-    return true;
-
   return AARCH64_CPU_HAS_ALL_FEATURES (features, reg->features);
 }
 
@@ -5232,41 +5229,41 @@ const aarch64_sys_ins_reg aarch64_sys_regs_ic[] =
 const aarch64_sys_ins_reg aarch64_sys_regs_dc[] =
 {
     { "zva",       CPENS (3, C7, C4, 1),  F_HASXT, AARCH64_NO_FEATURES },
-    { "gva",       CPENS (3, C7, C4, 3),  F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-    { "gzva",      CPENS (3, C7, C4, 4),  F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
+    { "gva",       CPENS (3, C7, C4, 3),  F_HASXT, AARCH64_FEATURE (MEMTAG) },
+    { "gzva",      CPENS (3, C7, C4, 4),  F_HASXT, AARCH64_FEATURE (MEMTAG) },
     { "ivac",       CPENS (0, C7, C6, 1),  F_HASXT, AARCH64_NO_FEATURES },
-    { "igvac",      CPENS (0, C7, C6, 3),  F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-    { "igsw",       CPENS (0, C7, C6, 4),  F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
+    { "igvac",      CPENS (0, C7, C6, 3),  F_HASXT, AARCH64_FEATURE (MEMTAG) },
+    { "igsw",       CPENS (0, C7, C6, 4),  F_HASXT, AARCH64_FEATURE (MEMTAG) },
     { "isw",       CPENS (0, C7, C6, 2),  F_HASXT, AARCH64_NO_FEATURES },
-    { "igdvac",            CPENS (0, C7, C6, 5),  F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-    { "igdsw",     CPENS (0, C7, C6, 6),  F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-    { "cigdvaps",   CPENS (0, C7, C15, 5), F_HASXT | F_ARCHEXT, AARCH64_FEATURES (2, MEMTAG, PoPS) },
-    { "civaps",     CPENS (0, C7, C15, 1), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (PoPS) },
+    { "igdvac",            CPENS (0, C7, C6, 5),  F_HASXT, AARCH64_FEATURE (MEMTAG) },
+    { "igdsw",     CPENS (0, C7, C6, 6),  F_HASXT, AARCH64_FEATURE (MEMTAG) },
+    { "cigdvaps",   CPENS (0, C7, C15, 5), F_HASXT, AARCH64_FEATURES (2, MEMTAG, PoPS) },
+    { "civaps",     CPENS (0, C7, C15, 1), F_HASXT, AARCH64_FEATURE (PoPS) },
     { "cvac",       CPENS (3, C7, C10, 1), F_HASXT, AARCH64_NO_FEATURES },
-    { "cgvac",      CPENS (3, C7, C10, 3), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-    { "cgdvac",     CPENS (3, C7, C10, 5), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-    { "cvaoc",      CPENS (3, C7, C11, 0), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (OCCMO) },
-    { "cgdvaoc",    CPENS (3, C7, C11, 7), F_HASXT | F_ARCHEXT, AARCH64_FEATURES (2, OCCMO, MEMTAG) },
+    { "cgvac",      CPENS (3, C7, C10, 3), F_HASXT, AARCH64_FEATURE (MEMTAG) },
+    { "cgdvac",     CPENS (3, C7, C10, 5), F_HASXT, AARCH64_FEATURE (MEMTAG) },
+    { "cvaoc",      CPENS (3, C7, C11, 0), F_HASXT, AARCH64_FEATURE (OCCMO) },
+    { "cgdvaoc",    CPENS (3, C7, C11, 7), F_HASXT, AARCH64_FEATURES (2, OCCMO, MEMTAG) },
     { "csw",       CPENS (0, C7, C10, 2), F_HASXT, AARCH64_NO_FEATURES },
-    { "cgsw",       CPENS (0, C7, C10, 4), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-    { "cgdsw",     CPENS (0, C7, C10, 6), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
+    { "cgsw",       CPENS (0, C7, C10, 4), F_HASXT, AARCH64_FEATURE (MEMTAG) },
+    { "cgdsw",     CPENS (0, C7, C10, 6), F_HASXT, AARCH64_FEATURE (MEMTAG) },
     { "cvau",       CPENS (3, C7, C11, 1), F_HASXT, AARCH64_NO_FEATURES },
-    { "cvap",       CPENS (3, C7, C12, 1), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (V8_2A) },
-    { "cgvap",      CPENS (3, C7, C12, 3), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-    { "cgdvap",     CPENS (3, C7, C12, 5), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-    { "cvadp",      CPENS (3, C7, C13, 1), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (CVADP) },
-    { "cgvadp",     CPENS (3, C7, C13, 3), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-    { "cgdvadp",    CPENS (3, C7, C13, 5), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
+    { "cvap",       CPENS (3, C7, C12, 1), F_HASXT, AARCH64_FEATURE (V8_2A) },
+    { "cgvap",      CPENS (3, C7, C12, 3), F_HASXT, AARCH64_FEATURE (MEMTAG) },
+    { "cgdvap",     CPENS (3, C7, C12, 5), F_HASXT, AARCH64_FEATURE (MEMTAG) },
+    { "cvadp",      CPENS (3, C7, C13, 1), F_HASXT, AARCH64_FEATURE (CVADP) },
+    { "cgvadp",     CPENS (3, C7, C13, 3), F_HASXT, AARCH64_FEATURE (MEMTAG) },
+    { "cgdvadp",    CPENS (3, C7, C13, 5), F_HASXT, AARCH64_FEATURE (MEMTAG) },
     { "civac",      CPENS (3, C7, C14, 1), F_HASXT, AARCH64_NO_FEATURES },
-    { "cigvac",     CPENS (3, C7, C14, 3), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-    { "cigdvac",    CPENS (3, C7, C14, 5), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
+    { "cigvac",     CPENS (3, C7, C14, 3), F_HASXT, AARCH64_FEATURE (MEMTAG) },
+    { "cigdvac",    CPENS (3, C7, C14, 5), F_HASXT, AARCH64_FEATURE (MEMTAG) },
     { "cisw",       CPENS (0, C7, C14, 2), F_HASXT, AARCH64_NO_FEATURES },
-    { "cigsw",      CPENS (0, C7, C14, 4), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-    { "cigdsw",     CPENS (0, C7, C14, 6), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (MEMTAG) },
-    { "civaoc",     CPENS (3, C7, C15, 0), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (OCCMO) },
-    { "cigdvaoc",   CPENS (3, C7, C15, 7), F_HASXT | F_ARCHEXT, AARCH64_FEATURES (2, OCCMO, MEMTAG) },
-    { "cipae",      CPENS (4, C7, C14, 0), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (V8_7A) },
-    { "cigdpae",    CPENS (4, C7, C14, 7), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (V8_7A) },
+    { "cigsw",      CPENS (0, C7, C14, 4), F_HASXT, AARCH64_FEATURE (MEMTAG) },
+    { "cigdsw",     CPENS (0, C7, C14, 6), F_HASXT, AARCH64_FEATURE (MEMTAG) },
+    { "civaoc",     CPENS (3, C7, C15, 0), F_HASXT, AARCH64_FEATURE (OCCMO) },
+    { "cigdvaoc",   CPENS (3, C7, C15, 7), F_HASXT, AARCH64_FEATURES (2, OCCMO, MEMTAG) },
+    { "cipae",      CPENS (4, C7, C14, 0), F_HASXT, AARCH64_FEATURE (V8_7A) },
+    { "cigdpae",    CPENS (4, C7, C14, 7), F_HASXT, AARCH64_FEATURE (V8_7A) },
     { "cipapa",     CPENS (6, C7, C14, 1), F_HASXT, AARCH64_NO_FEATURES },
     { "cigdpapa",   CPENS (6, C7, C14, 5), F_HASXT, AARCH64_NO_FEATURES },
     { 0,       CPENS(0,0,0,0), 0, AARCH64_NO_FEATURES }
@@ -5286,11 +5283,11 @@ const aarch64_sys_ins_reg aarch64_sys_regs_at[] =
     { "s1e2w",      CPENS (4, C7, C8, 1), F_HASXT, AARCH64_NO_FEATURES },
     { "s1e3r",      CPENS (6, C7, C8, 0), F_HASXT, AARCH64_NO_FEATURES },
     { "s1e3w",      CPENS (6, C7, C8, 1), F_HASXT, AARCH64_NO_FEATURES },
-    { "s1e1rp",     CPENS (0, C7, C9, 0), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (V8_2A) },
-    { "s1e1wp",     CPENS (0, C7, C9, 1), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (V8_2A) },
-    { "s1e1a",      CPENS (0, C7, C9, 2), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (ATS1A) },
-    { "s1e2a",      CPENS (4, C7, C9, 2), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (ATS1A) },
-    { "s1e3a",      CPENS (6, C7, C9, 2), F_HASXT | F_ARCHEXT, AARCH64_FEATURE (ATS1A) },
+    { "s1e1rp",     CPENS (0, C7, C9, 0), F_HASXT, AARCH64_FEATURE (V8_2A) },
+    { "s1e1wp",     CPENS (0, C7, C9, 1), F_HASXT, AARCH64_FEATURE (V8_2A) },
+    { "s1e1a",      CPENS (0, C7, C9, 2), F_HASXT, AARCH64_FEATURE (ATS1A) },
+    { "s1e2a",      CPENS (4, C7, C9, 2), F_HASXT, AARCH64_FEATURE (ATS1A) },
+    { "s1e3a",      CPENS (6, C7, C9, 2), F_HASXT, AARCH64_FEATURE (ATS1A) },
     { 0,       CPENS(0,0,0,0), 0, AARCH64_NO_FEATURES }
 };
 
@@ -5303,7 +5300,7 @@ const aarch64_sys_ins_reg aarch64_sys_regs_tlbi[] =
 
 #define TLBI_XS_OP(OP, CODE, FLAGS) \
     { OP, CODE, FLAGS, AARCH64_NO_FEATURES }, \
-    { OP "nxs", CODE | CPENS (0, C9, 0, 0), FLAGS | F_ARCHEXT, AARCH64_FEATURE (XS) },
+    { OP "nxs", CODE | CPENS (0, C9, 0, 0), FLAGS, AARCH64_FEATURE (XS) },
 
     TLBI_XS_OP ( "vmalle1",   CPENS (0, C8, C7, 0), 0)
     TLBI_XS_OP ( "vae1",      CPENS (0, C8, C7, 1), F_HASXT | F_REG_128)
@@ -5340,8 +5337,8 @@ const aarch64_sys_ins_reg aarch64_sys_regs_tlbi[] =
 
 #undef TLBI_XS_OP
 #define TLBI_XS_OP(OP, CODE, FLAGS) \
-    { OP, CODE, FLAGS | F_ARCHEXT, AARCH64_FEATURE (V8_4A) }, \
-    { OP "nxs", CODE | CPENS (0, C9, 0, 0), FLAGS | F_ARCHEXT, AARCH64_FEATURE (XS) },
+    { OP, CODE, FLAGS, AARCH64_FEATURE (V8_4A) }, \
+    { OP "nxs", CODE | CPENS (0, C9, 0, 0), FLAGS, AARCH64_FEATURE (XS) },
 
     TLBI_XS_OP ( "vmalle1os",    CPENS (0, C8, C1, 0), 0 )
     TLBI_XS_OP ( "vae1os",       CPENS (0, C8, C1, 1), F_HASXT | F_REG_128 )
@@ -5402,7 +5399,7 @@ const aarch64_sys_ins_reg aarch64_sys_regs_sr[] =
        (op2) based on the instruction in which it is used (cfp/dvp/cpp).
        Thus op2 is masked out and instead encoded directly in the
        aarch64_opcode_table entries for the respective instructions.  */
-    { "rctx",   CPENS(3,C7,C3,0), F_HASXT | F_ARCHEXT | F_REG_WRITE, AARCH64_FEATURE (PREDRES) }, /* WO */
+    { "rctx",   CPENS(3,C7,C3,0), F_HASXT | F_REG_WRITE, AARCH64_FEATURE (PREDRES) }, /* WO */
     { 0,       CPENS(0,0,0,0), 0, AARCH64_NO_FEATURES }
 };
 
@@ -5415,7 +5412,6 @@ aarch64_sys_ins_reg_has_xt (const aarch64_sys_ins_reg *sys_ins_reg)
 extern bool
 aarch64_sys_ins_reg_supported_p (const aarch64_feature_set features,
                                 const char *reg_name,
-                                uint32_t reg_flags,
                                 const aarch64_feature_set *reg_features)
 {
   /* Armv8-R has no EL3.  */
@@ -5426,9 +5422,6 @@ aarch64_sys_ins_reg_supported_p (const aarch64_feature_set features,
        return false;
     }
 
-  if (!(reg_flags & F_ARCHEXT))
-    return true;
-
   return AARCH64_CPU_HAS_ALL_FEATURES (features, *reg_features);
 }
 
index 68e297f56f757c2d0f63b396a4b520fd77d9b513..4182c9d5f678beac3a240e08c9842e8620a32bb6 100644 (file)
@@ -307,8 +307,7 @@ verify_constraints (const struct aarch64_inst *, const aarch64_insn, bfd_vma,
 #undef F_DEPRECATED
 #define F_DEPRECATED   (1 << 0)  /* Deprecated system register.  */
 
-#undef F_ARCHEXT
-#define F_ARCHEXT      (1 << 1)  /* Architecture dependent system register.  */
+/*                     (1 << 1)     Unused.  */
 
 #undef F_HASXT
 #define F_HASXT                (1 << 2)  /* System instruction register <Xt>
index 5cb2342ba9b3fbd451d5cd61642d2fa8df3d11a0..dd00c0fdad0bf4be707c946b92224e63d5ff1592 100644 (file)
   The FEATURES field maps onto ISA flags and specifies the architectural
   feature requirements of the system register.  */
 
-  SYSREG ("accdata_el1",       CPENC (3,0,13,0,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("actlr_el1",         CPENC (3,0,1,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("actlr_el2",         CPENC (3,4,1,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("actlr_el3",         CPENC (3,6,1,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("afsr0_el1",         CPENC (3,0,5,1,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("afsr0_el12",                CPENC (3,5,5,1,0),      F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("afsr0_el2",         CPENC (3,4,5,1,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("afsr0_el3",         CPENC (3,6,5,1,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("afsr1_el1",         CPENC (3,0,5,1,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("afsr1_el12",                CPENC (3,5,5,1,1),      F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("afsr1_el2",         CPENC (3,4,5,1,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("afsr1_el3",         CPENC (3,6,5,1,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("aidr_el1",          CPENC (3,1,0,0,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("allint",            CPENC (3,0,4,3,0),      F_ARCHEXT,              AARCH64_FEATURE (V8_8A))
-  SYSREG ("amair_el1",         CPENC (3,0,10,3,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("amair_el12",                CPENC (3,5,10,3,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("amair_el2",         CPENC (3,4,10,3,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("amair_el3",         CPENC (3,6,10,3,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("amair2_el1",                CPENC (3,0,10,3,1),     F_ARCHEXT,              AARCH64_FEATURE (AIE))
-  SYSREG ("amair2_el12",       CPENC (3,5,10,3,1),     F_ARCHEXT,              AARCH64_FEATURE (AIE))
-  SYSREG ("amair2_el2",                CPENC (3,4,10,3,1),     F_ARCHEXT,              AARCH64_FEATURE (AIE))
-  SYSREG ("amair2_el3",                CPENC (3,6,10,3,1),     F_ARCHEXT,              AARCH64_FEATURE (AIE))
-  SYSREG ("amcfgr_el0",                CPENC (3,3,13,2,1),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8_4A))
-  SYSREG ("amcg1idr_el0",      CPENC (3,3,13,2,6),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8_6A))
-  SYSREG ("amcgcr_el0",                CPENC (3,3,13,2,2),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8_4A))
-  SYSREG ("amcntenclr0_el0",   CPENC (3,3,13,2,4),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amcntenclr1_el0",   CPENC (3,3,13,3,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amcntenset0_el0",   CPENC (3,3,13,2,5),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amcntenset1_el0",   CPENC (3,3,13,3,1),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amcr_el0",          CPENC (3,3,13,2,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr00_el0",    CPENC (3,3,13,4,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr01_el0",    CPENC (3,3,13,4,1),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr02_el0",    CPENC (3,3,13,4,2),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr03_el0",    CPENC (3,3,13,4,3),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr10_el0",    CPENC (3,3,13,12,0),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr110_el0",   CPENC (3,3,13,13,2),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr111_el0",   CPENC (3,3,13,13,3),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr112_el0",   CPENC (3,3,13,13,4),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr113_el0",   CPENC (3,3,13,13,5),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr114_el0",   CPENC (3,3,13,13,6),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr115_el0",   CPENC (3,3,13,13,7),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr11_el0",    CPENC (3,3,13,12,1),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr12_el0",    CPENC (3,3,13,12,2),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr13_el0",    CPENC (3,3,13,12,3),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr14_el0",    CPENC (3,3,13,12,4),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr15_el0",    CPENC (3,3,13,12,5),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr16_el0",    CPENC (3,3,13,12,6),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr17_el0",    CPENC (3,3,13,12,7),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr18_el0",    CPENC (3,3,13,13,0),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntr19_el0",    CPENC (3,3,13,13,1),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevcntvoff00_el2", CPENC (3,4,13,8,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff010_el2",        CPENC (3,4,13,9,2),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff011_el2",        CPENC (3,4,13,9,3),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff012_el2",        CPENC (3,4,13,9,4),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff013_el2",        CPENC (3,4,13,9,5),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff014_el2",        CPENC (3,4,13,9,6),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff015_el2",        CPENC (3,4,13,9,7),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff01_el2", CPENC (3,4,13,8,1),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff02_el2", CPENC (3,4,13,8,2),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff03_el2", CPENC (3,4,13,8,3),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff04_el2", CPENC (3,4,13,8,4),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff05_el2", CPENC (3,4,13,8,5),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff06_el2", CPENC (3,4,13,8,6),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff07_el2", CPENC (3,4,13,8,7),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff08_el2", CPENC (3,4,13,9,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff09_el2", CPENC (3,4,13,9,1),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff10_el2", CPENC (3,4,13,10,0),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff110_el2",        CPENC (3,4,13,11,2),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff111_el2",        CPENC (3,4,13,11,3),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff112_el2",        CPENC (3,4,13,11,4),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff113_el2",        CPENC (3,4,13,11,5),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff114_el2",        CPENC (3,4,13,11,6),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff115_el2",        CPENC (3,4,13,11,7),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff11_el2", CPENC (3,4,13,10,1),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff12_el2", CPENC (3,4,13,10,2),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff13_el2", CPENC (3,4,13,10,3),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff14_el2", CPENC (3,4,13,10,4),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff15_el2", CPENC (3,4,13,10,5),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff16_el2", CPENC (3,4,13,10,6),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff17_el2", CPENC (3,4,13,10,7),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff18_el2", CPENC (3,4,13,11,0),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevcntvoff19_el2", CPENC (3,4,13,11,1),    F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("amevtyper00_el0",   CPENC (3,3,13,6,0),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper01_el0",   CPENC (3,3,13,6,1),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper02_el0",   CPENC (3,3,13,6,2),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper03_el0",   CPENC (3,3,13,6,3),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper10_el0",   CPENC (3,3,13,14,0),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper110_el0",  CPENC (3,3,13,15,2),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper111_el0",  CPENC (3,3,13,15,3),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper112_el0",  CPENC (3,3,13,15,4),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper113_el0",  CPENC (3,3,13,15,5),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper114_el0",  CPENC (3,3,13,15,6),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper115_el0",  CPENC (3,3,13,15,7),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper11_el0",   CPENC (3,3,13,14,1),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper12_el0",   CPENC (3,3,13,14,2),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper13_el0",   CPENC (3,3,13,14,3),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper14_el0",   CPENC (3,3,13,14,4),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper15_el0",   CPENC (3,3,13,14,5),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper16_el0",   CPENC (3,3,13,14,6),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper17_el0",   CPENC (3,3,13,14,7),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper18_el0",   CPENC (3,3,13,15,0),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amevtyper19_el0",   CPENC (3,3,13,15,1),    F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("amuserenr_el0",     CPENC (3,3,13,2,3),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("apdakeyhi_el1",     CPENC (3,0,2,2,1),      F_ARCHEXT,              AARCH64_FEATURE (V8_3A))
-  SYSREG ("apdakeylo_el1",     CPENC (3,0,2,2,0),      F_ARCHEXT,              AARCH64_FEATURE (V8_3A))
-  SYSREG ("apdbkeyhi_el1",     CPENC (3,0,2,2,3),      F_ARCHEXT,              AARCH64_FEATURE (V8_3A))
-  SYSREG ("apdbkeylo_el1",     CPENC (3,0,2,2,2),      F_ARCHEXT,              AARCH64_FEATURE (V8_3A))
-  SYSREG ("apgakeyhi_el1",     CPENC (3,0,2,3,1),      F_ARCHEXT,              AARCH64_FEATURE (V8_3A))
-  SYSREG ("apgakeylo_el1",     CPENC (3,0,2,3,0),      F_ARCHEXT,              AARCH64_FEATURE (V8_3A))
-  SYSREG ("apiakeyhi_el1",     CPENC (3,0,2,1,1),      F_ARCHEXT,              AARCH64_FEATURE (V8_3A))
-  SYSREG ("apiakeylo_el1",     CPENC (3,0,2,1,0),      F_ARCHEXT,              AARCH64_FEATURE (V8_3A))
-  SYSREG ("apibkeyhi_el1",     CPENC (3,0,2,1,3),      F_ARCHEXT,              AARCH64_FEATURE (V8_3A))
-  SYSREG ("apibkeylo_el1",     CPENC (3,0,2,1,2),      F_ARCHEXT,              AARCH64_FEATURE (V8_3A))
-  SYSREG ("brbcr_el1",         CPENC (2,1,9,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("brbcr_el12",                CPENC (2,5,9,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("brbcr_el2",         CPENC (2,4,9,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("brbfcr_el1",                CPENC (2,1,9,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("brbidr0_el1",       CPENC (2,1,9,2,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf0_el1",       CPENC (2,1,8,0,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf10_el1",      CPENC (2,1,8,10,0),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf11_el1",      CPENC (2,1,8,11,0),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf12_el1",      CPENC (2,1,8,12,0),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf13_el1",      CPENC (2,1,8,13,0),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf14_el1",      CPENC (2,1,8,14,0),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf15_el1",      CPENC (2,1,8,15,0),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf16_el1",      CPENC (2,1,8,0,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf17_el1",      CPENC (2,1,8,1,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf18_el1",      CPENC (2,1,8,2,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf19_el1",      CPENC (2,1,8,3,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf1_el1",       CPENC (2,1,8,1,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf20_el1",      CPENC (2,1,8,4,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf21_el1",      CPENC (2,1,8,5,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf22_el1",      CPENC (2,1,8,6,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf23_el1",      CPENC (2,1,8,7,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf24_el1",      CPENC (2,1,8,8,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf25_el1",      CPENC (2,1,8,9,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf26_el1",      CPENC (2,1,8,10,4),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf27_el1",      CPENC (2,1,8,11,4),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf28_el1",      CPENC (2,1,8,12,4),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf29_el1",      CPENC (2,1,8,13,4),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf2_el1",       CPENC (2,1,8,2,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf30_el1",      CPENC (2,1,8,14,4),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf31_el1",      CPENC (2,1,8,15,4),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf3_el1",       CPENC (2,1,8,3,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf4_el1",       CPENC (2,1,8,4,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf5_el1",       CPENC (2,1,8,5,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf6_el1",       CPENC (2,1,8,6,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf7_el1",       CPENC (2,1,8,7,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf8_el1",       CPENC (2,1,8,8,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinf9_el1",       CPENC (2,1,8,9,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbinfinj_el1",     CPENC (2,1,9,1,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc0_el1",       CPENC (2,1,8,0,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc10_el1",      CPENC (2,1,8,10,1),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc11_el1",      CPENC (2,1,8,11,1),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc12_el1",      CPENC (2,1,8,12,1),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc13_el1",      CPENC (2,1,8,13,1),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc14_el1",      CPENC (2,1,8,14,1),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc15_el1",      CPENC (2,1,8,15,1),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc16_el1",      CPENC (2,1,8,0,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc17_el1",      CPENC (2,1,8,1,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc18_el1",      CPENC (2,1,8,2,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc19_el1",      CPENC (2,1,8,3,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc1_el1",       CPENC (2,1,8,1,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc20_el1",      CPENC (2,1,8,4,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc21_el1",      CPENC (2,1,8,5,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc22_el1",      CPENC (2,1,8,6,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc23_el1",      CPENC (2,1,8,7,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc24_el1",      CPENC (2,1,8,8,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc25_el1",      CPENC (2,1,8,9,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc26_el1",      CPENC (2,1,8,10,5),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc27_el1",      CPENC (2,1,8,11,5),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc28_el1",      CPENC (2,1,8,12,5),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc29_el1",      CPENC (2,1,8,13,5),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc2_el1",       CPENC (2,1,8,2,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc30_el1",      CPENC (2,1,8,14,5),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc31_el1",      CPENC (2,1,8,15,5),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc3_el1",       CPENC (2,1,8,3,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc4_el1",       CPENC (2,1,8,4,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc5_el1",       CPENC (2,1,8,5,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc6_el1",       CPENC (2,1,8,6,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc7_el1",       CPENC (2,1,8,7,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc8_el1",       CPENC (2,1,8,8,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrc9_el1",       CPENC (2,1,8,9,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbsrcinj_el1",     CPENC (2,1,9,1,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt0_el1",       CPENC (2,1,8,0,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt10_el1",      CPENC (2,1,8,10,2),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt11_el1",      CPENC (2,1,8,11,2),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt12_el1",      CPENC (2,1,8,12,2),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt13_el1",      CPENC (2,1,8,13,2),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt14_el1",      CPENC (2,1,8,14,2),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt15_el1",      CPENC (2,1,8,15,2),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt16_el1",      CPENC (2,1,8,0,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt17_el1",      CPENC (2,1,8,1,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt18_el1",      CPENC (2,1,8,2,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt19_el1",      CPENC (2,1,8,3,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt1_el1",       CPENC (2,1,8,1,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt20_el1",      CPENC (2,1,8,4,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt21_el1",      CPENC (2,1,8,5,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt22_el1",      CPENC (2,1,8,6,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt23_el1",      CPENC (2,1,8,7,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt24_el1",      CPENC (2,1,8,8,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt25_el1",      CPENC (2,1,8,9,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt26_el1",      CPENC (2,1,8,10,6),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt27_el1",      CPENC (2,1,8,11,6),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt28_el1",      CPENC (2,1,8,12,6),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt29_el1",      CPENC (2,1,8,13,6),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt2_el1",       CPENC (2,1,8,2,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt30_el1",      CPENC (2,1,8,14,6),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt31_el1",      CPENC (2,1,8,15,6),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt3_el1",       CPENC (2,1,8,3,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt4_el1",       CPENC (2,1,8,4,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt5_el1",       CPENC (2,1,8,5,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt6_el1",       CPENC (2,1,8,6,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt7_el1",       CPENC (2,1,8,7,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt8_el1",       CPENC (2,1,8,8,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgt9_el1",       CPENC (2,1,8,9,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("brbtgtinj_el1",     CPENC (2,1,9,1,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("brbts_el1",         CPENC (2,1,9,0,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ccsidr2_el1",       CPENC (3,1,0,0,2),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8_3A))
-  SYSREG ("ccsidr_el1",                CPENC (3,1,0,0,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("clidr_el1",         CPENC (3,1,0,0,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("cntfrq_el0",                CPENC (3,3,14,0,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cnthctl_el2",       CPENC (3,4,14,1,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cnthp_ctl_el2",     CPENC (3,4,14,2,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cnthp_cval_el2",    CPENC (3,4,14,2,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cnthp_tval_el2",    CPENC (3,4,14,2,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cnthps_ctl_el2",    CPENC (3,4,14,5,1),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("cnthps_cval_el2",   CPENC (3,4,14,5,2),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("cnthps_tval_el2",   CPENC (3,4,14,5,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("cnthv_ctl_el2",     CPENC (3,4,14,3,1),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("cnthv_cval_el2",    CPENC (3,4,14,3,2),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("cnthv_tval_el2",    CPENC (3,4,14,3,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("cnthvs_ctl_el2",    CPENC (3,4,14,4,1),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("cnthvs_cval_el2",   CPENC (3,4,14,4,2),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("cnthvs_tval_el2",   CPENC (3,4,14,4,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("cntkctl_el1",       CPENC (3,0,14,1,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cntkctl_el12",      CPENC (3,5,14,1,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("cntp_ctl_el0",      CPENC (3,3,14,2,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cntp_ctl_el02",     CPENC (3,5,14,2,1),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("cntp_cval_el0",     CPENC (3,3,14,2,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cntp_cval_el02",    CPENC (3,5,14,2,2),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("cntp_tval_el0",     CPENC (3,3,14,2,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cntp_tval_el02",    CPENC (3,5,14,2,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("cntpct_el0",                CPENC (3,3,14,0,1),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("cntpctss_el0",      CPENC (3,3,14,0,5),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8_6A))
-  SYSREG ("cntpoff_el2",       CPENC (3,4,14,0,6),     F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("cntps_ctl_el1",     CPENC (3,7,14,2,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cntps_cval_el1",    CPENC (3,7,14,2,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cntps_tval_el1",    CPENC (3,7,14,2,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cntv_ctl_el0",      CPENC (3,3,14,3,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cntv_ctl_el02",     CPENC (3,5,14,3,1),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("cntv_cval_el0",     CPENC (3,3,14,3,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cntv_cval_el02",    CPENC (3,5,14,3,2),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("cntv_tval_el0",     CPENC (3,3,14,3,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cntv_tval_el02",    CPENC (3,5,14,3,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("cntvct_el0",                CPENC (3,3,14,0,2),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("cntvctss_el0",      CPENC (3,3,14,0,6),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8_6A))
-  SYSREG ("cntvoff_el2",       CPENC (3,4,14,0,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("contextidr_el1",    CPENC (3,0,13,0,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("contextidr_el12",   CPENC (3,5,13,0,1),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("contextidr_el2",    CPENC (3,4,13,0,1),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("cpacr_el1",         CPENC (3,0,1,0,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cpacr_el12",                CPENC (3,5,1,0,2),      F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("cptr_el2",          CPENC (3,4,1,1,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("cptr_el3",          CPENC (3,6,1,1,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("csrcr_el0",         CPENC (2,3,8,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("csrcr_el1",         CPENC (2,0,8,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("csrcr_el12",                CPENC (2,5,8,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("csrcr_el2",         CPENC (2,4,8,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("csridr_el0",                CPENC (2,3,8,0,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("csrptr_el0",                CPENC (2,3,8,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("csrptr_el1",                CPENC (2,0,8,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("csrptr_el12",       CPENC (2,5,8,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("csrptr_el2",                CPENC (2,4,8,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("csrptridx_el0",     CPENC (2,3,8,0,3),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("csrptridx_el1",     CPENC (2,0,8,0,3),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("csrptridx_el2",     CPENC (2,4,8,0,3),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("csselr_el1",                CPENC (3,2,0,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ctr_el0",           CPENC (3,3,0,0,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("currentel",         CPENC (3,0,4,2,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("dacr32_el2",                CPENC (3,4,3,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("daif",              CPENC (3,3,4,2,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgauthstatus_el1", CPENC (2,0,7,14,6),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr0_el1",       CPENC (2,0,0,0,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr10_el1",      CPENC (2,0,0,10,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr11_el1",      CPENC (2,0,0,11,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr12_el1",      CPENC (2,0,0,12,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr13_el1",      CPENC (2,0,0,13,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr14_el1",      CPENC (2,0,0,14,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr15_el1",      CPENC (2,0,0,15,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr1_el1",       CPENC (2,0,0,1,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr2_el1",       CPENC (2,0,0,2,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr3_el1",       CPENC (2,0,0,3,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr4_el1",       CPENC (2,0,0,4,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr5_el1",       CPENC (2,0,0,5,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr6_el1",       CPENC (2,0,0,6,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr7_el1",       CPENC (2,0,0,7,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr8_el1",       CPENC (2,0,0,8,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbcr9_el1",       CPENC (2,0,0,9,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr0_el1",       CPENC (2,0,0,0,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr10_el1",      CPENC (2,0,0,10,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr11_el1",      CPENC (2,0,0,11,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr12_el1",      CPENC (2,0,0,12,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr13_el1",      CPENC (2,0,0,13,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr14_el1",      CPENC (2,0,0,14,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr15_el1",      CPENC (2,0,0,15,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr1_el1",       CPENC (2,0,0,1,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr2_el1",       CPENC (2,0,0,2,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr3_el1",       CPENC (2,0,0,3,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr4_el1",       CPENC (2,0,0,4,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr5_el1",       CPENC (2,0,0,5,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr6_el1",       CPENC (2,0,0,6,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr7_el1",       CPENC (2,0,0,7,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr8_el1",       CPENC (2,0,0,8,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgbvr9_el1",       CPENC (2,0,0,9,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgclaimclr_el1",   CPENC (2,0,7,9,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgclaimset_el1",   CPENC (2,0,7,8,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgdtr_el0",                CPENC (2,3,0,4,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgdtrrx_el0",      CPENC (2,3,0,5,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("dbgdtrtx_el0",      CPENC (2,3,0,5,0),      F_REG_WRITE,            AARCH64_NO_FEATURES)
-  SYSREG ("dbgprcr_el1",       CPENC (2,0,1,4,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgvcr32_el2",      CPENC (2,4,0,7,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr0_el1",       CPENC (2,0,0,0,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr10_el1",      CPENC (2,0,0,10,7),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr11_el1",      CPENC (2,0,0,11,7),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr12_el1",      CPENC (2,0,0,12,7),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr13_el1",      CPENC (2,0,0,13,7),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr14_el1",      CPENC (2,0,0,14,7),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr15_el1",      CPENC (2,0,0,15,7),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr1_el1",       CPENC (2,0,0,1,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr2_el1",       CPENC (2,0,0,2,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr3_el1",       CPENC (2,0,0,3,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr4_el1",       CPENC (2,0,0,4,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr5_el1",       CPENC (2,0,0,5,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr6_el1",       CPENC (2,0,0,6,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr7_el1",       CPENC (2,0,0,7,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr8_el1",       CPENC (2,0,0,8,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwcr9_el1",       CPENC (2,0,0,9,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr0_el1",       CPENC (2,0,0,0,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr10_el1",      CPENC (2,0,0,10,6),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr11_el1",      CPENC (2,0,0,11,6),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr12_el1",      CPENC (2,0,0,12,6),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr13_el1",      CPENC (2,0,0,13,6),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr14_el1",      CPENC (2,0,0,14,6),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr15_el1",      CPENC (2,0,0,15,6),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr1_el1",       CPENC (2,0,0,1,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr2_el1",       CPENC (2,0,0,2,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr3_el1",       CPENC (2,0,0,3,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr4_el1",       CPENC (2,0,0,4,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr5_el1",       CPENC (2,0,0,5,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr6_el1",       CPENC (2,0,0,6,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr7_el1",       CPENC (2,0,0,7,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr8_el1",       CPENC (2,0,0,8,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dbgwvr9_el1",       CPENC (2,0,0,9,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dczid_el0",         CPENC (3,3,0,0,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("disr_el1",          CPENC (3,0,12,1,1),     F_ARCHEXT,              AARCH64_FEATURE (RAS))
-  SYSREG ("dit",               CPENC (3,3,4,2,5),      F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("dlr_el0",           CPENC (3,3,4,5,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("dspsr_el0",         CPENC (3,3,4,5,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("elr_el1",           CPENC (3,0,4,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("elr_el12",          CPENC (3,5,4,0,1),      F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("elr_el2",           CPENC (3,4,4,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("elr_el3",           CPENC (3,6,4,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("erridr_el1",                CPENC (3,0,5,3,0),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (RAS))
-  SYSREG ("errselr_el1",       CPENC (3,0,5,3,1),      F_ARCHEXT,              AARCH64_FEATURE (RAS))
-  SYSREG ("erxaddr_el1",       CPENC (3,0,5,4,3),      F_ARCHEXT,              AARCH64_FEATURE (RAS))
-  SYSREG ("erxctlr_el1",       CPENC (3,0,5,4,1),      F_ARCHEXT,              AARCH64_FEATURE (RAS))
-  SYSREG ("erxfr_el1",         CPENC (3,0,5,4,0),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (RAS))
-  SYSREG ("erxgsr_el1",                CPENC (3,0,5,3,2),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (RASv2))
-  SYSREG ("erxmisc0_el1",      CPENC (3,0,5,5,0),      F_ARCHEXT,              AARCH64_FEATURE (RAS))
-  SYSREG ("erxmisc1_el1",      CPENC (3,0,5,5,1),      F_ARCHEXT,              AARCH64_FEATURE (RAS))
-  SYSREG ("erxmisc2_el1",      CPENC (3,0,5,5,2),      F_ARCHEXT,              AARCH64_FEATURE (RAS))
-  SYSREG ("erxmisc3_el1",      CPENC (3,0,5,5,3),      F_ARCHEXT,              AARCH64_FEATURE (RAS))
-  SYSREG ("erxpfgcdn_el1",     CPENC (3,0,5,4,6),      F_ARCHEXT,              AARCH64_FEATURE (RAS))
-  SYSREG ("erxpfgctl_el1",     CPENC (3,0,5,4,5),      F_ARCHEXT,              AARCH64_FEATURE (RAS))
-  SYSREG ("erxpfgf_el1",       CPENC (3,0,5,4,4),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (RAS))
-  SYSREG ("erxstatus_el1",     CPENC (3,0,5,4,2),      F_ARCHEXT,              AARCH64_FEATURE (RAS))
-  SYSREG ("esr_el1",           CPENC (3,0,5,2,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("esr_el12",          CPENC (3,5,5,2,0),      F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("esr_el2",           CPENC (3,4,5,2,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("esr_el3",           CPENC (3,6,5,2,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("far_el1",           CPENC (3,0,6,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("far_el12",          CPENC (3,5,6,0,0),      F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("far_el2",           CPENC (3,4,6,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("far_el3",           CPENC (3,6,6,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("fpcr",              CPENC (3,3,4,4,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("fpexc32_el2",       CPENC (3,4,5,3,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("fpmr",              CPENC (3,3,4,4,2),      F_ARCHEXT,              AARCH64_FEATURE (FP8))
-  SYSREG ("fpsr",              CPENC (3,3,4,4,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("gcspr_el0",         CPENC (3,3,2,5,1),      F_ARCHEXT,              AARCH64_FEATURE (GCS))
-  SYSREG ("gcspr_el1",         CPENC (3,0,2,5,1),      F_ARCHEXT,              AARCH64_FEATURE (GCS))
-  SYSREG ("gcspr_el2",         CPENC (3,4,2,5,1),      F_ARCHEXT,              AARCH64_FEATURE (GCS))
-  SYSREG ("gcspr_el12",                CPENC (3,5,2,5,1),      F_ARCHEXT,              AARCH64_FEATURE (GCS))
-  SYSREG ("gcspr_el3",         CPENC (3,6,2,5,1),      F_ARCHEXT,              AARCH64_FEATURE (GCS))
-  SYSREG ("gcscre0_el1",       CPENC (3,0,2,5,2),      F_ARCHEXT,              AARCH64_FEATURE (GCS))
-  SYSREG ("gcscr_el1",         CPENC (3,0,2,5,0),      F_ARCHEXT,              AARCH64_FEATURE (GCS))
-  SYSREG ("gcscr_el2",         CPENC (3,4,2,5,0),      F_ARCHEXT,              AARCH64_FEATURE (GCS))
-  SYSREG ("gcscr_el12",                CPENC (3,5,2,5,0),      F_ARCHEXT,              AARCH64_FEATURE (GCS))
-  SYSREG ("gcscr_el3",         CPENC (3,6,2,5,0),      F_ARCHEXT,              AARCH64_FEATURE (GCS))
-  SYSREG ("gcr_el1",           CPENC (3,0,1,0,6),      F_ARCHEXT,              AARCH64_FEATURE (MEMTAG))
-  SYSREG ("gmid_el1",          CPENC (3,1,0,0,4),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (MEMTAG))
-  SYSREG ("gpcbw_el3",         CPENC (3,6,2,1,5),      F_ARCHEXT,              AARCH64_FEATURE (V9_5A))
-  SYSREG ("gpccr_el3",         CPENC (3,6,2,1,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("gptbr_el3",         CPENC (3,6,2,1,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("hacr_el2",          CPENC (3,4,1,1,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("hafgrtr_el2",       CPENC (3,4,3,1,6),      F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("hcr_el2",           CPENC (3,4,1,1,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("hcrx_el2",          CPENC (3,4,1,2,2),      F_ARCHEXT,              AARCH64_FEATURE (V8_7A))
-  SYSREG ("hdfgrtr_el2",       CPENC (3,4,3,1,4),      F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("hdfgrtr2_el2",      CPENC (3,4,3,1,0),      F_ARCHEXT,              AARCH64_FEATURE (FGT2))
-  SYSREG ("hdfgwtr_el2",       CPENC (3,4,3,1,5),      F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("hdfgwtr2_el2",      CPENC (3,4,3,1,1),      F_ARCHEXT,              AARCH64_FEATURE (FGT2))
-  SYSREG ("hfgitr_el2",                CPENC (3,4,1,1,6),      F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("hfgitr2_el2",       CPENC (3,4,3,1,7),      F_ARCHEXT,              AARCH64_FEATURE (V8_8A))
-  SYSREG ("hfgrtr_el2",                CPENC (3,4,1,1,4),      F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("hfgrtr2_el2",       CPENC (3,4,3,1,2),      F_ARCHEXT,              AARCH64_FEATURE (FGT2))
-  SYSREG ("hfgwtr_el2",                CPENC (3,4,1,1,5),      F_ARCHEXT,              AARCH64_FEATURE (V8_6A))
-  SYSREG ("hfgwtr2_el2",       CPENC (3,4,3,1,3),      F_ARCHEXT,              AARCH64_FEATURE (FGT2))
-  SYSREG ("hpfar_el2",         CPENC (3,4,6,0,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("hstr_el2",          CPENC (3,4,1,1,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_ap0r0_el1",     CPENC (3,0,12,8,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_ap0r1_el1",     CPENC (3,0,12,8,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_ap0r2_el1",     CPENC (3,0,12,8,6),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_ap0r3_el1",     CPENC (3,0,12,8,7),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_ap1r0_el1",     CPENC (3,0,12,9,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_ap1r1_el1",     CPENC (3,0,12,9,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_ap1r2_el1",     CPENC (3,0,12,9,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_ap1r3_el1",     CPENC (3,0,12,9,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_asgi1r_el1",    CPENC (3,0,12,11,6),    F_REG_WRITE,            AARCH64_NO_FEATURES)
-  SYSREG ("icc_bpr0_el1",      CPENC (3,0,12,8,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_bpr1_el1",      CPENC (3,0,12,12,3),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_ctlr_el1",      CPENC (3,0,12,12,4),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_ctlr_el3",      CPENC (3,6,12,12,4),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_dir_el1",       CPENC (3,0,12,11,1),    F_REG_WRITE,            AARCH64_NO_FEATURES)
-  SYSREG ("icc_eoir0_el1",     CPENC (3,0,12,8,1),     F_REG_WRITE,            AARCH64_NO_FEATURES)
-  SYSREG ("icc_eoir1_el1",     CPENC (3,0,12,12,1),    F_REG_WRITE,            AARCH64_NO_FEATURES)
-  SYSREG ("icc_hppir0_el1",    CPENC (3,0,12,8,2),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("icc_hppir1_el1",    CPENC (3,0,12,12,2),    F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("icc_iar0_el1",      CPENC (3,0,12,8,0),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("icc_iar1_el1",      CPENC (3,0,12,12,0),    F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("icc_igrpen0_el1",   CPENC (3,0,12,12,6),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_igrpen1_el1",   CPENC (3,0,12,12,7),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_igrpen1_el3",   CPENC (3,6,12,12,7),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_nmiar1_el1",    CPENC (3,0,12,9,5),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8_8A))
-  SYSREG ("icc_pmr_el1",       CPENC (3,0,4,6,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_rpr_el1",       CPENC (3,0,12,11,3),    F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("icc_sgi0r_el1",     CPENC (3,0,12,11,7),    F_REG_WRITE,            AARCH64_NO_FEATURES)
-  SYSREG ("icc_sgi1r_el1",     CPENC (3,0,12,11,5),    F_REG_WRITE,            AARCH64_NO_FEATURES)
-  SYSREG ("icc_sre_el1",       CPENC (3,0,12,12,5),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_sre_el2",       CPENC (3,4,12,9,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("icc_sre_el3",       CPENC (3,6,12,12,5),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_ap0r0_el2",     CPENC (3,4,12,8,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_ap0r1_el2",     CPENC (3,4,12,8,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_ap0r2_el2",     CPENC (3,4,12,8,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_ap0r3_el2",     CPENC (3,4,12,8,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_ap1r0_el2",     CPENC (3,4,12,9,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_ap1r1_el2",     CPENC (3,4,12,9,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_ap1r2_el2",     CPENC (3,4,12,9,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_ap1r3_el2",     CPENC (3,4,12,9,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_eisr_el2",      CPENC (3,4,12,11,3),    F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("ich_elrsr_el2",     CPENC (3,4,12,11,5),    F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("ich_hcr_el2",       CPENC (3,4,12,11,0),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr0_el2",       CPENC (3,4,12,12,0),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr10_el2",      CPENC (3,4,12,13,2),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr11_el2",      CPENC (3,4,12,13,3),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr12_el2",      CPENC (3,4,12,13,4),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr13_el2",      CPENC (3,4,12,13,5),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr14_el2",      CPENC (3,4,12,13,6),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr15_el2",      CPENC (3,4,12,13,7),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr1_el2",       CPENC (3,4,12,12,1),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr2_el2",       CPENC (3,4,12,12,2),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr3_el2",       CPENC (3,4,12,12,3),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr4_el2",       CPENC (3,4,12,12,4),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr5_el2",       CPENC (3,4,12,12,5),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr6_el2",       CPENC (3,4,12,12,6),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr7_el2",       CPENC (3,4,12,12,7),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr8_el2",       CPENC (3,4,12,13,0),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_lr9_el2",       CPENC (3,4,12,13,1),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_misr_el2",      CPENC (3,4,12,11,2),    F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("ich_vmcr_el2",      CPENC (3,4,12,11,7),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ich_vtr_el2",       CPENC (3,4,12,11,1),    F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64afr0_el1",   CPENC (3,0,0,5,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64afr1_el1",   CPENC (3,0,0,5,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64dfr0_el1",   CPENC (3,0,0,5,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64dfr1_el1",   CPENC (3,0,0,5,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64dfr2_el1",   CPENC (3,0,0,5,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64fpfr0_el1",  CPENC (3,0,0,4,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64isar0_el1",  CPENC (3,0,0,6,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64isar1_el1",  CPENC (3,0,0,6,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64isar2_el1",  CPENC (3,0,0,6,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64isar3_el1",  CPENC (3,0,0,6,3),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64mmfr0_el1",  CPENC (3,0,0,7,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64mmfr1_el1",  CPENC (3,0,0,7,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64mmfr2_el1",  CPENC (3,0,0,7,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64mmfr3_el1",  CPENC (3,0,0,7,3),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64mmfr4_el1",  CPENC (3,0,0,7,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64pfr0_el1",   CPENC (3,0,0,4,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64pfr1_el1",   CPENC (3,0,0,4,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64pfr2_el1",   CPENC (3,0,0,4,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_aa64smfr0_el1",  CPENC (3,0,0,4,5),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (SME))
-  SYSREG ("id_aa64zfr0_el1",   CPENC (3,0,0,4,4),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (SVE))
-  SYSREG ("id_afr0_el1",       CPENC (3,0,0,1,3),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_dfr0_el1",       CPENC (3,0,0,1,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_dfr1_el1",       CPENC (3,0,0,3,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_isar0_el1",      CPENC (3,0,0,2,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_isar1_el1",      CPENC (3,0,0,2,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_isar2_el1",      CPENC (3,0,0,2,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_isar3_el1",      CPENC (3,0,0,2,3),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_isar4_el1",      CPENC (3,0,0,2,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_isar5_el1",      CPENC (3,0,0,2,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_isar6_el1",      CPENC (3,0,0,2,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_mmfr0_el1",      CPENC (3,0,0,1,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_mmfr1_el1",      CPENC (3,0,0,1,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_mmfr2_el1",      CPENC (3,0,0,1,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_mmfr3_el1",      CPENC (3,0,0,1,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_mmfr4_el1",      CPENC (3,0,0,2,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_mmfr5_el1",      CPENC (3,0,0,3,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_pfr0_el1",       CPENC (3,0,0,1,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_pfr1_el1",       CPENC (3,0,0,1,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("id_pfr2_el1",       CPENC (3,0,0,3,4),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (ID_PFR2))
-  SYSREG ("ifsr32_el2",                CPENC (3,4,5,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("isr_el1",           CPENC (3,0,12,1,0),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("lorc_el1",          CPENC (3,0,10,4,3),     F_ARCHEXT,              AARCH64_FEATURE (LOR))
-  SYSREG ("lorea_el1",         CPENC (3,0,10,4,1),     F_ARCHEXT,              AARCH64_FEATURE (LOR))
-  SYSREG ("lorid_el1",         CPENC (3,0,10,4,7),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (LOR))
-  SYSREG ("lorn_el1",          CPENC (3,0,10,4,2),     F_ARCHEXT,              AARCH64_FEATURE (LOR))
-  SYSREG ("lorsa_el1",         CPENC (3,0,10,4,0),     F_ARCHEXT,              AARCH64_FEATURE (LOR))
-  SYSREG ("mair_el1",          CPENC (3,0,10,2,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mair_el12",         CPENC (3,5,10,2,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("mair_el2",          CPENC (3,4,10,2,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mair_el3",          CPENC (3,6,10,2,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mair2_el1",         CPENC (3,0,10,2,1),     F_ARCHEXT,              AARCH64_FEATURE (AIE))
-  SYSREG ("mair2_el12",                CPENC (3,5,10,2,1),     F_ARCHEXT,              AARCH64_FEATURE (AIE))
-  SYSREG ("mair2_el2",         CPENC (3,4,10,1,1),     F_ARCHEXT,              AARCH64_FEATURE (AIE))
-  SYSREG ("mair2_el3",         CPENC (3,6,10,1,1),     F_ARCHEXT,              AARCH64_FEATURE (AIE))
-  SYSREG ("mdccint_el1",       CPENC (2,0,0,2,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mdccsr_el0",                CPENC (2,3,0,1,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("mdcr_el2",          CPENC (3,4,1,1,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mdcr_el3",          CPENC (3,6,1,3,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mdrar_el1",         CPENC (2,0,1,0,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("mdscr_el1",         CPENC (2,0,0,2,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mdselr_el1",                CPENC (2,0,0,4,2),      F_ARCHEXT,              AARCH64_FEATURE (DEBUGv8p9))
-  SYSREG ("mdstepop_el1",      CPENC (2,0,0,5,2),      F_ARCHEXT,              AARCH64_FEATURE (STEP2))
-  SYSREG ("mecid_a0_el2",      CPENC (3,4,10,8,1),     F_ARCHEXT,              AARCH64_FEATURE (V8_7A))
-  SYSREG ("mecid_a1_el2",      CPENC (3,4,10,8,3),     F_ARCHEXT,              AARCH64_FEATURE (V8_7A))
-  SYSREG ("mecid_p0_el2",      CPENC (3,4,10,8,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_7A))
-  SYSREG ("mecid_p1_el2",      CPENC (3,4,10,8,2),     F_ARCHEXT,              AARCH64_FEATURE (V8_7A))
-  SYSREG ("mecid_rl_a_el3",    CPENC (3,6,10,10,1),    F_ARCHEXT,              AARCH64_FEATURE (V8_7A))
-  SYSREG ("mecidr_el2",                CPENC (3,4,10,8,7),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8_7A))
-  SYSREG ("mfar_el3",          CPENC (3,6,6,0,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("midr_el1",          CPENC (3,0,0,0,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("mpam0_el1",         CPENC (3,0,10,5,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpam1_el1",         CPENC (3,0,10,5,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpam1_el12",                CPENC (3,5,10,5,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpam2_el2",         CPENC (3,4,10,5,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpam3_el3",         CPENC (3,6,10,5,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpambw0_el1",       CPENC (3,0,10,5,5),     F_ARCHEXT,              AARCH64_FEATURE (V9_3A))
-  SYSREG ("mpambw1_el1",       CPENC (3,0,10,5,4),     F_ARCHEXT,              AARCH64_FEATURE (V9_3A))
-  SYSREG ("mpambw1_el12",      CPENC (3,5,10,5,4),     F_ARCHEXT,              AARCH64_FEATURE (V9_3A))
-  SYSREG ("mpambw2_el2",       CPENC (3,4,10,5,4),     F_ARCHEXT,              AARCH64_FEATURE (V9_3A))
-  SYSREG ("mpambw3_el3",       CPENC (3,6,10,5,4),     F_ARCHEXT,              AARCH64_FEATURE (V9_3A))
-  SYSREG ("mpambwcap_el2",     CPENC (3,4,10,5,6),     F_ARCHEXT,              AARCH64_FEATURE (V9_3A))
-  SYSREG ("mpambwidr_el1",     CPENC (3,0,10,4,5),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V9_3A))
-  SYSREG ("mpambwsm_el1",      CPENC (3,0,10,5,7),     F_ARCHEXT,              AARCH64_FEATURES (2, SME, V9_3A))
-  SYSREG ("mpamhcr_el2",       CPENC (3,4,10,4,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpamidr_el1",       CPENC (3,0,10,4,4),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("mpamsm_el1",                CPENC (3,0,10,5,3),     F_ARCHEXT,              AARCH64_FEATURE (SME))
-  SYSREG ("mpamvpm0_el2",      CPENC (3,4,10,6,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpamvpm1_el2",      CPENC (3,4,10,6,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpamvpm2_el2",      CPENC (3,4,10,6,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpamvpm3_el2",      CPENC (3,4,10,6,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpamvpm4_el2",      CPENC (3,4,10,6,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpamvpm5_el2",      CPENC (3,4,10,6,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpamvpm6_el2",      CPENC (3,4,10,6,6),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpamvpm7_el2",      CPENC (3,4,10,6,7),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpamvpmv_el2",      CPENC (3,4,10,4,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("mpidr_el1",         CPENC (3,0,0,0,5),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("mpuir_el1",         CPENC (3,0,0,0,4),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8R))
-  SYSREG ("mpuir_el2",         CPENC (3,4,0,0,4),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8R))
-  SYSREG ("mvfr0_el1",         CPENC (3,0,0,3,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("mvfr1_el1",         CPENC (3,0,0,3,1),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("mvfr2_el1",         CPENC (3,0,0,3,2),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("nzcv",              CPENC (3,3,4,2,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("osdlr_el1",         CPENC (2,0,1,3,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("osdtrrx_el1",       CPENC (2,0,0,0,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("osdtrtx_el1",       CPENC (2,0,0,3,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("oseccr_el1",                CPENC (2,0,0,6,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("oslar_el1",         CPENC (2,0,1,0,4),      F_REG_WRITE,            AARCH64_NO_FEATURES)
-  SYSREG ("oslsr_el1",         CPENC (2,0,1,1,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("pir_el1",           CPENC (3,0,10,2,3),     F_ARCHEXT,              AARCH64_FEATURE (S1PIE))
-  SYSREG ("pir_el12",          CPENC (3,5,10,2,3),     F_ARCHEXT,              AARCH64_FEATURE (S1PIE))
-  SYSREG ("pir_el2",           CPENC (3,4,10,2,3),     F_ARCHEXT,              AARCH64_FEATURE (S1PIE))
-  SYSREG ("pir_el3",           CPENC (3,6,10,2,3),     F_ARCHEXT,              AARCH64_FEATURE (S1PIE))
-  SYSREG ("pire0_el1",         CPENC (3,0,10,2,2),     F_ARCHEXT,              AARCH64_FEATURE (S1PIE))
-  SYSREG ("pire0_el12",                CPENC (3,5,10,2,2),     F_ARCHEXT,              AARCH64_FEATURE (S1PIE))
-  SYSREG ("pire0_el2",         CPENC (3,4,10,2,2),     F_ARCHEXT,              AARCH64_FEATURE (S1PIE))
-  SYSREG ("pan",               CPENC (3,0,4,2,3),      F_ARCHEXT,              AARCH64_FEATURE (PAN))
-  SYSREG ("par_el1",           CPENC (3,0,7,4,0),      F_REG_128,              AARCH64_NO_FEATURES)
-  SYSREG ("pfar_el1",          CPENC (3,0,6,0,5),      F_ARCHEXT,              AARCH64_FEATURE (PFAR))
-  SYSREG ("pfar_el12",         CPENC (3,5,6,0,5),      F_ARCHEXT,              AARCH64_FEATURE (PFAR))
-  SYSREG ("pfar_el2",          CPENC (3,4,6,0,5),      F_ARCHEXT,              AARCH64_FEATURE (PFAR))
-  SYSREG ("pmbidr_el1",                CPENC (3,0,9,10,7),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PROFILE))
-  SYSREG ("pmblimitr_el1",     CPENC (3,0,9,10,0),     F_ARCHEXT,              AARCH64_FEATURE (PROFILE))
-  SYSREG ("pmbmar_el1",                CPENC (3,0,9,10,5),     F_ARCHEXT,              AARCH64_FEATURES (2, PROFILE, V9_5A))
-  SYSREG ("pmbptr_el1",                CPENC (3,0,9,10,1),     F_ARCHEXT,              AARCH64_FEATURE (PROFILE))
-  SYSREG ("pmbsr_el1",         CPENC (3,0,9,10,3),     F_ARCHEXT,              AARCH64_FEATURE (PROFILE))
-  SYSREG ("pmbsr_el12",                CPENC (3,5,9,10,3),     F_ARCHEXT,              AARCH64_FEATURES (2, V9_5A, PROFILE))
-  SYSREG ("pmbsr_el2",         CPENC (3,4,9,10,3),     F_ARCHEXT,              AARCH64_FEATURES (2, V9_5A, PROFILE))
-  SYSREG ("pmbsr_el3",         CPENC (3,6,9,10,3),     F_ARCHEXT,              AARCH64_FEATURES (2, V9_5A, PROFILE))
-  SYSREG ("pmccfiltr_el0",     CPENC (3,3,14,15,7),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmccntr_el0",       CPENC (3,3,9,13,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmccntsvr_el1",     CPENC (2,0,14,11,7),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmceid0_el0",       CPENC (3,3,9,12,6),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("pmceid1_el0",       CPENC (3,3,9,12,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("pmcntenclr_el0",    CPENC (3,3,9,12,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmcntenset_el0",    CPENC (3,3,9,12,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmcr_el0",          CPENC (3,3,9,12,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmecr_el1",         CPENC (3,0,9,14,5),     F_ARCHEXT,              AARCH64_FEATURE (SEBEP))
-  SYSREG ("pmevcntr0_el0",     CPENC (3,3,14,8,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr10_el0",    CPENC (3,3,14,9,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr11_el0",    CPENC (3,3,14,9,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr12_el0",    CPENC (3,3,14,9,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr13_el0",    CPENC (3,3,14,9,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr14_el0",    CPENC (3,3,14,9,6),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr15_el0",    CPENC (3,3,14,9,7),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr16_el0",    CPENC (3,3,14,10,0),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr17_el0",    CPENC (3,3,14,10,1),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr18_el0",    CPENC (3,3,14,10,2),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr19_el0",    CPENC (3,3,14,10,3),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr1_el0",     CPENC (3,3,14,8,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr20_el0",    CPENC (3,3,14,10,4),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr21_el0",    CPENC (3,3,14,10,5),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr22_el0",    CPENC (3,3,14,10,6),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr23_el0",    CPENC (3,3,14,10,7),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr24_el0",    CPENC (3,3,14,11,0),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr25_el0",    CPENC (3,3,14,11,1),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr26_el0",    CPENC (3,3,14,11,2),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr27_el0",    CPENC (3,3,14,11,3),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr28_el0",    CPENC (3,3,14,11,4),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr29_el0",    CPENC (3,3,14,11,5),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr2_el0",     CPENC (3,3,14,8,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr30_el0",    CPENC (3,3,14,11,6),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr3_el0",     CPENC (3,3,14,8,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr4_el0",     CPENC (3,3,14,8,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr5_el0",     CPENC (3,3,14,8,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr6_el0",     CPENC (3,3,14,8,6),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr7_el0",     CPENC (3,3,14,8,7),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr8_el0",     CPENC (3,3,14,9,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntr9_el0",     CPENC (3,3,14,9,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevcntsvr0_el1",   CPENC (2,0,14,8,0),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr10_el1",  CPENC (2,0,14,9,2),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr11_el1",  CPENC (2,0,14,9,3),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr12_el1",  CPENC (2,0,14,9,4),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr13_el1",  CPENC (2,0,14,9,5),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr14_el1",  CPENC (2,0,14,9,6),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr15_el1",  CPENC (2,0,14,9,7),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr16_el1",  CPENC (2,0,14,10,0),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr17_el1",  CPENC (2,0,14,10,1),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr18_el1",  CPENC (2,0,14,10,2),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr19_el1",  CPENC (2,0,14,10,3),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr1_el1",   CPENC (2,0,14,8,1),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr20_el1",  CPENC (2,0,14,10,4),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr21_el1",  CPENC (2,0,14,10,5),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr22_el1",  CPENC (2,0,14,10,6),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr23_el1",  CPENC (2,0,14,10,7),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr24_el1",  CPENC (2,0,14,11,0),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr25_el1",  CPENC (2,0,14,11,1),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr26_el1",  CPENC (2,0,14,11,2),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr27_el1",  CPENC (2,0,14,11,3),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr28_el1",  CPENC (2,0,14,11,4),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr29_el1",  CPENC (2,0,14,11,5),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr2_el1",   CPENC (2,0,14,8,2),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr30_el1",  CPENC (2,0,14,11,6),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr3_el1",   CPENC (2,0,14,8,3),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr4_el1",   CPENC (2,0,14,8,4),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr5_el1",   CPENC (2,0,14,8,5),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr6_el1",   CPENC (2,0,14,8,6),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr7_el1",   CPENC (2,0,14,8,7),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr8_el1",   CPENC (2,0,14,9,0),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevcntsvr9_el1",   CPENC (2,0,14,9,1),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmevtyper0_el0",    CPENC (3,3,14,12,0),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper10_el0",   CPENC (3,3,14,13,2),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper11_el0",   CPENC (3,3,14,13,3),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper12_el0",   CPENC (3,3,14,13,4),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper13_el0",   CPENC (3,3,14,13,5),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper14_el0",   CPENC (3,3,14,13,6),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper15_el0",   CPENC (3,3,14,13,7),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper16_el0",   CPENC (3,3,14,14,0),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper17_el0",   CPENC (3,3,14,14,1),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper18_el0",   CPENC (3,3,14,14,2),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper19_el0",   CPENC (3,3,14,14,3),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper1_el0",    CPENC (3,3,14,12,1),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper20_el0",   CPENC (3,3,14,14,4),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper21_el0",   CPENC (3,3,14,14,5),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper22_el0",   CPENC (3,3,14,14,6),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper23_el0",   CPENC (3,3,14,14,7),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper24_el0",   CPENC (3,3,14,15,0),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper25_el0",   CPENC (3,3,14,15,1),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper26_el0",   CPENC (3,3,14,15,2),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper27_el0",   CPENC (3,3,14,15,3),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper28_el0",   CPENC (3,3,14,15,4),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper29_el0",   CPENC (3,3,14,15,5),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper2_el0",    CPENC (3,3,14,12,2),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper30_el0",   CPENC (3,3,14,15,6),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper3_el0",    CPENC (3,3,14,12,3),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper4_el0",    CPENC (3,3,14,12,4),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper5_el0",    CPENC (3,3,14,12,5),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper6_el0",    CPENC (3,3,14,12,6),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper7_el0",    CPENC (3,3,14,12,7),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper8_el0",    CPENC (3,3,14,13,0),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmevtyper9_el0",    CPENC (3,3,14,13,1),    0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmiar_el1",         CPENC (3,0,9,14,7),     F_ARCHEXT,              AARCH64_FEATURE (SEBEP))
-  SYSREG ("pmicfiltr_el0",     CPENC (3,3,9,6,0),      F_ARCHEXT,              AARCH64_FEATURE (PMUv3_ICNTR))
-  SYSREG ("pmicntr_el0",       CPENC (3,3,9,4,0),      F_ARCHEXT,              AARCH64_FEATURE (PMUv3_ICNTR))
-  SYSREG ("pmicntsvr_el1",     CPENC (2,0,14,12,0),    F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmintenclr_el1",    CPENC (3,0,9,14,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmintenset_el1",    CPENC (3,0,9,14,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmmir_el1",         CPENC (3,0,9,14,6),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (V8_4A))
-  SYSREG ("pmovsclr_el0",      CPENC (3,3,9,12,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmovsset_el0",      CPENC (3,3,9,14,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmscr_el1",         CPENC (3,0,9,9,0),      F_ARCHEXT,              AARCH64_FEATURE (PROFILE))
-  SYSREG ("pmscr_el12",                CPENC (3,5,9,9,0),      F_ARCHEXT,              AARCH64_FEATURE (PROFILE))
-  SYSREG ("pmscr_el2",         CPENC (3,4,9,9,0),      F_ARCHEXT,              AARCH64_FEATURE (PROFILE))
-  SYSREG ("pmsdsfr_el1",       CPENC (3,0,9,10,4),     F_ARCHEXT,              AARCH64_FEATURE (SPE_FDS))
-  SYSREG ("pmselr_el0",                CPENC (3,3,9,12,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmsevfr_el1",       CPENC (3,0,9,9,5),      F_ARCHEXT,              AARCH64_FEATURE (PROFILE))
-  SYSREG ("pmsfcr_el1",                CPENC (3,0,9,9,4),      F_ARCHEXT,              AARCH64_FEATURE (PROFILE))
-  SYSREG ("pmsicr_el1",                CPENC (3,0,9,9,2),      F_ARCHEXT,              AARCH64_FEATURE (PROFILE))
-  SYSREG ("pmsidr_el1",                CPENC (3,0,9,9,7),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (PROFILE))
-  SYSREG ("pmsirr_el1",                CPENC (3,0,9,9,3),      F_ARCHEXT,              AARCH64_FEATURE (PROFILE))
-  SYSREG ("pmslatfr_el1",      CPENC (3,0,9,9,6),      F_ARCHEXT,              AARCH64_FEATURE (PROFILE))
-  SYSREG ("pmsnevfr_el1",      CPENC (3,0,9,9,1),      F_ARCHEXT,              AARCH64_FEATURE (V8_7A))
-  SYSREG ("pmsscr_el1",                CPENC (3,0,9,13,3),     F_ARCHEXT,              AARCH64_FEATURE (PMUv3_SS))
-  SYSREG ("pmswinc_el0",       CPENC (3,3,9,12,4),     F_REG_WRITE,            AARCH64_NO_FEATURES)
-  SYSREG ("pmuacr_el1",                CPENC (3,0,9,14,4),     F_ARCHEXT,              AARCH64_FEATURE (PMUv3p9))
-  SYSREG ("pmuserenr_el0",     CPENC (3,3,9,14,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmxevcntr_el0",     CPENC (3,3,9,13,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmxevtyper_el0",    CPENC (3,3,9,13,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("pmzr_el0",          CPENC (3,3,9,13,4),     F_REG_WRITE|F_ARCHEXT,  AARCH64_FEATURE (PMUv3_ICNTR))
-  SYSREG ("por_el0",           CPENC (3,3,10,2,4),     F_ARCHEXT,              AARCH64_FEATURE (S1POE))
-  SYSREG ("por_el1",           CPENC (3,0,10,2,4),     F_ARCHEXT,              AARCH64_FEATURE (S1POE))
-  SYSREG ("por_el12",          CPENC (3,5,10,2,4),     F_ARCHEXT,              AARCH64_FEATURE (S1POE))
-  SYSREG ("por_el2",           CPENC (3,4,10,2,4),     F_ARCHEXT,              AARCH64_FEATURE (S1POE))
-  SYSREG ("por_el3",           CPENC (3,6,10,2,4),     F_ARCHEXT,              AARCH64_FEATURE (S1POE))
-  SYSREG ("prbar10_el1",       CPENC (3,0,6,13,0),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar10_el2",       CPENC (3,4,6,13,0),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar11_el1",       CPENC (3,0,6,13,4),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar11_el2",       CPENC (3,4,6,13,4),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar12_el1",       CPENC (3,0,6,14,0),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar12_el2",       CPENC (3,4,6,14,0),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar13_el1",       CPENC (3,0,6,14,4),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar13_el2",       CPENC (3,4,6,14,4),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar14_el1",       CPENC (3,0,6,15,0),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar14_el2",       CPENC (3,4,6,15,0),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar15_el1",       CPENC (3,0,6,15,4),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar15_el2",       CPENC (3,4,6,15,4),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar1_el1",                CPENC (3,0,6,8,4),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar1_el2",                CPENC (3,4,6,8,4),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar2_el1",                CPENC (3,0,6,9,0),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar2_el2",                CPENC (3,4,6,9,0),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar3_el1",                CPENC (3,0,6,9,4),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar3_el2",                CPENC (3,4,6,9,4),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar4_el1",                CPENC (3,0,6,10,0),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar4_el2",                CPENC (3,4,6,10,0),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar5_el1",                CPENC (3,0,6,10,4),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar5_el2",                CPENC (3,4,6,10,4),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar6_el1",                CPENC (3,0,6,11,0),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar6_el2",                CPENC (3,4,6,11,0),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar7_el1",                CPENC (3,0,6,11,4),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar7_el2",                CPENC (3,4,6,11,4),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar8_el1",                CPENC (3,0,6,12,0),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar8_el2",                CPENC (3,4,6,12,0),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar9_el1",                CPENC (3,0,6,12,4),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar9_el2",                CPENC (3,4,6,12,4),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar_el1",         CPENC (3,0,6,8,0),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prbar_el2",         CPENC (3,4,6,8,0),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prenr_el1",         CPENC (3,0,6,1,1),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prenr_el2",         CPENC (3,4,6,1,1),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar10_el1",       CPENC (3,0,6,13,1),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar10_el2",       CPENC (3,4,6,13,1),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar11_el1",       CPENC (3,0,6,13,5),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar11_el2",       CPENC (3,4,6,13,5),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar12_el1",       CPENC (3,0,6,14,1),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar12_el2",       CPENC (3,4,6,14,1),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar13_el1",       CPENC (3,0,6,14,5),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar13_el2",       CPENC (3,4,6,14,5),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar14_el1",       CPENC (3,0,6,15,1),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar14_el2",       CPENC (3,4,6,15,1),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar15_el1",       CPENC (3,0,6,15,5),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar15_el2",       CPENC (3,4,6,15,5),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar1_el1",                CPENC (3,0,6,8,5),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar1_el2",                CPENC (3,4,6,8,5),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar2_el1",                CPENC (3,0,6,9,1),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar2_el2",                CPENC (3,4,6,9,1),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar3_el1",                CPENC (3,0,6,9,5),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar3_el2",                CPENC (3,4,6,9,5),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar4_el1",                CPENC (3,0,6,10,1),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar4_el2",                CPENC (3,4,6,10,1),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar5_el1",                CPENC (3,0,6,10,5),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar5_el2",                CPENC (3,4,6,10,5),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar6_el1",                CPENC (3,0,6,11,1),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar6_el2",                CPENC (3,4,6,11,1),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar7_el1",                CPENC (3,0,6,11,5),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar7_el2",                CPENC (3,4,6,11,5),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar8_el1",                CPENC (3,0,6,12,1),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar8_el2",                CPENC (3,4,6,12,1),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar9_el1",                CPENC (3,0,6,12,5),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar9_el2",                CPENC (3,4,6,12,5),     F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar_el1",         CPENC (3,0,6,8,1),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prlar_el2",         CPENC (3,4,6,8,1),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prselr_el1",                CPENC (3,0,6,2,1),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("prselr_el2",                CPENC (3,4,6,2,1),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("rcwmask_el1",       CPENC (3,0,13,0,6),     F_ARCHEXT|F_REG_128,    AARCH64_FEATURE (THE))
-  SYSREG ("rcwsmask_el1",      CPENC (3,0,13,0,3),     F_ARCHEXT|F_REG_128,    AARCH64_FEATURE (THE))
-  SYSREG ("revidr_el1",                CPENC (3,0,0,0,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("rgsr_el1",          CPENC (3,0,1,0,5),      F_ARCHEXT,              AARCH64_FEATURE (MEMTAG))
-  SYSREG ("rmr_el1",           CPENC (3,0,12,0,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("rmr_el2",           CPENC (3,4,12,0,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("rmr_el3",           CPENC (3,6,12,0,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("rndr",              CPENC (3,3,2,4,0),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (RNG))
-  SYSREG ("rndrrs",            CPENC (3,3,2,4,1),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (RNG))
-  SYSREG ("rvbar_el1",         CPENC (3,0,12,0,1),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("rvbar_el2",         CPENC (3,4,12,0,1),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("rvbar_el3",         CPENC (3,6,12,0,1),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("scr_el3",           CPENC (3,6,1,1,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("sctlr_el1",         CPENC (3,0,1,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("sctlr_el12",                CPENC (3,5,1,0,0),      F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("sctlr_el2",         CPENC (3,4,1,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("sctlr_el3",         CPENC (3,6,1,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("sctlr2_el1",                CPENC (3,0,1,0,3),      F_ARCHEXT,              AARCH64_FEATURE (SCTLR2))
-  SYSREG ("sctlr2_el12",       CPENC (3,5,1,0,3),      F_ARCHEXT,              AARCH64_FEATURE (SCTLR2))
-  SYSREG ("sctlr2_el2",                CPENC (3,4,1,0,3),      F_ARCHEXT,              AARCH64_FEATURE (SCTLR2))
-  SYSREG ("sctlr2_el3",                CPENC (3,6,1,0,3),      F_ARCHEXT,              AARCH64_FEATURE (SCTLR2))
-  SYSREG ("scxtnum_el0",       CPENC (3,3,13,0,7),     F_ARCHEXT,              AARCH64_FEATURE (SCXTNUM))
-  SYSREG ("scxtnum_el1",       CPENC (3,0,13,0,7),     F_ARCHEXT,              AARCH64_FEATURE (SCXTNUM))
-  SYSREG ("scxtnum_el12",      CPENC (3,5,13,0,7),     F_ARCHEXT,              AARCH64_FEATURE (SCXTNUM))
-  SYSREG ("scxtnum_el2",       CPENC (3,4,13,0,7),     F_ARCHEXT,              AARCH64_FEATURE (SCXTNUM))
-  SYSREG ("scxtnum_el3",       CPENC (3,6,13,0,7),     F_ARCHEXT,              AARCH64_FEATURE (SCXTNUM))
-  SYSREG ("sder32_el2",                CPENC (3,4,1,3,1),      F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("sder32_el3",                CPENC (3,6,1,1,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("smcr_el1",          CPENC (3,0,1,2,6),      F_ARCHEXT,              AARCH64_FEATURE (SME))
-  SYSREG ("smcr_el12",         CPENC (3,5,1,2,6),      F_ARCHEXT,              AARCH64_FEATURE (SME))
-  SYSREG ("smcr_el2",          CPENC (3,4,1,2,6),      F_ARCHEXT,              AARCH64_FEATURE (SME))
-  SYSREG ("smcr_el3",          CPENC (3,6,1,2,6),      F_ARCHEXT,              AARCH64_FEATURE (SME))
-  SYSREG ("smidr_el1",         CPENC (3,1,0,0,6),      F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (SME))
-  SYSREG ("smpri_el1",         CPENC (3,0,1,2,4),      F_ARCHEXT,              AARCH64_FEATURE (SME))
-  SYSREG ("smprimap_el2",      CPENC (3,4,1,2,5),      F_ARCHEXT,              AARCH64_FEATURE (SME))
-  SYSREG ("sp_el0",            CPENC (3,0,4,1,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("sp_el1",            CPENC (3,4,4,1,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("sp_el2",            CPENC (3,6,4,1,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("spmaccessr_el1",    CPENC (2,0,9,13,3),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmaccessr_el2",    CPENC (2,4,9,13,3),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmaccessr_el3",    CPENC (2,6,9,13,3),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmcfgr_el1",       CPENC (2,0,9,13,7),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (SPMU))
-  SYSREG ("spmcgcr0_el1",      CPENC (2,0,9,13,0),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (SPMU))
-  SYSREG ("spmcgcr1_el1",      CPENC (2,0,9,13,1),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (SPMU))
-  SYSREG ("spmcntenclr_el0",   CPENC (2,3,9,12,2),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmcntenset_el0",   CPENC (2,3,9,12,1),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmcr_el0",         CPENC (2,3,9,12,0),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmdevaff_el1",     CPENC (2,0,9,13,6),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (SPMU))
-  SYSREG ("spmdevarch_el1",    CPENC (2,0,9,13,5),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr0_el0",    CPENC (2,3,14,0,0),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr1_el0",    CPENC (2,3,14,0,1),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr2_el0",    CPENC (2,3,14,0,2),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr3_el0",    CPENC (2,3,14,0,3),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr4_el0",    CPENC (2,3,14,0,4),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr5_el0",    CPENC (2,3,14,0,5),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr6_el0",    CPENC (2,3,14,0,6),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr7_el0",    CPENC (2,3,14,0,7),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr8_el0",    CPENC (2,3,14,1,0),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr9_el0",    CPENC (2,3,14,1,1),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr10_el0",   CPENC (2,3,14,1,2),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr11_el0",   CPENC (2,3,14,1,3),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr12_el0",   CPENC (2,3,14,1,4),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr13_el0",   CPENC (2,3,14,1,5),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr14_el0",   CPENC (2,3,14,1,6),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevcntr15_el0",   CPENC (2,3,14,1,7),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r0_el0",  CPENC (2,3,14,6,0),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r1_el0",  CPENC (2,3,14,6,1),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r2_el0",  CPENC (2,3,14,6,2),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r3_el0",  CPENC (2,3,14,6,3),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r4_el0",  CPENC (2,3,14,6,4),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r5_el0",  CPENC (2,3,14,6,5),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r6_el0",  CPENC (2,3,14,6,6),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r7_el0",  CPENC (2,3,14,6,7),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r8_el0",  CPENC (2,3,14,7,0),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r9_el0",  CPENC (2,3,14,7,1),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r10_el0", CPENC (2,3,14,7,2),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r11_el0", CPENC (2,3,14,7,3),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r12_el0", CPENC (2,3,14,7,4),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r13_el0", CPENC (2,3,14,7,5),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r14_el0", CPENC (2,3,14,7,6),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfilt2r15_el0", CPENC (2,3,14,7,7),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr0_el0",   CPENC (2,3,14,4,0),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr1_el0",   CPENC (2,3,14,4,1),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr2_el0",   CPENC (2,3,14,4,2),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr3_el0",   CPENC (2,3,14,4,3),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr4_el0",   CPENC (2,3,14,4,4),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr5_el0",   CPENC (2,3,14,4,5),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr6_el0",   CPENC (2,3,14,4,6),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr7_el0",   CPENC (2,3,14,4,7),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr8_el0",   CPENC (2,3,14,5,0),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr9_el0",   CPENC (2,3,14,5,1),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr10_el0",  CPENC (2,3,14,5,2),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr11_el0",  CPENC (2,3,14,5,3),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr12_el0",  CPENC (2,3,14,5,4),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr13_el0",  CPENC (2,3,14,5,5),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr14_el0",  CPENC (2,3,14,5,6),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevfiltr15_el0",  CPENC (2,3,14,5,7),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper0_el0",   CPENC (2,3,14,2,0),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper1_el0",   CPENC (2,3,14,2,1),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper2_el0",   CPENC (2,3,14,2,2),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper3_el0",   CPENC (2,3,14,2,3),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper4_el0",   CPENC (2,3,14,2,4),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper5_el0",   CPENC (2,3,14,2,5),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper6_el0",   CPENC (2,3,14,2,6),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper7_el0",   CPENC (2,3,14,2,7),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper8_el0",   CPENC (2,3,14,3,0),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper9_el0",   CPENC (2,3,14,3,1),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper10_el0",  CPENC (2,3,14,3,2),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper11_el0",  CPENC (2,3,14,3,3),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper12_el0",  CPENC (2,3,14,3,4),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper13_el0",  CPENC (2,3,14,3,5),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper14_el0",  CPENC (2,3,14,3,6),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmevtyper15_el0",  CPENC (2,3,14,3,7),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmiidr_el1",       CPENC (2,0,9,13,4),     F_REG_READ|F_ARCHEXT,   AARCH64_FEATURE (SPMU))
-  SYSREG ("spmintenclr_el1",   CPENC (2,0,9,14,2),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmintenset_el1",   CPENC (2,0,9,14,1),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmovsclr_el0",     CPENC (2,3,9,12,3),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmovsset_el0",     CPENC (2,3,9,14,3),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmrootcr_el3",     CPENC (2,6,9,14,7),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmscr_el1",                CPENC (2,7,9,14,7),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmselr_el0",       CPENC (2,3,9,12,5),     F_ARCHEXT,              AARCH64_FEATURE (SPMU))
-  SYSREG ("spmzr_el0",         CPENC (2,3,9,12,4),     F_ARCHEXT,              AARCH64_FEATURE (SPMU2))
-  SYSREG ("spsel",             CPENC (3,0,4,2,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("spsr_abt",          CPENC (3,4,4,3,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("spsr_el1",          CPENC (3,0,4,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("spsr_el12",         CPENC (3,5,4,0,0),      F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("spsr_el2",          CPENC (3,4,4,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("spsr_el3",          CPENC (3,6,4,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("spsr_fiq",          CPENC (3,4,4,3,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("spsr_hyp",          CPENC (3,4,4,0,0),      F_DEPRECATED,           AARCH64_NO_FEATURES)
-  SYSREG ("spsr_irq",          CPENC (3,4,4,3,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("spsr_svc",          CPENC (3,0,4,0,0),      F_DEPRECATED,           AARCH64_NO_FEATURES)
-  SYSREG ("spsr_und",          CPENC (3,4,4,3,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ssbs",              CPENC (3,3,4,2,6),      F_ARCHEXT,              AARCH64_FEATURE (SSBS))
-  SYSREG ("svcr",              CPENC (3,3,4,2,2),      F_ARCHEXT,              AARCH64_FEATURE (SME))
-  SYSREG ("s2pir_el2",         CPENC (3,4,10,2,5),     F_ARCHEXT,              AARCH64_FEATURE (S2PIE))
-  SYSREG ("s2por_el1",         CPENC (3,0,10,2,5),     F_ARCHEXT,              AARCH64_FEATURE (S2POE))
-  SYSREG ("tco",               CPENC (3,3,4,2,7),      F_ARCHEXT,              AARCH64_FEATURE (MEMTAG))
-  SYSREG ("tcr_el1",           CPENC (3,0,2,0,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("tcr_el12",          CPENC (3,5,2,0,2),      F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("tcr_el2",           CPENC (3,4,2,0,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("tcr_el3",           CPENC (3,6,2,0,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("tcr2_el1",          CPENC (3,0,2,0,3),      F_ARCHEXT,              AARCH64_FEATURE (TCR2))
-  SYSREG ("tcr2_el12",         CPENC (3,5,2,0,3),      F_ARCHEXT,              AARCH64_FEATURE (TCR2))
-  SYSREG ("tcr2_el2",          CPENC (3,4,2,0,3),      F_ARCHEXT,              AARCH64_FEATURE (TCR2))
-  SYSREG ("teecr32_el1",       CPENC (2,2,0,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("teehbr32_el1",      CPENC (2,2,1,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("tfsr_el1",          CPENC (3,0,5,6,0),      F_ARCHEXT,              AARCH64_FEATURE (MEMTAG))
-  SYSREG ("tfsr_el12",         CPENC (3,5,5,6,0),      F_ARCHEXT,              AARCH64_FEATURE (MEMTAG))
-  SYSREG ("tfsr_el2",          CPENC (3,4,5,6,0),      F_ARCHEXT,              AARCH64_FEATURE (MEMTAG))
-  SYSREG ("tfsr_el3",          CPENC (3,6,5,6,0),      F_ARCHEXT,              AARCH64_FEATURE (MEMTAG))
-  SYSREG ("tfsre0_el1",                CPENC (3,0,5,6,1),      F_ARCHEXT,              AARCH64_FEATURE (MEMTAG))
-  SYSREG ("tpidr2_el0",                CPENC (3,3,13,0,5),     F_ARCHEXT,              AARCH64_FEATURE (SME))
-  SYSREG ("tpidr_el0",         CPENC (3,3,13,0,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("tpidr_el1",         CPENC (3,0,13,0,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("tpidr_el2",         CPENC (3,4,13,0,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("tpidr_el3",         CPENC (3,6,13,0,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("tpidrro_el0",       CPENC (3,3,13,0,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trbbaser_el1",      CPENC (3,0,9,11,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trbidr_el1",                CPENC (3,0,9,11,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trblimitr_el1",     CPENC (3,0,9,11,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trbmar_el1",                CPENC (3,0,9,11,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trbptr_el1",                CPENC (3,0,9,11,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trbsr_el1",         CPENC (3,0,9,11,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trbsr_el12",                CPENC (3,5,9,11,3),     F_ARCHEXT,              AARCH64_FEATURE (V9_5A))
-  SYSREG ("trbsr_el2",         CPENC (3,4,9,11,3),     F_ARCHEXT,              AARCH64_FEATURE (V9_5A))
-  SYSREG ("trbsr_el3",         CPENC (3,6,9,11,3),     F_ARCHEXT,              AARCH64_FEATURE (V9_5A))
-  SYSREG ("trbtrg_el1",                CPENC (3,0,9,11,6),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr0",         CPENC (2,1,2,0,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr1",         CPENC (2,1,2,2,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr10",                CPENC (2,1,2,4,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr11",                CPENC (2,1,2,6,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr12",                CPENC (2,1,2,8,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr13",                CPENC (2,1,2,10,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr14",                CPENC (2,1,2,12,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr15",                CPENC (2,1,2,14,3),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr2",         CPENC (2,1,2,4,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr3",         CPENC (2,1,2,6,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr4",         CPENC (2,1,2,8,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr5",         CPENC (2,1,2,10,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr6",         CPENC (2,1,2,12,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr7",         CPENC (2,1,2,14,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr8",         CPENC (2,1,2,0,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacatr9",         CPENC (2,1,2,2,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr0",          CPENC (2,1,2,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr1",          CPENC (2,1,2,2,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr10",         CPENC (2,1,2,4,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr11",         CPENC (2,1,2,6,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr12",         CPENC (2,1,2,8,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr13",         CPENC (2,1,2,10,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr14",         CPENC (2,1,2,12,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr15",         CPENC (2,1,2,14,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr2",          CPENC (2,1,2,4,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr3",          CPENC (2,1,2,6,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr4",          CPENC (2,1,2,8,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr5",          CPENC (2,1,2,10,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr6",          CPENC (2,1,2,12,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr7",          CPENC (2,1,2,14,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr8",          CPENC (2,1,2,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcacvr9",          CPENC (2,1,2,2,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcauthstatus",     CPENC (2,1,7,14,6),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcauxctlr",                CPENC (2,1,0,6,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcbbctlr",         CPENC (2,1,0,15,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcccctlr",         CPENC (2,1,0,14,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccidcctlr0",      CPENC (2,1,3,0,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccidcctlr1",      CPENC (2,1,3,1,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccidcvr0",                CPENC (2,1,3,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccidcvr1",                CPENC (2,1,3,2,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccidcvr2",                CPENC (2,1,3,4,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccidcvr3",                CPENC (2,1,3,6,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccidcvr4",                CPENC (2,1,3,8,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccidcvr5",                CPENC (2,1,3,10,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccidcvr6",                CPENC (2,1,3,12,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccidcvr7",                CPENC (2,1,3,14,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccidr0",          CPENC (2,1,7,12,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trccidr1",          CPENC (2,1,7,13,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trccidr2",          CPENC (2,1,7,14,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trccidr3",          CPENC (2,1,7,15,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcclaimclr",       CPENC (2,1,7,9,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcclaimset",       CPENC (2,1,7,8,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccntctlr0",       CPENC (2,1,0,4,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccntctlr1",       CPENC (2,1,0,5,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccntctlr2",       CPENC (2,1,0,6,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccntctlr3",       CPENC (2,1,0,7,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccntrldvr0",      CPENC (2,1,0,0,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccntrldvr1",      CPENC (2,1,0,1,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccntrldvr2",      CPENC (2,1,0,2,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccntrldvr3",      CPENC (2,1,0,3,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccntvr0",         CPENC (2,1,0,8,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccntvr1",         CPENC (2,1,0,9,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccntvr2",         CPENC (2,1,0,10,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trccntvr3",         CPENC (2,1,0,11,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcconfigr",                CPENC (2,1,0,4,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdevaff0",                CPENC (2,1,7,10,6),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcdevaff1",                CPENC (2,1,7,11,6),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcdevarch",                CPENC (2,1,7,15,6),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcdevid",          CPENC (2,1,7,2,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcdevtype",                CPENC (2,1,7,3,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcmr0",         CPENC (2,1,2,0,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcmr1",         CPENC (2,1,2,4,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcmr2",         CPENC (2,1,2,8,6),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcmr3",         CPENC (2,1,2,12,6),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcmr4",         CPENC (2,1,2,0,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcmr5",         CPENC (2,1,2,4,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcmr6",         CPENC (2,1,2,8,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcmr7",         CPENC (2,1,2,12,7),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcvr0",         CPENC (2,1,2,0,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcvr1",         CPENC (2,1,2,4,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcvr2",         CPENC (2,1,2,8,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcvr3",         CPENC (2,1,2,12,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcvr4",         CPENC (2,1,2,0,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcvr5",         CPENC (2,1,2,4,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcvr6",         CPENC (2,1,2,8,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcdvcvr7",         CPENC (2,1,2,12,5),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trceventctl0r",     CPENC (2,1,0,8,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trceventctl1r",     CPENC (2,1,0,9,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcextinselr",      CPENC (2,1,0,8,4),      F_REG_ALIAS,            AARCH64_NO_FEATURES)
-  SYSREG ("trcextinselr0",     CPENC (2,1,0,8,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcextinselr1",     CPENC (2,1,0,9,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcextinselr2",     CPENC (2,1,0,10,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcextinselr3",     CPENC (2,1,0,11,4),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcidr0",           CPENC (2,1,0,8,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcidr1",           CPENC (2,1,0,9,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcidr10",          CPENC (2,1,0,2,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcidr11",          CPENC (2,1,0,3,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcidr12",          CPENC (2,1,0,4,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcidr13",          CPENC (2,1,0,5,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcidr2",           CPENC (2,1,0,10,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcidr3",           CPENC (2,1,0,11,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcidr4",           CPENC (2,1,0,12,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcidr5",           CPENC (2,1,0,13,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcidr6",           CPENC (2,1,0,14,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcidr7",           CPENC (2,1,0,15,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcidr8",           CPENC (2,1,0,0,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcidr9",           CPENC (2,1,0,1,6),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcimspec0",                CPENC (2,1,0,0,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcimspec1",                CPENC (2,1,0,1,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcimspec2",                CPENC (2,1,0,2,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcimspec3",                CPENC (2,1,0,3,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcimspec4",                CPENC (2,1,0,4,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcimspec5",                CPENC (2,1,0,5,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcimspec6",                CPENC (2,1,0,6,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcimspec7",                CPENC (2,1,0,7,7),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcitctrl",         CPENC (2,1,7,0,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcitecr_el1",      CPENC (3,0,1,2,3),      F_ARCHEXT,              AARCH64_FEATURE (ITE))
-  SYSREG ("trcitecr_el12",     CPENC (3,5,1,2,3),      F_ARCHEXT,              AARCH64_FEATURE (ITE))
-  SYSREG ("trcitecr_el2",      CPENC (3,4,1,2,3),      F_ARCHEXT,              AARCH64_FEATURE (ITE))
-  SYSREG ("trciteedcr",                CPENC (2,1,0,2,1),      F_ARCHEXT,              AARCH64_FEATURE (ITE))
-  SYSREG ("trclar",            CPENC (2,1,7,12,6),     F_REG_WRITE,            AARCH64_NO_FEATURES)
-  SYSREG ("trclsr",            CPENC (2,1,7,13,6),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcoslar",          CPENC (2,1,1,0,4),      F_REG_WRITE,            AARCH64_NO_FEATURES)
-  SYSREG ("trcoslsr",          CPENC (2,1,1,1,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcpdcr",           CPENC (2,1,1,4,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcpdsr",           CPENC (2,1,1,5,4),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcpidr0",          CPENC (2,1,7,8,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcpidr1",          CPENC (2,1,7,9,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcpidr2",          CPENC (2,1,7,10,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcpidr3",          CPENC (2,1,7,11,7),     F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcpidr4",          CPENC (2,1,7,4,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcpidr5",          CPENC (2,1,7,5,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcpidr6",          CPENC (2,1,7,6,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcpidr7",          CPENC (2,1,7,7,7),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcprgctlr",                CPENC (2,1,0,1,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcprocselr",       CPENC (2,1,0,2,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcqctlr",          CPENC (2,1,0,1,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr10",       CPENC (2,1,1,10,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr11",       CPENC (2,1,1,11,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr12",       CPENC (2,1,1,12,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr13",       CPENC (2,1,1,13,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr14",       CPENC (2,1,1,14,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr15",       CPENC (2,1,1,15,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr16",       CPENC (2,1,1,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr17",       CPENC (2,1,1,1,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr18",       CPENC (2,1,1,2,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr19",       CPENC (2,1,1,3,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr2",                CPENC (2,1,1,2,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr20",       CPENC (2,1,1,4,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr21",       CPENC (2,1,1,5,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr22",       CPENC (2,1,1,6,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr23",       CPENC (2,1,1,7,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr24",       CPENC (2,1,1,8,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr25",       CPENC (2,1,1,9,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr26",       CPENC (2,1,1,10,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr27",       CPENC (2,1,1,11,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr28",       CPENC (2,1,1,12,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr29",       CPENC (2,1,1,13,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr3",                CPENC (2,1,1,3,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr30",       CPENC (2,1,1,14,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr31",       CPENC (2,1,1,15,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr4",                CPENC (2,1,1,4,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr5",                CPENC (2,1,1,5,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr6",                CPENC (2,1,1,6,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr7",                CPENC (2,1,1,7,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr8",                CPENC (2,1,1,8,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsctlr9",                CPENC (2,1,1,9,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcrsr",            CPENC (2,1,0,10,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcseqevr0",                CPENC (2,1,0,0,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcseqevr1",                CPENC (2,1,0,1,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcseqevr2",                CPENC (2,1,0,2,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcseqrstevr",      CPENC (2,1,0,6,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcseqstr",         CPENC (2,1,0,7,4),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcssccr0",         CPENC (2,1,1,0,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcssccr1",         CPENC (2,1,1,1,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcssccr2",         CPENC (2,1,1,2,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcssccr3",         CPENC (2,1,1,3,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcssccr4",         CPENC (2,1,1,4,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcssccr5",         CPENC (2,1,1,5,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcssccr6",         CPENC (2,1,1,6,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcssccr7",         CPENC (2,1,1,7,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsscsr0",         CPENC (2,1,1,8,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsscsr1",         CPENC (2,1,1,9,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsscsr2",         CPENC (2,1,1,10,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsscsr3",         CPENC (2,1,1,11,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsscsr4",         CPENC (2,1,1,12,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsscsr5",         CPENC (2,1,1,13,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsscsr6",         CPENC (2,1,1,14,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsscsr7",         CPENC (2,1,1,15,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsspcicr0",       CPENC (2,1,1,0,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsspcicr1",       CPENC (2,1,1,1,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsspcicr2",       CPENC (2,1,1,2,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsspcicr3",       CPENC (2,1,1,3,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsspcicr4",       CPENC (2,1,1,4,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsspcicr5",       CPENC (2,1,1,5,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsspcicr6",       CPENC (2,1,1,6,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcsspcicr7",       CPENC (2,1,1,7,3),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcstallctlr",      CPENC (2,1,0,11,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcstatr",          CPENC (2,1,0,3,0),      F_REG_READ,             AARCH64_NO_FEATURES)
-  SYSREG ("trcsyncpr",         CPENC (2,1,0,13,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trctraceidr",       CPENC (2,1,0,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trctsctlr",         CPENC (2,1,0,12,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvdarcctlr",      CPENC (2,1,0,10,2),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvdctlr",         CPENC (2,1,0,8,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvdsacctlr",      CPENC (2,1,0,9,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvictlr",         CPENC (2,1,0,0,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcviiectlr",       CPENC (2,1,0,1,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvipcssctlr",     CPENC (2,1,0,3,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvissctlr",       CPENC (2,1,0,2,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvmidcctlr0",     CPENC (2,1,3,2,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvmidcctlr1",     CPENC (2,1,3,3,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvmidcvr0",       CPENC (2,1,3,0,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvmidcvr1",       CPENC (2,1,3,2,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvmidcvr2",       CPENC (2,1,3,4,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvmidcvr3",       CPENC (2,1,3,6,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvmidcvr4",       CPENC (2,1,3,8,1),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvmidcvr5",       CPENC (2,1,3,10,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvmidcvr6",       CPENC (2,1,3,12,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trcvmidcvr7",       CPENC (2,1,3,14,1),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("trfcr_el1",         CPENC (3,0,1,2,1),      F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("trfcr_el12",                CPENC (3,5,1,2,1),      F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("trfcr_el2",         CPENC (3,4,1,2,1),      F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("ttbr0_el1",         CPENC (3,0,2,0,0),      F_REG_128,              AARCH64_NO_FEATURES)
-  SYSREG ("ttbr0_el12",                CPENC (3,5,2,0,0),      F_ARCHEXT|F_REG_128,    AARCH64_FEATURE (V8_1A))
-  SYSREG ("ttbr0_el2",         CPENC (3,4,2,0,0),      F_ARCHEXT|F_REG_128,    AARCH64_FEATURE (V8A))
-  SYSREG ("ttbr0_el3",         CPENC (3,6,2,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("ttbr1_el1",         CPENC (3,0,2,0,1),      F_REG_128,              AARCH64_NO_FEATURES)
-  SYSREG ("ttbr1_el12",                CPENC (3,5,2,0,1),      F_ARCHEXT|F_REG_128,    AARCH64_FEATURE (V8_1A))
-  SYSREG ("ttbr1_el2",         CPENC (3,4,2,0,1),      F_ARCHEXT|F_REG_128,    AARCH64_FEATURES (2, V8A, V8_1A))
-  SYSREG ("uao",               CPENC (3,0,4,2,4),      F_ARCHEXT,              AARCH64_FEATURE (V8_2A))
-  SYSREG ("vbar_el1",          CPENC (3,0,12,0,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("vbar_el12",         CPENC (3,5,12,0,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_1A))
-  SYSREG ("vbar_el2",          CPENC (3,4,12,0,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("vbar_el3",          CPENC (3,6,12,0,0),     0,                      AARCH64_NO_FEATURES)
-  SYSREG ("vdisr_el2",         CPENC (3,4,12,1,1),     F_ARCHEXT,              AARCH64_FEATURE (RAS))
-  SYSREG ("vdisr_el3",         CPENC (3,6,12,1,1),     F_ARCHEXT,              AARCH64_FEATURE (E3DSE))
-  SYSREG ("vmecid_a_el2",      CPENC (3,4,10,9,1),     F_ARCHEXT,              AARCH64_FEATURE (V8_7A))
-  SYSREG ("vmecid_p_el2",      CPENC (3,4,10,9,0),     F_ARCHEXT,              AARCH64_FEATURE (V8_7A))
-  SYSREG ("vmpidr_el2",                CPENC (3,4,0,0,5),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("vncr_el2",          CPENC (3,4,2,2,0),      F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("vpidr_el2",         CPENC (3,4,0,0,0),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("vsctlr_el2",                CPENC (3,4,2,0,0),      F_ARCHEXT,              AARCH64_FEATURE (V8R))
-  SYSREG ("vsesr_el2",         CPENC (3,4,5,2,3),      F_ARCHEXT,              AARCH64_FEATURE (RAS))
-  SYSREG ("vsesr_el3",         CPENC (3,6,5,2,3),      F_ARCHEXT,              AARCH64_FEATURE (E3DSE))
-  SYSREG ("vstcr_el2",         CPENC (3,4,2,6,2),      F_ARCHEXT,              AARCH64_FEATURE (V8_4A))
-  SYSREG ("vsttbr_el2",                CPENC (3,4,2,6,0),      F_ARCHEXT,              AARCH64_FEATURES (2, V8A, V8_4A))
-  SYSREG ("vtcr_el2",          CPENC (3,4,2,1,2),      0,                      AARCH64_NO_FEATURES)
-  SYSREG ("vttbr_el2",         CPENC (3,4,2,1,0),      F_ARCHEXT|F_REG_128,    AARCH64_FEATURE (V8A))
-  SYSREG ("zcr_el1",           CPENC (3,0,1,2,0),      F_ARCHEXT,              AARCH64_FEATURE (SVE))
-  SYSREG ("zcr_el12",          CPENC (3,5,1,2,0),      F_ARCHEXT,              AARCH64_FEATURE (SVE))
-  SYSREG ("zcr_el2",           CPENC (3,4,1,2,0),      F_ARCHEXT,              AARCH64_FEATURE (SVE))
-  SYSREG ("zcr_el3",           CPENC (3,6,1,2,0),      F_ARCHEXT,              AARCH64_FEATURE (SVE))
+  SYSREG ("accdata_el1",       CPENC (3,0,13,0,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("actlr_el1",         CPENC (3,0,1,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("actlr_el2",         CPENC (3,4,1,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("actlr_el3",         CPENC (3,6,1,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("afsr0_el1",         CPENC (3,0,5,1,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("afsr0_el12",                CPENC (3,5,5,1,0),      0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("afsr0_el2",         CPENC (3,4,5,1,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("afsr0_el3",         CPENC (3,6,5,1,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("afsr1_el1",         CPENC (3,0,5,1,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("afsr1_el12",                CPENC (3,5,5,1,1),      0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("afsr1_el2",         CPENC (3,4,5,1,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("afsr1_el3",         CPENC (3,6,5,1,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("aidr_el1",          CPENC (3,1,0,0,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("allint",            CPENC (3,0,4,3,0),      0,              AARCH64_FEATURE (V8_8A))
+  SYSREG ("amair_el1",         CPENC (3,0,10,3,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("amair_el12",                CPENC (3,5,10,3,0),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("amair_el2",         CPENC (3,4,10,3,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("amair_el3",         CPENC (3,6,10,3,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("amair2_el1",                CPENC (3,0,10,3,1),     0,              AARCH64_FEATURE (AIE))
+  SYSREG ("amair2_el12",       CPENC (3,5,10,3,1),     0,              AARCH64_FEATURE (AIE))
+  SYSREG ("amair2_el2",                CPENC (3,4,10,3,1),     0,              AARCH64_FEATURE (AIE))
+  SYSREG ("amair2_el3",                CPENC (3,6,10,3,1),     0,              AARCH64_FEATURE (AIE))
+  SYSREG ("amcfgr_el0",                CPENC (3,3,13,2,1),     F_REG_READ,     AARCH64_FEATURE (V8_4A))
+  SYSREG ("amcg1idr_el0",      CPENC (3,3,13,2,6),     F_REG_READ,     AARCH64_FEATURE (V8_6A))
+  SYSREG ("amcgcr_el0",                CPENC (3,3,13,2,2),     F_REG_READ,     AARCH64_FEATURE (V8_4A))
+  SYSREG ("amcntenclr0_el0",   CPENC (3,3,13,2,4),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amcntenclr1_el0",   CPENC (3,3,13,3,0),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amcntenset0_el0",   CPENC (3,3,13,2,5),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amcntenset1_el0",   CPENC (3,3,13,3,1),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amcr_el0",          CPENC (3,3,13,2,0),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr00_el0",    CPENC (3,3,13,4,0),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr01_el0",    CPENC (3,3,13,4,1),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr02_el0",    CPENC (3,3,13,4,2),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr03_el0",    CPENC (3,3,13,4,3),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr10_el0",    CPENC (3,3,13,12,0),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr110_el0",   CPENC (3,3,13,13,2),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr111_el0",   CPENC (3,3,13,13,3),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr112_el0",   CPENC (3,3,13,13,4),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr113_el0",   CPENC (3,3,13,13,5),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr114_el0",   CPENC (3,3,13,13,6),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr115_el0",   CPENC (3,3,13,13,7),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr11_el0",    CPENC (3,3,13,12,1),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr12_el0",    CPENC (3,3,13,12,2),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr13_el0",    CPENC (3,3,13,12,3),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr14_el0",    CPENC (3,3,13,12,4),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr15_el0",    CPENC (3,3,13,12,5),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr16_el0",    CPENC (3,3,13,12,6),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr17_el0",    CPENC (3,3,13,12,7),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr18_el0",    CPENC (3,3,13,13,0),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntr19_el0",    CPENC (3,3,13,13,1),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevcntvoff00_el2", CPENC (3,4,13,8,0),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff010_el2",        CPENC (3,4,13,9,2),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff011_el2",        CPENC (3,4,13,9,3),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff012_el2",        CPENC (3,4,13,9,4),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff013_el2",        CPENC (3,4,13,9,5),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff014_el2",        CPENC (3,4,13,9,6),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff015_el2",        CPENC (3,4,13,9,7),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff01_el2", CPENC (3,4,13,8,1),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff02_el2", CPENC (3,4,13,8,2),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff03_el2", CPENC (3,4,13,8,3),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff04_el2", CPENC (3,4,13,8,4),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff05_el2", CPENC (3,4,13,8,5),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff06_el2", CPENC (3,4,13,8,6),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff07_el2", CPENC (3,4,13,8,7),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff08_el2", CPENC (3,4,13,9,0),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff09_el2", CPENC (3,4,13,9,1),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff10_el2", CPENC (3,4,13,10,0),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff110_el2",        CPENC (3,4,13,11,2),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff111_el2",        CPENC (3,4,13,11,3),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff112_el2",        CPENC (3,4,13,11,4),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff113_el2",        CPENC (3,4,13,11,5),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff114_el2",        CPENC (3,4,13,11,6),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff115_el2",        CPENC (3,4,13,11,7),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff11_el2", CPENC (3,4,13,10,1),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff12_el2", CPENC (3,4,13,10,2),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff13_el2", CPENC (3,4,13,10,3),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff14_el2", CPENC (3,4,13,10,4),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff15_el2", CPENC (3,4,13,10,5),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff16_el2", CPENC (3,4,13,10,6),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff17_el2", CPENC (3,4,13,10,7),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff18_el2", CPENC (3,4,13,11,0),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevcntvoff19_el2", CPENC (3,4,13,11,1),    0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("amevtyper00_el0",   CPENC (3,3,13,6,0),     F_REG_READ,     AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper01_el0",   CPENC (3,3,13,6,1),     F_REG_READ,     AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper02_el0",   CPENC (3,3,13,6,2),     F_REG_READ,     AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper03_el0",   CPENC (3,3,13,6,3),     F_REG_READ,     AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper10_el0",   CPENC (3,3,13,14,0),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper110_el0",  CPENC (3,3,13,15,2),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper111_el0",  CPENC (3,3,13,15,3),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper112_el0",  CPENC (3,3,13,15,4),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper113_el0",  CPENC (3,3,13,15,5),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper114_el0",  CPENC (3,3,13,15,6),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper115_el0",  CPENC (3,3,13,15,7),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper11_el0",   CPENC (3,3,13,14,1),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper12_el0",   CPENC (3,3,13,14,2),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper13_el0",   CPENC (3,3,13,14,3),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper14_el0",   CPENC (3,3,13,14,4),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper15_el0",   CPENC (3,3,13,14,5),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper16_el0",   CPENC (3,3,13,14,6),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper17_el0",   CPENC (3,3,13,14,7),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper18_el0",   CPENC (3,3,13,15,0),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amevtyper19_el0",   CPENC (3,3,13,15,1),    0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("amuserenr_el0",     CPENC (3,3,13,2,3),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("apdakeyhi_el1",     CPENC (3,0,2,2,1),      0,              AARCH64_FEATURE (V8_3A))
+  SYSREG ("apdakeylo_el1",     CPENC (3,0,2,2,0),      0,              AARCH64_FEATURE (V8_3A))
+  SYSREG ("apdbkeyhi_el1",     CPENC (3,0,2,2,3),      0,              AARCH64_FEATURE (V8_3A))
+  SYSREG ("apdbkeylo_el1",     CPENC (3,0,2,2,2),      0,              AARCH64_FEATURE (V8_3A))
+  SYSREG ("apgakeyhi_el1",     CPENC (3,0,2,3,1),      0,              AARCH64_FEATURE (V8_3A))
+  SYSREG ("apgakeylo_el1",     CPENC (3,0,2,3,0),      0,              AARCH64_FEATURE (V8_3A))
+  SYSREG ("apiakeyhi_el1",     CPENC (3,0,2,1,1),      0,              AARCH64_FEATURE (V8_3A))
+  SYSREG ("apiakeylo_el1",     CPENC (3,0,2,1,0),      0,              AARCH64_FEATURE (V8_3A))
+  SYSREG ("apibkeyhi_el1",     CPENC (3,0,2,1,3),      0,              AARCH64_FEATURE (V8_3A))
+  SYSREG ("apibkeylo_el1",     CPENC (3,0,2,1,2),      0,              AARCH64_FEATURE (V8_3A))
+  SYSREG ("brbcr_el1",         CPENC (2,1,9,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("brbcr_el12",                CPENC (2,5,9,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("brbcr_el2",         CPENC (2,4,9,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("brbfcr_el1",                CPENC (2,1,9,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("brbidr0_el1",       CPENC (2,1,9,2,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf0_el1",       CPENC (2,1,8,0,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf10_el1",      CPENC (2,1,8,10,0),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf11_el1",      CPENC (2,1,8,11,0),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf12_el1",      CPENC (2,1,8,12,0),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf13_el1",      CPENC (2,1,8,13,0),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf14_el1",      CPENC (2,1,8,14,0),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf15_el1",      CPENC (2,1,8,15,0),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf16_el1",      CPENC (2,1,8,0,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf17_el1",      CPENC (2,1,8,1,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf18_el1",      CPENC (2,1,8,2,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf19_el1",      CPENC (2,1,8,3,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf1_el1",       CPENC (2,1,8,1,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf20_el1",      CPENC (2,1,8,4,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf21_el1",      CPENC (2,1,8,5,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf22_el1",      CPENC (2,1,8,6,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf23_el1",      CPENC (2,1,8,7,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf24_el1",      CPENC (2,1,8,8,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf25_el1",      CPENC (2,1,8,9,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf26_el1",      CPENC (2,1,8,10,4),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf27_el1",      CPENC (2,1,8,11,4),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf28_el1",      CPENC (2,1,8,12,4),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf29_el1",      CPENC (2,1,8,13,4),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf2_el1",       CPENC (2,1,8,2,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf30_el1",      CPENC (2,1,8,14,4),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf31_el1",      CPENC (2,1,8,15,4),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf3_el1",       CPENC (2,1,8,3,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf4_el1",       CPENC (2,1,8,4,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf5_el1",       CPENC (2,1,8,5,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf6_el1",       CPENC (2,1,8,6,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf7_el1",       CPENC (2,1,8,7,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf8_el1",       CPENC (2,1,8,8,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinf9_el1",       CPENC (2,1,8,9,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbinfinj_el1",     CPENC (2,1,9,1,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc0_el1",       CPENC (2,1,8,0,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc10_el1",      CPENC (2,1,8,10,1),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc11_el1",      CPENC (2,1,8,11,1),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc12_el1",      CPENC (2,1,8,12,1),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc13_el1",      CPENC (2,1,8,13,1),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc14_el1",      CPENC (2,1,8,14,1),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc15_el1",      CPENC (2,1,8,15,1),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc16_el1",      CPENC (2,1,8,0,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc17_el1",      CPENC (2,1,8,1,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc18_el1",      CPENC (2,1,8,2,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc19_el1",      CPENC (2,1,8,3,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc1_el1",       CPENC (2,1,8,1,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc20_el1",      CPENC (2,1,8,4,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc21_el1",      CPENC (2,1,8,5,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc22_el1",      CPENC (2,1,8,6,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc23_el1",      CPENC (2,1,8,7,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc24_el1",      CPENC (2,1,8,8,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc25_el1",      CPENC (2,1,8,9,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc26_el1",      CPENC (2,1,8,10,5),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc27_el1",      CPENC (2,1,8,11,5),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc28_el1",      CPENC (2,1,8,12,5),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc29_el1",      CPENC (2,1,8,13,5),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc2_el1",       CPENC (2,1,8,2,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc30_el1",      CPENC (2,1,8,14,5),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc31_el1",      CPENC (2,1,8,15,5),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc3_el1",       CPENC (2,1,8,3,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc4_el1",       CPENC (2,1,8,4,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc5_el1",       CPENC (2,1,8,5,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc6_el1",       CPENC (2,1,8,6,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc7_el1",       CPENC (2,1,8,7,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc8_el1",       CPENC (2,1,8,8,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrc9_el1",       CPENC (2,1,8,9,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbsrcinj_el1",     CPENC (2,1,9,1,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt0_el1",       CPENC (2,1,8,0,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt10_el1",      CPENC (2,1,8,10,2),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt11_el1",      CPENC (2,1,8,11,2),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt12_el1",      CPENC (2,1,8,12,2),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt13_el1",      CPENC (2,1,8,13,2),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt14_el1",      CPENC (2,1,8,14,2),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt15_el1",      CPENC (2,1,8,15,2),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt16_el1",      CPENC (2,1,8,0,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt17_el1",      CPENC (2,1,8,1,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt18_el1",      CPENC (2,1,8,2,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt19_el1",      CPENC (2,1,8,3,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt1_el1",       CPENC (2,1,8,1,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt20_el1",      CPENC (2,1,8,4,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt21_el1",      CPENC (2,1,8,5,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt22_el1",      CPENC (2,1,8,6,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt23_el1",      CPENC (2,1,8,7,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt24_el1",      CPENC (2,1,8,8,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt25_el1",      CPENC (2,1,8,9,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt26_el1",      CPENC (2,1,8,10,6),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt27_el1",      CPENC (2,1,8,11,6),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt28_el1",      CPENC (2,1,8,12,6),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt29_el1",      CPENC (2,1,8,13,6),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt2_el1",       CPENC (2,1,8,2,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt30_el1",      CPENC (2,1,8,14,6),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt31_el1",      CPENC (2,1,8,15,6),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt3_el1",       CPENC (2,1,8,3,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt4_el1",       CPENC (2,1,8,4,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt5_el1",       CPENC (2,1,8,5,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt6_el1",       CPENC (2,1,8,6,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt7_el1",       CPENC (2,1,8,7,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt8_el1",       CPENC (2,1,8,8,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgt9_el1",       CPENC (2,1,8,9,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("brbtgtinj_el1",     CPENC (2,1,9,1,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("brbts_el1",         CPENC (2,1,9,0,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("ccsidr2_el1",       CPENC (3,1,0,0,2),      F_REG_READ,     AARCH64_FEATURE (V8_3A))
+  SYSREG ("ccsidr_el1",                CPENC (3,1,0,0,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("clidr_el1",         CPENC (3,1,0,0,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("cntfrq_el0",                CPENC (3,3,14,0,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cnthctl_el2",       CPENC (3,4,14,1,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cnthp_ctl_el2",     CPENC (3,4,14,2,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cnthp_cval_el2",    CPENC (3,4,14,2,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cnthp_tval_el2",    CPENC (3,4,14,2,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cnthps_ctl_el2",    CPENC (3,4,14,5,1),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("cnthps_cval_el2",   CPENC (3,4,14,5,2),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("cnthps_tval_el2",   CPENC (3,4,14,5,0),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("cnthv_ctl_el2",     CPENC (3,4,14,3,1),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("cnthv_cval_el2",    CPENC (3,4,14,3,2),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("cnthv_tval_el2",    CPENC (3,4,14,3,0),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("cnthvs_ctl_el2",    CPENC (3,4,14,4,1),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("cnthvs_cval_el2",   CPENC (3,4,14,4,2),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("cnthvs_tval_el2",   CPENC (3,4,14,4,0),     0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("cntkctl_el1",       CPENC (3,0,14,1,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cntkctl_el12",      CPENC (3,5,14,1,0),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("cntp_ctl_el0",      CPENC (3,3,14,2,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cntp_ctl_el02",     CPENC (3,5,14,2,1),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("cntp_cval_el0",     CPENC (3,3,14,2,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cntp_cval_el02",    CPENC (3,5,14,2,2),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("cntp_tval_el0",     CPENC (3,3,14,2,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cntp_tval_el02",    CPENC (3,5,14,2,0),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("cntpct_el0",                CPENC (3,3,14,0,1),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("cntpctss_el0",      CPENC (3,3,14,0,5),     F_REG_READ,     AARCH64_FEATURE (V8_6A))
+  SYSREG ("cntpoff_el2",       CPENC (3,4,14,0,6),     0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("cntps_ctl_el1",     CPENC (3,7,14,2,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cntps_cval_el1",    CPENC (3,7,14,2,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cntps_tval_el1",    CPENC (3,7,14,2,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cntv_ctl_el0",      CPENC (3,3,14,3,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cntv_ctl_el02",     CPENC (3,5,14,3,1),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("cntv_cval_el0",     CPENC (3,3,14,3,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cntv_cval_el02",    CPENC (3,5,14,3,2),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("cntv_tval_el0",     CPENC (3,3,14,3,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("cntv_tval_el02",    CPENC (3,5,14,3,0),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("cntvct_el0",                CPENC (3,3,14,0,2),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("cntvctss_el0",      CPENC (3,3,14,0,6),     F_REG_READ,     AARCH64_FEATURE (V8_6A))
+  SYSREG ("cntvoff_el2",       CPENC (3,4,14,0,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("contextidr_el1",    CPENC (3,0,13,0,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("contextidr_el12",   CPENC (3,5,13,0,1),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("contextidr_el2",    CPENC (3,4,13,0,1),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("cpacr_el1",         CPENC (3,0,1,0,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("cpacr_el12",                CPENC (3,5,1,0,2),      0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("cptr_el2",          CPENC (3,4,1,1,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("cptr_el3",          CPENC (3,6,1,1,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("csrcr_el0",         CPENC (2,3,8,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("csrcr_el1",         CPENC (2,0,8,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("csrcr_el12",                CPENC (2,5,8,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("csrcr_el2",         CPENC (2,4,8,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("csridr_el0",                CPENC (2,3,8,0,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("csrptr_el0",                CPENC (2,3,8,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("csrptr_el1",                CPENC (2,0,8,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("csrptr_el12",       CPENC (2,5,8,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("csrptr_el2",                CPENC (2,4,8,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("csrptridx_el0",     CPENC (2,3,8,0,3),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("csrptridx_el1",     CPENC (2,0,8,0,3),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("csrptridx_el2",     CPENC (2,4,8,0,3),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("csselr_el1",                CPENC (3,2,0,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("ctr_el0",           CPENC (3,3,0,0,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("currentel",         CPENC (3,0,4,2,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("dacr32_el2",                CPENC (3,4,3,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("daif",              CPENC (3,3,4,2,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgauthstatus_el1", CPENC (2,0,7,14,6),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr0_el1",       CPENC (2,0,0,0,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr10_el1",      CPENC (2,0,0,10,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr11_el1",      CPENC (2,0,0,11,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr12_el1",      CPENC (2,0,0,12,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr13_el1",      CPENC (2,0,0,13,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr14_el1",      CPENC (2,0,0,14,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr15_el1",      CPENC (2,0,0,15,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr1_el1",       CPENC (2,0,0,1,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr2_el1",       CPENC (2,0,0,2,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr3_el1",       CPENC (2,0,0,3,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr4_el1",       CPENC (2,0,0,4,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr5_el1",       CPENC (2,0,0,5,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr6_el1",       CPENC (2,0,0,6,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr7_el1",       CPENC (2,0,0,7,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr8_el1",       CPENC (2,0,0,8,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbcr9_el1",       CPENC (2,0,0,9,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr0_el1",       CPENC (2,0,0,0,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr10_el1",      CPENC (2,0,0,10,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr11_el1",      CPENC (2,0,0,11,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr12_el1",      CPENC (2,0,0,12,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr13_el1",      CPENC (2,0,0,13,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr14_el1",      CPENC (2,0,0,14,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr15_el1",      CPENC (2,0,0,15,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr1_el1",       CPENC (2,0,0,1,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr2_el1",       CPENC (2,0,0,2,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr3_el1",       CPENC (2,0,0,3,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr4_el1",       CPENC (2,0,0,4,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr5_el1",       CPENC (2,0,0,5,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr6_el1",       CPENC (2,0,0,6,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr7_el1",       CPENC (2,0,0,7,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr8_el1",       CPENC (2,0,0,8,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgbvr9_el1",       CPENC (2,0,0,9,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgclaimclr_el1",   CPENC (2,0,7,9,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgclaimset_el1",   CPENC (2,0,7,8,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgdtr_el0",                CPENC (2,3,0,4,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgdtrrx_el0",      CPENC (2,3,0,5,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("dbgdtrtx_el0",      CPENC (2,3,0,5,0),      F_REG_WRITE,    AARCH64_NO_FEATURES)
+  SYSREG ("dbgprcr_el1",       CPENC (2,0,1,4,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgvcr32_el2",      CPENC (2,4,0,7,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr0_el1",       CPENC (2,0,0,0,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr10_el1",      CPENC (2,0,0,10,7),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr11_el1",      CPENC (2,0,0,11,7),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr12_el1",      CPENC (2,0,0,12,7),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr13_el1",      CPENC (2,0,0,13,7),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr14_el1",      CPENC (2,0,0,14,7),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr15_el1",      CPENC (2,0,0,15,7),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr1_el1",       CPENC (2,0,0,1,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr2_el1",       CPENC (2,0,0,2,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr3_el1",       CPENC (2,0,0,3,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr4_el1",       CPENC (2,0,0,4,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr5_el1",       CPENC (2,0,0,5,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr6_el1",       CPENC (2,0,0,6,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr7_el1",       CPENC (2,0,0,7,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr8_el1",       CPENC (2,0,0,8,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwcr9_el1",       CPENC (2,0,0,9,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr0_el1",       CPENC (2,0,0,0,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr10_el1",      CPENC (2,0,0,10,6),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr11_el1",      CPENC (2,0,0,11,6),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr12_el1",      CPENC (2,0,0,12,6),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr13_el1",      CPENC (2,0,0,13,6),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr14_el1",      CPENC (2,0,0,14,6),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr15_el1",      CPENC (2,0,0,15,6),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr1_el1",       CPENC (2,0,0,1,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr2_el1",       CPENC (2,0,0,2,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr3_el1",       CPENC (2,0,0,3,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr4_el1",       CPENC (2,0,0,4,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr5_el1",       CPENC (2,0,0,5,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr6_el1",       CPENC (2,0,0,6,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr7_el1",       CPENC (2,0,0,7,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr8_el1",       CPENC (2,0,0,8,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dbgwvr9_el1",       CPENC (2,0,0,9,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dczid_el0",         CPENC (3,3,0,0,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("disr_el1",          CPENC (3,0,12,1,1),     0,              AARCH64_FEATURE (RAS))
+  SYSREG ("dit",               CPENC (3,3,4,2,5),      0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("dlr_el0",           CPENC (3,3,4,5,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("dspsr_el0",         CPENC (3,3,4,5,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("elr_el1",           CPENC (3,0,4,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("elr_el12",          CPENC (3,5,4,0,1),      0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("elr_el2",           CPENC (3,4,4,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("elr_el3",           CPENC (3,6,4,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("erridr_el1",                CPENC (3,0,5,3,0),      F_REG_READ,     AARCH64_FEATURE (RAS))
+  SYSREG ("errselr_el1",       CPENC (3,0,5,3,1),      0,              AARCH64_FEATURE (RAS))
+  SYSREG ("erxaddr_el1",       CPENC (3,0,5,4,3),      0,              AARCH64_FEATURE (RAS))
+  SYSREG ("erxctlr_el1",       CPENC (3,0,5,4,1),      0,              AARCH64_FEATURE (RAS))
+  SYSREG ("erxfr_el1",         CPENC (3,0,5,4,0),      F_REG_READ,     AARCH64_FEATURE (RAS))
+  SYSREG ("erxgsr_el1",                CPENC (3,0,5,3,2),      F_REG_READ,     AARCH64_FEATURE (RASv2))
+  SYSREG ("erxmisc0_el1",      CPENC (3,0,5,5,0),      0,              AARCH64_FEATURE (RAS))
+  SYSREG ("erxmisc1_el1",      CPENC (3,0,5,5,1),      0,              AARCH64_FEATURE (RAS))
+  SYSREG ("erxmisc2_el1",      CPENC (3,0,5,5,2),      0,              AARCH64_FEATURE (RAS))
+  SYSREG ("erxmisc3_el1",      CPENC (3,0,5,5,3),      0,              AARCH64_FEATURE (RAS))
+  SYSREG ("erxpfgcdn_el1",     CPENC (3,0,5,4,6),      0,              AARCH64_FEATURE (RAS))
+  SYSREG ("erxpfgctl_el1",     CPENC (3,0,5,4,5),      0,              AARCH64_FEATURE (RAS))
+  SYSREG ("erxpfgf_el1",       CPENC (3,0,5,4,4),      F_REG_READ,     AARCH64_FEATURE (RAS))
+  SYSREG ("erxstatus_el1",     CPENC (3,0,5,4,2),      0,              AARCH64_FEATURE (RAS))
+  SYSREG ("esr_el1",           CPENC (3,0,5,2,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("esr_el12",          CPENC (3,5,5,2,0),      0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("esr_el2",           CPENC (3,4,5,2,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("esr_el3",           CPENC (3,6,5,2,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("far_el1",           CPENC (3,0,6,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("far_el12",          CPENC (3,5,6,0,0),      0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("far_el2",           CPENC (3,4,6,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("far_el3",           CPENC (3,6,6,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("fpcr",              CPENC (3,3,4,4,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("fpexc32_el2",       CPENC (3,4,5,3,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("fpmr",              CPENC (3,3,4,4,2),      0,              AARCH64_FEATURE (FP8))
+  SYSREG ("fpsr",              CPENC (3,3,4,4,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("gcspr_el0",         CPENC (3,3,2,5,1),      0,              AARCH64_FEATURE (GCS))
+  SYSREG ("gcspr_el1",         CPENC (3,0,2,5,1),      0,              AARCH64_FEATURE (GCS))
+  SYSREG ("gcspr_el2",         CPENC (3,4,2,5,1),      0,              AARCH64_FEATURE (GCS))
+  SYSREG ("gcspr_el12",                CPENC (3,5,2,5,1),      0,              AARCH64_FEATURE (GCS))
+  SYSREG ("gcspr_el3",         CPENC (3,6,2,5,1),      0,              AARCH64_FEATURE (GCS))
+  SYSREG ("gcscre0_el1",       CPENC (3,0,2,5,2),      0,              AARCH64_FEATURE (GCS))
+  SYSREG ("gcscr_el1",         CPENC (3,0,2,5,0),      0,              AARCH64_FEATURE (GCS))
+  SYSREG ("gcscr_el2",         CPENC (3,4,2,5,0),      0,              AARCH64_FEATURE (GCS))
+  SYSREG ("gcscr_el12",                CPENC (3,5,2,5,0),      0,              AARCH64_FEATURE (GCS))
+  SYSREG ("gcscr_el3",         CPENC (3,6,2,5,0),      0,              AARCH64_FEATURE (GCS))
+  SYSREG ("gcr_el1",           CPENC (3,0,1,0,6),      0,              AARCH64_FEATURE (MEMTAG))
+  SYSREG ("gmid_el1",          CPENC (3,1,0,0,4),      F_REG_READ,     AARCH64_FEATURE (MEMTAG))
+  SYSREG ("gpcbw_el3",         CPENC (3,6,2,1,5),      0,              AARCH64_FEATURE (V9_5A))
+  SYSREG ("gpccr_el3",         CPENC (3,6,2,1,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("gptbr_el3",         CPENC (3,6,2,1,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("hacr_el2",          CPENC (3,4,1,1,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("hafgrtr_el2",       CPENC (3,4,3,1,6),      0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("hcr_el2",           CPENC (3,4,1,1,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("hcrx_el2",          CPENC (3,4,1,2,2),      0,              AARCH64_FEATURE (V8_7A))
+  SYSREG ("hdfgrtr_el2",       CPENC (3,4,3,1,4),      0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("hdfgrtr2_el2",      CPENC (3,4,3,1,0),      0,              AARCH64_FEATURE (FGT2))
+  SYSREG ("hdfgwtr_el2",       CPENC (3,4,3,1,5),      0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("hdfgwtr2_el2",      CPENC (3,4,3,1,1),      0,              AARCH64_FEATURE (FGT2))
+  SYSREG ("hfgitr_el2",                CPENC (3,4,1,1,6),      0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("hfgitr2_el2",       CPENC (3,4,3,1,7),      0,              AARCH64_FEATURE (V8_8A))
+  SYSREG ("hfgrtr_el2",                CPENC (3,4,1,1,4),      0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("hfgrtr2_el2",       CPENC (3,4,3,1,2),      0,              AARCH64_FEATURE (FGT2))
+  SYSREG ("hfgwtr_el2",                CPENC (3,4,1,1,5),      0,              AARCH64_FEATURE (V8_6A))
+  SYSREG ("hfgwtr2_el2",       CPENC (3,4,3,1,3),      0,              AARCH64_FEATURE (FGT2))
+  SYSREG ("hpfar_el2",         CPENC (3,4,6,0,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("hstr_el2",          CPENC (3,4,1,1,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_ap0r0_el1",     CPENC (3,0,12,8,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_ap0r1_el1",     CPENC (3,0,12,8,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_ap0r2_el1",     CPENC (3,0,12,8,6),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_ap0r3_el1",     CPENC (3,0,12,8,7),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_ap1r0_el1",     CPENC (3,0,12,9,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_ap1r1_el1",     CPENC (3,0,12,9,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_ap1r2_el1",     CPENC (3,0,12,9,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_ap1r3_el1",     CPENC (3,0,12,9,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_asgi1r_el1",    CPENC (3,0,12,11,6),    F_REG_WRITE,    AARCH64_NO_FEATURES)
+  SYSREG ("icc_bpr0_el1",      CPENC (3,0,12,8,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_bpr1_el1",      CPENC (3,0,12,12,3),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_ctlr_el1",      CPENC (3,0,12,12,4),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_ctlr_el3",      CPENC (3,6,12,12,4),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_dir_el1",       CPENC (3,0,12,11,1),    F_REG_WRITE,    AARCH64_NO_FEATURES)
+  SYSREG ("icc_eoir0_el1",     CPENC (3,0,12,8,1),     F_REG_WRITE,    AARCH64_NO_FEATURES)
+  SYSREG ("icc_eoir1_el1",     CPENC (3,0,12,12,1),    F_REG_WRITE,    AARCH64_NO_FEATURES)
+  SYSREG ("icc_hppir0_el1",    CPENC (3,0,12,8,2),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("icc_hppir1_el1",    CPENC (3,0,12,12,2),    F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("icc_iar0_el1",      CPENC (3,0,12,8,0),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("icc_iar1_el1",      CPENC (3,0,12,12,0),    F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("icc_igrpen0_el1",   CPENC (3,0,12,12,6),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_igrpen1_el1",   CPENC (3,0,12,12,7),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_igrpen1_el3",   CPENC (3,6,12,12,7),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_nmiar1_el1",    CPENC (3,0,12,9,5),     F_REG_READ,     AARCH64_FEATURE (V8_8A))
+  SYSREG ("icc_pmr_el1",       CPENC (3,0,4,6,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_rpr_el1",       CPENC (3,0,12,11,3),    F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("icc_sgi0r_el1",     CPENC (3,0,12,11,7),    F_REG_WRITE,    AARCH64_NO_FEATURES)
+  SYSREG ("icc_sgi1r_el1",     CPENC (3,0,12,11,5),    F_REG_WRITE,    AARCH64_NO_FEATURES)
+  SYSREG ("icc_sre_el1",       CPENC (3,0,12,12,5),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_sre_el2",       CPENC (3,4,12,9,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("icc_sre_el3",       CPENC (3,6,12,12,5),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_ap0r0_el2",     CPENC (3,4,12,8,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_ap0r1_el2",     CPENC (3,4,12,8,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_ap0r2_el2",     CPENC (3,4,12,8,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_ap0r3_el2",     CPENC (3,4,12,8,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_ap1r0_el2",     CPENC (3,4,12,9,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_ap1r1_el2",     CPENC (3,4,12,9,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_ap1r2_el2",     CPENC (3,4,12,9,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_ap1r3_el2",     CPENC (3,4,12,9,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_eisr_el2",      CPENC (3,4,12,11,3),    F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("ich_elrsr_el2",     CPENC (3,4,12,11,5),    F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("ich_hcr_el2",       CPENC (3,4,12,11,0),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr0_el2",       CPENC (3,4,12,12,0),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr10_el2",      CPENC (3,4,12,13,2),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr11_el2",      CPENC (3,4,12,13,3),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr12_el2",      CPENC (3,4,12,13,4),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr13_el2",      CPENC (3,4,12,13,5),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr14_el2",      CPENC (3,4,12,13,6),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr15_el2",      CPENC (3,4,12,13,7),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr1_el2",       CPENC (3,4,12,12,1),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr2_el2",       CPENC (3,4,12,12,2),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr3_el2",       CPENC (3,4,12,12,3),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr4_el2",       CPENC (3,4,12,12,4),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr5_el2",       CPENC (3,4,12,12,5),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr6_el2",       CPENC (3,4,12,12,6),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr7_el2",       CPENC (3,4,12,12,7),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr8_el2",       CPENC (3,4,12,13,0),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_lr9_el2",       CPENC (3,4,12,13,1),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_misr_el2",      CPENC (3,4,12,11,2),    F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("ich_vmcr_el2",      CPENC (3,4,12,11,7),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("ich_vtr_el2",       CPENC (3,4,12,11,1),    F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64afr0_el1",   CPENC (3,0,0,5,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64afr1_el1",   CPENC (3,0,0,5,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64dfr0_el1",   CPENC (3,0,0,5,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64dfr1_el1",   CPENC (3,0,0,5,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64dfr2_el1",   CPENC (3,0,0,5,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64fpfr0_el1",  CPENC (3,0,0,4,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64isar0_el1",  CPENC (3,0,0,6,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64isar1_el1",  CPENC (3,0,0,6,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64isar2_el1",  CPENC (3,0,0,6,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64isar3_el1",  CPENC (3,0,0,6,3),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64mmfr0_el1",  CPENC (3,0,0,7,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64mmfr1_el1",  CPENC (3,0,0,7,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64mmfr2_el1",  CPENC (3,0,0,7,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64mmfr3_el1",  CPENC (3,0,0,7,3),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64mmfr4_el1",  CPENC (3,0,0,7,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64pfr0_el1",   CPENC (3,0,0,4,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64pfr1_el1",   CPENC (3,0,0,4,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64pfr2_el1",   CPENC (3,0,0,4,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_aa64smfr0_el1",  CPENC (3,0,0,4,5),      F_REG_READ,     AARCH64_FEATURE (SME))
+  SYSREG ("id_aa64zfr0_el1",   CPENC (3,0,0,4,4),      F_REG_READ,     AARCH64_FEATURE (SVE))
+  SYSREG ("id_afr0_el1",       CPENC (3,0,0,1,3),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_dfr0_el1",       CPENC (3,0,0,1,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_dfr1_el1",       CPENC (3,0,0,3,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_isar0_el1",      CPENC (3,0,0,2,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_isar1_el1",      CPENC (3,0,0,2,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_isar2_el1",      CPENC (3,0,0,2,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_isar3_el1",      CPENC (3,0,0,2,3),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_isar4_el1",      CPENC (3,0,0,2,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_isar5_el1",      CPENC (3,0,0,2,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_isar6_el1",      CPENC (3,0,0,2,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_mmfr0_el1",      CPENC (3,0,0,1,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_mmfr1_el1",      CPENC (3,0,0,1,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_mmfr2_el1",      CPENC (3,0,0,1,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_mmfr3_el1",      CPENC (3,0,0,1,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_mmfr4_el1",      CPENC (3,0,0,2,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_mmfr5_el1",      CPENC (3,0,0,3,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_pfr0_el1",       CPENC (3,0,0,1,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_pfr1_el1",       CPENC (3,0,0,1,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("id_pfr2_el1",       CPENC (3,0,0,3,4),      F_REG_READ,     AARCH64_FEATURE (ID_PFR2))
+  SYSREG ("ifsr32_el2",                CPENC (3,4,5,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("isr_el1",           CPENC (3,0,12,1,0),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("lorc_el1",          CPENC (3,0,10,4,3),     0,              AARCH64_FEATURE (LOR))
+  SYSREG ("lorea_el1",         CPENC (3,0,10,4,1),     0,              AARCH64_FEATURE (LOR))
+  SYSREG ("lorid_el1",         CPENC (3,0,10,4,7),     F_REG_READ,     AARCH64_FEATURE (LOR))
+  SYSREG ("lorn_el1",          CPENC (3,0,10,4,2),     0,              AARCH64_FEATURE (LOR))
+  SYSREG ("lorsa_el1",         CPENC (3,0,10,4,0),     0,              AARCH64_FEATURE (LOR))
+  SYSREG ("mair_el1",          CPENC (3,0,10,2,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mair_el12",         CPENC (3,5,10,2,0),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("mair_el2",          CPENC (3,4,10,2,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mair_el3",          CPENC (3,6,10,2,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mair2_el1",         CPENC (3,0,10,2,1),     0,              AARCH64_FEATURE (AIE))
+  SYSREG ("mair2_el12",                CPENC (3,5,10,2,1),     0,              AARCH64_FEATURE (AIE))
+  SYSREG ("mair2_el2",         CPENC (3,4,10,1,1),     0,              AARCH64_FEATURE (AIE))
+  SYSREG ("mair2_el3",         CPENC (3,6,10,1,1),     0,              AARCH64_FEATURE (AIE))
+  SYSREG ("mdccint_el1",       CPENC (2,0,0,2,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("mdccsr_el0",                CPENC (2,3,0,1,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("mdcr_el2",          CPENC (3,4,1,1,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("mdcr_el3",          CPENC (3,6,1,3,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("mdrar_el1",         CPENC (2,0,1,0,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("mdscr_el1",         CPENC (2,0,0,2,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("mdselr_el1",                CPENC (2,0,0,4,2),      0,              AARCH64_FEATURE (DEBUGv8p9))
+  SYSREG ("mdstepop_el1",      CPENC (2,0,0,5,2),      0,              AARCH64_FEATURE (STEP2))
+  SYSREG ("mecid_a0_el2",      CPENC (3,4,10,8,1),     0,              AARCH64_FEATURE (V8_7A))
+  SYSREG ("mecid_a1_el2",      CPENC (3,4,10,8,3),     0,              AARCH64_FEATURE (V8_7A))
+  SYSREG ("mecid_p0_el2",      CPENC (3,4,10,8,0),     0,              AARCH64_FEATURE (V8_7A))
+  SYSREG ("mecid_p1_el2",      CPENC (3,4,10,8,2),     0,              AARCH64_FEATURE (V8_7A))
+  SYSREG ("mecid_rl_a_el3",    CPENC (3,6,10,10,1),    0,              AARCH64_FEATURE (V8_7A))
+  SYSREG ("mecidr_el2",                CPENC (3,4,10,8,7),     F_REG_READ,     AARCH64_FEATURE (V8_7A))
+  SYSREG ("mfar_el3",          CPENC (3,6,6,0,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("midr_el1",          CPENC (3,0,0,0,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("mpam0_el1",         CPENC (3,0,10,5,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpam1_el1",         CPENC (3,0,10,5,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpam1_el12",                CPENC (3,5,10,5,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpam2_el2",         CPENC (3,4,10,5,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpam3_el3",         CPENC (3,6,10,5,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpambw0_el1",       CPENC (3,0,10,5,5),     0,              AARCH64_FEATURE (V9_3A))
+  SYSREG ("mpambw1_el1",       CPENC (3,0,10,5,4),     0,              AARCH64_FEATURE (V9_3A))
+  SYSREG ("mpambw1_el12",      CPENC (3,5,10,5,4),     0,              AARCH64_FEATURE (V9_3A))
+  SYSREG ("mpambw2_el2",       CPENC (3,4,10,5,4),     0,              AARCH64_FEATURE (V9_3A))
+  SYSREG ("mpambw3_el3",       CPENC (3,6,10,5,4),     0,              AARCH64_FEATURE (V9_3A))
+  SYSREG ("mpambwcap_el2",     CPENC (3,4,10,5,6),     0,              AARCH64_FEATURE (V9_3A))
+  SYSREG ("mpambwidr_el1",     CPENC (3,0,10,4,5),     F_REG_READ,     AARCH64_FEATURE (V9_3A))
+  SYSREG ("mpambwsm_el1",      CPENC (3,0,10,5,7),     0,              AARCH64_FEATURES (2, SME, V9_3A))
+  SYSREG ("mpamhcr_el2",       CPENC (3,4,10,4,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpamidr_el1",       CPENC (3,0,10,4,4),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("mpamsm_el1",                CPENC (3,0,10,5,3),     0,              AARCH64_FEATURE (SME))
+  SYSREG ("mpamvpm0_el2",      CPENC (3,4,10,6,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpamvpm1_el2",      CPENC (3,4,10,6,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpamvpm2_el2",      CPENC (3,4,10,6,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpamvpm3_el2",      CPENC (3,4,10,6,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpamvpm4_el2",      CPENC (3,4,10,6,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpamvpm5_el2",      CPENC (3,4,10,6,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpamvpm6_el2",      CPENC (3,4,10,6,6),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpamvpm7_el2",      CPENC (3,4,10,6,7),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpamvpmv_el2",      CPENC (3,4,10,4,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("mpidr_el1",         CPENC (3,0,0,0,5),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("mpuir_el1",         CPENC (3,0,0,0,4),      F_REG_READ,     AARCH64_FEATURE (V8R))
+  SYSREG ("mpuir_el2",         CPENC (3,4,0,0,4),      F_REG_READ,     AARCH64_FEATURE (V8R))
+  SYSREG ("mvfr0_el1",         CPENC (3,0,0,3,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("mvfr1_el1",         CPENC (3,0,0,3,1),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("mvfr2_el1",         CPENC (3,0,0,3,2),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("nzcv",              CPENC (3,3,4,2,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("osdlr_el1",         CPENC (2,0,1,3,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("osdtrrx_el1",       CPENC (2,0,0,0,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("osdtrtx_el1",       CPENC (2,0,0,3,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("oseccr_el1",                CPENC (2,0,0,6,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("oslar_el1",         CPENC (2,0,1,0,4),      F_REG_WRITE,    AARCH64_NO_FEATURES)
+  SYSREG ("oslsr_el1",         CPENC (2,0,1,1,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("pir_el1",           CPENC (3,0,10,2,3),     0,              AARCH64_FEATURE (S1PIE))
+  SYSREG ("pir_el12",          CPENC (3,5,10,2,3),     0,              AARCH64_FEATURE (S1PIE))
+  SYSREG ("pir_el2",           CPENC (3,4,10,2,3),     0,              AARCH64_FEATURE (S1PIE))
+  SYSREG ("pir_el3",           CPENC (3,6,10,2,3),     0,              AARCH64_FEATURE (S1PIE))
+  SYSREG ("pire0_el1",         CPENC (3,0,10,2,2),     0,              AARCH64_FEATURE (S1PIE))
+  SYSREG ("pire0_el12",                CPENC (3,5,10,2,2),     0,              AARCH64_FEATURE (S1PIE))
+  SYSREG ("pire0_el2",         CPENC (3,4,10,2,2),     0,              AARCH64_FEATURE (S1PIE))
+  SYSREG ("pan",               CPENC (3,0,4,2,3),      0,              AARCH64_FEATURE (PAN))
+  SYSREG ("par_el1",           CPENC (3,0,7,4,0),      F_REG_128,      AARCH64_NO_FEATURES)
+  SYSREG ("pfar_el1",          CPENC (3,0,6,0,5),      0,              AARCH64_FEATURE (PFAR))
+  SYSREG ("pfar_el12",         CPENC (3,5,6,0,5),      0,              AARCH64_FEATURE (PFAR))
+  SYSREG ("pfar_el2",          CPENC (3,4,6,0,5),      0,              AARCH64_FEATURE (PFAR))
+  SYSREG ("pmbidr_el1",                CPENC (3,0,9,10,7),     F_REG_READ,     AARCH64_FEATURE (PROFILE))
+  SYSREG ("pmblimitr_el1",     CPENC (3,0,9,10,0),     0,              AARCH64_FEATURE (PROFILE))
+  SYSREG ("pmbmar_el1",                CPENC (3,0,9,10,5),     0,              AARCH64_FEATURES (2, PROFILE, V9_5A))
+  SYSREG ("pmbptr_el1",                CPENC (3,0,9,10,1),     0,              AARCH64_FEATURE (PROFILE))
+  SYSREG ("pmbsr_el1",         CPENC (3,0,9,10,3),     0,              AARCH64_FEATURE (PROFILE))
+  SYSREG ("pmbsr_el12",                CPENC (3,5,9,10,3),     0,              AARCH64_FEATURES (2, V9_5A, PROFILE))
+  SYSREG ("pmbsr_el2",         CPENC (3,4,9,10,3),     0,              AARCH64_FEATURES (2, V9_5A, PROFILE))
+  SYSREG ("pmbsr_el3",         CPENC (3,6,9,10,3),     0,              AARCH64_FEATURES (2, V9_5A, PROFILE))
+  SYSREG ("pmccfiltr_el0",     CPENC (3,3,14,15,7),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmccntr_el0",       CPENC (3,3,9,13,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmccntsvr_el1",     CPENC (2,0,14,11,7),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmceid0_el0",       CPENC (3,3,9,12,6),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("pmceid1_el0",       CPENC (3,3,9,12,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("pmcntenclr_el0",    CPENC (3,3,9,12,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmcntenset_el0",    CPENC (3,3,9,12,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmcr_el0",          CPENC (3,3,9,12,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmecr_el1",         CPENC (3,0,9,14,5),     0,              AARCH64_FEATURE (SEBEP))
+  SYSREG ("pmevcntr0_el0",     CPENC (3,3,14,8,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr10_el0",    CPENC (3,3,14,9,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr11_el0",    CPENC (3,3,14,9,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr12_el0",    CPENC (3,3,14,9,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr13_el0",    CPENC (3,3,14,9,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr14_el0",    CPENC (3,3,14,9,6),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr15_el0",    CPENC (3,3,14,9,7),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr16_el0",    CPENC (3,3,14,10,0),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr17_el0",    CPENC (3,3,14,10,1),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr18_el0",    CPENC (3,3,14,10,2),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr19_el0",    CPENC (3,3,14,10,3),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr1_el0",     CPENC (3,3,14,8,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr20_el0",    CPENC (3,3,14,10,4),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr21_el0",    CPENC (3,3,14,10,5),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr22_el0",    CPENC (3,3,14,10,6),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr23_el0",    CPENC (3,3,14,10,7),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr24_el0",    CPENC (3,3,14,11,0),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr25_el0",    CPENC (3,3,14,11,1),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr26_el0",    CPENC (3,3,14,11,2),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr27_el0",    CPENC (3,3,14,11,3),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr28_el0",    CPENC (3,3,14,11,4),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr29_el0",    CPENC (3,3,14,11,5),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr2_el0",     CPENC (3,3,14,8,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr30_el0",    CPENC (3,3,14,11,6),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr3_el0",     CPENC (3,3,14,8,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr4_el0",     CPENC (3,3,14,8,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr5_el0",     CPENC (3,3,14,8,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr6_el0",     CPENC (3,3,14,8,6),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr7_el0",     CPENC (3,3,14,8,7),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr8_el0",     CPENC (3,3,14,9,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntr9_el0",     CPENC (3,3,14,9,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevcntsvr0_el1",   CPENC (2,0,14,8,0),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr10_el1",  CPENC (2,0,14,9,2),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr11_el1",  CPENC (2,0,14,9,3),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr12_el1",  CPENC (2,0,14,9,4),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr13_el1",  CPENC (2,0,14,9,5),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr14_el1",  CPENC (2,0,14,9,6),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr15_el1",  CPENC (2,0,14,9,7),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr16_el1",  CPENC (2,0,14,10,0),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr17_el1",  CPENC (2,0,14,10,1),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr18_el1",  CPENC (2,0,14,10,2),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr19_el1",  CPENC (2,0,14,10,3),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr1_el1",   CPENC (2,0,14,8,1),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr20_el1",  CPENC (2,0,14,10,4),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr21_el1",  CPENC (2,0,14,10,5),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr22_el1",  CPENC (2,0,14,10,6),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr23_el1",  CPENC (2,0,14,10,7),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr24_el1",  CPENC (2,0,14,11,0),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr25_el1",  CPENC (2,0,14,11,1),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr26_el1",  CPENC (2,0,14,11,2),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr27_el1",  CPENC (2,0,14,11,3),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr28_el1",  CPENC (2,0,14,11,4),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr29_el1",  CPENC (2,0,14,11,5),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr2_el1",   CPENC (2,0,14,8,2),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr30_el1",  CPENC (2,0,14,11,6),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr3_el1",   CPENC (2,0,14,8,3),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr4_el1",   CPENC (2,0,14,8,4),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr5_el1",   CPENC (2,0,14,8,5),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr6_el1",   CPENC (2,0,14,8,6),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr7_el1",   CPENC (2,0,14,8,7),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr8_el1",   CPENC (2,0,14,9,0),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevcntsvr9_el1",   CPENC (2,0,14,9,1),     F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmevtyper0_el0",    CPENC (3,3,14,12,0),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper10_el0",   CPENC (3,3,14,13,2),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper11_el0",   CPENC (3,3,14,13,3),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper12_el0",   CPENC (3,3,14,13,4),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper13_el0",   CPENC (3,3,14,13,5),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper14_el0",   CPENC (3,3,14,13,6),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper15_el0",   CPENC (3,3,14,13,7),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper16_el0",   CPENC (3,3,14,14,0),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper17_el0",   CPENC (3,3,14,14,1),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper18_el0",   CPENC (3,3,14,14,2),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper19_el0",   CPENC (3,3,14,14,3),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper1_el0",    CPENC (3,3,14,12,1),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper20_el0",   CPENC (3,3,14,14,4),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper21_el0",   CPENC (3,3,14,14,5),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper22_el0",   CPENC (3,3,14,14,6),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper23_el0",   CPENC (3,3,14,14,7),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper24_el0",   CPENC (3,3,14,15,0),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper25_el0",   CPENC (3,3,14,15,1),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper26_el0",   CPENC (3,3,14,15,2),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper27_el0",   CPENC (3,3,14,15,3),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper28_el0",   CPENC (3,3,14,15,4),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper29_el0",   CPENC (3,3,14,15,5),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper2_el0",    CPENC (3,3,14,12,2),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper30_el0",   CPENC (3,3,14,15,6),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper3_el0",    CPENC (3,3,14,12,3),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper4_el0",    CPENC (3,3,14,12,4),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper5_el0",    CPENC (3,3,14,12,5),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper6_el0",    CPENC (3,3,14,12,6),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper7_el0",    CPENC (3,3,14,12,7),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper8_el0",    CPENC (3,3,14,13,0),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmevtyper9_el0",    CPENC (3,3,14,13,1),    0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmiar_el1",         CPENC (3,0,9,14,7),     0,              AARCH64_FEATURE (SEBEP))
+  SYSREG ("pmicfiltr_el0",     CPENC (3,3,9,6,0),      0,              AARCH64_FEATURE (PMUv3_ICNTR))
+  SYSREG ("pmicntr_el0",       CPENC (3,3,9,4,0),      0,              AARCH64_FEATURE (PMUv3_ICNTR))
+  SYSREG ("pmicntsvr_el1",     CPENC (2,0,14,12,0),    F_REG_READ,     AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmintenclr_el1",    CPENC (3,0,9,14,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmintenset_el1",    CPENC (3,0,9,14,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmmir_el1",         CPENC (3,0,9,14,6),     F_REG_READ,     AARCH64_FEATURE (V8_4A))
+  SYSREG ("pmovsclr_el0",      CPENC (3,3,9,12,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmovsset_el0",      CPENC (3,3,9,14,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmscr_el1",         CPENC (3,0,9,9,0),      0,              AARCH64_FEATURE (PROFILE))
+  SYSREG ("pmscr_el12",                CPENC (3,5,9,9,0),      0,              AARCH64_FEATURE (PROFILE))
+  SYSREG ("pmscr_el2",         CPENC (3,4,9,9,0),      0,              AARCH64_FEATURE (PROFILE))
+  SYSREG ("pmsdsfr_el1",       CPENC (3,0,9,10,4),     0,              AARCH64_FEATURE (SPE_FDS))
+  SYSREG ("pmselr_el0",                CPENC (3,3,9,12,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmsevfr_el1",       CPENC (3,0,9,9,5),      0,              AARCH64_FEATURE (PROFILE))
+  SYSREG ("pmsfcr_el1",                CPENC (3,0,9,9,4),      0,              AARCH64_FEATURE (PROFILE))
+  SYSREG ("pmsicr_el1",                CPENC (3,0,9,9,2),      0,              AARCH64_FEATURE (PROFILE))
+  SYSREG ("pmsidr_el1",                CPENC (3,0,9,9,7),      F_REG_READ,     AARCH64_FEATURE (PROFILE))
+  SYSREG ("pmsirr_el1",                CPENC (3,0,9,9,3),      0,              AARCH64_FEATURE (PROFILE))
+  SYSREG ("pmslatfr_el1",      CPENC (3,0,9,9,6),      0,              AARCH64_FEATURE (PROFILE))
+  SYSREG ("pmsnevfr_el1",      CPENC (3,0,9,9,1),      0,              AARCH64_FEATURE (V8_7A))
+  SYSREG ("pmsscr_el1",                CPENC (3,0,9,13,3),     0,              AARCH64_FEATURE (PMUv3_SS))
+  SYSREG ("pmswinc_el0",       CPENC (3,3,9,12,4),     F_REG_WRITE,    AARCH64_NO_FEATURES)
+  SYSREG ("pmuacr_el1",                CPENC (3,0,9,14,4),     0,              AARCH64_FEATURE (PMUv3p9))
+  SYSREG ("pmuserenr_el0",     CPENC (3,3,9,14,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmxevcntr_el0",     CPENC (3,3,9,13,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmxevtyper_el0",    CPENC (3,3,9,13,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("pmzr_el0",          CPENC (3,3,9,13,4),     F_REG_WRITE,    AARCH64_FEATURE (PMUv3_ICNTR))
+  SYSREG ("por_el0",           CPENC (3,3,10,2,4),     0,              AARCH64_FEATURE (S1POE))
+  SYSREG ("por_el1",           CPENC (3,0,10,2,4),     0,              AARCH64_FEATURE (S1POE))
+  SYSREG ("por_el12",          CPENC (3,5,10,2,4),     0,              AARCH64_FEATURE (S1POE))
+  SYSREG ("por_el2",           CPENC (3,4,10,2,4),     0,              AARCH64_FEATURE (S1POE))
+  SYSREG ("por_el3",           CPENC (3,6,10,2,4),     0,              AARCH64_FEATURE (S1POE))
+  SYSREG ("prbar10_el1",       CPENC (3,0,6,13,0),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar10_el2",       CPENC (3,4,6,13,0),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar11_el1",       CPENC (3,0,6,13,4),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar11_el2",       CPENC (3,4,6,13,4),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar12_el1",       CPENC (3,0,6,14,0),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar12_el2",       CPENC (3,4,6,14,0),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar13_el1",       CPENC (3,0,6,14,4),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar13_el2",       CPENC (3,4,6,14,4),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar14_el1",       CPENC (3,0,6,15,0),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar14_el2",       CPENC (3,4,6,15,0),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar15_el1",       CPENC (3,0,6,15,4),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar15_el2",       CPENC (3,4,6,15,4),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar1_el1",                CPENC (3,0,6,8,4),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar1_el2",                CPENC (3,4,6,8,4),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar2_el1",                CPENC (3,0,6,9,0),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar2_el2",                CPENC (3,4,6,9,0),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar3_el1",                CPENC (3,0,6,9,4),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar3_el2",                CPENC (3,4,6,9,4),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar4_el1",                CPENC (3,0,6,10,0),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar4_el2",                CPENC (3,4,6,10,0),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar5_el1",                CPENC (3,0,6,10,4),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar5_el2",                CPENC (3,4,6,10,4),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar6_el1",                CPENC (3,0,6,11,0),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar6_el2",                CPENC (3,4,6,11,0),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar7_el1",                CPENC (3,0,6,11,4),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar7_el2",                CPENC (3,4,6,11,4),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar8_el1",                CPENC (3,0,6,12,0),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar8_el2",                CPENC (3,4,6,12,0),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar9_el1",                CPENC (3,0,6,12,4),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar9_el2",                CPENC (3,4,6,12,4),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar_el1",         CPENC (3,0,6,8,0),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prbar_el2",         CPENC (3,4,6,8,0),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prenr_el1",         CPENC (3,0,6,1,1),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prenr_el2",         CPENC (3,4,6,1,1),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar10_el1",       CPENC (3,0,6,13,1),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar10_el2",       CPENC (3,4,6,13,1),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar11_el1",       CPENC (3,0,6,13,5),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar11_el2",       CPENC (3,4,6,13,5),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar12_el1",       CPENC (3,0,6,14,1),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar12_el2",       CPENC (3,4,6,14,1),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar13_el1",       CPENC (3,0,6,14,5),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar13_el2",       CPENC (3,4,6,14,5),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar14_el1",       CPENC (3,0,6,15,1),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar14_el2",       CPENC (3,4,6,15,1),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar15_el1",       CPENC (3,0,6,15,5),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar15_el2",       CPENC (3,4,6,15,5),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar1_el1",                CPENC (3,0,6,8,5),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar1_el2",                CPENC (3,4,6,8,5),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar2_el1",                CPENC (3,0,6,9,1),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar2_el2",                CPENC (3,4,6,9,1),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar3_el1",                CPENC (3,0,6,9,5),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar3_el2",                CPENC (3,4,6,9,5),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar4_el1",                CPENC (3,0,6,10,1),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar4_el2",                CPENC (3,4,6,10,1),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar5_el1",                CPENC (3,0,6,10,5),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar5_el2",                CPENC (3,4,6,10,5),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar6_el1",                CPENC (3,0,6,11,1),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar6_el2",                CPENC (3,4,6,11,1),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar7_el1",                CPENC (3,0,6,11,5),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar7_el2",                CPENC (3,4,6,11,5),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar8_el1",                CPENC (3,0,6,12,1),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar8_el2",                CPENC (3,4,6,12,1),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar9_el1",                CPENC (3,0,6,12,5),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar9_el2",                CPENC (3,4,6,12,5),     0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar_el1",         CPENC (3,0,6,8,1),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prlar_el2",         CPENC (3,4,6,8,1),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prselr_el1",                CPENC (3,0,6,2,1),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("prselr_el2",                CPENC (3,4,6,2,1),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("rcwmask_el1",       CPENC (3,0,13,0,6),     F_REG_128,      AARCH64_FEATURE (THE))
+  SYSREG ("rcwsmask_el1",      CPENC (3,0,13,0,3),     F_REG_128,      AARCH64_FEATURE (THE))
+  SYSREG ("revidr_el1",                CPENC (3,0,0,0,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("rgsr_el1",          CPENC (3,0,1,0,5),      0,              AARCH64_FEATURE (MEMTAG))
+  SYSREG ("rmr_el1",           CPENC (3,0,12,0,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("rmr_el2",           CPENC (3,4,12,0,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("rmr_el3",           CPENC (3,6,12,0,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("rndr",              CPENC (3,3,2,4,0),      F_REG_READ,     AARCH64_FEATURE (RNG))
+  SYSREG ("rndrrs",            CPENC (3,3,2,4,1),      F_REG_READ,     AARCH64_FEATURE (RNG))
+  SYSREG ("rvbar_el1",         CPENC (3,0,12,0,1),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("rvbar_el2",         CPENC (3,4,12,0,1),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("rvbar_el3",         CPENC (3,6,12,0,1),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("scr_el3",           CPENC (3,6,1,1,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("sctlr_el1",         CPENC (3,0,1,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("sctlr_el12",                CPENC (3,5,1,0,0),      0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("sctlr_el2",         CPENC (3,4,1,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("sctlr_el3",         CPENC (3,6,1,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("sctlr2_el1",                CPENC (3,0,1,0,3),      0,              AARCH64_FEATURE (SCTLR2))
+  SYSREG ("sctlr2_el12",       CPENC (3,5,1,0,3),      0,              AARCH64_FEATURE (SCTLR2))
+  SYSREG ("sctlr2_el2",                CPENC (3,4,1,0,3),      0,              AARCH64_FEATURE (SCTLR2))
+  SYSREG ("sctlr2_el3",                CPENC (3,6,1,0,3),      0,              AARCH64_FEATURE (SCTLR2))
+  SYSREG ("scxtnum_el0",       CPENC (3,3,13,0,7),     0,              AARCH64_FEATURE (SCXTNUM))
+  SYSREG ("scxtnum_el1",       CPENC (3,0,13,0,7),     0,              AARCH64_FEATURE (SCXTNUM))
+  SYSREG ("scxtnum_el12",      CPENC (3,5,13,0,7),     0,              AARCH64_FEATURE (SCXTNUM))
+  SYSREG ("scxtnum_el2",       CPENC (3,4,13,0,7),     0,              AARCH64_FEATURE (SCXTNUM))
+  SYSREG ("scxtnum_el3",       CPENC (3,6,13,0,7),     0,              AARCH64_FEATURE (SCXTNUM))
+  SYSREG ("sder32_el2",                CPENC (3,4,1,3,1),      0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("sder32_el3",                CPENC (3,6,1,1,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("smcr_el1",          CPENC (3,0,1,2,6),      0,              AARCH64_FEATURE (SME))
+  SYSREG ("smcr_el12",         CPENC (3,5,1,2,6),      0,              AARCH64_FEATURE (SME))
+  SYSREG ("smcr_el2",          CPENC (3,4,1,2,6),      0,              AARCH64_FEATURE (SME))
+  SYSREG ("smcr_el3",          CPENC (3,6,1,2,6),      0,              AARCH64_FEATURE (SME))
+  SYSREG ("smidr_el1",         CPENC (3,1,0,0,6),      F_REG_READ,     AARCH64_FEATURE (SME))
+  SYSREG ("smpri_el1",         CPENC (3,0,1,2,4),      0,              AARCH64_FEATURE (SME))
+  SYSREG ("smprimap_el2",      CPENC (3,4,1,2,5),      0,              AARCH64_FEATURE (SME))
+  SYSREG ("sp_el0",            CPENC (3,0,4,1,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("sp_el1",            CPENC (3,4,4,1,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("sp_el2",            CPENC (3,6,4,1,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("spmaccessr_el1",    CPENC (2,0,9,13,3),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmaccessr_el2",    CPENC (2,4,9,13,3),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmaccessr_el3",    CPENC (2,6,9,13,3),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmcfgr_el1",       CPENC (2,0,9,13,7),     F_REG_READ,     AARCH64_FEATURE (SPMU))
+  SYSREG ("spmcgcr0_el1",      CPENC (2,0,9,13,0),     F_REG_READ,     AARCH64_FEATURE (SPMU))
+  SYSREG ("spmcgcr1_el1",      CPENC (2,0,9,13,1),     F_REG_READ,     AARCH64_FEATURE (SPMU))
+  SYSREG ("spmcntenclr_el0",   CPENC (2,3,9,12,2),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmcntenset_el0",   CPENC (2,3,9,12,1),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmcr_el0",         CPENC (2,3,9,12,0),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmdevaff_el1",     CPENC (2,0,9,13,6),     F_REG_READ,     AARCH64_FEATURE (SPMU))
+  SYSREG ("spmdevarch_el1",    CPENC (2,0,9,13,5),     F_REG_READ,     AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr0_el0",    CPENC (2,3,14,0,0),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr1_el0",    CPENC (2,3,14,0,1),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr2_el0",    CPENC (2,3,14,0,2),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr3_el0",    CPENC (2,3,14,0,3),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr4_el0",    CPENC (2,3,14,0,4),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr5_el0",    CPENC (2,3,14,0,5),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr6_el0",    CPENC (2,3,14,0,6),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr7_el0",    CPENC (2,3,14,0,7),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr8_el0",    CPENC (2,3,14,1,0),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr9_el0",    CPENC (2,3,14,1,1),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr10_el0",   CPENC (2,3,14,1,2),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr11_el0",   CPENC (2,3,14,1,3),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr12_el0",   CPENC (2,3,14,1,4),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr13_el0",   CPENC (2,3,14,1,5),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr14_el0",   CPENC (2,3,14,1,6),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevcntr15_el0",   CPENC (2,3,14,1,7),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r0_el0",  CPENC (2,3,14,6,0),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r1_el0",  CPENC (2,3,14,6,1),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r2_el0",  CPENC (2,3,14,6,2),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r3_el0",  CPENC (2,3,14,6,3),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r4_el0",  CPENC (2,3,14,6,4),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r5_el0",  CPENC (2,3,14,6,5),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r6_el0",  CPENC (2,3,14,6,6),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r7_el0",  CPENC (2,3,14,6,7),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r8_el0",  CPENC (2,3,14,7,0),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r9_el0",  CPENC (2,3,14,7,1),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r10_el0", CPENC (2,3,14,7,2),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r11_el0", CPENC (2,3,14,7,3),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r12_el0", CPENC (2,3,14,7,4),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r13_el0", CPENC (2,3,14,7,5),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r14_el0", CPENC (2,3,14,7,6),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfilt2r15_el0", CPENC (2,3,14,7,7),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr0_el0",   CPENC (2,3,14,4,0),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr1_el0",   CPENC (2,3,14,4,1),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr2_el0",   CPENC (2,3,14,4,2),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr3_el0",   CPENC (2,3,14,4,3),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr4_el0",   CPENC (2,3,14,4,4),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr5_el0",   CPENC (2,3,14,4,5),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr6_el0",   CPENC (2,3,14,4,6),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr7_el0",   CPENC (2,3,14,4,7),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr8_el0",   CPENC (2,3,14,5,0),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr9_el0",   CPENC (2,3,14,5,1),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr10_el0",  CPENC (2,3,14,5,2),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr11_el0",  CPENC (2,3,14,5,3),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr12_el0",  CPENC (2,3,14,5,4),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr13_el0",  CPENC (2,3,14,5,5),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr14_el0",  CPENC (2,3,14,5,6),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevfiltr15_el0",  CPENC (2,3,14,5,7),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper0_el0",   CPENC (2,3,14,2,0),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper1_el0",   CPENC (2,3,14,2,1),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper2_el0",   CPENC (2,3,14,2,2),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper3_el0",   CPENC (2,3,14,2,3),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper4_el0",   CPENC (2,3,14,2,4),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper5_el0",   CPENC (2,3,14,2,5),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper6_el0",   CPENC (2,3,14,2,6),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper7_el0",   CPENC (2,3,14,2,7),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper8_el0",   CPENC (2,3,14,3,0),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper9_el0",   CPENC (2,3,14,3,1),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper10_el0",  CPENC (2,3,14,3,2),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper11_el0",  CPENC (2,3,14,3,3),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper12_el0",  CPENC (2,3,14,3,4),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper13_el0",  CPENC (2,3,14,3,5),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper14_el0",  CPENC (2,3,14,3,6),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmevtyper15_el0",  CPENC (2,3,14,3,7),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmiidr_el1",       CPENC (2,0,9,13,4),     F_REG_READ,     AARCH64_FEATURE (SPMU))
+  SYSREG ("spmintenclr_el1",   CPENC (2,0,9,14,2),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmintenset_el1",   CPENC (2,0,9,14,1),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmovsclr_el0",     CPENC (2,3,9,12,3),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmovsset_el0",     CPENC (2,3,9,14,3),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmrootcr_el3",     CPENC (2,6,9,14,7),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmscr_el1",                CPENC (2,7,9,14,7),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmselr_el0",       CPENC (2,3,9,12,5),     0,              AARCH64_FEATURE (SPMU))
+  SYSREG ("spmzr_el0",         CPENC (2,3,9,12,4),     0,              AARCH64_FEATURE (SPMU2))
+  SYSREG ("spsel",             CPENC (3,0,4,2,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("spsr_abt",          CPENC (3,4,4,3,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("spsr_el1",          CPENC (3,0,4,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("spsr_el12",         CPENC (3,5,4,0,0),      0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("spsr_el2",          CPENC (3,4,4,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("spsr_el3",          CPENC (3,6,4,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("spsr_fiq",          CPENC (3,4,4,3,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("spsr_hyp",          CPENC (3,4,4,0,0),      F_DEPRECATED,   AARCH64_NO_FEATURES)
+  SYSREG ("spsr_irq",          CPENC (3,4,4,3,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("spsr_svc",          CPENC (3,0,4,0,0),      F_DEPRECATED,   AARCH64_NO_FEATURES)
+  SYSREG ("spsr_und",          CPENC (3,4,4,3,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("ssbs",              CPENC (3,3,4,2,6),      0,              AARCH64_FEATURE (SSBS))
+  SYSREG ("svcr",              CPENC (3,3,4,2,2),      0,              AARCH64_FEATURE (SME))
+  SYSREG ("s2pir_el2",         CPENC (3,4,10,2,5),     0,              AARCH64_FEATURE (S2PIE))
+  SYSREG ("s2por_el1",         CPENC (3,0,10,2,5),     0,              AARCH64_FEATURE (S2POE))
+  SYSREG ("tco",               CPENC (3,3,4,2,7),      0,              AARCH64_FEATURE (MEMTAG))
+  SYSREG ("tcr_el1",           CPENC (3,0,2,0,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("tcr_el12",          CPENC (3,5,2,0,2),      0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("tcr_el2",           CPENC (3,4,2,0,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("tcr_el3",           CPENC (3,6,2,0,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("tcr2_el1",          CPENC (3,0,2,0,3),      0,              AARCH64_FEATURE (TCR2))
+  SYSREG ("tcr2_el12",         CPENC (3,5,2,0,3),      0,              AARCH64_FEATURE (TCR2))
+  SYSREG ("tcr2_el2",          CPENC (3,4,2,0,3),      0,              AARCH64_FEATURE (TCR2))
+  SYSREG ("teecr32_el1",       CPENC (2,2,0,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("teehbr32_el1",      CPENC (2,2,1,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("tfsr_el1",          CPENC (3,0,5,6,0),      0,              AARCH64_FEATURE (MEMTAG))
+  SYSREG ("tfsr_el12",         CPENC (3,5,5,6,0),      0,              AARCH64_FEATURE (MEMTAG))
+  SYSREG ("tfsr_el2",          CPENC (3,4,5,6,0),      0,              AARCH64_FEATURE (MEMTAG))
+  SYSREG ("tfsr_el3",          CPENC (3,6,5,6,0),      0,              AARCH64_FEATURE (MEMTAG))
+  SYSREG ("tfsre0_el1",                CPENC (3,0,5,6,1),      0,              AARCH64_FEATURE (MEMTAG))
+  SYSREG ("tpidr2_el0",                CPENC (3,3,13,0,5),     0,              AARCH64_FEATURE (SME))
+  SYSREG ("tpidr_el0",         CPENC (3,3,13,0,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("tpidr_el1",         CPENC (3,0,13,0,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("tpidr_el2",         CPENC (3,4,13,0,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("tpidr_el3",         CPENC (3,6,13,0,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("tpidrro_el0",       CPENC (3,3,13,0,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trbbaser_el1",      CPENC (3,0,9,11,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trbidr_el1",                CPENC (3,0,9,11,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trblimitr_el1",     CPENC (3,0,9,11,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trbmar_el1",                CPENC (3,0,9,11,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trbptr_el1",                CPENC (3,0,9,11,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trbsr_el1",         CPENC (3,0,9,11,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trbsr_el12",                CPENC (3,5,9,11,3),     0,              AARCH64_FEATURE (V9_5A))
+  SYSREG ("trbsr_el2",         CPENC (3,4,9,11,3),     0,              AARCH64_FEATURE (V9_5A))
+  SYSREG ("trbsr_el3",         CPENC (3,6,9,11,3),     0,              AARCH64_FEATURE (V9_5A))
+  SYSREG ("trbtrg_el1",                CPENC (3,0,9,11,6),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr0",         CPENC (2,1,2,0,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr1",         CPENC (2,1,2,2,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr10",                CPENC (2,1,2,4,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr11",                CPENC (2,1,2,6,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr12",                CPENC (2,1,2,8,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr13",                CPENC (2,1,2,10,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr14",                CPENC (2,1,2,12,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr15",                CPENC (2,1,2,14,3),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr2",         CPENC (2,1,2,4,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr3",         CPENC (2,1,2,6,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr4",         CPENC (2,1,2,8,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr5",         CPENC (2,1,2,10,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr6",         CPENC (2,1,2,12,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr7",         CPENC (2,1,2,14,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr8",         CPENC (2,1,2,0,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacatr9",         CPENC (2,1,2,2,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr0",          CPENC (2,1,2,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr1",          CPENC (2,1,2,2,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr10",         CPENC (2,1,2,4,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr11",         CPENC (2,1,2,6,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr12",         CPENC (2,1,2,8,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr13",         CPENC (2,1,2,10,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr14",         CPENC (2,1,2,12,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr15",         CPENC (2,1,2,14,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr2",          CPENC (2,1,2,4,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr3",          CPENC (2,1,2,6,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr4",          CPENC (2,1,2,8,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr5",          CPENC (2,1,2,10,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr6",          CPENC (2,1,2,12,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr7",          CPENC (2,1,2,14,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr8",          CPENC (2,1,2,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcacvr9",          CPENC (2,1,2,2,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcauthstatus",     CPENC (2,1,7,14,6),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcauxctlr",                CPENC (2,1,0,6,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcbbctlr",         CPENC (2,1,0,15,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcccctlr",         CPENC (2,1,0,14,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccidcctlr0",      CPENC (2,1,3,0,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccidcctlr1",      CPENC (2,1,3,1,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccidcvr0",                CPENC (2,1,3,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccidcvr1",                CPENC (2,1,3,2,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccidcvr2",                CPENC (2,1,3,4,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccidcvr3",                CPENC (2,1,3,6,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccidcvr4",                CPENC (2,1,3,8,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccidcvr5",                CPENC (2,1,3,10,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccidcvr6",                CPENC (2,1,3,12,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccidcvr7",                CPENC (2,1,3,14,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccidr0",          CPENC (2,1,7,12,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trccidr1",          CPENC (2,1,7,13,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trccidr2",          CPENC (2,1,7,14,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trccidr3",          CPENC (2,1,7,15,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcclaimclr",       CPENC (2,1,7,9,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcclaimset",       CPENC (2,1,7,8,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccntctlr0",       CPENC (2,1,0,4,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccntctlr1",       CPENC (2,1,0,5,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccntctlr2",       CPENC (2,1,0,6,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccntctlr3",       CPENC (2,1,0,7,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccntrldvr0",      CPENC (2,1,0,0,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccntrldvr1",      CPENC (2,1,0,1,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccntrldvr2",      CPENC (2,1,0,2,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccntrldvr3",      CPENC (2,1,0,3,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccntvr0",         CPENC (2,1,0,8,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccntvr1",         CPENC (2,1,0,9,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccntvr2",         CPENC (2,1,0,10,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trccntvr3",         CPENC (2,1,0,11,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcconfigr",                CPENC (2,1,0,4,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdevaff0",                CPENC (2,1,7,10,6),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcdevaff1",                CPENC (2,1,7,11,6),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcdevarch",                CPENC (2,1,7,15,6),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcdevid",          CPENC (2,1,7,2,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcdevtype",                CPENC (2,1,7,3,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcmr0",         CPENC (2,1,2,0,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcmr1",         CPENC (2,1,2,4,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcmr2",         CPENC (2,1,2,8,6),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcmr3",         CPENC (2,1,2,12,6),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcmr4",         CPENC (2,1,2,0,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcmr5",         CPENC (2,1,2,4,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcmr6",         CPENC (2,1,2,8,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcmr7",         CPENC (2,1,2,12,7),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcvr0",         CPENC (2,1,2,0,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcvr1",         CPENC (2,1,2,4,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcvr2",         CPENC (2,1,2,8,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcvr3",         CPENC (2,1,2,12,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcvr4",         CPENC (2,1,2,0,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcvr5",         CPENC (2,1,2,4,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcvr6",         CPENC (2,1,2,8,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcdvcvr7",         CPENC (2,1,2,12,5),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trceventctl0r",     CPENC (2,1,0,8,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trceventctl1r",     CPENC (2,1,0,9,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcextinselr",      CPENC (2,1,0,8,4),      F_REG_ALIAS,    AARCH64_NO_FEATURES)
+  SYSREG ("trcextinselr0",     CPENC (2,1,0,8,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcextinselr1",     CPENC (2,1,0,9,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcextinselr2",     CPENC (2,1,0,10,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcextinselr3",     CPENC (2,1,0,11,4),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcidr0",           CPENC (2,1,0,8,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcidr1",           CPENC (2,1,0,9,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcidr10",          CPENC (2,1,0,2,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcidr11",          CPENC (2,1,0,3,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcidr12",          CPENC (2,1,0,4,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcidr13",          CPENC (2,1,0,5,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcidr2",           CPENC (2,1,0,10,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcidr3",           CPENC (2,1,0,11,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcidr4",           CPENC (2,1,0,12,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcidr5",           CPENC (2,1,0,13,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcidr6",           CPENC (2,1,0,14,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcidr7",           CPENC (2,1,0,15,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcidr8",           CPENC (2,1,0,0,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcidr9",           CPENC (2,1,0,1,6),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcimspec0",                CPENC (2,1,0,0,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcimspec1",                CPENC (2,1,0,1,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcimspec2",                CPENC (2,1,0,2,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcimspec3",                CPENC (2,1,0,3,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcimspec4",                CPENC (2,1,0,4,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcimspec5",                CPENC (2,1,0,5,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcimspec6",                CPENC (2,1,0,6,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcimspec7",                CPENC (2,1,0,7,7),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcitctrl",         CPENC (2,1,7,0,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcitecr_el1",      CPENC (3,0,1,2,3),      0,              AARCH64_FEATURE (ITE))
+  SYSREG ("trcitecr_el12",     CPENC (3,5,1,2,3),      0,              AARCH64_FEATURE (ITE))
+  SYSREG ("trcitecr_el2",      CPENC (3,4,1,2,3),      0,              AARCH64_FEATURE (ITE))
+  SYSREG ("trciteedcr",                CPENC (2,1,0,2,1),      0,              AARCH64_FEATURE (ITE))
+  SYSREG ("trclar",            CPENC (2,1,7,12,6),     F_REG_WRITE,    AARCH64_NO_FEATURES)
+  SYSREG ("trclsr",            CPENC (2,1,7,13,6),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcoslar",          CPENC (2,1,1,0,4),      F_REG_WRITE,    AARCH64_NO_FEATURES)
+  SYSREG ("trcoslsr",          CPENC (2,1,1,1,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcpdcr",           CPENC (2,1,1,4,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcpdsr",           CPENC (2,1,1,5,4),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcpidr0",          CPENC (2,1,7,8,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcpidr1",          CPENC (2,1,7,9,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcpidr2",          CPENC (2,1,7,10,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcpidr3",          CPENC (2,1,7,11,7),     F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcpidr4",          CPENC (2,1,7,4,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcpidr5",          CPENC (2,1,7,5,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcpidr6",          CPENC (2,1,7,6,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcpidr7",          CPENC (2,1,7,7,7),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcprgctlr",                CPENC (2,1,0,1,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcprocselr",       CPENC (2,1,0,2,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcqctlr",          CPENC (2,1,0,1,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr10",       CPENC (2,1,1,10,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr11",       CPENC (2,1,1,11,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr12",       CPENC (2,1,1,12,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr13",       CPENC (2,1,1,13,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr14",       CPENC (2,1,1,14,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr15",       CPENC (2,1,1,15,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr16",       CPENC (2,1,1,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr17",       CPENC (2,1,1,1,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr18",       CPENC (2,1,1,2,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr19",       CPENC (2,1,1,3,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr2",                CPENC (2,1,1,2,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr20",       CPENC (2,1,1,4,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr21",       CPENC (2,1,1,5,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr22",       CPENC (2,1,1,6,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr23",       CPENC (2,1,1,7,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr24",       CPENC (2,1,1,8,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr25",       CPENC (2,1,1,9,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr26",       CPENC (2,1,1,10,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr27",       CPENC (2,1,1,11,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr28",       CPENC (2,1,1,12,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr29",       CPENC (2,1,1,13,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr3",                CPENC (2,1,1,3,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr30",       CPENC (2,1,1,14,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr31",       CPENC (2,1,1,15,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr4",                CPENC (2,1,1,4,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr5",                CPENC (2,1,1,5,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr6",                CPENC (2,1,1,6,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr7",                CPENC (2,1,1,7,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr8",                CPENC (2,1,1,8,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsctlr9",                CPENC (2,1,1,9,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcrsr",            CPENC (2,1,0,10,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcseqevr0",                CPENC (2,1,0,0,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcseqevr1",                CPENC (2,1,0,1,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcseqevr2",                CPENC (2,1,0,2,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcseqrstevr",      CPENC (2,1,0,6,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcseqstr",         CPENC (2,1,0,7,4),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcssccr0",         CPENC (2,1,1,0,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcssccr1",         CPENC (2,1,1,1,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcssccr2",         CPENC (2,1,1,2,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcssccr3",         CPENC (2,1,1,3,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcssccr4",         CPENC (2,1,1,4,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcssccr5",         CPENC (2,1,1,5,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcssccr6",         CPENC (2,1,1,6,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcssccr7",         CPENC (2,1,1,7,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsscsr0",         CPENC (2,1,1,8,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsscsr1",         CPENC (2,1,1,9,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsscsr2",         CPENC (2,1,1,10,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsscsr3",         CPENC (2,1,1,11,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsscsr4",         CPENC (2,1,1,12,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsscsr5",         CPENC (2,1,1,13,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsscsr6",         CPENC (2,1,1,14,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsscsr7",         CPENC (2,1,1,15,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsspcicr0",       CPENC (2,1,1,0,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsspcicr1",       CPENC (2,1,1,1,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsspcicr2",       CPENC (2,1,1,2,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsspcicr3",       CPENC (2,1,1,3,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsspcicr4",       CPENC (2,1,1,4,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsspcicr5",       CPENC (2,1,1,5,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsspcicr6",       CPENC (2,1,1,6,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcsspcicr7",       CPENC (2,1,1,7,3),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcstallctlr",      CPENC (2,1,0,11,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcstatr",          CPENC (2,1,0,3,0),      F_REG_READ,     AARCH64_NO_FEATURES)
+  SYSREG ("trcsyncpr",         CPENC (2,1,0,13,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trctraceidr",       CPENC (2,1,0,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trctsctlr",         CPENC (2,1,0,12,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvdarcctlr",      CPENC (2,1,0,10,2),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvdctlr",         CPENC (2,1,0,8,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvdsacctlr",      CPENC (2,1,0,9,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvictlr",         CPENC (2,1,0,0,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcviiectlr",       CPENC (2,1,0,1,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvipcssctlr",     CPENC (2,1,0,3,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvissctlr",       CPENC (2,1,0,2,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvmidcctlr0",     CPENC (2,1,3,2,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvmidcctlr1",     CPENC (2,1,3,3,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvmidcvr0",       CPENC (2,1,3,0,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvmidcvr1",       CPENC (2,1,3,2,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvmidcvr2",       CPENC (2,1,3,4,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvmidcvr3",       CPENC (2,1,3,6,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvmidcvr4",       CPENC (2,1,3,8,1),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvmidcvr5",       CPENC (2,1,3,10,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvmidcvr6",       CPENC (2,1,3,12,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trcvmidcvr7",       CPENC (2,1,3,14,1),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("trfcr_el1",         CPENC (3,0,1,2,1),      0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("trfcr_el12",                CPENC (3,5,1,2,1),      0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("trfcr_el2",         CPENC (3,4,1,2,1),      0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("ttbr0_el1",         CPENC (3,0,2,0,0),      F_REG_128,      AARCH64_NO_FEATURES)
+  SYSREG ("ttbr0_el12",                CPENC (3,5,2,0,0),      F_REG_128,      AARCH64_FEATURE (V8_1A))
+  SYSREG ("ttbr0_el2",         CPENC (3,4,2,0,0),      F_REG_128,      AARCH64_FEATURE (V8A))
+  SYSREG ("ttbr0_el3",         CPENC (3,6,2,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("ttbr1_el1",         CPENC (3,0,2,0,1),      F_REG_128,      AARCH64_NO_FEATURES)
+  SYSREG ("ttbr1_el12",                CPENC (3,5,2,0,1),      F_REG_128,      AARCH64_FEATURE (V8_1A))
+  SYSREG ("ttbr1_el2",         CPENC (3,4,2,0,1),      F_REG_128,      AARCH64_FEATURES (2, V8A, V8_1A))
+  SYSREG ("uao",               CPENC (3,0,4,2,4),      0,              AARCH64_FEATURE (V8_2A))
+  SYSREG ("vbar_el1",          CPENC (3,0,12,0,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("vbar_el12",         CPENC (3,5,12,0,0),     0,              AARCH64_FEATURE (V8_1A))
+  SYSREG ("vbar_el2",          CPENC (3,4,12,0,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("vbar_el3",          CPENC (3,6,12,0,0),     0,              AARCH64_NO_FEATURES)
+  SYSREG ("vdisr_el2",         CPENC (3,4,12,1,1),     0,              AARCH64_FEATURE (RAS))
+  SYSREG ("vdisr_el3",         CPENC (3,6,12,1,1),     0,              AARCH64_FEATURE (E3DSE))
+  SYSREG ("vmecid_a_el2",      CPENC (3,4,10,9,1),     0,              AARCH64_FEATURE (V8_7A))
+  SYSREG ("vmecid_p_el2",      CPENC (3,4,10,9,0),     0,              AARCH64_FEATURE (V8_7A))
+  SYSREG ("vmpidr_el2",                CPENC (3,4,0,0,5),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("vncr_el2",          CPENC (3,4,2,2,0),      0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("vpidr_el2",         CPENC (3,4,0,0,0),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("vsctlr_el2",                CPENC (3,4,2,0,0),      0,              AARCH64_FEATURE (V8R))
+  SYSREG ("vsesr_el2",         CPENC (3,4,5,2,3),      0,              AARCH64_FEATURE (RAS))
+  SYSREG ("vsesr_el3",         CPENC (3,6,5,2,3),      0,              AARCH64_FEATURE (E3DSE))
+  SYSREG ("vstcr_el2",         CPENC (3,4,2,6,2),      0,              AARCH64_FEATURE (V8_4A))
+  SYSREG ("vsttbr_el2",                CPENC (3,4,2,6,0),      0,              AARCH64_FEATURES (2, V8A, V8_4A))
+  SYSREG ("vtcr_el2",          CPENC (3,4,2,1,2),      0,              AARCH64_NO_FEATURES)
+  SYSREG ("vttbr_el2",         CPENC (3,4,2,1,0),      F_REG_128,      AARCH64_FEATURE (V8A))
+  SYSREG ("zcr_el1",           CPENC (3,0,1,2,0),      0,              AARCH64_FEATURE (SVE))
+  SYSREG ("zcr_el12",          CPENC (3,5,1,2,0),      0,              AARCH64_FEATURE (SVE))
+  SYSREG ("zcr_el2",           CPENC (3,4,1,2,0),      0,              AARCH64_FEATURE (SVE))
+  SYSREG ("zcr_el3",           CPENC (3,6,1,2,0),      0,              AARCH64_FEATURE (SVE))