xref: /aosp_15_r20/external/llvm/lib/Target/AArch64/AArch64SystemOperands.td (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker//===- AArch64SystemOperands.td ----------------------------*- tablegen -*-===//
2*9880d681SAndroid Build Coastguard Worker//
3*9880d681SAndroid Build Coastguard Worker//                     The LLVM Compiler Infrastructure
4*9880d681SAndroid Build Coastguard Worker//
5*9880d681SAndroid Build Coastguard Worker// This file is distributed under the University of Illinois Open Source
6*9880d681SAndroid Build Coastguard Worker// License. See LICENSE.TXT for details.
7*9880d681SAndroid Build Coastguard Worker//
8*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
9*9880d681SAndroid Build Coastguard Worker//
10*9880d681SAndroid Build Coastguard Worker// This file defines the symbolic operands permitted for various kinds of
11*9880d681SAndroid Build Coastguard Worker// AArch64 system instruction.
12*9880d681SAndroid Build Coastguard Worker//
13*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
14*9880d681SAndroid Build Coastguard Worker
15*9880d681SAndroid Build Coastguard Workerinclude "llvm/TableGen/SearchableTable.td"
16*9880d681SAndroid Build Coastguard Worker
17*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
18*9880d681SAndroid Build Coastguard Worker// AT (address translate) instruction options.
19*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
20*9880d681SAndroid Build Coastguard Worker
21*9880d681SAndroid Build Coastguard Workerclass AT<string name, bits<2> op0, bits<3> op1, bits<4> crn, bits<4> crm,
22*9880d681SAndroid Build Coastguard Worker         bits<3> op2> : SearchableTable {
23*9880d681SAndroid Build Coastguard Worker  let SearchableFields = ["Name", "Encoding"];
24*9880d681SAndroid Build Coastguard Worker  let EnumValueField = "Encoding";
25*9880d681SAndroid Build Coastguard Worker
26*9880d681SAndroid Build Coastguard Worker  string Name = name;
27*9880d681SAndroid Build Coastguard Worker  bits<16> Encoding;
28*9880d681SAndroid Build Coastguard Worker  let Encoding{15-14} = op0;
29*9880d681SAndroid Build Coastguard Worker  let Encoding{13-11} = op1;
30*9880d681SAndroid Build Coastguard Worker  let Encoding{10-7} = crn;
31*9880d681SAndroid Build Coastguard Worker  let Encoding{6-3} = crm;
32*9880d681SAndroid Build Coastguard Worker  let Encoding{2-0} = op2;
33*9880d681SAndroid Build Coastguard Worker}
34*9880d681SAndroid Build Coastguard Worker
35*9880d681SAndroid Build Coastguard Workerdef : AT<"S1E1R",  0b01, 0b000, 0b0111, 0b1000, 0b000>;
36*9880d681SAndroid Build Coastguard Workerdef : AT<"S1E2R",  0b01, 0b100, 0b0111, 0b1000, 0b000>;
37*9880d681SAndroid Build Coastguard Workerdef : AT<"S1E3R",  0b01, 0b110, 0b0111, 0b1000, 0b000>;
38*9880d681SAndroid Build Coastguard Workerdef : AT<"S1E1W",  0b01, 0b000, 0b0111, 0b1000, 0b001>;
39*9880d681SAndroid Build Coastguard Workerdef : AT<"S1E2W",  0b01, 0b100, 0b0111, 0b1000, 0b001>;
40*9880d681SAndroid Build Coastguard Workerdef : AT<"S1E3W",  0b01, 0b110, 0b0111, 0b1000, 0b001>;
41*9880d681SAndroid Build Coastguard Workerdef : AT<"S1E0R",  0b01, 0b000, 0b0111, 0b1000, 0b010>;
42*9880d681SAndroid Build Coastguard Workerdef : AT<"S1E0W",  0b01, 0b000, 0b0111, 0b1000, 0b011>;
43*9880d681SAndroid Build Coastguard Workerdef : AT<"S12E1R", 0b01, 0b100, 0b0111, 0b1000, 0b100>;
44*9880d681SAndroid Build Coastguard Workerdef : AT<"S12E1W", 0b01, 0b100, 0b0111, 0b1000, 0b101>;
45*9880d681SAndroid Build Coastguard Workerdef : AT<"S12E0R", 0b01, 0b100, 0b0111, 0b1000, 0b110>;
46*9880d681SAndroid Build Coastguard Workerdef : AT<"S12E0W", 0b01, 0b100, 0b0111, 0b1000, 0b111>;
47*9880d681SAndroid Build Coastguard Workerdef : AT<"S1E1RP", 0b01, 0b000, 0b0111, 0b1001, 0b000>;
48*9880d681SAndroid Build Coastguard Workerdef : AT<"S1E1WP", 0b01, 0b000, 0b0111, 0b1001, 0b001>;
49*9880d681SAndroid Build Coastguard Worker
50*9880d681SAndroid Build Coastguard Worker
51*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
52*9880d681SAndroid Build Coastguard Worker// DMB/DSB (data barrier) instruction options.
53*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
54*9880d681SAndroid Build Coastguard Worker
55*9880d681SAndroid Build Coastguard Workerclass DB<string name, bits<4> encoding> : SearchableTable {
56*9880d681SAndroid Build Coastguard Worker  let SearchableFields = ["Name", "Encoding"];
57*9880d681SAndroid Build Coastguard Worker  let EnumValueField = "Encoding";
58*9880d681SAndroid Build Coastguard Worker
59*9880d681SAndroid Build Coastguard Worker  string Name = name;
60*9880d681SAndroid Build Coastguard Worker  bits<4> Encoding = encoding;
61*9880d681SAndroid Build Coastguard Worker}
62*9880d681SAndroid Build Coastguard Worker
63*9880d681SAndroid Build Coastguard Workerdef : DB<"oshld", 0x1>;
64*9880d681SAndroid Build Coastguard Workerdef : DB<"oshst", 0x2>;
65*9880d681SAndroid Build Coastguard Workerdef : DB<"osh",   0x3>;
66*9880d681SAndroid Build Coastguard Workerdef : DB<"nshld", 0x5>;
67*9880d681SAndroid Build Coastguard Workerdef : DB<"nshst", 0x6>;
68*9880d681SAndroid Build Coastguard Workerdef : DB<"nsh",   0x7>;
69*9880d681SAndroid Build Coastguard Workerdef : DB<"ishld", 0x9>;
70*9880d681SAndroid Build Coastguard Workerdef : DB<"ishst", 0xa>;
71*9880d681SAndroid Build Coastguard Workerdef : DB<"ish",   0xb>;
72*9880d681SAndroid Build Coastguard Workerdef : DB<"ld",    0xd>;
73*9880d681SAndroid Build Coastguard Workerdef : DB<"st",    0xe>;
74*9880d681SAndroid Build Coastguard Workerdef : DB<"sy",    0xf>;
75*9880d681SAndroid Build Coastguard Worker
76*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
77*9880d681SAndroid Build Coastguard Worker// DC (data cache maintenance) instruction options.
78*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
79*9880d681SAndroid Build Coastguard Worker
80*9880d681SAndroid Build Coastguard Workerclass DC<string name, bits<2> op0, bits<3> op1, bits<4> crn, bits<4> crm,
81*9880d681SAndroid Build Coastguard Worker         bits<3> op2> : SearchableTable {
82*9880d681SAndroid Build Coastguard Worker  let SearchableFields = ["Name", "Encoding"];
83*9880d681SAndroid Build Coastguard Worker  let EnumValueField = "Encoding";
84*9880d681SAndroid Build Coastguard Worker
85*9880d681SAndroid Build Coastguard Worker  string Name = name;
86*9880d681SAndroid Build Coastguard Worker  bits<16> Encoding;
87*9880d681SAndroid Build Coastguard Worker  let Encoding{15-14} = op0;
88*9880d681SAndroid Build Coastguard Worker  let Encoding{13-11} = op1;
89*9880d681SAndroid Build Coastguard Worker  let Encoding{10-7} = crn;
90*9880d681SAndroid Build Coastguard Worker  let Encoding{6-3} = crm;
91*9880d681SAndroid Build Coastguard Worker  let Encoding{2-0} = op2;
92*9880d681SAndroid Build Coastguard Worker}
93*9880d681SAndroid Build Coastguard Worker
94*9880d681SAndroid Build Coastguard Workerdef : DC<"ZVA",   0b01, 0b011, 0b0111, 0b0100, 0b001>;
95*9880d681SAndroid Build Coastguard Workerdef : DC<"IVAC",  0b01, 0b000, 0b0111, 0b0110, 0b001>;
96*9880d681SAndroid Build Coastguard Workerdef : DC<"ISW",   0b01, 0b000, 0b0111, 0b0110, 0b010>;
97*9880d681SAndroid Build Coastguard Workerdef : DC<"CVAC",  0b01, 0b011, 0b0111, 0b1010, 0b001>;
98*9880d681SAndroid Build Coastguard Workerdef : DC<"CSW",   0b01, 0b000, 0b0111, 0b1010, 0b010>;
99*9880d681SAndroid Build Coastguard Workerdef : DC<"CVAU",  0b01, 0b011, 0b0111, 0b1011, 0b001>;
100*9880d681SAndroid Build Coastguard Workerdef : DC<"CIVAC", 0b01, 0b011, 0b0111, 0b1110, 0b001>;
101*9880d681SAndroid Build Coastguard Workerdef : DC<"CISW",  0b01, 0b000, 0b0111, 0b1110, 0b010>;
102*9880d681SAndroid Build Coastguard Worker
103*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
104*9880d681SAndroid Build Coastguard Worker// IC (instruction cache maintenance) instruction options.
105*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
106*9880d681SAndroid Build Coastguard Worker
107*9880d681SAndroid Build Coastguard Workerclass IC<string name, bits<3> op1, bits<4> crn, bits<4> crm, bits<3> op2,
108*9880d681SAndroid Build Coastguard Worker         bit needsreg> : SearchableTable {
109*9880d681SAndroid Build Coastguard Worker  let SearchableFields = ["Name", "Encoding"];
110*9880d681SAndroid Build Coastguard Worker  let EnumValueField = "Encoding";
111*9880d681SAndroid Build Coastguard Worker
112*9880d681SAndroid Build Coastguard Worker  string Name = name;
113*9880d681SAndroid Build Coastguard Worker  bits<14> Encoding;
114*9880d681SAndroid Build Coastguard Worker  let Encoding{13-11} = op1;
115*9880d681SAndroid Build Coastguard Worker  let Encoding{10-7} = crn;
116*9880d681SAndroid Build Coastguard Worker  let Encoding{6-3} = crm;
117*9880d681SAndroid Build Coastguard Worker  let Encoding{2-0} = op2;
118*9880d681SAndroid Build Coastguard Worker  bit NeedsReg = needsreg;
119*9880d681SAndroid Build Coastguard Worker}
120*9880d681SAndroid Build Coastguard Worker
121*9880d681SAndroid Build Coastguard Workerdef : IC<"IALLUIS", 0b000, 0b0111, 0b0001, 0b000, 0>;
122*9880d681SAndroid Build Coastguard Workerdef : IC<"IALLU",   0b000, 0b0111, 0b0101, 0b000, 0>;
123*9880d681SAndroid Build Coastguard Workerdef : IC<"IVAU",    0b000, 0b0111, 0b0001, 0b000, 1>;
124*9880d681SAndroid Build Coastguard Worker
125*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
126*9880d681SAndroid Build Coastguard Worker// ISB (instruction-fetch barrier) instruction options.
127*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
128*9880d681SAndroid Build Coastguard Worker
129*9880d681SAndroid Build Coastguard Workerclass ISB<string name, bits<4> encoding> : SearchableTable{
130*9880d681SAndroid Build Coastguard Worker  let SearchableFields = ["Name", "Encoding"];
131*9880d681SAndroid Build Coastguard Worker  let EnumValueField = "Encoding";
132*9880d681SAndroid Build Coastguard Worker
133*9880d681SAndroid Build Coastguard Worker  string Name = name;
134*9880d681SAndroid Build Coastguard Worker  bits<4> Encoding;
135*9880d681SAndroid Build Coastguard Worker  let Encoding = encoding;
136*9880d681SAndroid Build Coastguard Worker}
137*9880d681SAndroid Build Coastguard Worker
138*9880d681SAndroid Build Coastguard Workerdef : ISB<"sy", 0xf>;
139*9880d681SAndroid Build Coastguard Worker
140*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
141*9880d681SAndroid Build Coastguard Worker// PRFM (prefetch) instruction options.
142*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
143*9880d681SAndroid Build Coastguard Worker
144*9880d681SAndroid Build Coastguard Workerclass PRFM<string name, bits<5> encoding> : SearchableTable {
145*9880d681SAndroid Build Coastguard Worker  let SearchableFields = ["Name", "Encoding"];
146*9880d681SAndroid Build Coastguard Worker  let EnumValueField = "Encoding";
147*9880d681SAndroid Build Coastguard Worker
148*9880d681SAndroid Build Coastguard Worker  string Name = name;
149*9880d681SAndroid Build Coastguard Worker  bits<5> Encoding;
150*9880d681SAndroid Build Coastguard Worker  let Encoding = encoding;
151*9880d681SAndroid Build Coastguard Worker}
152*9880d681SAndroid Build Coastguard Worker
153*9880d681SAndroid Build Coastguard Workerdef : PRFM<"pldl1keep", 0x00>;
154*9880d681SAndroid Build Coastguard Workerdef : PRFM<"pldl1strm", 0x01>;
155*9880d681SAndroid Build Coastguard Workerdef : PRFM<"pldl2keep", 0x02>;
156*9880d681SAndroid Build Coastguard Workerdef : PRFM<"pldl2strm", 0x03>;
157*9880d681SAndroid Build Coastguard Workerdef : PRFM<"pldl3keep", 0x04>;
158*9880d681SAndroid Build Coastguard Workerdef : PRFM<"pldl3strm", 0x05>;
159*9880d681SAndroid Build Coastguard Workerdef : PRFM<"plil1keep", 0x08>;
160*9880d681SAndroid Build Coastguard Workerdef : PRFM<"plil1strm", 0x09>;
161*9880d681SAndroid Build Coastguard Workerdef : PRFM<"plil2keep", 0x0a>;
162*9880d681SAndroid Build Coastguard Workerdef : PRFM<"plil2strm", 0x0b>;
163*9880d681SAndroid Build Coastguard Workerdef : PRFM<"plil3keep", 0x0c>;
164*9880d681SAndroid Build Coastguard Workerdef : PRFM<"plil3strm", 0x0d>;
165*9880d681SAndroid Build Coastguard Workerdef : PRFM<"pstl1keep", 0x10>;
166*9880d681SAndroid Build Coastguard Workerdef : PRFM<"pstl1strm", 0x11>;
167*9880d681SAndroid Build Coastguard Workerdef : PRFM<"pstl2keep", 0x12>;
168*9880d681SAndroid Build Coastguard Workerdef : PRFM<"pstl2strm", 0x13>;
169*9880d681SAndroid Build Coastguard Workerdef : PRFM<"pstl3keep", 0x14>;
170*9880d681SAndroid Build Coastguard Workerdef : PRFM<"pstl3strm", 0x15>;
171*9880d681SAndroid Build Coastguard Worker
172*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
173*9880d681SAndroid Build Coastguard Worker// PState instruction options.
174*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
175*9880d681SAndroid Build Coastguard Worker
176*9880d681SAndroid Build Coastguard Workerclass PState<string name, bits<5> encoding> : SearchableTable {
177*9880d681SAndroid Build Coastguard Worker  let SearchableFields = ["Name", "Encoding"];
178*9880d681SAndroid Build Coastguard Worker  let EnumValueField = "Encoding";
179*9880d681SAndroid Build Coastguard Worker
180*9880d681SAndroid Build Coastguard Worker  string Name = name;
181*9880d681SAndroid Build Coastguard Worker  bits<5> Encoding;
182*9880d681SAndroid Build Coastguard Worker  let Encoding = encoding;
183*9880d681SAndroid Build Coastguard Worker  code Requires = [{ {} }];
184*9880d681SAndroid Build Coastguard Worker}
185*9880d681SAndroid Build Coastguard Worker
186*9880d681SAndroid Build Coastguard Workerdef : PState<"SPSel",   0b00101>;
187*9880d681SAndroid Build Coastguard Workerdef : PState<"DAIFSet", 0b11110>;
188*9880d681SAndroid Build Coastguard Workerdef : PState<"DAIFClr", 0b11111>;
189*9880d681SAndroid Build Coastguard Worker// v8.1a "Privileged Access Never" extension-specific PStates
190*9880d681SAndroid Build Coastguard Workerlet Requires = [{ {AArch64::HasV8_1aOps} }] in
191*9880d681SAndroid Build Coastguard Workerdef : PState<"PAN",     0b00100>;
192*9880d681SAndroid Build Coastguard Worker// v8.2a "User Access Override" extension-specific PStates
193*9880d681SAndroid Build Coastguard Workerlet Requires = [{ {AArch64::HasV8_2aOps} }] in
194*9880d681SAndroid Build Coastguard Workerdef : PState<"UAO",     0b00011>;
195*9880d681SAndroid Build Coastguard Worker
196*9880d681SAndroid Build Coastguard Worker
197*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
198*9880d681SAndroid Build Coastguard Worker// PSB instruction options.
199*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
200*9880d681SAndroid Build Coastguard Worker
201*9880d681SAndroid Build Coastguard Workerclass PSB<string name, bits<5> encoding> : SearchableTable {
202*9880d681SAndroid Build Coastguard Worker  let SearchableFields = ["Name", "Encoding"];
203*9880d681SAndroid Build Coastguard Worker  let EnumValueField = "Encoding";
204*9880d681SAndroid Build Coastguard Worker
205*9880d681SAndroid Build Coastguard Worker  string Name = name;
206*9880d681SAndroid Build Coastguard Worker  bits<5> Encoding;
207*9880d681SAndroid Build Coastguard Worker  let Encoding = encoding;
208*9880d681SAndroid Build Coastguard Worker}
209*9880d681SAndroid Build Coastguard Worker
210*9880d681SAndroid Build Coastguard Workerdef : PSB<"csync", 0x11>;
211*9880d681SAndroid Build Coastguard Worker
212*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
213*9880d681SAndroid Build Coastguard Worker// TLBI (translation lookaside buffer invalidate) instruction options.
214*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
215*9880d681SAndroid Build Coastguard Worker
216*9880d681SAndroid Build Coastguard Workerclass TLBI<string name, bits<2> op0, bits<3> op1, bits<4> crn, bits<4> crm,
217*9880d681SAndroid Build Coastguard Worker             bits<3> op2, bit needsreg = 1> : SearchableTable {
218*9880d681SAndroid Build Coastguard Worker  let SearchableFields = ["Name", "Encoding"];
219*9880d681SAndroid Build Coastguard Worker  let EnumValueField = "Encoding";
220*9880d681SAndroid Build Coastguard Worker
221*9880d681SAndroid Build Coastguard Worker  string Name = name;
222*9880d681SAndroid Build Coastguard Worker  bits<16> Encoding;
223*9880d681SAndroid Build Coastguard Worker  let Encoding{15-14} = op0;
224*9880d681SAndroid Build Coastguard Worker  let Encoding{13-11} = op1;
225*9880d681SAndroid Build Coastguard Worker  let Encoding{10-7} = crn;
226*9880d681SAndroid Build Coastguard Worker  let Encoding{6-3} = crm;
227*9880d681SAndroid Build Coastguard Worker  let Encoding{2-0} = op2;
228*9880d681SAndroid Build Coastguard Worker  bit NeedsReg = needsreg;
229*9880d681SAndroid Build Coastguard Worker}
230*9880d681SAndroid Build Coastguard Worker
231*9880d681SAndroid Build Coastguard Workerdef : TLBI<"IPAS2E1IS",    0b01, 0b100, 0b1000, 0b0000, 0b001>;
232*9880d681SAndroid Build Coastguard Workerdef : TLBI<"IPAS2LE1IS",   0b01, 0b100, 0b1000, 0b0000, 0b101>;
233*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VMALLE1IS",    0b01, 0b000, 0b1000, 0b0011, 0b000, 0>;
234*9880d681SAndroid Build Coastguard Workerdef : TLBI<"ALLE2IS",      0b01, 0b100, 0b1000, 0b0011, 0b000, 0>;
235*9880d681SAndroid Build Coastguard Workerdef : TLBI<"ALLE3IS",      0b01, 0b110, 0b1000, 0b0011, 0b000, 0>;
236*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VAE1IS",       0b01, 0b000, 0b1000, 0b0011, 0b001>;
237*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VAE2IS",       0b01, 0b100, 0b1000, 0b0011, 0b001>;
238*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VAE3IS",       0b01, 0b110, 0b1000, 0b0011, 0b001>;
239*9880d681SAndroid Build Coastguard Workerdef : TLBI<"ASIDE1IS",     0b01, 0b000, 0b1000, 0b0011, 0b010>;
240*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VAAE1IS",      0b01, 0b000, 0b1000, 0b0011, 0b011>;
241*9880d681SAndroid Build Coastguard Workerdef : TLBI<"ALLE1IS",      0b01, 0b100, 0b1000, 0b0011, 0b100, 0>;
242*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VALE1IS",      0b01, 0b000, 0b1000, 0b0011, 0b101>;
243*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VALE2IS",      0b01, 0b100, 0b1000, 0b0011, 0b101>;
244*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VALE3IS",      0b01, 0b110, 0b1000, 0b0011, 0b101>;
245*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VMALLS12E1IS", 0b01, 0b100, 0b1000, 0b0011, 0b110, 0>;
246*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VAALE1IS",     0b01, 0b000, 0b1000, 0b0011, 0b111>;
247*9880d681SAndroid Build Coastguard Workerdef : TLBI<"IPAS2E1",      0b01, 0b100, 0b1000, 0b0100, 0b001>;
248*9880d681SAndroid Build Coastguard Workerdef : TLBI<"IPAS2LE1",     0b01, 0b100, 0b1000, 0b0100, 0b101>;
249*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VMALLE1",      0b01, 0b000, 0b1000, 0b0111, 0b000, 0>;
250*9880d681SAndroid Build Coastguard Workerdef : TLBI<"ALLE2",        0b01, 0b100, 0b1000, 0b0111, 0b000, 0>;
251*9880d681SAndroid Build Coastguard Workerdef : TLBI<"ALLE3",        0b01, 0b110, 0b1000, 0b0111, 0b000, 0>;
252*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VAE1",         0b01, 0b000, 0b1000, 0b0111, 0b001>;
253*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VAE2",         0b01, 0b100, 0b1000, 0b0111, 0b001>;
254*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VAE3",         0b01, 0b110, 0b1000, 0b0111, 0b001>;
255*9880d681SAndroid Build Coastguard Workerdef : TLBI<"ASIDE1",       0b01, 0b000, 0b1000, 0b0111, 0b010>;
256*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VAAE1",        0b01, 0b000, 0b1000, 0b0111, 0b011>;
257*9880d681SAndroid Build Coastguard Workerdef : TLBI<"ALLE1",        0b01, 0b100, 0b1000, 0b0111, 0b100, 0>;
258*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VALE1",        0b01, 0b000, 0b1000, 0b0111, 0b101>;
259*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VALE2",        0b01, 0b100, 0b1000, 0b0111, 0b101>;
260*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VALE3",        0b01, 0b110, 0b1000, 0b0111, 0b101>;
261*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VMALLS12E1",   0b01, 0b100, 0b1000, 0b0111, 0b110, 0>;
262*9880d681SAndroid Build Coastguard Workerdef : TLBI<"VAALE1",       0b01, 0b000, 0b1000, 0b0111, 0b111>;
263*9880d681SAndroid Build Coastguard Worker
264*9880d681SAndroid Build Coastguard Worker
265*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
266*9880d681SAndroid Build Coastguard Worker// MRS/MSR (system register read/write) instruction options.
267*9880d681SAndroid Build Coastguard Worker//===----------------------------------------------------------------------===//
268*9880d681SAndroid Build Coastguard Worker
269*9880d681SAndroid Build Coastguard Workerclass SysReg<string name, bits<2> op0, bits<3> op1, bits<4> crn, bits<4> crm,
270*9880d681SAndroid Build Coastguard Worker             bits<3> op2> : SearchableTable {
271*9880d681SAndroid Build Coastguard Worker  let SearchableFields = ["Name", "Encoding"];
272*9880d681SAndroid Build Coastguard Worker  let EnumValueField = "Encoding";
273*9880d681SAndroid Build Coastguard Worker
274*9880d681SAndroid Build Coastguard Worker  string Name = name;
275*9880d681SAndroid Build Coastguard Worker  bits<16> Encoding;
276*9880d681SAndroid Build Coastguard Worker  let Encoding{15-14} = op0;
277*9880d681SAndroid Build Coastguard Worker  let Encoding{13-11} = op1;
278*9880d681SAndroid Build Coastguard Worker  let Encoding{10-7} = crn;
279*9880d681SAndroid Build Coastguard Worker  let Encoding{6-3} = crm;
280*9880d681SAndroid Build Coastguard Worker  let Encoding{2-0} = op2;
281*9880d681SAndroid Build Coastguard Worker  bit Readable = ?;
282*9880d681SAndroid Build Coastguard Worker  bit Writeable = ?;
283*9880d681SAndroid Build Coastguard Worker  code Requires = [{ {} }];
284*9880d681SAndroid Build Coastguard Worker}
285*9880d681SAndroid Build Coastguard Worker
286*9880d681SAndroid Build Coastguard Workerclass RWSysReg<string name, bits<2> op0, bits<3> op1, bits<4> crn, bits<4> crm,
287*9880d681SAndroid Build Coastguard Worker               bits<3> op2>
288*9880d681SAndroid Build Coastguard Worker    : SysReg<name, op0, op1, crn, crm, op2> {
289*9880d681SAndroid Build Coastguard Worker  let Readable = 1;
290*9880d681SAndroid Build Coastguard Worker  let Writeable = 1;
291*9880d681SAndroid Build Coastguard Worker}
292*9880d681SAndroid Build Coastguard Worker
293*9880d681SAndroid Build Coastguard Workerclass ROSysReg<string name, bits<2> op0, bits<3> op1, bits<4> crn, bits<4> crm,
294*9880d681SAndroid Build Coastguard Worker               bits<3> op2>
295*9880d681SAndroid Build Coastguard Worker    : SysReg<name, op0, op1, crn, crm, op2> {
296*9880d681SAndroid Build Coastguard Worker  let Readable = 1;
297*9880d681SAndroid Build Coastguard Worker  let Writeable = 0;
298*9880d681SAndroid Build Coastguard Worker}
299*9880d681SAndroid Build Coastguard Worker
300*9880d681SAndroid Build Coastguard Workerclass WOSysReg<string name, bits<2> op0, bits<3> op1, bits<4> crn, bits<4> crm,
301*9880d681SAndroid Build Coastguard Worker               bits<3> op2>
302*9880d681SAndroid Build Coastguard Worker    : SysReg<name, op0, op1, crn, crm, op2> {
303*9880d681SAndroid Build Coastguard Worker  let Readable = 0;
304*9880d681SAndroid Build Coastguard Worker  let Writeable = 1;
305*9880d681SAndroid Build Coastguard Worker}
306*9880d681SAndroid Build Coastguard Worker
307*9880d681SAndroid Build Coastguard Worker//===----------------------
308*9880d681SAndroid Build Coastguard Worker// Read-only regs
309*9880d681SAndroid Build Coastguard Worker//===----------------------
310*9880d681SAndroid Build Coastguard Worker
311*9880d681SAndroid Build Coastguard Worker//                                    Op0    Op1     CRn     CRm    Op2
312*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"MDCCSR_EL0",         0b10, 0b011, 0b0000, 0b0001, 0b000>;
313*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"DBGDTRRX_EL0",       0b10, 0b011, 0b0000, 0b0101, 0b000>;
314*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"MDRAR_EL1",          0b10, 0b000, 0b0001, 0b0000, 0b000>;
315*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"OSLSR_EL1",          0b10, 0b000, 0b0001, 0b0001, 0b100>;
316*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"DBGAUTHSTATUS_EL1",  0b10, 0b000, 0b0111, 0b1110, 0b110>;
317*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"PMCEID0_EL0",        0b11, 0b011, 0b1001, 0b1100, 0b110>;
318*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"PMCEID1_EL0",        0b11, 0b011, 0b1001, 0b1100, 0b111>;
319*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"MIDR_EL1",           0b11, 0b000, 0b0000, 0b0000, 0b000>;
320*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"CCSIDR_EL1",         0b11, 0b001, 0b0000, 0b0000, 0b000>;
321*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"CLIDR_EL1",          0b11, 0b001, 0b0000, 0b0000, 0b001>;
322*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"CTR_EL0",            0b11, 0b011, 0b0000, 0b0000, 0b001>;
323*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"MPIDR_EL1",          0b11, 0b000, 0b0000, 0b0000, 0b101>;
324*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"REVIDR_EL1",         0b11, 0b000, 0b0000, 0b0000, 0b110>;
325*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"AIDR_EL1",           0b11, 0b001, 0b0000, 0b0000, 0b111>;
326*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"DCZID_EL0",          0b11, 0b011, 0b0000, 0b0000, 0b111>;
327*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_PFR0_EL1",        0b11, 0b000, 0b0000, 0b0001, 0b000>;
328*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_PFR1_EL1",        0b11, 0b000, 0b0000, 0b0001, 0b001>;
329*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_DFR0_EL1",        0b11, 0b000, 0b0000, 0b0001, 0b010>;
330*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_AFR0_EL1",        0b11, 0b000, 0b0000, 0b0001, 0b011>;
331*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_MMFR0_EL1",       0b11, 0b000, 0b0000, 0b0001, 0b100>;
332*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_MMFR1_EL1",       0b11, 0b000, 0b0000, 0b0001, 0b101>;
333*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_MMFR2_EL1",       0b11, 0b000, 0b0000, 0b0001, 0b110>;
334*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_MMFR3_EL1",       0b11, 0b000, 0b0000, 0b0001, 0b111>;
335*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_ISAR0_EL1",       0b11, 0b000, 0b0000, 0b0010, 0b000>;
336*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_ISAR1_EL1",       0b11, 0b000, 0b0000, 0b0010, 0b001>;
337*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_ISAR2_EL1",       0b11, 0b000, 0b0000, 0b0010, 0b010>;
338*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_ISAR3_EL1",       0b11, 0b000, 0b0000, 0b0010, 0b011>;
339*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_ISAR4_EL1",       0b11, 0b000, 0b0000, 0b0010, 0b100>;
340*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_ISAR5_EL1",       0b11, 0b000, 0b0000, 0b0010, 0b101>;
341*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_AA64PFR0_EL1",     0b11, 0b000, 0b0000, 0b0100, 0b000>;
342*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_AA64PFR1_EL1",     0b11, 0b000, 0b0000, 0b0100, 0b001>;
343*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_AA64DFR0_EL1",     0b11, 0b000, 0b0000, 0b0101, 0b000>;
344*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_AA64DFR1_EL1",     0b11, 0b000, 0b0000, 0b0101, 0b001>;
345*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_AA64AFR0_EL1",     0b11, 0b000, 0b0000, 0b0101, 0b100>;
346*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_AA64AFR1_EL1",     0b11, 0b000, 0b0000, 0b0101, 0b101>;
347*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_AA64ISAR0_EL1",    0b11, 0b000, 0b0000, 0b0110, 0b000>;
348*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_AA64ISAR1_EL1",    0b11, 0b000, 0b0000, 0b0110, 0b001>;
349*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_AA64MMFR0_EL1",    0b11, 0b000, 0b0000, 0b0111, 0b000>;
350*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_AA64MMFR1_EL1",    0b11, 0b000, 0b0000, 0b0111, 0b001>;
351*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_AA64MMFR2_EL1",    0b11, 0b000, 0b0000, 0b0111, 0b010> {
352*9880d681SAndroid Build Coastguard Worker  let Requires = [{ {AArch64::HasV8_2aOps} }];
353*9880d681SAndroid Build Coastguard Worker}
354*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"MVFR0_EL1",          0b11, 0b000, 0b0000, 0b0011, 0b000>;
355*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"MVFR1_EL1",          0b11, 0b000, 0b0000, 0b0011, 0b001>;
356*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"MVFR2_EL1",          0b11, 0b000, 0b0000, 0b0011, 0b010>;
357*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"RVBAR_EL1",          0b11, 0b000, 0b1100, 0b0000, 0b001>;
358*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"RVBAR_EL2",          0b11, 0b100, 0b1100, 0b0000, 0b001>;
359*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"RVBAR_EL3",          0b11, 0b110, 0b1100, 0b0000, 0b001>;
360*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ISR_EL1",            0b11, 0b000, 0b1100, 0b0001, 0b000>;
361*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"CNTPCT_EL0",         0b11, 0b011, 0b1110, 0b0000, 0b001>;
362*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"CNTVCT_EL0",         0b11, 0b011, 0b1110, 0b0000, 0b010>;
363*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ID_MMFR4_EL1",       0b11, 0b000, 0b0000, 0b0010, 0b110>;
364*9880d681SAndroid Build Coastguard Worker
365*9880d681SAndroid Build Coastguard Worker// Trace registers
366*9880d681SAndroid Build Coastguard Worker//                                 Op0    Op1     CRn     CRm    Op2
367*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCSTATR",           0b10, 0b001, 0b0000, 0b0011, 0b000>;
368*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR8",            0b10, 0b001, 0b0000, 0b0000, 0b110>;
369*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR9",            0b10, 0b001, 0b0000, 0b0001, 0b110>;
370*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR10",           0b10, 0b001, 0b0000, 0b0010, 0b110>;
371*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR11",           0b10, 0b001, 0b0000, 0b0011, 0b110>;
372*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR12",           0b10, 0b001, 0b0000, 0b0100, 0b110>;
373*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR13",           0b10, 0b001, 0b0000, 0b0101, 0b110>;
374*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR0",            0b10, 0b001, 0b0000, 0b1000, 0b111>;
375*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR1",            0b10, 0b001, 0b0000, 0b1001, 0b111>;
376*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR2",            0b10, 0b001, 0b0000, 0b1010, 0b111>;
377*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR3",            0b10, 0b001, 0b0000, 0b1011, 0b111>;
378*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR4",            0b10, 0b001, 0b0000, 0b1100, 0b111>;
379*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR5",            0b10, 0b001, 0b0000, 0b1101, 0b111>;
380*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR6",            0b10, 0b001, 0b0000, 0b1110, 0b111>;
381*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCIDR7",            0b10, 0b001, 0b0000, 0b1111, 0b111>;
382*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCOSLSR",           0b10, 0b001, 0b0001, 0b0001, 0b100>;
383*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCPDSR",            0b10, 0b001, 0b0001, 0b0101, 0b100>;
384*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCDEVAFF0",         0b10, 0b001, 0b0111, 0b1010, 0b110>;
385*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCDEVAFF1",         0b10, 0b001, 0b0111, 0b1011, 0b110>;
386*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCLSR",             0b10, 0b001, 0b0111, 0b1101, 0b110>;
387*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCAUTHSTATUS",      0b10, 0b001, 0b0111, 0b1110, 0b110>;
388*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCDEVARCH",         0b10, 0b001, 0b0111, 0b1111, 0b110>;
389*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCDEVID",           0b10, 0b001, 0b0111, 0b0010, 0b111>;
390*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCDEVTYPE",         0b10, 0b001, 0b0111, 0b0011, 0b111>;
391*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCPIDR4",           0b10, 0b001, 0b0111, 0b0100, 0b111>;
392*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCPIDR5",           0b10, 0b001, 0b0111, 0b0101, 0b111>;
393*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCPIDR6",           0b10, 0b001, 0b0111, 0b0110, 0b111>;
394*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCPIDR7",           0b10, 0b001, 0b0111, 0b0111, 0b111>;
395*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCPIDR0",           0b10, 0b001, 0b0111, 0b1000, 0b111>;
396*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCPIDR1",           0b10, 0b001, 0b0111, 0b1001, 0b111>;
397*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCPIDR2",           0b10, 0b001, 0b0111, 0b1010, 0b111>;
398*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCPIDR3",           0b10, 0b001, 0b0111, 0b1011, 0b111>;
399*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCCIDR0",           0b10, 0b001, 0b0111, 0b1100, 0b111>;
400*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCCIDR1",           0b10, 0b001, 0b0111, 0b1101, 0b111>;
401*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCCIDR2",           0b10, 0b001, 0b0111, 0b1110, 0b111>;
402*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"TRCCIDR3",           0b10, 0b001, 0b0111, 0b1111, 0b111>;
403*9880d681SAndroid Build Coastguard Worker
404*9880d681SAndroid Build Coastguard Worker// GICv3 registers
405*9880d681SAndroid Build Coastguard Worker//                                 Op0    Op1     CRn     CRm    Op2
406*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ICC_IAR1_EL1",       0b11, 0b000, 0b1100, 0b1100, 0b000>;
407*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ICC_IAR0_EL1",       0b11, 0b000, 0b1100, 0b1000, 0b000>;
408*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ICC_HPPIR1_EL1",     0b11, 0b000, 0b1100, 0b1100, 0b010>;
409*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ICC_HPPIR0_EL1",     0b11, 0b000, 0b1100, 0b1000, 0b010>;
410*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ICC_RPR_EL1",        0b11, 0b000, 0b1100, 0b1011, 0b011>;
411*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ICH_VTR_EL2",        0b11, 0b100, 0b1100, 0b1011, 0b001>;
412*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ICH_EISR_EL2",       0b11, 0b100, 0b1100, 0b1011, 0b011>;
413*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ICH_ELSR_EL2",       0b11, 0b100, 0b1100, 0b1011, 0b101>;
414*9880d681SAndroid Build Coastguard Worker
415*9880d681SAndroid Build Coastguard Worker// v8.1a "Limited Ordering Regions" extension-specific system register
416*9880d681SAndroid Build Coastguard Worker//                         Op0    Op1     CRn     CRm    Op2
417*9880d681SAndroid Build Coastguard Workerlet Requires = [{ {AArch64::HasV8_1aOps} }] in
418*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"LORID_EL1",  0b11, 0b000, 0b1010, 0b0100, 0b111>;
419*9880d681SAndroid Build Coastguard Worker
420*9880d681SAndroid Build Coastguard Worker// v8.2a "RAS extension" registers
421*9880d681SAndroid Build Coastguard Worker//                         Op0    Op1     CRn     CRm    Op2
422*9880d681SAndroid Build Coastguard Workerlet Requires = [{ {AArch64::FeatureRAS} }] in {
423*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ERRIDR_EL1", 0b11, 0b000, 0b0101, 0b0011, 0b000>;
424*9880d681SAndroid Build Coastguard Workerdef : ROSysReg<"ERXFR_EL1",  0b11, 0b000, 0b0101, 0b0100, 0b000>;
425*9880d681SAndroid Build Coastguard Worker}
426*9880d681SAndroid Build Coastguard Worker
427*9880d681SAndroid Build Coastguard Worker//===----------------------
428*9880d681SAndroid Build Coastguard Worker// Write-only regs
429*9880d681SAndroid Build Coastguard Worker//===----------------------
430*9880d681SAndroid Build Coastguard Worker
431*9880d681SAndroid Build Coastguard Worker//                                 Op0    Op1     CRn     CRm    Op2
432*9880d681SAndroid Build Coastguard Workerdef : WOSysReg<"DBGDTRTX_EL0",       0b10, 0b011, 0b0000, 0b0101, 0b000>;
433*9880d681SAndroid Build Coastguard Workerdef : WOSysReg<"OSLAR_EL1",          0b10, 0b000, 0b0001, 0b0000, 0b100>;
434*9880d681SAndroid Build Coastguard Workerdef : WOSysReg<"PMSWINC_EL0",        0b11, 0b011, 0b1001, 0b1100, 0b100>;
435*9880d681SAndroid Build Coastguard Worker
436*9880d681SAndroid Build Coastguard Worker// Trace Registers
437*9880d681SAndroid Build Coastguard Worker//                                 Op0    Op1     CRn     CRm    Op2
438*9880d681SAndroid Build Coastguard Workerdef : WOSysReg<"TRCOSLAR",           0b10, 0b001, 0b0001, 0b0000, 0b100>;
439*9880d681SAndroid Build Coastguard Workerdef : WOSysReg<"TRCLAR",             0b10, 0b001, 0b0111, 0b1100, 0b110>;
440*9880d681SAndroid Build Coastguard Worker
441*9880d681SAndroid Build Coastguard Worker// GICv3 registers
442*9880d681SAndroid Build Coastguard Worker//                                 Op0    Op1     CRn     CRm    Op2
443*9880d681SAndroid Build Coastguard Workerdef : WOSysReg<"ICC_EOIR1_EL1",      0b11, 0b000, 0b1100, 0b1100, 0b001>;
444*9880d681SAndroid Build Coastguard Workerdef : WOSysReg<"ICC_EOIR0_EL1",      0b11, 0b000, 0b1100, 0b1000, 0b001>;
445*9880d681SAndroid Build Coastguard Workerdef : WOSysReg<"ICC_DIR_EL1",        0b11, 0b000, 0b1100, 0b1011, 0b001>;
446*9880d681SAndroid Build Coastguard Workerdef : WOSysReg<"ICC_SGI1R_EL1",      0b11, 0b000, 0b1100, 0b1011, 0b101>;
447*9880d681SAndroid Build Coastguard Workerdef : WOSysReg<"ICC_ASGI1R_EL1",     0b11, 0b000, 0b1100, 0b1011, 0b110>;
448*9880d681SAndroid Build Coastguard Workerdef : WOSysReg<"ICC_SGI0R_EL1",      0b11, 0b000, 0b1100, 0b1011, 0b111>;
449*9880d681SAndroid Build Coastguard Worker
450*9880d681SAndroid Build Coastguard Worker//===----------------------
451*9880d681SAndroid Build Coastguard Worker// Read-write regs
452*9880d681SAndroid Build Coastguard Worker//===----------------------
453*9880d681SAndroid Build Coastguard Worker
454*9880d681SAndroid Build Coastguard Worker//                                 Op0    Op1     CRn     CRm    Op2
455*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"OSDTRRX_EL1",        0b10, 0b000, 0b0000, 0b0000, 0b010>;
456*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"OSDTRTX_EL1",        0b10, 0b000, 0b0000, 0b0011, 0b010>;
457*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TEECR32_EL1",        0b10, 0b010, 0b0000, 0b0000, 0b000>;
458*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"MDCCINT_EL1",        0b10, 0b000, 0b0000, 0b0010, 0b000>;
459*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"MDSCR_EL1",          0b10, 0b000, 0b0000, 0b0010, 0b010>;
460*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGDTR_EL0",         0b10, 0b011, 0b0000, 0b0100, 0b000>;
461*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"OSECCR_EL1",         0b10, 0b000, 0b0000, 0b0110, 0b010>;
462*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGVCR32_EL2",       0b10, 0b100, 0b0000, 0b0111, 0b000>;
463*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR0_EL1",        0b10, 0b000, 0b0000, 0b0000, 0b100>;
464*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR1_EL1",        0b10, 0b000, 0b0000, 0b0001, 0b100>;
465*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR2_EL1",        0b10, 0b000, 0b0000, 0b0010, 0b100>;
466*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR3_EL1",        0b10, 0b000, 0b0000, 0b0011, 0b100>;
467*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR4_EL1",        0b10, 0b000, 0b0000, 0b0100, 0b100>;
468*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR5_EL1",        0b10, 0b000, 0b0000, 0b0101, 0b100>;
469*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR6_EL1",        0b10, 0b000, 0b0000, 0b0110, 0b100>;
470*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR7_EL1",        0b10, 0b000, 0b0000, 0b0111, 0b100>;
471*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR8_EL1",        0b10, 0b000, 0b0000, 0b1000, 0b100>;
472*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR9_EL1",        0b10, 0b000, 0b0000, 0b1001, 0b100>;
473*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR10_EL1",       0b10, 0b000, 0b0000, 0b1010, 0b100>;
474*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR11_EL1",       0b10, 0b000, 0b0000, 0b1011, 0b100>;
475*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR12_EL1",       0b10, 0b000, 0b0000, 0b1100, 0b100>;
476*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR13_EL1",       0b10, 0b000, 0b0000, 0b1101, 0b100>;
477*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR14_EL1",       0b10, 0b000, 0b0000, 0b1110, 0b100>;
478*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBVR15_EL1",       0b10, 0b000, 0b0000, 0b1111, 0b100>;
479*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR0_EL1",        0b10, 0b000, 0b0000, 0b0000, 0b101>;
480*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR1_EL1",        0b10, 0b000, 0b0000, 0b0001, 0b101>;
481*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR2_EL1",        0b10, 0b000, 0b0000, 0b0010, 0b101>;
482*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR3_EL1",        0b10, 0b000, 0b0000, 0b0011, 0b101>;
483*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR4_EL1",        0b10, 0b000, 0b0000, 0b0100, 0b101>;
484*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR5_EL1",        0b10, 0b000, 0b0000, 0b0101, 0b101>;
485*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR6_EL1",        0b10, 0b000, 0b0000, 0b0110, 0b101>;
486*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR7_EL1",        0b10, 0b000, 0b0000, 0b0111, 0b101>;
487*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR8_EL1",        0b10, 0b000, 0b0000, 0b1000, 0b101>;
488*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR9_EL1",        0b10, 0b000, 0b0000, 0b1001, 0b101>;
489*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR10_EL1",       0b10, 0b000, 0b0000, 0b1010, 0b101>;
490*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR11_EL1",       0b10, 0b000, 0b0000, 0b1011, 0b101>;
491*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR12_EL1",       0b10, 0b000, 0b0000, 0b1100, 0b101>;
492*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR13_EL1",       0b10, 0b000, 0b0000, 0b1101, 0b101>;
493*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR14_EL1",       0b10, 0b000, 0b0000, 0b1110, 0b101>;
494*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGBCR15_EL1",       0b10, 0b000, 0b0000, 0b1111, 0b101>;
495*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR0_EL1",        0b10, 0b000, 0b0000, 0b0000, 0b110>;
496*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR1_EL1",        0b10, 0b000, 0b0000, 0b0001, 0b110>;
497*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR2_EL1",        0b10, 0b000, 0b0000, 0b0010, 0b110>;
498*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR3_EL1",        0b10, 0b000, 0b0000, 0b0011, 0b110>;
499*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR4_EL1",        0b10, 0b000, 0b0000, 0b0100, 0b110>;
500*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR5_EL1",        0b10, 0b000, 0b0000, 0b0101, 0b110>;
501*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR6_EL1",        0b10, 0b000, 0b0000, 0b0110, 0b110>;
502*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR7_EL1",        0b10, 0b000, 0b0000, 0b0111, 0b110>;
503*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR8_EL1",        0b10, 0b000, 0b0000, 0b1000, 0b110>;
504*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR9_EL1",        0b10, 0b000, 0b0000, 0b1001, 0b110>;
505*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR10_EL1",       0b10, 0b000, 0b0000, 0b1010, 0b110>;
506*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR11_EL1",       0b10, 0b000, 0b0000, 0b1011, 0b110>;
507*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR12_EL1",       0b10, 0b000, 0b0000, 0b1100, 0b110>;
508*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR13_EL1",       0b10, 0b000, 0b0000, 0b1101, 0b110>;
509*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR14_EL1",       0b10, 0b000, 0b0000, 0b1110, 0b110>;
510*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWVR15_EL1",       0b10, 0b000, 0b0000, 0b1111, 0b110>;
511*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR0_EL1",        0b10, 0b000, 0b0000, 0b0000, 0b111>;
512*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR1_EL1",        0b10, 0b000, 0b0000, 0b0001, 0b111>;
513*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR2_EL1",        0b10, 0b000, 0b0000, 0b0010, 0b111>;
514*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR3_EL1",        0b10, 0b000, 0b0000, 0b0011, 0b111>;
515*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR4_EL1",        0b10, 0b000, 0b0000, 0b0100, 0b111>;
516*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR5_EL1",        0b10, 0b000, 0b0000, 0b0101, 0b111>;
517*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR6_EL1",        0b10, 0b000, 0b0000, 0b0110, 0b111>;
518*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR7_EL1",        0b10, 0b000, 0b0000, 0b0111, 0b111>;
519*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR8_EL1",        0b10, 0b000, 0b0000, 0b1000, 0b111>;
520*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR9_EL1",        0b10, 0b000, 0b0000, 0b1001, 0b111>;
521*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR10_EL1",       0b10, 0b000, 0b0000, 0b1010, 0b111>;
522*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR11_EL1",       0b10, 0b000, 0b0000, 0b1011, 0b111>;
523*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR12_EL1",       0b10, 0b000, 0b0000, 0b1100, 0b111>;
524*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR13_EL1",       0b10, 0b000, 0b0000, 0b1101, 0b111>;
525*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR14_EL1",       0b10, 0b000, 0b0000, 0b1110, 0b111>;
526*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGWCR15_EL1",       0b10, 0b000, 0b0000, 0b1111, 0b111>;
527*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TEEHBR32_EL1",       0b10, 0b010, 0b0001, 0b0000, 0b000>;
528*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"OSDLR_EL1",          0b10, 0b000, 0b0001, 0b0011, 0b100>;
529*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGPRCR_EL1",        0b10, 0b000, 0b0001, 0b0100, 0b100>;
530*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGCLAIMSET_EL1",    0b10, 0b000, 0b0111, 0b1000, 0b110>;
531*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DBGCLAIMCLR_EL1",    0b10, 0b000, 0b0111, 0b1001, 0b110>;
532*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CSSELR_EL1",         0b11, 0b010, 0b0000, 0b0000, 0b000>;
533*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"VPIDR_EL2",          0b11, 0b100, 0b0000, 0b0000, 0b000>;
534*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"VMPIDR_EL2",         0b11, 0b100, 0b0000, 0b0000, 0b101>;
535*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CPACR_EL1",          0b11, 0b000, 0b0001, 0b0000, 0b010>;
536*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SCTLR_EL1",          0b11, 0b000, 0b0001, 0b0000, 0b000>;
537*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SCTLR_EL2",          0b11, 0b100, 0b0001, 0b0000, 0b000>;
538*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SCTLR_EL3",          0b11, 0b110, 0b0001, 0b0000, 0b000>;
539*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ACTLR_EL1",          0b11, 0b000, 0b0001, 0b0000, 0b001>;
540*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ACTLR_EL2",          0b11, 0b100, 0b0001, 0b0000, 0b001>;
541*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ACTLR_EL3",          0b11, 0b110, 0b0001, 0b0000, 0b001>;
542*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"HCR_EL2",            0b11, 0b100, 0b0001, 0b0001, 0b000>;
543*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SCR_EL3",            0b11, 0b110, 0b0001, 0b0001, 0b000>;
544*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"MDCR_EL2",           0b11, 0b100, 0b0001, 0b0001, 0b001>;
545*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SDER32_EL3",         0b11, 0b110, 0b0001, 0b0001, 0b001>;
546*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CPTR_EL2",           0b11, 0b100, 0b0001, 0b0001, 0b010>;
547*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CPTR_EL3",           0b11, 0b110, 0b0001, 0b0001, 0b010>;
548*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"HSTR_EL2",           0b11, 0b100, 0b0001, 0b0001, 0b011>;
549*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"HACR_EL2",           0b11, 0b100, 0b0001, 0b0001, 0b111>;
550*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"MDCR_EL3",           0b11, 0b110, 0b0001, 0b0011, 0b001>;
551*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TTBR0_EL1",          0b11, 0b000, 0b0010, 0b0000, 0b000>;
552*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TTBR0_EL2",          0b11, 0b100, 0b0010, 0b0000, 0b000>;
553*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TTBR0_EL3",          0b11, 0b110, 0b0010, 0b0000, 0b000>;
554*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TTBR1_EL1",          0b11, 0b000, 0b0010, 0b0000, 0b001>;
555*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TCR_EL1",            0b11, 0b000, 0b0010, 0b0000, 0b010>;
556*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TCR_EL2",            0b11, 0b100, 0b0010, 0b0000, 0b010>;
557*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TCR_EL3",            0b11, 0b110, 0b0010, 0b0000, 0b010>;
558*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"VTTBR_EL2",          0b11, 0b100, 0b0010, 0b0001, 0b000>;
559*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"VTCR_EL2",           0b11, 0b100, 0b0010, 0b0001, 0b010>;
560*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DACR32_EL2",         0b11, 0b100, 0b0011, 0b0000, 0b000>;
561*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SPSR_EL1",           0b11, 0b000, 0b0100, 0b0000, 0b000>;
562*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SPSR_EL2",           0b11, 0b100, 0b0100, 0b0000, 0b000>;
563*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SPSR_EL3",           0b11, 0b110, 0b0100, 0b0000, 0b000>;
564*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ELR_EL1",            0b11, 0b000, 0b0100, 0b0000, 0b001>;
565*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ELR_EL2",            0b11, 0b100, 0b0100, 0b0000, 0b001>;
566*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ELR_EL3",            0b11, 0b110, 0b0100, 0b0000, 0b001>;
567*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SP_EL0",             0b11, 0b000, 0b0100, 0b0001, 0b000>;
568*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SP_EL1",             0b11, 0b100, 0b0100, 0b0001, 0b000>;
569*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SP_EL2",             0b11, 0b110, 0b0100, 0b0001, 0b000>;
570*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SPSel",              0b11, 0b000, 0b0100, 0b0010, 0b000>;
571*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"NZCV",               0b11, 0b011, 0b0100, 0b0010, 0b000>;
572*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DAIF",               0b11, 0b011, 0b0100, 0b0010, 0b001>;
573*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CurrentEL",          0b11, 0b000, 0b0100, 0b0010, 0b010>;
574*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SPSR_irq",           0b11, 0b100, 0b0100, 0b0011, 0b000>;
575*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SPSR_abt",           0b11, 0b100, 0b0100, 0b0011, 0b001>;
576*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SPSR_und",           0b11, 0b100, 0b0100, 0b0011, 0b010>;
577*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SPSR_fiq",           0b11, 0b100, 0b0100, 0b0011, 0b011>;
578*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"FPCR",               0b11, 0b011, 0b0100, 0b0100, 0b000>;
579*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"FPSR",               0b11, 0b011, 0b0100, 0b0100, 0b001>;
580*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DSPSR_EL0",          0b11, 0b011, 0b0100, 0b0101, 0b000>;
581*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DLR_EL0",            0b11, 0b011, 0b0100, 0b0101, 0b001>;
582*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"IFSR32_EL2",         0b11, 0b100, 0b0101, 0b0000, 0b001>;
583*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"AFSR0_EL1",          0b11, 0b000, 0b0101, 0b0001, 0b000>;
584*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"AFSR0_EL2",          0b11, 0b100, 0b0101, 0b0001, 0b000>;
585*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"AFSR0_EL3",          0b11, 0b110, 0b0101, 0b0001, 0b000>;
586*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"AFSR1_EL1",          0b11, 0b000, 0b0101, 0b0001, 0b001>;
587*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"AFSR1_EL2",          0b11, 0b100, 0b0101, 0b0001, 0b001>;
588*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"AFSR1_EL3",          0b11, 0b110, 0b0101, 0b0001, 0b001>;
589*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ESR_EL1",            0b11, 0b000, 0b0101, 0b0010, 0b000>;
590*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ESR_EL2",            0b11, 0b100, 0b0101, 0b0010, 0b000>;
591*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ESR_EL3",            0b11, 0b110, 0b0101, 0b0010, 0b000>;
592*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"FPEXC32_EL2",        0b11, 0b100, 0b0101, 0b0011, 0b000>;
593*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"FAR_EL1",            0b11, 0b000, 0b0110, 0b0000, 0b000>;
594*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"FAR_EL2",            0b11, 0b100, 0b0110, 0b0000, 0b000>;
595*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"FAR_EL3",            0b11, 0b110, 0b0110, 0b0000, 0b000>;
596*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"HPFAR_EL2",          0b11, 0b100, 0b0110, 0b0000, 0b100>;
597*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PAR_EL1",            0b11, 0b000, 0b0111, 0b0100, 0b000>;
598*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMCR_EL0",           0b11, 0b011, 0b1001, 0b1100, 0b000>;
599*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMCNTENSET_EL0",     0b11, 0b011, 0b1001, 0b1100, 0b001>;
600*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMCNTENCLR_EL0",     0b11, 0b011, 0b1001, 0b1100, 0b010>;
601*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMOVSCLR_EL0",       0b11, 0b011, 0b1001, 0b1100, 0b011>;
602*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMSELR_EL0",         0b11, 0b011, 0b1001, 0b1100, 0b101>;
603*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMCCNTR_EL0",        0b11, 0b011, 0b1001, 0b1101, 0b000>;
604*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMXEVTYPER_EL0",     0b11, 0b011, 0b1001, 0b1101, 0b001>;
605*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMXEVCNTR_EL0",      0b11, 0b011, 0b1001, 0b1101, 0b010>;
606*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMUSERENR_EL0",      0b11, 0b011, 0b1001, 0b1110, 0b000>;
607*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMINTENSET_EL1",     0b11, 0b000, 0b1001, 0b1110, 0b001>;
608*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMINTENCLR_EL1",     0b11, 0b000, 0b1001, 0b1110, 0b010>;
609*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMOVSSET_EL0",       0b11, 0b011, 0b1001, 0b1110, 0b011>;
610*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"MAIR_EL1",           0b11, 0b000, 0b1010, 0b0010, 0b000>;
611*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"MAIR_EL2",           0b11, 0b100, 0b1010, 0b0010, 0b000>;
612*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"MAIR_EL3",           0b11, 0b110, 0b1010, 0b0010, 0b000>;
613*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"AMAIR_EL1",          0b11, 0b000, 0b1010, 0b0011, 0b000>;
614*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"AMAIR_EL2",          0b11, 0b100, 0b1010, 0b0011, 0b000>;
615*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"AMAIR_EL3",          0b11, 0b110, 0b1010, 0b0011, 0b000>;
616*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"VBAR_EL1",           0b11, 0b000, 0b1100, 0b0000, 0b000>;
617*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"VBAR_EL2",           0b11, 0b100, 0b1100, 0b0000, 0b000>;
618*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"VBAR_EL3",           0b11, 0b110, 0b1100, 0b0000, 0b000>;
619*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"RMR_EL1",            0b11, 0b000, 0b1100, 0b0000, 0b010>;
620*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"RMR_EL2",            0b11, 0b100, 0b1100, 0b0000, 0b010>;
621*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"RMR_EL3",            0b11, 0b110, 0b1100, 0b0000, 0b010>;
622*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CONTEXTIDR_EL1",     0b11, 0b000, 0b1101, 0b0000, 0b001>;
623*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TPIDR_EL0",          0b11, 0b011, 0b1101, 0b0000, 0b010>;
624*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TPIDR_EL2",          0b11, 0b100, 0b1101, 0b0000, 0b010>;
625*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TPIDR_EL3",          0b11, 0b110, 0b1101, 0b0000, 0b010>;
626*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TPIDRRO_EL0",        0b11, 0b011, 0b1101, 0b0000, 0b011>;
627*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TPIDR_EL1",          0b11, 0b000, 0b1101, 0b0000, 0b100>;
628*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTFRQ_EL0",         0b11, 0b011, 0b1110, 0b0000, 0b000>;
629*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTVOFF_EL2",        0b11, 0b100, 0b1110, 0b0000, 0b011>;
630*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTKCTL_EL1",        0b11, 0b000, 0b1110, 0b0001, 0b000>;
631*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTHCTL_EL2",        0b11, 0b100, 0b1110, 0b0001, 0b000>;
632*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTP_TVAL_EL0",      0b11, 0b011, 0b1110, 0b0010, 0b000>;
633*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTHP_TVAL_EL2",     0b11, 0b100, 0b1110, 0b0010, 0b000>;
634*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTPS_TVAL_EL1",     0b11, 0b111, 0b1110, 0b0010, 0b000>;
635*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTP_CTL_EL0",       0b11, 0b011, 0b1110, 0b0010, 0b001>;
636*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTHP_CTL_EL2",      0b11, 0b100, 0b1110, 0b0010, 0b001>;
637*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTPS_CTL_EL1",      0b11, 0b111, 0b1110, 0b0010, 0b001>;
638*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTP_CVAL_EL0",      0b11, 0b011, 0b1110, 0b0010, 0b010>;
639*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTHP_CVAL_EL2",     0b11, 0b100, 0b1110, 0b0010, 0b010>;
640*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTPS_CVAL_EL1",     0b11, 0b111, 0b1110, 0b0010, 0b010>;
641*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTV_TVAL_EL0",      0b11, 0b011, 0b1110, 0b0011, 0b000>;
642*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTV_CTL_EL0",       0b11, 0b011, 0b1110, 0b0011, 0b001>;
643*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTV_CVAL_EL0",      0b11, 0b011, 0b1110, 0b0011, 0b010>;
644*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR0_EL0",      0b11, 0b011, 0b1110, 0b1000, 0b000>;
645*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR1_EL0",      0b11, 0b011, 0b1110, 0b1000, 0b001>;
646*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR2_EL0",      0b11, 0b011, 0b1110, 0b1000, 0b010>;
647*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR3_EL0",      0b11, 0b011, 0b1110, 0b1000, 0b011>;
648*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR4_EL0",      0b11, 0b011, 0b1110, 0b1000, 0b100>;
649*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR5_EL0",      0b11, 0b011, 0b1110, 0b1000, 0b101>;
650*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR6_EL0",      0b11, 0b011, 0b1110, 0b1000, 0b110>;
651*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR7_EL0",      0b11, 0b011, 0b1110, 0b1000, 0b111>;
652*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR8_EL0",      0b11, 0b011, 0b1110, 0b1001, 0b000>;
653*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR9_EL0",      0b11, 0b011, 0b1110, 0b1001, 0b001>;
654*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR10_EL0",     0b11, 0b011, 0b1110, 0b1001, 0b010>;
655*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR11_EL0",     0b11, 0b011, 0b1110, 0b1001, 0b011>;
656*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR12_EL0",     0b11, 0b011, 0b1110, 0b1001, 0b100>;
657*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR13_EL0",     0b11, 0b011, 0b1110, 0b1001, 0b101>;
658*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR14_EL0",     0b11, 0b011, 0b1110, 0b1001, 0b110>;
659*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR15_EL0",     0b11, 0b011, 0b1110, 0b1001, 0b111>;
660*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR16_EL0",     0b11, 0b011, 0b1110, 0b1010, 0b000>;
661*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR17_EL0",     0b11, 0b011, 0b1110, 0b1010, 0b001>;
662*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR18_EL0",     0b11, 0b011, 0b1110, 0b1010, 0b010>;
663*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR19_EL0",     0b11, 0b011, 0b1110, 0b1010, 0b011>;
664*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR20_EL0",     0b11, 0b011, 0b1110, 0b1010, 0b100>;
665*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR21_EL0",     0b11, 0b011, 0b1110, 0b1010, 0b101>;
666*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR22_EL0",     0b11, 0b011, 0b1110, 0b1010, 0b110>;
667*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR23_EL0",     0b11, 0b011, 0b1110, 0b1010, 0b111>;
668*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR24_EL0",     0b11, 0b011, 0b1110, 0b1011, 0b000>;
669*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR25_EL0",     0b11, 0b011, 0b1110, 0b1011, 0b001>;
670*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR26_EL0",     0b11, 0b011, 0b1110, 0b1011, 0b010>;
671*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR27_EL0",     0b11, 0b011, 0b1110, 0b1011, 0b011>;
672*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR28_EL0",     0b11, 0b011, 0b1110, 0b1011, 0b100>;
673*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR29_EL0",     0b11, 0b011, 0b1110, 0b1011, 0b101>;
674*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVCNTR30_EL0",     0b11, 0b011, 0b1110, 0b1011, 0b110>;
675*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMCCFILTR_EL0",      0b11, 0b011, 0b1110, 0b1111, 0b111>;
676*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER0_EL0",     0b11, 0b011, 0b1110, 0b1100, 0b000>;
677*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER1_EL0",     0b11, 0b011, 0b1110, 0b1100, 0b001>;
678*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER2_EL0",     0b11, 0b011, 0b1110, 0b1100, 0b010>;
679*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER3_EL0",     0b11, 0b011, 0b1110, 0b1100, 0b011>;
680*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER4_EL0",     0b11, 0b011, 0b1110, 0b1100, 0b100>;
681*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER5_EL0",     0b11, 0b011, 0b1110, 0b1100, 0b101>;
682*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER6_EL0",     0b11, 0b011, 0b1110, 0b1100, 0b110>;
683*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER7_EL0",     0b11, 0b011, 0b1110, 0b1100, 0b111>;
684*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER8_EL0",     0b11, 0b011, 0b1110, 0b1101, 0b000>;
685*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER9_EL0",     0b11, 0b011, 0b1110, 0b1101, 0b001>;
686*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER10_EL0",    0b11, 0b011, 0b1110, 0b1101, 0b010>;
687*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER11_EL0",    0b11, 0b011, 0b1110, 0b1101, 0b011>;
688*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER12_EL0",    0b11, 0b011, 0b1110, 0b1101, 0b100>;
689*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER13_EL0",    0b11, 0b011, 0b1110, 0b1101, 0b101>;
690*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER14_EL0",    0b11, 0b011, 0b1110, 0b1101, 0b110>;
691*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER15_EL0",    0b11, 0b011, 0b1110, 0b1101, 0b111>;
692*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER16_EL0",    0b11, 0b011, 0b1110, 0b1110, 0b000>;
693*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER17_EL0",    0b11, 0b011, 0b1110, 0b1110, 0b001>;
694*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER18_EL0",    0b11, 0b011, 0b1110, 0b1110, 0b010>;
695*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER19_EL0",    0b11, 0b011, 0b1110, 0b1110, 0b011>;
696*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER20_EL0",    0b11, 0b011, 0b1110, 0b1110, 0b100>;
697*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER21_EL0",    0b11, 0b011, 0b1110, 0b1110, 0b101>;
698*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER22_EL0",    0b11, 0b011, 0b1110, 0b1110, 0b110>;
699*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER23_EL0",    0b11, 0b011, 0b1110, 0b1110, 0b111>;
700*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER24_EL0",    0b11, 0b011, 0b1110, 0b1111, 0b000>;
701*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER25_EL0",    0b11, 0b011, 0b1110, 0b1111, 0b001>;
702*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER26_EL0",    0b11, 0b011, 0b1110, 0b1111, 0b010>;
703*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER27_EL0",    0b11, 0b011, 0b1110, 0b1111, 0b011>;
704*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER28_EL0",    0b11, 0b011, 0b1110, 0b1111, 0b100>;
705*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER29_EL0",    0b11, 0b011, 0b1110, 0b1111, 0b101>;
706*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMEVTYPER30_EL0",    0b11, 0b011, 0b1110, 0b1111, 0b110>;
707*9880d681SAndroid Build Coastguard Worker
708*9880d681SAndroid Build Coastguard Worker// Trace registers
709*9880d681SAndroid Build Coastguard Worker//                                 Op0    Op1     CRn     CRm    Op2
710*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCPRGCTLR",         0b10, 0b001, 0b0000, 0b0001, 0b000>;
711*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCPROCSELR",        0b10, 0b001, 0b0000, 0b0010, 0b000>;
712*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCONFIGR",         0b10, 0b001, 0b0000, 0b0100, 0b000>;
713*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCAUXCTLR",         0b10, 0b001, 0b0000, 0b0110, 0b000>;
714*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCEVENTCTL0R",      0b10, 0b001, 0b0000, 0b1000, 0b000>;
715*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCEVENTCTL1R",      0b10, 0b001, 0b0000, 0b1001, 0b000>;
716*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSTALLCTLR",       0b10, 0b001, 0b0000, 0b1011, 0b000>;
717*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCTSCTLR",          0b10, 0b001, 0b0000, 0b1100, 0b000>;
718*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSYNCPR",          0b10, 0b001, 0b0000, 0b1101, 0b000>;
719*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCCCTLR",          0b10, 0b001, 0b0000, 0b1110, 0b000>;
720*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCBBCTLR",          0b10, 0b001, 0b0000, 0b1111, 0b000>;
721*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCTRACEIDR",        0b10, 0b001, 0b0000, 0b0000, 0b001>;
722*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCQCTLR",           0b10, 0b001, 0b0000, 0b0001, 0b001>;
723*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVICTLR",          0b10, 0b001, 0b0000, 0b0000, 0b010>;
724*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVIIECTLR",        0b10, 0b001, 0b0000, 0b0001, 0b010>;
725*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVISSCTLR",        0b10, 0b001, 0b0000, 0b0010, 0b010>;
726*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVIPCSSCTLR",      0b10, 0b001, 0b0000, 0b0011, 0b010>;
727*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVDCTLR",          0b10, 0b001, 0b0000, 0b1000, 0b010>;
728*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVDSACCTLR",       0b10, 0b001, 0b0000, 0b1001, 0b010>;
729*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVDARCCTLR",       0b10, 0b001, 0b0000, 0b1010, 0b010>;
730*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSEQEVR0",         0b10, 0b001, 0b0000, 0b0000, 0b100>;
731*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSEQEVR1",         0b10, 0b001, 0b0000, 0b0001, 0b100>;
732*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSEQEVR2",         0b10, 0b001, 0b0000, 0b0010, 0b100>;
733*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSEQRSTEVR",       0b10, 0b001, 0b0000, 0b0110, 0b100>;
734*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSEQSTR",          0b10, 0b001, 0b0000, 0b0111, 0b100>;
735*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCEXTINSELR",       0b10, 0b001, 0b0000, 0b1000, 0b100>;
736*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCNTRLDVR0",       0b10, 0b001, 0b0000, 0b0000, 0b101>;
737*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCNTRLDVR1",       0b10, 0b001, 0b0000, 0b0001, 0b101>;
738*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCNTRLDVR2",       0b10, 0b001, 0b0000, 0b0010, 0b101>;
739*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCNTRLDVR3",       0b10, 0b001, 0b0000, 0b0011, 0b101>;
740*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCNTCTLR0",        0b10, 0b001, 0b0000, 0b0100, 0b101>;
741*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCNTCTLR1",        0b10, 0b001, 0b0000, 0b0101, 0b101>;
742*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCNTCTLR2",        0b10, 0b001, 0b0000, 0b0110, 0b101>;
743*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCNTCTLR3",        0b10, 0b001, 0b0000, 0b0111, 0b101>;
744*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCNTVR0",          0b10, 0b001, 0b0000, 0b1000, 0b101>;
745*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCNTVR1",          0b10, 0b001, 0b0000, 0b1001, 0b101>;
746*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCNTVR2",          0b10, 0b001, 0b0000, 0b1010, 0b101>;
747*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCNTVR3",          0b10, 0b001, 0b0000, 0b1011, 0b101>;
748*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCIMSPEC0",         0b10, 0b001, 0b0000, 0b0000, 0b111>;
749*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCIMSPEC1",         0b10, 0b001, 0b0000, 0b0001, 0b111>;
750*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCIMSPEC2",         0b10, 0b001, 0b0000, 0b0010, 0b111>;
751*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCIMSPEC3",         0b10, 0b001, 0b0000, 0b0011, 0b111>;
752*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCIMSPEC4",         0b10, 0b001, 0b0000, 0b0100, 0b111>;
753*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCIMSPEC5",         0b10, 0b001, 0b0000, 0b0101, 0b111>;
754*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCIMSPEC6",         0b10, 0b001, 0b0000, 0b0110, 0b111>;
755*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCIMSPEC7",         0b10, 0b001, 0b0000, 0b0111, 0b111>;
756*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR2",         0b10, 0b001, 0b0001, 0b0010, 0b000>;
757*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR3",         0b10, 0b001, 0b0001, 0b0011, 0b000>;
758*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR4",         0b10, 0b001, 0b0001, 0b0100, 0b000>;
759*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR5",         0b10, 0b001, 0b0001, 0b0101, 0b000>;
760*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR6",         0b10, 0b001, 0b0001, 0b0110, 0b000>;
761*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR7",         0b10, 0b001, 0b0001, 0b0111, 0b000>;
762*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR8",         0b10, 0b001, 0b0001, 0b1000, 0b000>;
763*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR9",         0b10, 0b001, 0b0001, 0b1001, 0b000>;
764*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR10",        0b10, 0b001, 0b0001, 0b1010, 0b000>;
765*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR11",        0b10, 0b001, 0b0001, 0b1011, 0b000>;
766*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR12",        0b10, 0b001, 0b0001, 0b1100, 0b000>;
767*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR13",        0b10, 0b001, 0b0001, 0b1101, 0b000>;
768*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR14",        0b10, 0b001, 0b0001, 0b1110, 0b000>;
769*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR15",        0b10, 0b001, 0b0001, 0b1111, 0b000>;
770*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR16",        0b10, 0b001, 0b0001, 0b0000, 0b001>;
771*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR17",        0b10, 0b001, 0b0001, 0b0001, 0b001>;
772*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR18",        0b10, 0b001, 0b0001, 0b0010, 0b001>;
773*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR19",        0b10, 0b001, 0b0001, 0b0011, 0b001>;
774*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR20",        0b10, 0b001, 0b0001, 0b0100, 0b001>;
775*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR21",        0b10, 0b001, 0b0001, 0b0101, 0b001>;
776*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR22",        0b10, 0b001, 0b0001, 0b0110, 0b001>;
777*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR23",        0b10, 0b001, 0b0001, 0b0111, 0b001>;
778*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR24",        0b10, 0b001, 0b0001, 0b1000, 0b001>;
779*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR25",        0b10, 0b001, 0b0001, 0b1001, 0b001>;
780*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR26",        0b10, 0b001, 0b0001, 0b1010, 0b001>;
781*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR27",        0b10, 0b001, 0b0001, 0b1011, 0b001>;
782*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR28",        0b10, 0b001, 0b0001, 0b1100, 0b001>;
783*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR29",        0b10, 0b001, 0b0001, 0b1101, 0b001>;
784*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR30",        0b10, 0b001, 0b0001, 0b1110, 0b001>;
785*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCRSCTLR31",        0b10, 0b001, 0b0001, 0b1111, 0b001>;
786*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCCR0",          0b10, 0b001, 0b0001, 0b0000, 0b010>;
787*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCCR1",          0b10, 0b001, 0b0001, 0b0001, 0b010>;
788*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCCR2",          0b10, 0b001, 0b0001, 0b0010, 0b010>;
789*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCCR3",          0b10, 0b001, 0b0001, 0b0011, 0b010>;
790*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCCR4",          0b10, 0b001, 0b0001, 0b0100, 0b010>;
791*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCCR5",          0b10, 0b001, 0b0001, 0b0101, 0b010>;
792*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCCR6",          0b10, 0b001, 0b0001, 0b0110, 0b010>;
793*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCCR7",          0b10, 0b001, 0b0001, 0b0111, 0b010>;
794*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCSR0",          0b10, 0b001, 0b0001, 0b1000, 0b010>;
795*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCSR1",          0b10, 0b001, 0b0001, 0b1001, 0b010>;
796*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCSR2",          0b10, 0b001, 0b0001, 0b1010, 0b010>;
797*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCSR3",          0b10, 0b001, 0b0001, 0b1011, 0b010>;
798*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCSR4",          0b10, 0b001, 0b0001, 0b1100, 0b010>;
799*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCSR5",          0b10, 0b001, 0b0001, 0b1101, 0b010>;
800*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCSR6",          0b10, 0b001, 0b0001, 0b1110, 0b010>;
801*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSCSR7",          0b10, 0b001, 0b0001, 0b1111, 0b010>;
802*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSPCICR0",        0b10, 0b001, 0b0001, 0b0000, 0b011>;
803*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSPCICR1",        0b10, 0b001, 0b0001, 0b0001, 0b011>;
804*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSPCICR2",        0b10, 0b001, 0b0001, 0b0010, 0b011>;
805*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSPCICR3",        0b10, 0b001, 0b0001, 0b0011, 0b011>;
806*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSPCICR4",        0b10, 0b001, 0b0001, 0b0100, 0b011>;
807*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSPCICR5",        0b10, 0b001, 0b0001, 0b0101, 0b011>;
808*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSPCICR6",        0b10, 0b001, 0b0001, 0b0110, 0b011>;
809*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCSSPCICR7",        0b10, 0b001, 0b0001, 0b0111, 0b011>;
810*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCPDCR",            0b10, 0b001, 0b0001, 0b0100, 0b100>;
811*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR0",           0b10, 0b001, 0b0010, 0b0000, 0b000>;
812*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR1",           0b10, 0b001, 0b0010, 0b0010, 0b000>;
813*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR2",           0b10, 0b001, 0b0010, 0b0100, 0b000>;
814*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR3",           0b10, 0b001, 0b0010, 0b0110, 0b000>;
815*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR4",           0b10, 0b001, 0b0010, 0b1000, 0b000>;
816*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR5",           0b10, 0b001, 0b0010, 0b1010, 0b000>;
817*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR6",           0b10, 0b001, 0b0010, 0b1100, 0b000>;
818*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR7",           0b10, 0b001, 0b0010, 0b1110, 0b000>;
819*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR8",           0b10, 0b001, 0b0010, 0b0000, 0b001>;
820*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR9",           0b10, 0b001, 0b0010, 0b0010, 0b001>;
821*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR10",          0b10, 0b001, 0b0010, 0b0100, 0b001>;
822*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR11",          0b10, 0b001, 0b0010, 0b0110, 0b001>;
823*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR12",          0b10, 0b001, 0b0010, 0b1000, 0b001>;
824*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR13",          0b10, 0b001, 0b0010, 0b1010, 0b001>;
825*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR14",          0b10, 0b001, 0b0010, 0b1100, 0b001>;
826*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACVR15",          0b10, 0b001, 0b0010, 0b1110, 0b001>;
827*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR0",          0b10, 0b001, 0b0010, 0b0000, 0b010>;
828*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR1",          0b10, 0b001, 0b0010, 0b0010, 0b010>;
829*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR2",          0b10, 0b001, 0b0010, 0b0100, 0b010>;
830*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR3",          0b10, 0b001, 0b0010, 0b0110, 0b010>;
831*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR4",          0b10, 0b001, 0b0010, 0b1000, 0b010>;
832*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR5",          0b10, 0b001, 0b0010, 0b1010, 0b010>;
833*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR6",          0b10, 0b001, 0b0010, 0b1100, 0b010>;
834*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR7",          0b10, 0b001, 0b0010, 0b1110, 0b010>;
835*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR8",          0b10, 0b001, 0b0010, 0b0000, 0b011>;
836*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR9",          0b10, 0b001, 0b0010, 0b0010, 0b011>;
837*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR10",         0b10, 0b001, 0b0010, 0b0100, 0b011>;
838*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR11",         0b10, 0b001, 0b0010, 0b0110, 0b011>;
839*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR12",         0b10, 0b001, 0b0010, 0b1000, 0b011>;
840*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR13",         0b10, 0b001, 0b0010, 0b1010, 0b011>;
841*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR14",         0b10, 0b001, 0b0010, 0b1100, 0b011>;
842*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCACATR15",         0b10, 0b001, 0b0010, 0b1110, 0b011>;
843*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCVR0",          0b10, 0b001, 0b0010, 0b0000, 0b100>;
844*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCVR1",          0b10, 0b001, 0b0010, 0b0100, 0b100>;
845*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCVR2",          0b10, 0b001, 0b0010, 0b1000, 0b100>;
846*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCVR3",          0b10, 0b001, 0b0010, 0b1100, 0b100>;
847*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCVR4",          0b10, 0b001, 0b0010, 0b0000, 0b101>;
848*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCVR5",          0b10, 0b001, 0b0010, 0b0100, 0b101>;
849*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCVR6",          0b10, 0b001, 0b0010, 0b1000, 0b101>;
850*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCVR7",          0b10, 0b001, 0b0010, 0b1100, 0b101>;
851*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCMR0",          0b10, 0b001, 0b0010, 0b0000, 0b110>;
852*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCMR1",          0b10, 0b001, 0b0010, 0b0100, 0b110>;
853*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCMR2",          0b10, 0b001, 0b0010, 0b1000, 0b110>;
854*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCMR3",          0b10, 0b001, 0b0010, 0b1100, 0b110>;
855*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCMR4",          0b10, 0b001, 0b0010, 0b0000, 0b111>;
856*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCMR5",          0b10, 0b001, 0b0010, 0b0100, 0b111>;
857*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCMR6",          0b10, 0b001, 0b0010, 0b1000, 0b111>;
858*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCDVCMR7",          0b10, 0b001, 0b0010, 0b1100, 0b111>;
859*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCIDCVR0",         0b10, 0b001, 0b0011, 0b0000, 0b000>;
860*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCIDCVR1",         0b10, 0b001, 0b0011, 0b0010, 0b000>;
861*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCIDCVR2",         0b10, 0b001, 0b0011, 0b0100, 0b000>;
862*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCIDCVR3",         0b10, 0b001, 0b0011, 0b0110, 0b000>;
863*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCIDCVR4",         0b10, 0b001, 0b0011, 0b1000, 0b000>;
864*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCIDCVR5",         0b10, 0b001, 0b0011, 0b1010, 0b000>;
865*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCIDCVR6",         0b10, 0b001, 0b0011, 0b1100, 0b000>;
866*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCIDCVR7",         0b10, 0b001, 0b0011, 0b1110, 0b000>;
867*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVMIDCVR0",        0b10, 0b001, 0b0011, 0b0000, 0b001>;
868*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVMIDCVR1",        0b10, 0b001, 0b0011, 0b0010, 0b001>;
869*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVMIDCVR2",        0b10, 0b001, 0b0011, 0b0100, 0b001>;
870*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVMIDCVR3",        0b10, 0b001, 0b0011, 0b0110, 0b001>;
871*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVMIDCVR4",        0b10, 0b001, 0b0011, 0b1000, 0b001>;
872*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVMIDCVR5",        0b10, 0b001, 0b0011, 0b1010, 0b001>;
873*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVMIDCVR6",        0b10, 0b001, 0b0011, 0b1100, 0b001>;
874*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVMIDCVR7",        0b10, 0b001, 0b0011, 0b1110, 0b001>;
875*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCIDCCTLR0",       0b10, 0b001, 0b0011, 0b0000, 0b010>;
876*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCIDCCTLR1",       0b10, 0b001, 0b0011, 0b0001, 0b010>;
877*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVMIDCCTLR0",      0b10, 0b001, 0b0011, 0b0010, 0b010>;
878*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCVMIDCCTLR1",      0b10, 0b001, 0b0011, 0b0011, 0b010>;
879*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCITCTRL",          0b10, 0b001, 0b0111, 0b0000, 0b100>;
880*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCLAIMSET",        0b10, 0b001, 0b0111, 0b1000, 0b110>;
881*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TRCCLAIMCLR",        0b10, 0b001, 0b0111, 0b1001, 0b110>;
882*9880d681SAndroid Build Coastguard Worker
883*9880d681SAndroid Build Coastguard Worker// GICv3 registers
884*9880d681SAndroid Build Coastguard Worker//                                 Op0    Op1     CRn     CRm    Op2
885*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_BPR1_EL1",       0b11, 0b000, 0b1100, 0b1100, 0b011>;
886*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_BPR0_EL1",       0b11, 0b000, 0b1100, 0b1000, 0b011>;
887*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_PMR_EL1",        0b11, 0b000, 0b0100, 0b0110, 0b000>;
888*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_CTLR_EL1",       0b11, 0b000, 0b1100, 0b1100, 0b100>;
889*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_CTLR_EL3",       0b11, 0b110, 0b1100, 0b1100, 0b100>;
890*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_SRE_EL1",        0b11, 0b000, 0b1100, 0b1100, 0b101>;
891*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_SRE_EL2",        0b11, 0b100, 0b1100, 0b1001, 0b101>;
892*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_SRE_EL3",        0b11, 0b110, 0b1100, 0b1100, 0b101>;
893*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_IGRPEN0_EL1",    0b11, 0b000, 0b1100, 0b1100, 0b110>;
894*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_IGRPEN1_EL1",    0b11, 0b000, 0b1100, 0b1100, 0b111>;
895*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_IGRPEN1_EL3",    0b11, 0b110, 0b1100, 0b1100, 0b111>;
896*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_SEIEN_EL1",      0b11, 0b000, 0b1100, 0b1101, 0b000>;
897*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_AP0R0_EL1",      0b11, 0b000, 0b1100, 0b1000, 0b100>;
898*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_AP0R1_EL1",      0b11, 0b000, 0b1100, 0b1000, 0b101>;
899*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_AP0R2_EL1",      0b11, 0b000, 0b1100, 0b1000, 0b110>;
900*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_AP0R3_EL1",      0b11, 0b000, 0b1100, 0b1000, 0b111>;
901*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_AP1R0_EL1",      0b11, 0b000, 0b1100, 0b1001, 0b000>;
902*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_AP1R1_EL1",      0b11, 0b000, 0b1100, 0b1001, 0b001>;
903*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_AP1R2_EL1",      0b11, 0b000, 0b1100, 0b1001, 0b010>;
904*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICC_AP1R3_EL1",      0b11, 0b000, 0b1100, 0b1001, 0b011>;
905*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_AP0R0_EL2",      0b11, 0b100, 0b1100, 0b1000, 0b000>;
906*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_AP0R1_EL2",      0b11, 0b100, 0b1100, 0b1000, 0b001>;
907*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_AP0R2_EL2",      0b11, 0b100, 0b1100, 0b1000, 0b010>;
908*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_AP0R3_EL2",      0b11, 0b100, 0b1100, 0b1000, 0b011>;
909*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_AP1R0_EL2",      0b11, 0b100, 0b1100, 0b1001, 0b000>;
910*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_AP1R1_EL2",      0b11, 0b100, 0b1100, 0b1001, 0b001>;
911*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_AP1R2_EL2",      0b11, 0b100, 0b1100, 0b1001, 0b010>;
912*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_AP1R3_EL2",      0b11, 0b100, 0b1100, 0b1001, 0b011>;
913*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_HCR_EL2",        0b11, 0b100, 0b1100, 0b1011, 0b000>;
914*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_MISR_EL2",       0b11, 0b100, 0b1100, 0b1011, 0b010>;
915*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_VMCR_EL2",       0b11, 0b100, 0b1100, 0b1011, 0b111>;
916*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_VSEIR_EL2",      0b11, 0b100, 0b1100, 0b1001, 0b100>;
917*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR0_EL2",        0b11, 0b100, 0b1100, 0b1100, 0b000>;
918*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR1_EL2",        0b11, 0b100, 0b1100, 0b1100, 0b001>;
919*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR2_EL2",        0b11, 0b100, 0b1100, 0b1100, 0b010>;
920*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR3_EL2",        0b11, 0b100, 0b1100, 0b1100, 0b011>;
921*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR4_EL2",        0b11, 0b100, 0b1100, 0b1100, 0b100>;
922*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR5_EL2",        0b11, 0b100, 0b1100, 0b1100, 0b101>;
923*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR6_EL2",        0b11, 0b100, 0b1100, 0b1100, 0b110>;
924*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR7_EL2",        0b11, 0b100, 0b1100, 0b1100, 0b111>;
925*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR8_EL2",        0b11, 0b100, 0b1100, 0b1101, 0b000>;
926*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR9_EL2",        0b11, 0b100, 0b1100, 0b1101, 0b001>;
927*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR10_EL2",       0b11, 0b100, 0b1100, 0b1101, 0b010>;
928*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR11_EL2",       0b11, 0b100, 0b1100, 0b1101, 0b011>;
929*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR12_EL2",       0b11, 0b100, 0b1100, 0b1101, 0b100>;
930*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR13_EL2",       0b11, 0b100, 0b1100, 0b1101, 0b101>;
931*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR14_EL2",       0b11, 0b100, 0b1100, 0b1101, 0b110>;
932*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ICH_LR15_EL2",       0b11, 0b100, 0b1100, 0b1101, 0b111>;
933*9880d681SAndroid Build Coastguard Worker
934*9880d681SAndroid Build Coastguard Worker// v8.1a "Privileged Access Never" extension-specific system registers
935*9880d681SAndroid Build Coastguard Workerlet Requires = [{ {AArch64::HasV8_1aOps} }] in
936*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PAN", 0b11, 0b000, 0b0100, 0b0010, 0b011>;
937*9880d681SAndroid Build Coastguard Worker
938*9880d681SAndroid Build Coastguard Worker// v8.1a "Limited Ordering Regions" extension-specific system registers
939*9880d681SAndroid Build Coastguard Worker//                         Op0    Op1     CRn     CRm    Op2
940*9880d681SAndroid Build Coastguard Workerlet Requires = [{ {AArch64::HasV8_1aOps} }] in {
941*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"LORSA_EL1",  0b11, 0b000, 0b1010, 0b0100, 0b000>;
942*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"LOREA_EL1",  0b11, 0b000, 0b1010, 0b0100, 0b001>;
943*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"LORN_EL1",   0b11, 0b000, 0b1010, 0b0100, 0b010>;
944*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"LORC_EL1",   0b11, 0b000, 0b1010, 0b0100, 0b011>;
945*9880d681SAndroid Build Coastguard Worker}
946*9880d681SAndroid Build Coastguard Worker
947*9880d681SAndroid Build Coastguard Worker// v8.1a "Virtualization hos extensions" system registers
948*9880d681SAndroid Build Coastguard Worker//                              Op0    Op1     CRn     CRm    Op2
949*9880d681SAndroid Build Coastguard Workerlet Requires = [{ {AArch64::HasV8_1aOps} }] in {
950*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TTBR1_EL2",       0b11, 0b100, 0b0010, 0b0000, 0b001>;
951*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CONTEXTIDR_EL2",  0b11, 0b100, 0b1101, 0b0000, 0b001>;
952*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTHV_TVAL_EL2",  0b11, 0b100, 0b1110, 0b0011, 0b000>;
953*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTHV_CVAL_EL2",  0b11, 0b100, 0b1110, 0b0011, 0b010>;
954*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTHV_CTL_EL2",   0b11, 0b100, 0b1110, 0b0011, 0b001>;
955*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SCTLR_EL12",      0b11, 0b101, 0b0001, 0b0000, 0b000>;
956*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CPACR_EL12",      0b11, 0b101, 0b0001, 0b0000, 0b010>;
957*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TTBR0_EL12",      0b11, 0b101, 0b0010, 0b0000, 0b000>;
958*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TTBR1_EL12",      0b11, 0b101, 0b0010, 0b0000, 0b001>;
959*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"TCR_EL12",        0b11, 0b101, 0b0010, 0b0000, 0b010>;
960*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"AFSR0_EL12",      0b11, 0b101, 0b0101, 0b0001, 0b000>;
961*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"AFSR1_EL12",      0b11, 0b101, 0b0101, 0b0001, 0b001>;
962*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ESR_EL12",        0b11, 0b101, 0b0101, 0b0010, 0b000>;
963*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"FAR_EL12",        0b11, 0b101, 0b0110, 0b0000, 0b000>;
964*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"MAIR_EL12",       0b11, 0b101, 0b1010, 0b0010, 0b000>;
965*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"AMAIR_EL12",      0b11, 0b101, 0b1010, 0b0011, 0b000>;
966*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"VBAR_EL12",       0b11, 0b101, 0b1100, 0b0000, 0b000>;
967*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CONTEXTIDR_EL12", 0b11, 0b101, 0b1101, 0b0000, 0b001>;
968*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTKCTL_EL12",    0b11, 0b101, 0b1110, 0b0001, 0b000>;
969*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTP_TVAL_EL02",  0b11, 0b101, 0b1110, 0b0010, 0b000>;
970*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTP_CTL_EL02",   0b11, 0b101, 0b1110, 0b0010, 0b001>;
971*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTP_CVAL_EL02",  0b11, 0b101, 0b1110, 0b0010, 0b010>;
972*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTV_TVAL_EL02",  0b11, 0b101, 0b1110, 0b0011, 0b000>;
973*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTV_CTL_EL02",   0b11, 0b101, 0b1110, 0b0011, 0b001>;
974*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CNTV_CVAL_EL02",  0b11, 0b101, 0b1110, 0b0011, 0b010>;
975*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"SPSR_EL12",       0b11, 0b101, 0b0100, 0b0000, 0b000>;
976*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ELR_EL12",        0b11, 0b101, 0b0100, 0b0000, 0b001>;
977*9880d681SAndroid Build Coastguard Worker}
978*9880d681SAndroid Build Coastguard Worker// v8.2a registers
979*9880d681SAndroid Build Coastguard Worker//                  Op0    Op1     CRn     CRm    Op2
980*9880d681SAndroid Build Coastguard Workerlet Requires = [{ {AArch64::HasV8_2aOps} }] in
981*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"UAO", 0b11, 0b000, 0b0100, 0b0010, 0b100>;
982*9880d681SAndroid Build Coastguard Worker
983*9880d681SAndroid Build Coastguard Worker// v8.2a "Statistical Profiling extension" registers
984*9880d681SAndroid Build Coastguard Worker//                            Op0    Op1     CRn     CRm    Op2
985*9880d681SAndroid Build Coastguard Workerlet Requires = [{ {AArch64::FeatureSPE} }] in {
986*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMBLIMITR_EL1", 0b11, 0b000, 0b1001, 0b1010, 0b000>;
987*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMBPTR_EL1",    0b11, 0b000, 0b1001, 0b1010, 0b001>;
988*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMBSR_EL1",     0b11, 0b000, 0b1001, 0b1010, 0b011>;
989*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMBIDR_EL1",    0b11, 0b000, 0b1001, 0b1010, 0b111>;
990*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMSCR_EL2",     0b11, 0b100, 0b1001, 0b1001, 0b000>;
991*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMSCR_EL12",    0b11, 0b101, 0b1001, 0b1001, 0b000>;
992*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMSCR_EL1",     0b11, 0b000, 0b1001, 0b1001, 0b000>;
993*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMSICR_EL1",    0b11, 0b000, 0b1001, 0b1001, 0b010>;
994*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMSIRR_EL1",    0b11, 0b000, 0b1001, 0b1001, 0b011>;
995*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMSFCR_EL1",    0b11, 0b000, 0b1001, 0b1001, 0b100>;
996*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMSEVFR_EL1",   0b11, 0b000, 0b1001, 0b1001, 0b101>;
997*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMSLATFR_EL1",  0b11, 0b000, 0b1001, 0b1001, 0b110>;
998*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"PMSIDR_EL1",    0b11, 0b000, 0b1001, 0b1001, 0b111>;
999*9880d681SAndroid Build Coastguard Worker}
1000*9880d681SAndroid Build Coastguard Worker
1001*9880d681SAndroid Build Coastguard Worker// v8.2a "RAS extension" registers
1002*9880d681SAndroid Build Coastguard Worker//                         Op0    Op1     CRn     CRm    Op2
1003*9880d681SAndroid Build Coastguard Workerlet Requires = [{ {AArch64::FeatureRAS} }] in {
1004*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ERRSELR_EL1",   0b11, 0b000, 0b0101, 0b0011, 0b001>;
1005*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ERXCTLR_EL1",   0b11, 0b000, 0b0101, 0b0100, 0b001>;
1006*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ERXSTATUS_EL1", 0b11, 0b000, 0b0101, 0b0100, 0b010>;
1007*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ERXADDR_EL1",   0b11, 0b000, 0b0101, 0b0100, 0b011>;
1008*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ERXMISC0_EL1",  0b11, 0b000, 0b0101, 0b0101, 0b000>;
1009*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"ERXMISC1_EL1",  0b11, 0b000, 0b0101, 0b0101, 0b001>;
1010*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"DISR_EL1",      0b11, 0b000, 0b1100, 0b0001, 0b001>;
1011*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"VDISR_EL2",     0b11, 0b100, 0b1100, 0b0001, 0b001>;
1012*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"VSESR_EL2",     0b11, 0b100, 0b0101, 0b0010, 0b011>;
1013*9880d681SAndroid Build Coastguard Worker}
1014*9880d681SAndroid Build Coastguard Worker
1015*9880d681SAndroid Build Coastguard Worker// Cyclone specific system registers
1016*9880d681SAndroid Build Coastguard Worker//                                 Op0    Op1     CRn     CRm    Op2
1017*9880d681SAndroid Build Coastguard Workerlet Requires = [{ {AArch64::ProcCyclone} }] in
1018*9880d681SAndroid Build Coastguard Workerdef : RWSysReg<"CPM_IOACC_CTL_EL3", 0b11, 0b111, 0b1111, 0b0010, 0b000>;
1019