Path: blob/master/runtime/compiler/p/codegen/J9UnresolvedDataSnippet.hpp
6004 views
/*******************************************************************************1* Copyright (c) 2000, 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 J9_PPCUNRESOLVEDDATASNIPPET_INCL23#define J9_PPCUNRESOLVEDDATASNIPPET_INCL2425/*26* The following #define and typedef must appear before any #includes in this file27*/28#ifndef J9_UNRESOLVEDDATASNIPPET_CONNECTOR29#define J9_UNRESOLVEDDATASNIPPET_CONNECTOR30namespace J9 { namespace Power { class UnresolvedDataSnippet; } }31namespace J9 { typedef J9::Power::UnresolvedDataSnippet UnresolvedDataSnippetConnector; }32#else33#error J9::Power::UnresolvedDataSnippet expected to be a primary connector, but a J9 connector is already defined34#endif3536#include "compiler/codegen/J9UnresolvedDataSnippet.hpp"3738#include <stdint.h>39#include "codegen/Snippet.hpp"40#include "il/SymbolReference.hpp"41#include "infra/Flags.hpp"4243namespace TR { class CodeGenerator; }44namespace TR { class MemoryReference; }45namespace TR { class Node; }46namespace TR { class RealRegister; }47namespace TR { class Symbol; }4849namespace J950{5152namespace Power53{5455class UnresolvedDataSnippet : public J9::UnresolvedDataSnippet56{5758TR::MemoryReference *_memoryReference;59TR::RealRegister *_dataRegister;6061public:6263UnresolvedDataSnippet(TR::CodeGenerator *, TR::Node *, TR::SymbolReference *s, bool isStore, bool canCauseGC);6465virtual Kind getKind() { return IsUnresolvedData; }6667TR::Symbol *getDataSymbol() {return getDataSymbolReference()->getSymbol();}6869TR::MemoryReference *getMemoryReference() {return _memoryReference;}70TR::MemoryReference *setMemoryReference(TR::MemoryReference *mr)71{return (_memoryReference = mr);}7273TR::RealRegister *getDataRegister() {return _dataRegister;}74void setDataRegister(TR::RealRegister *r) {_dataRegister = r;}7576bool isSpecialDouble() {return _flags.testAll(TO_MASK32(IsSpecialDouble));}77void setIsSpecialDouble() {_flags.set(TO_MASK32(IsSpecialDouble));}78void resetIsSpecialDouble() {_flags.reset(TO_MASK32(IsSpecialDouble));}7980bool inSyncSequence() {return _flags.testAll(TO_MASK32(InSyncSequence));}81void setInSyncSequence() {_flags.set(TO_MASK32(InSyncSequence));}82void resetInSyncSequence() {_flags.reset(TO_MASK32(InSyncSequence));}8384bool is32BitLong() {return _flags.testAll(TO_MASK32(Is32BitLong));}85void setIs32BitLong() {_flags.set(TO_MASK32(Is32BitLong));}86void resetIs32BitLong() {_flags.reset(TO_MASK32(Is32BitLong));}8788uint8_t *getAddressOfDataReference();8990virtual uint8_t *emitSnippetBody();9192virtual uint32_t getLength(int32_t estimatedSnippetStart);939495protected:9697enum98{99IsSpecialDouble = J9::UnresolvedDataSnippet::NextSnippetFlag,100InSyncSequence,101Is32BitLong,102NextSnippetFlag103};104105static_assert((int32_t)NextSnippetFlag <= (int32_t)J9::UnresolvedDataSnippet::MaxSnippetFlag,106"TR::UnresolvedDataSnippet too many flag bits for flag width");107108};109110}111112}113114#endif115116117