Path: blob/master/runtime/compiler/p/codegen/J9CodeGenerator.hpp
6004 views
/*******************************************************************************1* Copyright (c) 2000, 2022 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 J9_POWER_CODEGENERATOR_INCL23#define J9_POWER_CODEGENERATOR_INCL2425/*26* The following #define and typedef must appear before any #includes in this file27*/28#ifndef J9_CODEGENERATOR_CONNECTOR29#define J9_CODEGENERATOR_CONNECTOR30namespace J9 { namespace Power { class CodeGenerator; } }31namespace J9 { typedef J9::Power::CodeGenerator CodeGeneratorConnector; }32#else33#error J9::Power::CodeGenerator expected to be a primary connector, but a J9 connector is already defined34#endif3536#include "j9cfg.h"37#include "compiler/codegen/J9CodeGenerator.hpp"3839#include <stdint.h>40#include "codegen/LinkageConventionsEnum.hpp"41#include "env/jittypes.h"4243namespace TR { class Recompilation; }4445extern TR::Instruction *loadAddressRAM32(TR::CodeGenerator *cg,46TR::Node * node,47int32_t value,48TR::Register *trgReg);4950extern TR::Instruction *loadAddressRAM(TR::CodeGenerator *cg,51TR::Node *node,52intptr_t value,53TR::Register *targetRegister);5455extern TR::Instruction *loadAddressJNI32(TR::CodeGenerator *cg,56TR::Node * node,57int32_t value,58TR::Register *trgReg);5960extern TR::Instruction *loadAddressJNI(TR::CodeGenerator *cg,61TR::Node *node,62intptr_t value,63TR::Register *targetRegister);6465namespace J966{6768namespace Power69{7071class OMR_EXTENSIBLE CodeGenerator : public J9::CodeGenerator72{7374protected:7576CodeGenerator(TR::Compilation *comp);7778public:7980void initialize();8182TR::Recompilation *allocateRecompilationInfo();8384TR::Linkage *createLinkage(TR_LinkageConventions lc);8586void generateBinaryEncodingPrologue(TR_PPCBinaryEncodingData *data);8788void lowerTreeIfNeeded(TR::Node *node, int32_t childNumber, TR::Node *parent, TR::TreeTop *tt);8990bool inlineDirectCall(TR::Node *node, TR::Register *&resultReg);9192TR::Linkage *deriveCallingLinkage(TR::Node *node, bool isIndirect);9394bool suppressInliningOfRecognizedMethod(TR::RecognizedMethod method);9596bool enableAESInHardwareTransformations();9798void insertPrefetchIfNecessary(TR::Node *node, TR::Register *targetRegister);99100int32_t getInternalPtrMapBit() { return 18;}101102bool canEmitDataForExternallyRelocatableInstructions();103104#ifdef J9VM_OPT_JAVA_CRYPTO_ACCELERATION105bool suppressInliningOfCryptoMethod(TR::RecognizedMethod method);106bool inlineCryptoMethod(TR::Node *node, TR::Register *&resultReg);107#endif108109/**110* \brief Determines whether the code generator supports stack allocations111*/112bool supportsStackAllocations() { return true; }113114// See J9::CodeGenerator::guaranteesResolvedDirectDispatchForSVM115bool guaranteesResolvedDirectDispatchForSVM() { return true; }116};117118}119120}121122#endif123124125