public inbox for gcc-patches@gcc.gnu.org
 help / color / mirror / Atom feed
From: Victor Do Nascimento <Victor.DoNascimento@arm.com>
To: Richard Earnshaw <Richard.Earnshaw@foss.arm.com>,
	gcc-patches@gcc.gnu.org,
	Ramana Radhakrishnan <ramanara@nvidia.com>
Cc: kyrylo.tkachov@arm.com, richard.sandiford@arm.com,
	Richard.Earnshaw@arm.com
Subject: Re: [PATCH 1/6] aarch64: Sync system register information with Binutils
Date: Thu, 5 Oct 2023 14:04:29 +0100	[thread overview]
Message-ID: <2744f78c-650d-b947-f0f2-41abe619c250@arm.com> (raw)
In-Reply-To: <bfe46c82-5e63-fff0-fd9a-bcbbfe0146dc@foss.arm.com>



On 10/5/23 12:42, Richard Earnshaw wrote:
> 
> 
> On 03/10/2023 16:18, Victor Do Nascimento wrote:
>> This patch adds the `aarch64-sys-regs.def' file to GCC, teaching
>> the compiler about system registers known to the assembler and how
>> these can be used.
>>
>> The macros used to hold system register information reflect those in
>> use by binutils, a design choice made to facilitate the sharing of data
>> between different parts of the toolchain.
>>
>> By aligning the representation of data common to different parts of
>> the toolchain we can greatly reduce the duplication of work,
>> facilitating the maintenance of the aarch64 back-end across different
>> parts of the toolchain; any `SYSREG (...)' that is added in one
>> project can just as easily be added to its counterpart.
>>
>> GCC does not implement the full range of ISA flags present in
>> Binutils.  Where this is the case, aliases must be added to aarch64.h
>> with the unknown architectural extension being mapped to its
>> associated base architecture, such that any flag present in Binutils
>> and used in system register definitions is understood in GCC.  Again,
>> this is done such that flags can be used interchangeably between
>> projects making use of the aarch64-system-regs.def file.  This is done
>> in the next patch in the series.
>>
>> `.arch' directives missing from the emitted assembly files as a
>> consequence of this aliasing are accounted for by the compiler using
>> the S<op0>_<op1>_<Cn>_<Cm>_<op2> encoding of system registers when
>> issuing mrs/msr instructions.  This design choice ensures the
>> assembler will accept anything that was deemed acceptable by the
>> compiler.
>>
>> gcc/ChangeLog:
>>
>>     * gcc/config/aarch64/aarch64-system-regs.def: New.
>> ---
>>   gcc/config/aarch64/aarch64-sys-regs.def | 1059 +++++++++++++++++++++++
>>   1 file changed, 1059 insertions(+)
>>   create mode 100644 gcc/config/aarch64/aarch64-sys-regs.def
> 
> This file is supposed to be /identical/ to the one in GNU Binutils, 
> right?

You're right Richard.

We want the same file to be compatible with both parts of the toolchain 
and, consequently, there is no compelling reason as to why the copy of 
the file found in GCC should in any way diverge from its Binutils 
counterpart.

> If so, I think it needs to continue to say that it is part of 
> GNU Binutils, not part of GCC.  Ramana, has this happened before?  If 
> not, does the SC have a position here?
> 
> R.

This does raise a very interesting question on the intellectual property 
front and one that is well beyond my competence to opine about.

Nonetheless, this is a question which may arise again if we abstract 
away more target description data into such .def files, as has been 
discussed for architectural feature flags (for example).

So what might be nice (but not necessarily tenable) is if we had 
appropriate provisions in place for where files were shared across 
different parts of the toolchain.

Something like "This file is a shared resource of GCC and Binutils."

Anyway, that's my two cents on the matter :).

Let's see what Ramana has to say on the matter.

V.


>> diff --git a/gcc/config/aarch64/aarch64-sys-regs.def 
>> b/gcc/config/aarch64/aarch64-sys-regs.def
>> new file mode 100644
>> index 00000000000..d77fee1d5e3
>> --- /dev/null
>> +++ b/gcc/config/aarch64/aarch64-sys-regs.def
>> @@ -0,0 +1,1059 @@
>> +/* Copyright (C) 2023 Free Software Foundation, Inc.
>> +   Contributed by Arm Ltd
>> +
>> +   This file is part of GCC.
>> +
>> +   GCC is free software; you can redistribute it and/or modify it
>> +   under the terms of the GNU General Public License as published
>> +   by the Free Software Foundation; either version 3, or (at your
>> +   option) any later version.
>> +
>> +   GCC is distributed in the hope that it will be useful, but WITHOUT
>> +   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
>> +   or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
>> +   License for more details.
>> +
>> +   You should have received a copy of the GNU General Public License
>> +   along with GCC; see the file COPYING3.  If not see
>> +   <http://www.gnu.org/licenses/>.  */
>> +
>> +/* Array of system registers and their associated arch features.
>> +
>> +   Before using #include to read this file, define a macro:
>> +
>> +     SYSREG (name, encoding, flags, features)
>> +
>> +  The NAME is the system register name, as recognized by the
>> +  assembler.  ENCODING provides the necessary information for the binary
>> +  encoding of the system register.  The FLAGS field is a bitmask of
>> +  relevant behavior information pertaining to the particular register.
>> +  For example: is it read/write-only? does it alias another register?
>> +  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 ("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 ("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 ("fpsr",        CPENC (3,3,4,4,1),    0,            
>> AARCH64_NO_FEATURES)
>> +  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 ("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 ("hdfgwtr_el2",    CPENC (3,4,3,1,5),    F_ARCHEXT,        
>> AARCH64_FEATURE (V8_6A))
>> +  SYSREG ("hfgitr_el2",        CPENC (3,4,1,1,6),    
>> F_ARCHEXT,        AARCH64_FEATURE (V8_6A))
>> +  SYSREG ("hfgrtr_el2",        CPENC (3,4,1,1,4),    
>> F_ARCHEXT,        AARCH64_FEATURE (V8_6A))
>> +  SYSREG ("hfgwtr_el2",        CPENC (3,4,1,1,5),    
>> F_ARCHEXT,        AARCH64_FEATURE (V8_6A))
>> +  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_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_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_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_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 ("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 ("mecid_a0_el2",    CPENC (3,4,10,8,1),    0,            
>> AARCH64_NO_FEATURES)
>> +  SYSREG ("mecid_a1_el2",    CPENC (3,4,10,8,3),    0,            
>> AARCH64_NO_FEATURES)
>> +  SYSREG ("mecid_p0_el2",    CPENC (3,4,10,8,0),    0,            
>> AARCH64_NO_FEATURES)
>> +  SYSREG ("mecid_p1_el2",    CPENC (3,4,10,8,2),    0,            
>> AARCH64_NO_FEATURES)
>> +  SYSREG ("mecid_rl_a_el3",    CPENC (3,6,10,10,1),    0,            
>> AARCH64_NO_FEATURES)
>> +  SYSREG ("mecidr_el2",        CPENC (3,4,10,8,7),    
>> F_REG_READ,        AARCH64_NO_FEATURES)
>> +  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 ("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 ("pan",        CPENC (3,0,4,2,3),    F_ARCHEXT,        
>> AARCH64_FEATURE (PAN))
>> +  SYSREG ("par_el1",        CPENC (3,0,7,4,0),    0,            
>> AARCH64_NO_FEATURES)
>> +  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 ("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 ("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 ("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 ("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 ("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 ("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 ("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 ("pmswinc_el0",    CPENC (3,3,9,12,4),    
>> F_REG_WRITE,        AARCH64_NO_FEATURES)
>> +  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 ("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 ("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 ("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 ("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 ("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 ("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 ("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 ("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),    0,            
>> AARCH64_NO_FEATURES)
>> +  SYSREG ("ttbr0_el12",        CPENC (3,5,2,0,0),    
>> F_ARCHEXT,        AARCH64_FEATURE (V8_1A))
>> +  SYSREG ("ttbr0_el2",        CPENC (3,4,2,0,0),    F_ARCHEXT,        
>> 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),    0,            
>> AARCH64_NO_FEATURES)
>> +  SYSREG ("ttbr1_el12",        CPENC (3,5,2,0,1),    
>> F_ARCHEXT,        AARCH64_FEATURE (V8_1A))
>> +  SYSREG ("ttbr1_el2",        CPENC (3,4,2,0,1),    F_ARCHEXT,        
>> 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 ("vmecid_a_el2",    CPENC (3,4,10,9,1),    0,            
>> AARCH64_NO_FEATURES)
>> +  SYSREG ("vmecid_p_el2",    CPENC (3,4,10,9,0),    0,            
>> AARCH64_NO_FEATURES)
>> +  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 ("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,        
>> 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))
>> \ No newline at end of file

  reply	other threads:[~2023-10-05 13:05 UTC|newest]

Thread overview: 22+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-10-03 15:18 [PATCH 0/6] aarch64: Add support for __arm_rsr and __arm_wsr ACLE function family Victor Do Nascimento
2023-10-03 15:18 ` [PATCH 1/6] aarch64: Sync system register information with Binutils Victor Do Nascimento
2023-10-05 11:42   ` Richard Earnshaw
2023-10-05 13:04     ` Victor Do Nascimento [this message]
2023-10-09  0:02       ` Ramana Radhakrishnan
2023-10-09 12:52         ` Victor Do Nascimento
2023-10-03 15:18 ` [PATCH 2/6] aarch64: Add support for aarch64-sys-regs.def Victor Do Nascimento
2023-10-05 12:03   ` Richard Earnshaw
2023-10-03 15:18 ` [PATCH 3/6] aarch64: Implement system register validation tools Victor Do Nascimento
2023-10-05 12:24   ` Richard Earnshaw
2023-10-03 15:18 ` [PATCH 4/6] aarch64: Add basic target_print_operand support for CONST_STRING Victor Do Nascimento
2023-10-05 12:26   ` Richard Earnshaw
2023-10-05 12:33     ` Richard Earnshaw
2023-10-05 12:47     ` Victor Do Nascimento
2023-10-03 15:18 ` [PATCH 5/6] aarch64: Implement system register r/w arm ACLE intrinsic functions Victor Do Nascimento
2023-10-05 12:40   ` Richard Earnshaw
2023-10-03 15:18 ` [PATCH 6/6] aarch64: Add front-end argument type checking for target builtins Victor Do Nascimento
2023-10-05 12:48   ` Richard Earnshaw
2023-10-07 11:53     ` Richard Sandiford
2023-10-09 13:12       ` Victor Do Nascimento
2023-10-10 11:20         ` Richard Earnshaw (lists)
2023-10-12 10:37           ` Richard Sandiford

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=2744f78c-650d-b947-f0f2-41abe619c250@arm.com \
    --to=victor.donascimento@arm.com \
    --cc=Richard.Earnshaw@arm.com \
    --cc=Richard.Earnshaw@foss.arm.com \
    --cc=gcc-patches@gcc.gnu.org \
    --cc=kyrylo.tkachov@arm.com \
    --cc=ramanara@nvidia.com \
    --cc=richard.sandiford@arm.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).