0N/A/*
1499N/A * Copyright (c) 2002, 2010, Oracle and/or its affiliates. All rights reserved.
0N/A * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
0N/A *
0N/A * This code is free software; you can redistribute it and/or modify it
0N/A * under the terms of the GNU General Public License version 2 only, as
0N/A * published by the Free Software Foundation.
0N/A *
0N/A * This code is distributed in the hope that it will be useful, but WITHOUT
0N/A * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
0N/A * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
0N/A * version 2 for more details (a copy is included in the LICENSE file that
0N/A * accompanied this code).
0N/A *
0N/A * You should have received a copy of the GNU General Public License version
0N/A * 2 along with this work; if not, write to the Free Software Foundation,
0N/A * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
0N/A *
1472N/A * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
1472N/A * or visit www.oracle.com if you need additional information or have any
1472N/A * questions.
0N/A *
0N/A */
0N/A
0N/A// make sure the defines don't screw up the declarations later on in this file
0N/A#define DONT_USE_REGISTER_DEFINES
0N/A
1879N/A#include "precompiled.hpp"
1879N/A#include "asm/assembler.hpp"
1879N/A#include "asm/register.hpp"
1879N/A#include "interp_masm_sparc.hpp"
1879N/A#include "register_sparc.hpp"
0N/A
0N/AREGISTER_DEFINITION(Register, noreg);
0N/A
0N/AREGISTER_DEFINITION(Register, G0);
0N/AREGISTER_DEFINITION(Register, G1);
0N/AREGISTER_DEFINITION(Register, G2);
0N/AREGISTER_DEFINITION(Register, G3);
0N/AREGISTER_DEFINITION(Register, G4);
0N/AREGISTER_DEFINITION(Register, G5);
0N/AREGISTER_DEFINITION(Register, G6);
0N/AREGISTER_DEFINITION(Register, G7);
0N/A
0N/AREGISTER_DEFINITION(Register, O0);
0N/AREGISTER_DEFINITION(Register, O1);
0N/AREGISTER_DEFINITION(Register, O2);
0N/AREGISTER_DEFINITION(Register, O3);
0N/AREGISTER_DEFINITION(Register, O4);
0N/AREGISTER_DEFINITION(Register, O5);
0N/AREGISTER_DEFINITION(Register, O6);
0N/AREGISTER_DEFINITION(Register, O7);
0N/A
0N/AREGISTER_DEFINITION(Register, L0);
0N/AREGISTER_DEFINITION(Register, L1);
0N/AREGISTER_DEFINITION(Register, L2);
0N/AREGISTER_DEFINITION(Register, L3);
0N/AREGISTER_DEFINITION(Register, L4);
0N/AREGISTER_DEFINITION(Register, L5);
0N/AREGISTER_DEFINITION(Register, L6);
0N/AREGISTER_DEFINITION(Register, L7);
0N/A
0N/AREGISTER_DEFINITION(Register, I0);
0N/AREGISTER_DEFINITION(Register, I1);
0N/AREGISTER_DEFINITION(Register, I2);
0N/AREGISTER_DEFINITION(Register, I3);
0N/AREGISTER_DEFINITION(Register, I4);
0N/AREGISTER_DEFINITION(Register, I5);
0N/AREGISTER_DEFINITION(Register, I6);
0N/AREGISTER_DEFINITION(Register, I7);
0N/A
0N/AREGISTER_DEFINITION(Register, FP);
0N/AREGISTER_DEFINITION(Register, SP);
0N/A
0N/AREGISTER_DEFINITION(FloatRegister, fnoreg);
0N/AREGISTER_DEFINITION(FloatRegister, F0);
0N/AREGISTER_DEFINITION(FloatRegister, F1);
0N/AREGISTER_DEFINITION(FloatRegister, F2);
0N/AREGISTER_DEFINITION(FloatRegister, F3);
0N/AREGISTER_DEFINITION(FloatRegister, F4);
0N/AREGISTER_DEFINITION(FloatRegister, F5);
0N/AREGISTER_DEFINITION(FloatRegister, F6);
0N/AREGISTER_DEFINITION(FloatRegister, F7);
0N/AREGISTER_DEFINITION(FloatRegister, F8);
0N/AREGISTER_DEFINITION(FloatRegister, F9);
0N/AREGISTER_DEFINITION(FloatRegister, F10);
0N/AREGISTER_DEFINITION(FloatRegister, F11);
0N/AREGISTER_DEFINITION(FloatRegister, F12);
0N/AREGISTER_DEFINITION(FloatRegister, F13);
0N/AREGISTER_DEFINITION(FloatRegister, F14);
0N/AREGISTER_DEFINITION(FloatRegister, F15);
0N/AREGISTER_DEFINITION(FloatRegister, F16);
0N/AREGISTER_DEFINITION(FloatRegister, F17);
0N/AREGISTER_DEFINITION(FloatRegister, F18);
0N/AREGISTER_DEFINITION(FloatRegister, F19);
0N/AREGISTER_DEFINITION(FloatRegister, F20);
0N/AREGISTER_DEFINITION(FloatRegister, F21);
0N/AREGISTER_DEFINITION(FloatRegister, F22);
0N/AREGISTER_DEFINITION(FloatRegister, F23);
0N/AREGISTER_DEFINITION(FloatRegister, F24);
0N/AREGISTER_DEFINITION(FloatRegister, F25);
0N/AREGISTER_DEFINITION(FloatRegister, F26);
0N/AREGISTER_DEFINITION(FloatRegister, F27);
0N/AREGISTER_DEFINITION(FloatRegister, F28);
0N/AREGISTER_DEFINITION(FloatRegister, F29);
0N/AREGISTER_DEFINITION(FloatRegister, F30);
0N/AREGISTER_DEFINITION(FloatRegister, F31);
0N/AREGISTER_DEFINITION(FloatRegister, F32);
0N/AREGISTER_DEFINITION(FloatRegister, F34);
0N/AREGISTER_DEFINITION(FloatRegister, F36);
0N/AREGISTER_DEFINITION(FloatRegister, F38);
0N/AREGISTER_DEFINITION(FloatRegister, F40);
0N/AREGISTER_DEFINITION(FloatRegister, F42);
0N/AREGISTER_DEFINITION(FloatRegister, F44);
0N/AREGISTER_DEFINITION(FloatRegister, F46);
0N/AREGISTER_DEFINITION(FloatRegister, F48);
0N/AREGISTER_DEFINITION(FloatRegister, F50);
0N/AREGISTER_DEFINITION(FloatRegister, F52);
0N/AREGISTER_DEFINITION(FloatRegister, F54);
0N/AREGISTER_DEFINITION(FloatRegister, F56);
0N/AREGISTER_DEFINITION(FloatRegister, F58);
0N/AREGISTER_DEFINITION(FloatRegister, F60);
0N/AREGISTER_DEFINITION(FloatRegister, F62);
0N/A
0N/A
0N/AREGISTER_DEFINITION( Register, Otos_i);
0N/AREGISTER_DEFINITION( Register, Otos_l);
0N/AREGISTER_DEFINITION( Register, Otos_l1);
0N/AREGISTER_DEFINITION( Register, Otos_l2);
0N/AREGISTER_DEFINITION(FloatRegister, Ftos_f);
0N/AREGISTER_DEFINITION(FloatRegister, Ftos_d);
0N/AREGISTER_DEFINITION(FloatRegister, Ftos_d1);
0N/AREGISTER_DEFINITION(FloatRegister, Ftos_d2);
0N/A
0N/A
0N/AREGISTER_DEFINITION(Register, G2_thread);
113N/AREGISTER_DEFINITION(Register, G6_heapbase);
0N/AREGISTER_DEFINITION(Register, G5_method);
0N/AREGISTER_DEFINITION(Register, G5_megamorphic_method);
0N/AREGISTER_DEFINITION(Register, G5_inline_cache_reg);
0N/AREGISTER_DEFINITION(Register, Gargs);
0N/AREGISTER_DEFINITION(Register, L7_thread_cache);
0N/AREGISTER_DEFINITION(Register, Gframe_size);
0N/AREGISTER_DEFINITION(Register, G1_scratch);
0N/AREGISTER_DEFINITION(Register, G3_scratch);
0N/AREGISTER_DEFINITION(Register, G4_scratch);
0N/AREGISTER_DEFINITION(Register, Gtemp);
1484N/AREGISTER_DEFINITION(Register, Lentry_args);
1484N/A
1484N/A// JSR 292
710N/AREGISTER_DEFINITION(Register, G5_method_type);
710N/AREGISTER_DEFINITION(Register, G3_method_handle);
1484N/AREGISTER_DEFINITION(Register, L7_mh_SP_save);
0N/A
0N/A#ifdef CC_INTERP
0N/AREGISTER_DEFINITION(Register, Lstate);
0N/AREGISTER_DEFINITION(Register, L1_scratch);
0N/AREGISTER_DEFINITION(Register, Lmirror);
0N/AREGISTER_DEFINITION(Register, L2_scratch);
0N/AREGISTER_DEFINITION(Register, L3_scratch);
0N/AREGISTER_DEFINITION(Register, L4_scratch);
0N/AREGISTER_DEFINITION(Register, Lscratch);
0N/AREGISTER_DEFINITION(Register, Lscratch2);
0N/AREGISTER_DEFINITION(Register, L7_scratch);
0N/AREGISTER_DEFINITION(Register, I5_savedSP);
0N/A#else // CC_INTERP
0N/AREGISTER_DEFINITION(Register, Lesp);
0N/AREGISTER_DEFINITION(Register, Lbcp);
0N/AREGISTER_DEFINITION(Register, Lmonitors);
0N/AREGISTER_DEFINITION(Register, Lbyte_code);
0N/AREGISTER_DEFINITION(Register, Llast_SP);
0N/AREGISTER_DEFINITION(Register, Lscratch);
0N/AREGISTER_DEFINITION(Register, Lscratch2);
0N/AREGISTER_DEFINITION(Register, LcpoolCache);
0N/AREGISTER_DEFINITION(Register, I5_savedSP);
0N/AREGISTER_DEFINITION(Register, O5_savedSP);
0N/AREGISTER_DEFINITION(Register, IdispatchAddress);
0N/AREGISTER_DEFINITION(Register, ImethodDataPtr);
0N/AREGISTER_DEFINITION(Register, IdispatchTables);
0N/A#endif // CC_INTERP
0N/AREGISTER_DEFINITION(Register, Lmethod);
0N/AREGISTER_DEFINITION(Register, Llocals);
0N/AREGISTER_DEFINITION(Register, Oexception);
0N/AREGISTER_DEFINITION(Register, Oissuing_pc);