Path: blob/master/runtime/compiler/aarch64/codegen/Instruction.hpp
6004 views
/*******************************************************************************1* Copyright (c) 2019, 2020 IBM Corp. and others2*3* This program and the accompanying materials are made available under4* the terms of the Eclipse Public License 2.0 which accompanies this5* distribution and is available at https://www.eclipse.org/legal/epl-2.0/6* or the Apache License, Version 2.0 which accompanies this distribution and7* is available at https://www.apache.org/licenses/LICENSE-2.0.8*9* This Source Code may also be made available under the following10* Secondary Licenses when the conditions for such availability set11* forth in the Eclipse Public License, v. 2.0 are satisfied: GNU12* General Public License, version 2 with the GNU Classpath13* Exception [1] and GNU General Public License, version 2 with the14* OpenJDK Assembly Exception [2].15*16* [1] https://www.gnu.org/software/classpath/license.html17* [2] http://openjdk.java.net/legal/assembly-exception.html18*19* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 OR LicenseRef-GPL-2.0 WITH Assembly-exception20*******************************************************************************/2122#ifndef TRJ9_INSTRUCTION_INCL23#define TRJ9_INSTRUCTION_INCL2425#include "codegen/J9Instruction.hpp"26#include "codegen/RegisterDependency.hpp"2728namespace TR29{30class Instruction;3132class OMR_EXTENSIBLE Instruction : public J9::InstructionConnector33{34public:3536/**37* @brief Constructor38* @param[in] op : opcode39* @param[in] node : node40* @param[in] precedingInstruction : preceding instruction41* @param[in] cg : CodeGenerator42*/43Instruction(TR::InstOpCode::Mnemonic op, TR::Node *node, TR::Instruction *precedingInstruction,44TR::CodeGenerator *cg)45: J9::InstructionConnector(cg, precedingInstruction, op, node)46{47}4849/**50* @brief Constructor51* @param[in] op : opcode52* @param[in] node : node53* @param[in] cg : CodeGenerator54*/55Instruction(TR::InstOpCode::Mnemonic op, TR::Node *node, TR::CodeGenerator *cg)56: J9::InstructionConnector(cg, op, node)57{58}5960/**61* @brief Constructor62* @param[in] op : opcode63* @param[in] node : node64* @param[in] cond : register dependency conditions65* @param[in] precedingInstruction : preceding instruction66* @param[in] cg : CodeGenerator67*/68Instruction(TR::InstOpCode::Mnemonic op, TR::Node *node, TR::RegisterDependencyConditions *cond,69TR::Instruction *precedingInstruction, TR::CodeGenerator *cg)70: J9::InstructionConnector(cg, precedingInstruction, op, node)71{72self()->setDependencyConditions(cond);73if (cond)74cond->bookKeepingRegisterUses(self(), cg);75}7677/**78* @brief Constructor79* @param[in] op : opcode80* @param[in] node : node81* @param[in] cond : register dependency conditions82* @param[in] cg : CodeGenerator83*/84Instruction(TR::InstOpCode::Mnemonic op, TR::Node *node, TR::RegisterDependencyConditions *cond,85TR::CodeGenerator *cg)86: J9::InstructionConnector(cg, op, node)87{88self()->setDependencyConditions(cond);89if (cond)90cond->bookKeepingRegisterUses(self(), cg);91}9293};9495} // TR9697#include "codegen/J9Instruction_inlines.hpp"9899/**100* @brief Type cast for instruction cursor101* @param[in] i : instruction cursor102* @return instruction cursor103*/104inline uint32_t *toARM64Cursor(uint8_t *i) { return (uint32_t *)i; }105106#endif107108109