Path: blob/master/runtime/compiler/x/env/J9CPU.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_X86_CPU_INCL23#define J9_X86_CPU_INCL2425/*26* The following #define and typedef must appear before any #includes in this file27*/28#ifndef J9_CPU_CONNECTOR29#define J9_CPU_CONNECTOR30namespace J9 { namespace X86 { class CPU; } }31namespace J9 { typedef J9::X86::CPU CPUConnector; }32#else33#error J9::X86::CPU expected to be a primary connector, but a J9 connector is already defined34#endif3536#include "compiler/env/J9CPU.hpp"37#include "env/ProcessorInfo.hpp"3839namespace J940{4142namespace X8643{4445class OMR_EXTENSIBLE CPU : public J9::CPU46{47protected:4849CPU() : J9::CPU() {}50CPU(const OMRProcessorDesc& processorDescription) : J9::CPU(processorDescription) {}5152public:5354/**55* @brief A factory method used to construct a CPU object for portable AOT compilations56* @param[in] omrPortLib : the port library57* @return TR::CPU58*/59static TR::CPU detectRelocatable(OMRPortLibrary * const omrPortLib);6061/**62* @brief Intialize _supportedFeatureMasks to the list of processor features that will be exploited by the compiler and set _isSupportedFeatureMasksEnabled to true63* @return void64*/65static void enableFeatureMasks();6667bool is(OMRProcessorArchitecture p);68bool supportsFeature(uint32_t feature);6970TR_X86CPUIDBuffer *queryX86TargetCPUID();71const char * getProcessorVendorId();72uint32_t getProcessorSignature();7374bool testOSForSSESupport() { return true; } // VM guarantees SSE/SSE2 are available75bool hasPopulationCountInstruction();7677bool isCompatible(const OMRProcessorDesc& processorDescription);7879uint32_t getX86ProcessorFeatureFlags();80uint32_t getX86ProcessorFeatureFlags2();81uint32_t getX86ProcessorFeatureFlags8();8283bool is_test(OMRProcessorArchitecture p);84bool supports_feature_test(uint32_t feature);85};8687}8889}9091#endif929394