/* * Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, * CA 94065 USA or visit www.oracle.com if you need additional information or * have any questions. * */ package sun.jvm.hotspot.asm.sparc; import sun.jvm.hotspot.asm.*; public interface SPARCInstructionFactory { public SPARCInstruction newCallInstruction(PCRelativeAddress addr); public SPARCInstruction newNoopInstruction(); public SPARCInstruction newSethiInstruction(int imm22, SPARCRegister rd); public SPARCInstruction newUnimpInstruction(int const22); public SPARCInstruction newBranchInstruction(String name, PCRelativeAddress addr, boolean isAnnuled, int conditionCode); public SPARCInstruction newSpecialLoadInstruction(String name, int specialReg, int cregNum, SPARCRegisterIndirectAddress addr); public SPARCInstruction newSpecialStoreInstruction(String name, int specialReg, int cregNum, SPARCRegisterIndirectAddress addr); public SPARCInstruction newLoadInstruction(String name, int opcode, SPARCRegisterIndirectAddress addr, SPARCRegister rd, int dataType); public SPARCInstruction newStoreInstruction(String name, int opcode, SPARCRegisterIndirectAddress addr, SPARCRegister rd, int dataType); public SPARCInstruction newStbarInstruction(); public SPARCInstruction newReadInstruction(int specialReg, int asrRegNum, SPARCRegister rd); public SPARCInstruction newWriteInstruction(int specialReg, int asrRegNum, SPARCRegister rs1, ImmediateOrRegister operand2); public SPARCInstruction newIllegalInstruction(int instruction); public SPARCInstruction newIndirectCallInstruction(SPARCRegisterIndirectAddress addr, SPARCRegister rd); public SPARCInstruction newReturnInstruction(SPARCRegisterIndirectAddress addr, SPARCRegister rd, boolean isLeaf); public SPARCInstruction newJmplInstruction(SPARCRegisterIndirectAddress addr, SPARCRegister rd); public SPARCInstruction newFP2RegisterInstruction(String name, int opf, SPARCFloatRegister rs, SPARCFloatRegister rd); public SPARCInstruction newFPMoveInstruction(String name, int opf, SPARCFloatRegister rs, SPARCFloatRegister rd); public SPARCInstruction newFPArithmeticInstruction(String name, int opf, int rtlOperation, SPARCFloatRegister rs1, SPARCFloatRegister rs2, SPARCFloatRegister rd); public SPARCInstruction newFlushInstruction(SPARCRegisterIndirectAddress addr); public SPARCInstruction newSaveInstruction(SPARCRegister rs1, ImmediateOrRegister operand2, SPARCRegister rd); public SPARCInstruction newRestoreInstruction(SPARCRegister rs1, ImmediateOrRegister operand2, SPARCRegister rd); public SPARCInstruction newTrapInstruction(String name, int conditionCode); public SPARCInstruction newRettInstruction(SPARCRegisterIndirectAddress addr); public SPARCInstruction newArithmeticInstruction(String name, int opcode, int rtlOperation, SPARCRegister rs1, ImmediateOrRegister operand2, SPARCRegister rd); public SPARCInstruction newLogicInstruction(String name, int opcode, int rtlOperation, SPARCRegister rs1, ImmediateOrRegister operand2, SPARCRegister rd); public SPARCInstruction newMoveInstruction(String name, int opcode, ImmediateOrRegister operand2, SPARCRegister rd); public SPARCInstruction newShiftInstruction(String name, int opcode, int rtlOperation, SPARCRegister rs1, ImmediateOrRegister operand2, SPARCRegister rd); public SPARCInstruction newCoprocessorInstruction(int instruction, int cpopcode, int opc, int rs1Num, int rs2Num, int rdNum); public SPARCInstruction newSwapInstruction(String name, SPARCRegisterIndirectAddress addr, SPARCRegister rd); public SPARCInstruction newLdstubInstruction(String name, SPARCRegisterIndirectAddress addr, SPARCRegister rd); }