| 1 | /* |
| 2 | * Copyright (c) 2002, 2016, Oracle and/or its affiliates. All rights reserved. |
| 3 | * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
| 4 | * |
| 5 | * This code is free software; you can redistribute it and/or modify it |
| 6 | * under the terms of the GNU General Public License version 2 only, as |
| 7 | * published by the Free Software Foundation. |
| 8 | * |
| 9 | * This code is distributed in the hope that it will be useful, but WITHOUT |
| 10 | * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
| 11 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
| 12 | * version 2 for more details (a copy is included in the LICENSE file that |
| 13 | * accompanied this code). |
| 14 | * |
| 15 | * You should have received a copy of the GNU General Public License version |
| 16 | * 2 along with this work; if not, write to the Free Software Foundation, |
| 17 | * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
| 18 | * |
| 19 | * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
| 20 | * or visit www.oracle.com if you need additional information or have any |
| 21 | * questions. |
| 22 | * |
| 23 | */ |
| 24 | |
| 25 | #include "precompiled.hpp" |
| 26 | #include "asm/assembler.hpp" |
| 27 | #include "asm/register.hpp" |
| 28 | #include "register_x86.hpp" |
| 29 | #include "interp_masm_x86.hpp" |
| 30 | |
| 31 | REGISTER_DEFINITION(Register, noreg); |
| 32 | REGISTER_DEFINITION(Register, rax); |
| 33 | REGISTER_DEFINITION(Register, rcx); |
| 34 | REGISTER_DEFINITION(Register, rdx); |
| 35 | REGISTER_DEFINITION(Register, rbx); |
| 36 | REGISTER_DEFINITION(Register, rsp); |
| 37 | REGISTER_DEFINITION(Register, rbp); |
| 38 | REGISTER_DEFINITION(Register, rsi); |
| 39 | REGISTER_DEFINITION(Register, rdi); |
| 40 | #ifdef AMD64 |
| 41 | REGISTER_DEFINITION(Register, r8); |
| 42 | REGISTER_DEFINITION(Register, r9); |
| 43 | REGISTER_DEFINITION(Register, r10); |
| 44 | REGISTER_DEFINITION(Register, r11); |
| 45 | REGISTER_DEFINITION(Register, r12); |
| 46 | REGISTER_DEFINITION(Register, r13); |
| 47 | REGISTER_DEFINITION(Register, r14); |
| 48 | REGISTER_DEFINITION(Register, r15); |
| 49 | #endif // AMD64 |
| 50 | |
| 51 | REGISTER_DEFINITION(FloatRegister, fnoreg); |
| 52 | |
| 53 | REGISTER_DEFINITION(XMMRegister, xnoreg); |
| 54 | REGISTER_DEFINITION(XMMRegister, xmm0 ); |
| 55 | REGISTER_DEFINITION(XMMRegister, xmm1 ); |
| 56 | REGISTER_DEFINITION(XMMRegister, xmm2 ); |
| 57 | REGISTER_DEFINITION(XMMRegister, xmm3 ); |
| 58 | REGISTER_DEFINITION(XMMRegister, xmm4 ); |
| 59 | REGISTER_DEFINITION(XMMRegister, xmm5 ); |
| 60 | REGISTER_DEFINITION(XMMRegister, xmm6 ); |
| 61 | REGISTER_DEFINITION(XMMRegister, xmm7 ); |
| 62 | #ifdef AMD64 |
| 63 | REGISTER_DEFINITION(XMMRegister, xmm8); |
| 64 | REGISTER_DEFINITION(XMMRegister, xmm9); |
| 65 | REGISTER_DEFINITION(XMMRegister, xmm10); |
| 66 | REGISTER_DEFINITION(XMMRegister, xmm11); |
| 67 | REGISTER_DEFINITION(XMMRegister, xmm12); |
| 68 | REGISTER_DEFINITION(XMMRegister, xmm13); |
| 69 | REGISTER_DEFINITION(XMMRegister, xmm14); |
| 70 | REGISTER_DEFINITION(XMMRegister, xmm15); |
| 71 | REGISTER_DEFINITION(XMMRegister, xmm16); |
| 72 | REGISTER_DEFINITION(XMMRegister, xmm17); |
| 73 | REGISTER_DEFINITION(XMMRegister, xmm18); |
| 74 | REGISTER_DEFINITION(XMMRegister, xmm19); |
| 75 | REGISTER_DEFINITION(XMMRegister, xmm20); |
| 76 | REGISTER_DEFINITION(XMMRegister, xmm21); |
| 77 | REGISTER_DEFINITION(XMMRegister, xmm22); |
| 78 | REGISTER_DEFINITION(XMMRegister, xmm23); |
| 79 | REGISTER_DEFINITION(XMMRegister, xmm24); |
| 80 | REGISTER_DEFINITION(XMMRegister, xmm25); |
| 81 | REGISTER_DEFINITION(XMMRegister, xmm26); |
| 82 | REGISTER_DEFINITION(XMMRegister, xmm27); |
| 83 | REGISTER_DEFINITION(XMMRegister, xmm28); |
| 84 | REGISTER_DEFINITION(XMMRegister, xmm29); |
| 85 | REGISTER_DEFINITION(XMMRegister, xmm30); |
| 86 | REGISTER_DEFINITION(XMMRegister, xmm31); |
| 87 | |
| 88 | REGISTER_DEFINITION(Register, c_rarg0); |
| 89 | REGISTER_DEFINITION(Register, c_rarg1); |
| 90 | REGISTER_DEFINITION(Register, c_rarg2); |
| 91 | REGISTER_DEFINITION(Register, c_rarg3); |
| 92 | |
| 93 | REGISTER_DEFINITION(XMMRegister, c_farg0); |
| 94 | REGISTER_DEFINITION(XMMRegister, c_farg1); |
| 95 | REGISTER_DEFINITION(XMMRegister, c_farg2); |
| 96 | REGISTER_DEFINITION(XMMRegister, c_farg3); |
| 97 | |
| 98 | // Non windows OS's have a few more argument registers |
| 99 | #ifndef _WIN64 |
| 100 | REGISTER_DEFINITION(Register, c_rarg4); |
| 101 | REGISTER_DEFINITION(Register, c_rarg5); |
| 102 | |
| 103 | REGISTER_DEFINITION(XMMRegister, c_farg4); |
| 104 | REGISTER_DEFINITION(XMMRegister, c_farg5); |
| 105 | REGISTER_DEFINITION(XMMRegister, c_farg6); |
| 106 | REGISTER_DEFINITION(XMMRegister, c_farg7); |
| 107 | #endif /* _WIN64 */ |
| 108 | |
| 109 | REGISTER_DEFINITION(Register, j_rarg0); |
| 110 | REGISTER_DEFINITION(Register, j_rarg1); |
| 111 | REGISTER_DEFINITION(Register, j_rarg2); |
| 112 | REGISTER_DEFINITION(Register, j_rarg3); |
| 113 | REGISTER_DEFINITION(Register, j_rarg4); |
| 114 | REGISTER_DEFINITION(Register, j_rarg5); |
| 115 | |
| 116 | REGISTER_DEFINITION(XMMRegister, j_farg0); |
| 117 | REGISTER_DEFINITION(XMMRegister, j_farg1); |
| 118 | REGISTER_DEFINITION(XMMRegister, j_farg2); |
| 119 | REGISTER_DEFINITION(XMMRegister, j_farg3); |
| 120 | REGISTER_DEFINITION(XMMRegister, j_farg4); |
| 121 | REGISTER_DEFINITION(XMMRegister, j_farg5); |
| 122 | REGISTER_DEFINITION(XMMRegister, j_farg6); |
| 123 | REGISTER_DEFINITION(XMMRegister, j_farg7); |
| 124 | |
| 125 | REGISTER_DEFINITION(Register, rscratch1); |
| 126 | REGISTER_DEFINITION(Register, rscratch2); |
| 127 | |
| 128 | REGISTER_DEFINITION(Register, r12_heapbase); |
| 129 | REGISTER_DEFINITION(Register, r15_thread); |
| 130 | #endif // AMD64 |
| 131 | |
| 132 | REGISTER_DEFINITION(MMXRegister, mnoreg ); |
| 133 | REGISTER_DEFINITION(MMXRegister, mmx0 ); |
| 134 | REGISTER_DEFINITION(MMXRegister, mmx1 ); |
| 135 | REGISTER_DEFINITION(MMXRegister, mmx2 ); |
| 136 | REGISTER_DEFINITION(MMXRegister, mmx3 ); |
| 137 | REGISTER_DEFINITION(MMXRegister, mmx4 ); |
| 138 | REGISTER_DEFINITION(MMXRegister, mmx5 ); |
| 139 | REGISTER_DEFINITION(MMXRegister, mmx6 ); |
| 140 | REGISTER_DEFINITION(MMXRegister, mmx7 ); |
| 141 | |
| 142 | REGISTER_DEFINITION(KRegister, knoreg); |
| 143 | REGISTER_DEFINITION(KRegister, k0); |
| 144 | REGISTER_DEFINITION(KRegister, k1); |
| 145 | REGISTER_DEFINITION(KRegister, k2); |
| 146 | REGISTER_DEFINITION(KRegister, k3); |
| 147 | REGISTER_DEFINITION(KRegister, k4); |
| 148 | REGISTER_DEFINITION(KRegister, k5); |
| 149 | REGISTER_DEFINITION(KRegister, k6); |
| 150 | REGISTER_DEFINITION(KRegister, k7); |
| 151 | |
| 152 | // JSR 292 |
| 153 | REGISTER_DEFINITION(Register, rbp_mh_SP_save); |
| 154 | |