Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/runtime/compiler/arm/env/J9CPU.cpp
6004 views
1
/*******************************************************************************
2
* Copyright (c) 2018, 2020 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 "env/CompilerEnv.hpp"
24
#include "env/CPU.hpp"
25
26
bool
27
J9::ARM::CPU::isCompatible(const OMRProcessorDesc& processorDescription)
28
{
29
return self()->getProcessorDescription().processor == processorDescription.processor;
30
}
31
32
OMRProcessorDesc
33
J9::ARM::CPU::getProcessorDescription()
34
{
35
static bool initialized = false;
36
if (!initialized)
37
{
38
memset(_processorDescription.features, 0, OMRPORT_SYSINFO_FEATURES_SIZE*sizeof(uint32_t));
39
switch (self()->id())
40
{
41
case TR_DefaultARMProcessor:
42
_processorDescription.processor = OMR_PROCESSOR_ARM_UNKNOWN;
43
break;
44
case TR_ARMv6:
45
_processorDescription.processor = OMR_PROCESSOR_ARM_V6;
46
break;
47
case TR_ARMv7:
48
_processorDescription.processor = OMR_PROCESSOR_ARM_V7;
49
break;
50
default:
51
TR_ASSERT_FATAL(false, "Invalid ARM64 Processor ID");
52
}
53
_processorDescription.physicalProcessor = _processorDescription.processor;
54
initialized = true;
55
}
56
return _processorDescription;
57
}
58
59
60
61