/* * Copyright (C) 2018 Intel Corporation * * SPDX-License-Identifier: MIT * */ #pragma once #include "gtsysinfo.h" #include "igfxfmid.h" #include "sku_info.h" #include "runtime/helpers/engine_node.h" #include "runtime/helpers/kmd_notify_properties.h" #include namespace OCLRT { enum class PreemptionMode : uint32_t { // Keep in sync with ForcePreemptionMode debug variable Initial = 0, Disabled = 1, MidBatch, ThreadGroup, MidThread, }; struct WhitelistedRegisters { bool csChicken1_0x2580; bool chicken0hdc_0xE5F0; }; struct RuntimeCapabilityTable { uint32_t maxRenderFrequency; double defaultProfilingTimerResolution; unsigned int clVersionSupport; bool ftrSupportsFP64; bool ftrSupports64BitMath; bool ftrSvm; bool ftrSupportsCoherency; bool ftrSupportsVmeAvcTextureSampler; bool ftrSupportsVmeAvcPreemption; bool ftrRenderCompressedBuffers; bool ftrRenderCompressedImages; PreemptionMode defaultPreemptionMode; WhitelistedRegisters whitelistedRegisters; bool (*isSimulation)(unsigned short); bool instrumentationEnabled; bool forceStatelessCompilationFor32Bit; KmdNotifyProperties kmdNotifyProperties; bool ftr64KBpages; EngineType defaultEngineType; size_t requiredPreemptionSurfaceSize; bool isCore; bool sourceLevelDebuggerSupported; uint32_t aubDeviceId; uint32_t extraQuantityThreadsPerEU; uint64_t gpuAddressSpace; }; struct HardwareCapabilities { size_t image3DMaxWidth; size_t image3DMaxHeight; uint64_t maxMemAllocSize; bool isStatelesToStatefullWithOffsetSupported; bool localMemorySupported; }; struct HardwareInfo { HardwareInfo() = default; HardwareInfo(const PLATFORM *platform, const FeatureTable *skuTable, const WorkaroundTable *waTable, const GT_SYSTEM_INFO *sysInfo, const RuntimeCapabilityTable &capabilityTable); const PLATFORM *pPlatform = nullptr; const FeatureTable *pSkuTable = nullptr; const WorkaroundTable *pWaTable = nullptr; const GT_SYSTEM_INFO *pSysInfo = nullptr; RuntimeCapabilityTable capabilityTable = {}; }; extern const WorkaroundTable emptyWaTable; extern const FeatureTable emptySkuTable; template struct HwMapper {}; template struct GfxFamilyMapper {}; // Global table of hardware prefixes extern bool familyEnabled[IGFX_MAX_CORE]; extern const char *familyName[IGFX_MAX_CORE]; extern const char *hardwarePrefix[]; extern const HardwareInfo *hardwareInfoTable[IGFX_MAX_PRODUCT]; extern void (*hardwareInfoSetup[IGFX_MAX_PRODUCT])(GT_SYSTEM_INFO *gtSystemInfo, FeatureTable *featureTable, bool setupFeatureTable); template struct EnableGfxFamilyHw { EnableGfxFamilyHw() { familyEnabled[gfxFamily] = true; familyName[gfxFamily] = GfxFamilyMapper::name; } }; const char *getPlatformType(const HardwareInfo &hwInfo); bool getHwInfoForPlatformString(const char *str, const HardwareInfo *&hwInfoIn); EngineType getChosenEngineType(const HardwareInfo &hwInfo); } // namespace OCLRT