Path: blob/master/runtime/compiler/p/env/J9CPU.cpp
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#include "compile/Compilation.hpp"23#include "env/CompilerEnv.hpp"24#include "env/CPU.hpp"25#include "j9.h"26#include "j9port.h"2728TR::CPU29J9::Power::CPU::detectRelocatable(OMRPortLibrary * const omrPortLib)30{31if (omrPortLib == NULL)32return TR::CPU();3334OMRPORT_ACCESS_FROM_OMRPORT(omrPortLib);35OMRProcessorDesc portableProcessorDescription;36omrsysinfo_get_processor_description(&portableProcessorDescription);3738if (portableProcessorDescription.processor > OMR_PROCESSOR_PPC_P8)39{40portableProcessorDescription.processor = OMR_PROCESSOR_PPC_P8;41portableProcessorDescription.physicalProcessor = OMR_PROCESSOR_PPC_P8;42}4344return TR::CPU::customize(portableProcessorDescription);45}4647bool48J9::Power::CPU::isCompatible(const OMRProcessorDesc& processorDescription)49{50const OMRProcessorArchitecture& targetProcessor = self()->getProcessorDescription().processor;51const OMRProcessorArchitecture& processor = processorDescription.processor;5253for (int i = 0; i < OMRPORT_SYSINFO_FEATURES_SIZE; i++)54{55if ((processorDescription.features[i] & self()->getProcessorDescription().features[i]) != processorDescription.features[i])56return false;57}5859// Backwards compatibility only applies to p4,p5,p6,p7 and onwards60// Looks for equality otherwise61if ((processor == OMR_PROCESSOR_PPC_GP62|| processor == OMR_PROCESSOR_PPC_GR63|| processor == OMR_PROCESSOR_PPC_P664|| (processor >= OMR_PROCESSOR_PPC_P7 && processor <= OMR_PROCESSOR_PPC_LAST))65&& (targetProcessor == OMR_PROCESSOR_PPC_GP66|| targetProcessor == OMR_PROCESSOR_PPC_GR67|| targetProcessor == OMR_PROCESSOR_PPC_P668|| targetProcessor >= OMR_PROCESSOR_PPC_P7 && targetProcessor <= OMR_PROCESSOR_PPC_LAST))69{70return targetProcessor >= processor;71}72return targetProcessor == processor;73}7475void76J9::Power::CPU::enableFeatureMasks()77{78// Only enable the features that compiler currently uses79const uint32_t utilizedFeatures [] = {OMR_FEATURE_PPC_HAS_ALTIVEC, OMR_FEATURE_PPC_HAS_DFP,80OMR_FEATURE_PPC_HTM, OMR_FEATURE_PPC_HAS_VSX};818283memset(_supportedFeatureMasks.features, 0, OMRPORT_SYSINFO_FEATURES_SIZE*sizeof(uint32_t));84OMRPORT_ACCESS_FROM_OMRPORT(TR::Compiler->omrPortLib);85for (size_t i = 0; i < sizeof(utilizedFeatures)/sizeof(uint32_t); i++)86{87omrsysinfo_processor_set_feature(&_supportedFeatureMasks, utilizedFeatures[i], TRUE);88}8990_isSupportedFeatureMasksEnabled = true;91}929394