Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/runtime/compiler/codegen/PrivateLinkage.cpp
6000 views
1
/*******************************************************************************
2
* Copyright (c) 2020, 2021 IBM Corp. and others
3
*
4
* This program and the accompanying materials are made available under
5
* the terms of the Eclipse Public License 2.0 which accompanies this
6
* distribution and is available at https://www.eclipse.org/legal/epl-2.0/
7
* or the Apache License, Version 2.0 which accompanies this distribution and
8
* is available at https://www.apache.org/licenses/LICENSE-2.0.
9
*
10
* This Source Code may also be made available under the following
11
* Secondary Licenses when the conditions for such availability set
12
* forth in the Eclipse Public License, v. 2.0 are satisfied: GNU
13
* General Public License, version 2 with the GNU Classpath
14
* Exception [1] and GNU General Public License, version 2 with the
15
* OpenJDK Assembly Exception [2].
16
*
17
* [1] https://www.gnu.org/software/classpath/license.html
18
* [2] http://openjdk.java.net/legal/assembly-exception.html
19
*
20
* 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-exception
21
*******************************************************************************/
22
23
#include "codegen/PrivateLinkage.hpp"
24
25
#include "codegen/CodeGenerator.hpp"
26
#include "codegen/Linkage_inlines.hpp"
27
#include "compile/ResolvedMethod.hpp"
28
#include "env/CompilerEnv.hpp"
29
#include "env/jittypes.h"
30
#include "il/ParameterSymbol.hpp"
31
32
intptr_t
33
J9::PrivateLinkage::entryPointFromCompiledMethod()
34
{
35
uint8_t *methodEntry = cg()->getCodeStart();
36
methodEntry += J9::PrivateLinkage::LinkageInfo::get(methodEntry)->getReservedWord();
37
return reinterpret_cast<intptr_t>(methodEntry);
38
}
39
40
intptr_t
41
J9::PrivateLinkage::entryPointFromInterpretedMethod()
42
{
43
return reinterpret_cast<intptr_t>(cg()->getCodeStart());
44
}
45
46
void
47
J9::PrivateLinkage::mapIncomingParms(TR::ResolvedMethodSymbol *method)
48
{
49
int32_t offsetToFirstArg = method->getNumParameterSlots() * TR::Compiler->om.sizeofReferenceAddress() + getOffsetToFirstParm();
50
51
const bool is64Bit = cg()->comp()->target().is64Bit();
52
ListIterator<TR::ParameterSymbol> paramIterator(&method->getParameterList());
53
for (TR::ParameterSymbol* paramCursor = paramIterator.getFirst(); paramCursor != NULL; paramCursor = paramIterator.getNext())
54
{
55
// This is a slightly convoluted way of enforcing the JVM specification which states that long and double
56
// variables take up two stack slots. A stack slot in OpenJ9 is a `uintptr_t`, so on 64-bit int variables
57
// are still placed in 64-bit stack slots, hence the need to check for 64-bit in the query below. For more
58
// details please see eclipse-openj9/openj9#8360.
59
int32_t slotMultiplier = is64Bit && paramCursor->getDataType() != TR::Address ? 2 : 1;
60
61
paramCursor->setParameterOffset(offsetToFirstArg -
62
paramCursor->getParameterOffset() -
63
paramCursor->getSize() * slotMultiplier);
64
}
65
}
66
67