Path: blob/master/runtime/compiler/codegen/PrivateLinkage.cpp
6000 views
/*******************************************************************************1* Copyright (c) 2020, 2021 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#include "codegen/PrivateLinkage.hpp"2324#include "codegen/CodeGenerator.hpp"25#include "codegen/Linkage_inlines.hpp"26#include "compile/ResolvedMethod.hpp"27#include "env/CompilerEnv.hpp"28#include "env/jittypes.h"29#include "il/ParameterSymbol.hpp"3031intptr_t32J9::PrivateLinkage::entryPointFromCompiledMethod()33{34uint8_t *methodEntry = cg()->getCodeStart();35methodEntry += J9::PrivateLinkage::LinkageInfo::get(methodEntry)->getReservedWord();36return reinterpret_cast<intptr_t>(methodEntry);37}3839intptr_t40J9::PrivateLinkage::entryPointFromInterpretedMethod()41{42return reinterpret_cast<intptr_t>(cg()->getCodeStart());43}4445void46J9::PrivateLinkage::mapIncomingParms(TR::ResolvedMethodSymbol *method)47{48int32_t offsetToFirstArg = method->getNumParameterSlots() * TR::Compiler->om.sizeofReferenceAddress() + getOffsetToFirstParm();4950const bool is64Bit = cg()->comp()->target().is64Bit();51ListIterator<TR::ParameterSymbol> paramIterator(&method->getParameterList());52for (TR::ParameterSymbol* paramCursor = paramIterator.getFirst(); paramCursor != NULL; paramCursor = paramIterator.getNext())53{54// This is a slightly convoluted way of enforcing the JVM specification which states that long and double55// variables take up two stack slots. A stack slot in OpenJ9 is a `uintptr_t`, so on 64-bit int variables56// are still placed in 64-bit stack slots, hence the need to check for 64-bit in the query below. For more57// details please see eclipse-openj9/openj9#8360.58int32_t slotMultiplier = is64Bit && paramCursor->getDataType() != TR::Address ? 2 : 1;5960paramCursor->setParameterOffset(offsetToFirstArg -61paramCursor->getParameterOffset() -62paramCursor->getSize() * slotMultiplier);63}64}656667