1 /*
  2  * Copyright (c) 2002, 2020, Oracle and/or its affiliates. All rights reserved.
  3  * Copyright (c) 2014, Red Hat Inc. All rights reserved.
  4  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  5  *
  6  * This code is free software; you can redistribute it and/or modify it
  7  * under the terms of the GNU General Public License version 2 only, as
  8  * published by the Free Software Foundation.
  9  *
 10  * This code is distributed in the hope that it will be useful, but WITHOUT
 11  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 12  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 13  * version 2 for more details (a copy is included in the LICENSE file that
 14  * accompanied this code).
 15  *
 16  * You should have received a copy of the GNU General Public License version
 17  * 2 along with this work; if not, write to the Free Software Foundation,
 18  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 19  *
 20  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 21  * or visit www.oracle.com if you need additional information or have any
 22  * questions.
 23  *
 24  */
 25 
 26 #include "precompiled.hpp"
 27 #include "asm/assembler.hpp"
 28 #include "asm/macroAssembler.inline.hpp"
 29 #include "asm/register.hpp"
 30 #include "register_aarch64.hpp"
 31 # include "interp_masm_aarch64.hpp"
 32 
 33 REGISTER_DEFINITION(Register, noreg);
 34 
 35 REGISTER_DEFINITION(Register, r0);
 36 REGISTER_DEFINITION(Register, r1);
 37 REGISTER_DEFINITION(Register, r2);
 38 REGISTER_DEFINITION(Register, r3);
 39 REGISTER_DEFINITION(Register, r4);
 40 REGISTER_DEFINITION(Register, r5);
 41 REGISTER_DEFINITION(Register, r6);
 42 REGISTER_DEFINITION(Register, r7);
 43 REGISTER_DEFINITION(Register, r8);
 44 REGISTER_DEFINITION(Register, r9);
 45 REGISTER_DEFINITION(Register, r10);
 46 REGISTER_DEFINITION(Register, r11);
 47 REGISTER_DEFINITION(Register, r12);
 48 REGISTER_DEFINITION(Register, r13);
 49 REGISTER_DEFINITION(Register, r14);
 50 REGISTER_DEFINITION(Register, r15);
 51 REGISTER_DEFINITION(Register, r16);
 52 REGISTER_DEFINITION(Register, r17);
 53 REGISTER_DEFINITION(Register, r18);
 54 REGISTER_DEFINITION(Register, r19);
 55 REGISTER_DEFINITION(Register, r20);
 56 REGISTER_DEFINITION(Register, r21);
 57 REGISTER_DEFINITION(Register, r22);
 58 REGISTER_DEFINITION(Register, r23);
 59 REGISTER_DEFINITION(Register, r24);
 60 REGISTER_DEFINITION(Register, r25);
 61 REGISTER_DEFINITION(Register, r26);
 62 REGISTER_DEFINITION(Register, r27);
 63 REGISTER_DEFINITION(Register, r28);
 64 REGISTER_DEFINITION(Register, r29);
 65 REGISTER_DEFINITION(Register, r30);
 66 REGISTER_DEFINITION(Register, sp);
 67 
 68 REGISTER_DEFINITION(FloatRegister, fnoreg);
 69 
 70 REGISTER_DEFINITION(FloatRegister, v0);
 71 REGISTER_DEFINITION(FloatRegister, v1);
 72 REGISTER_DEFINITION(FloatRegister, v2);
 73 REGISTER_DEFINITION(FloatRegister, v3);
 74 REGISTER_DEFINITION(FloatRegister, v4);
 75 REGISTER_DEFINITION(FloatRegister, v5);
 76 REGISTER_DEFINITION(FloatRegister, v6);
 77 REGISTER_DEFINITION(FloatRegister, v7);
 78 REGISTER_DEFINITION(FloatRegister, v8);
 79 REGISTER_DEFINITION(FloatRegister, v9);
 80 REGISTER_DEFINITION(FloatRegister, v10);
 81 REGISTER_DEFINITION(FloatRegister, v11);
 82 REGISTER_DEFINITION(FloatRegister, v12);
 83 REGISTER_DEFINITION(FloatRegister, v13);
 84 REGISTER_DEFINITION(FloatRegister, v14);
 85 REGISTER_DEFINITION(FloatRegister, v15);
 86 REGISTER_DEFINITION(FloatRegister, v16);
 87 REGISTER_DEFINITION(FloatRegister, v17);
 88 REGISTER_DEFINITION(FloatRegister, v18);
 89 REGISTER_DEFINITION(FloatRegister, v19);
 90 REGISTER_DEFINITION(FloatRegister, v20);
 91 REGISTER_DEFINITION(FloatRegister, v21);
 92 REGISTER_DEFINITION(FloatRegister, v22);
 93 REGISTER_DEFINITION(FloatRegister, v23);
 94 REGISTER_DEFINITION(FloatRegister, v24);
 95 REGISTER_DEFINITION(FloatRegister, v25);
 96 REGISTER_DEFINITION(FloatRegister, v26);
 97 REGISTER_DEFINITION(FloatRegister, v27);
 98 REGISTER_DEFINITION(FloatRegister, v28);
 99 REGISTER_DEFINITION(FloatRegister, v29);
100 REGISTER_DEFINITION(FloatRegister, v30);
101 REGISTER_DEFINITION(FloatRegister, v31);
102 
103 REGISTER_DEFINITION(Register, zr);
104 
105 REGISTER_DEFINITION(Register, c_rarg0);
106 REGISTER_DEFINITION(Register, c_rarg1);
107 REGISTER_DEFINITION(Register, c_rarg2);
108 REGISTER_DEFINITION(Register, c_rarg3);
109 REGISTER_DEFINITION(Register, c_rarg4);
110 REGISTER_DEFINITION(Register, c_rarg5);
111 REGISTER_DEFINITION(Register, c_rarg6);
112 REGISTER_DEFINITION(Register, c_rarg7);
113 
114 REGISTER_DEFINITION(FloatRegister, c_farg0);
115 REGISTER_DEFINITION(FloatRegister, c_farg1);
116 REGISTER_DEFINITION(FloatRegister, c_farg2);
117 REGISTER_DEFINITION(FloatRegister, c_farg3);
118 REGISTER_DEFINITION(FloatRegister, c_farg4);
119 REGISTER_DEFINITION(FloatRegister, c_farg5);
120 REGISTER_DEFINITION(FloatRegister, c_farg6);
121 REGISTER_DEFINITION(FloatRegister, c_farg7);
122 
123 REGISTER_DEFINITION(Register, j_rarg0);
124 REGISTER_DEFINITION(Register, j_rarg1);
125 REGISTER_DEFINITION(Register, j_rarg2);
126 REGISTER_DEFINITION(Register, j_rarg3);
127 REGISTER_DEFINITION(Register, j_rarg4);
128 REGISTER_DEFINITION(Register, j_rarg5);
129 REGISTER_DEFINITION(Register, j_rarg6);
130 REGISTER_DEFINITION(Register, j_rarg7);
131 
132 REGISTER_DEFINITION(FloatRegister, j_farg0);
133 REGISTER_DEFINITION(FloatRegister, j_farg1);
134 REGISTER_DEFINITION(FloatRegister, j_farg2);
135 REGISTER_DEFINITION(FloatRegister, j_farg3);
136 REGISTER_DEFINITION(FloatRegister, j_farg4);
137 REGISTER_DEFINITION(FloatRegister, j_farg5);
138 REGISTER_DEFINITION(FloatRegister, j_farg6);
139 REGISTER_DEFINITION(FloatRegister, j_farg7);
140 
141 REGISTER_DEFINITION(Register, rscratch1);
142 REGISTER_DEFINITION(Register, rscratch2);
143 REGISTER_DEFINITION(Register, esp);
144 REGISTER_DEFINITION(Register, rdispatch);
145 REGISTER_DEFINITION(Register, rcpool);
146 REGISTER_DEFINITION(Register, rmonitors);
147 REGISTER_DEFINITION(Register, rlocals);
148 REGISTER_DEFINITION(Register, rmethod);
149 REGISTER_DEFINITION(Register, rbcp);
150 
151 REGISTER_DEFINITION(Register, lr);
152 REGISTER_DEFINITION(Register, rfp);
153 REGISTER_DEFINITION(Register, rthread);
154 REGISTER_DEFINITION(Register, rheapbase);
155 
156 REGISTER_DEFINITION(Register, r31_sp);
157 
158 REGISTER_DEFINITION(FloatRegister, z0);
159 REGISTER_DEFINITION(FloatRegister, z1);
160 REGISTER_DEFINITION(FloatRegister, z2);
161 REGISTER_DEFINITION(FloatRegister, z3);
162 REGISTER_DEFINITION(FloatRegister, z4);
163 REGISTER_DEFINITION(FloatRegister, z5);
164 REGISTER_DEFINITION(FloatRegister, z6);
165 REGISTER_DEFINITION(FloatRegister, z7);
166 REGISTER_DEFINITION(FloatRegister, z8);
167 REGISTER_DEFINITION(FloatRegister, z9);
168 REGISTER_DEFINITION(FloatRegister, z10);
169 REGISTER_DEFINITION(FloatRegister, z11);
170 REGISTER_DEFINITION(FloatRegister, z12);
171 REGISTER_DEFINITION(FloatRegister, z13);
172 REGISTER_DEFINITION(FloatRegister, z14);
173 REGISTER_DEFINITION(FloatRegister, z15);
174 REGISTER_DEFINITION(FloatRegister, z16);
175 REGISTER_DEFINITION(FloatRegister, z17);
176 REGISTER_DEFINITION(FloatRegister, z18);
177 REGISTER_DEFINITION(FloatRegister, z19);
178 REGISTER_DEFINITION(FloatRegister, z20);
179 REGISTER_DEFINITION(FloatRegister, z21);
180 REGISTER_DEFINITION(FloatRegister, z22);
181 REGISTER_DEFINITION(FloatRegister, z23);
182 REGISTER_DEFINITION(FloatRegister, z24);
183 REGISTER_DEFINITION(FloatRegister, z25);
184 REGISTER_DEFINITION(FloatRegister, z26);
185 REGISTER_DEFINITION(FloatRegister, z27);
186 REGISTER_DEFINITION(FloatRegister, z28);
187 REGISTER_DEFINITION(FloatRegister, z29);
188 REGISTER_DEFINITION(FloatRegister, z30);
189 REGISTER_DEFINITION(FloatRegister, z31);
190 
191 REGISTER_DEFINITION(PRegister, p0);
192 REGISTER_DEFINITION(PRegister, p1);
193 REGISTER_DEFINITION(PRegister, p2);
194 REGISTER_DEFINITION(PRegister, p3);
195 REGISTER_DEFINITION(PRegister, p4);
196 REGISTER_DEFINITION(PRegister, p5);
197 REGISTER_DEFINITION(PRegister, p6);
198 REGISTER_DEFINITION(PRegister, p7);
199 REGISTER_DEFINITION(PRegister, p8);
200 REGISTER_DEFINITION(PRegister, p9);
201 REGISTER_DEFINITION(PRegister, p10);
202 REGISTER_DEFINITION(PRegister, p11);
203 REGISTER_DEFINITION(PRegister, p12);
204 REGISTER_DEFINITION(PRegister, p13);
205 REGISTER_DEFINITION(PRegister, p14);
206 REGISTER_DEFINITION(PRegister, p15);
207 
208 REGISTER_DEFINITION(PRegister, ptrue);