2017-12-21 00:45:38 +01:00
|
|
|
/*
|
2021-12-20 12:58:34 +00:00
|
|
|
* Copyright (C) 2018-2022 Intel Corporation
|
2017-12-21 00:45:38 +01:00
|
|
|
*
|
2018-09-18 09:11:08 +02:00
|
|
|
* SPDX-License-Identifier: MIT
|
2017-12-21 00:45:38 +01:00
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
2020-02-23 22:44:01 +01:00
|
|
|
#include "shared/source/helpers/hw_info.h"
|
2021-09-09 12:27:41 +00:00
|
|
|
#include "shared/source/helpers/local_memory_access_modes.h"
|
2020-02-23 22:44:01 +01:00
|
|
|
#include "shared/source/unified_memory/usm_memory_support.h"
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2019-02-27 11:39:32 +01:00
|
|
|
#include "igfxfmid.h"
|
2022-03-10 17:27:38 +00:00
|
|
|
#include "platforms.h"
|
2019-02-27 11:39:32 +01:00
|
|
|
|
2019-03-26 11:59:46 +01:00
|
|
|
namespace NEO {
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
|
struct HardwareInfo;
|
2021-07-06 13:29:10 +00:00
|
|
|
struct StateComputeModeProperties;
|
2021-08-31 15:48:56 +00:00
|
|
|
struct PipelineSelectArgs;
|
2017-12-21 00:45:38 +01:00
|
|
|
class OSInterface;
|
|
|
|
|
class HwInfoConfig;
|
2022-01-05 15:24:16 +01:00
|
|
|
enum class DriverModelType;
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
|
extern HwInfoConfig *hwInfoConfigFactory[IGFX_MAX_PRODUCT];
|
|
|
|
|
|
|
|
|
|
class HwInfoConfig {
|
|
|
|
|
public:
|
|
|
|
|
static HwInfoConfig *get(PRODUCT_FAMILY product) {
|
|
|
|
|
return hwInfoConfigFactory[product];
|
|
|
|
|
}
|
2021-11-26 09:40:06 +00:00
|
|
|
static constexpr uint32_t uuidSize = 16u;
|
2021-05-24 21:06:15 +02:00
|
|
|
int configureHwInfoWddm(const HardwareInfo *inHwInfo, HardwareInfo *outHwInfo, OSInterface *osIface);
|
|
|
|
|
int configureHwInfoDrm(const HardwareInfo *inHwInfo, HardwareInfo *outHwInfo, OSInterface *osIface);
|
2017-12-21 00:45:38 +01:00
|
|
|
virtual int configureHardwareCustom(HardwareInfo *hwInfo, OSInterface *osIface) = 0;
|
2020-11-20 10:45:15 +01:00
|
|
|
virtual void adjustPlatformForProductFamily(HardwareInfo *hwInfo) = 0;
|
2021-04-06 12:35:03 +00:00
|
|
|
virtual void adjustSamplerState(void *sampler, const HardwareInfo &hwInfo) = 0;
|
2020-05-19 12:46:31 +02:00
|
|
|
virtual uint64_t getHostMemCapabilities(const HardwareInfo *hwInfo) = 0;
|
2020-01-31 10:05:51 +01:00
|
|
|
virtual uint64_t getDeviceMemCapabilities() = 0;
|
|
|
|
|
virtual uint64_t getSingleDeviceSharedMemCapabilities() = 0;
|
|
|
|
|
virtual uint64_t getCrossDeviceSharedMemCapabilities() = 0;
|
2021-12-01 15:14:07 +00:00
|
|
|
virtual uint64_t getSharedSystemMemCapabilities(const HardwareInfo *hwInfo) = 0;
|
2021-03-26 09:57:36 +00:00
|
|
|
virtual void getKernelExtendedProperties(uint32_t *fp16, uint32_t *fp32, uint32_t *fp64) = 0;
|
2022-03-07 17:00:26 +00:00
|
|
|
virtual std::vector<int32_t> getKernelSupportedThreadArbitrationPolicies() = 0;
|
2021-01-26 14:31:39 +00:00
|
|
|
virtual void convertTimestampsFromOaToCsDomain(uint64_t ×tampData) = 0;
|
2021-04-19 11:31:20 +00:00
|
|
|
virtual uint32_t getDeviceMemoryMaxClkRate(const HardwareInfo *hwInfo) = 0;
|
2021-06-23 13:34:56 +00:00
|
|
|
virtual bool isAdditionalStateBaseAddressWARequired(const HardwareInfo &hwInfo) const = 0;
|
2021-07-06 10:14:23 +00:00
|
|
|
virtual bool isMaxThreadsForWorkgroupWARequired(const HardwareInfo &hwInfo) const = 0;
|
|
|
|
|
virtual uint32_t getMaxThreadsForWorkgroupInDSSOrSS(const HardwareInfo &hwInfo, uint32_t maxNumEUsPerSubSlice, uint32_t maxNumEUsPerDualSubSlice) const = 0;
|
|
|
|
|
virtual uint32_t getMaxThreadsForWorkgroup(const HardwareInfo &hwInfo, uint32_t maxNumEUsPerSubSlice) const = 0;
|
2021-07-06 13:29:10 +00:00
|
|
|
virtual void setForceNonCoherent(void *const commandPtr, const StateComputeModeProperties &properties) = 0;
|
2021-08-17 12:00:35 +00:00
|
|
|
virtual bool obtainBlitterPreference(const HardwareInfo &hwInfo) const = 0;
|
2021-10-27 20:22:31 +00:00
|
|
|
virtual bool isBlitterFullySupported(const HardwareInfo &hwInfo) const = 0;
|
2021-08-19 11:06:49 +00:00
|
|
|
virtual bool isPageTableManagerSupported(const HardwareInfo &hwInfo) const = 0;
|
2022-03-10 17:27:38 +00:00
|
|
|
virtual PRODUCT_CONFIG getProductConfigFromHwInfo(const HardwareInfo &hwInfo) const = 0;
|
2021-08-20 15:41:43 +00:00
|
|
|
virtual uint32_t getHwRevIdFromStepping(uint32_t stepping, const HardwareInfo &hwInfo) const = 0;
|
2021-08-27 13:30:39 +00:00
|
|
|
virtual uint32_t getSteppingFromHwRevId(const HardwareInfo &hwInfo) const = 0;
|
|
|
|
|
virtual uint32_t getAubStreamSteppingFromHwRevId(const HardwareInfo &hwInfo) const = 0;
|
2021-08-31 15:48:56 +00:00
|
|
|
virtual void setAdditionalPipelineSelectFields(void *pipelineSelectCmd, const PipelineSelectArgs &pipelineSelectArgs, const HardwareInfo &hwInfo) = 0;
|
2021-09-02 11:11:39 +00:00
|
|
|
virtual bool isDefaultEngineTypeAdjustmentRequired(const HardwareInfo &hwInfo) const = 0;
|
2021-11-30 12:43:06 +00:00
|
|
|
virtual bool overrideGfxPartitionLayoutForWsl() const = 0;
|
2021-08-31 15:17:18 +00:00
|
|
|
virtual std::string getDeviceMemoryName() const = 0;
|
2021-09-06 10:34:34 +00:00
|
|
|
virtual bool isDisableOverdispatchAvailable(const HardwareInfo &hwInfo) const = 0;
|
2021-12-03 13:52:16 +00:00
|
|
|
virtual bool allowCompression(const HardwareInfo &hwInfo) const = 0;
|
2021-09-08 15:07:46 +00:00
|
|
|
virtual bool allowStatelessCompression(const HardwareInfo &hwInfo) const = 0;
|
2021-09-09 12:27:41 +00:00
|
|
|
virtual LocalMemoryAccessMode getLocalMemoryAccessMode(const HardwareInfo &hwInfo) const = 0;
|
2021-09-14 14:57:43 +00:00
|
|
|
virtual bool isAllocationSizeAdjustmentRequired(const HardwareInfo &hwInfo) const = 0;
|
2021-09-15 09:53:12 +00:00
|
|
|
virtual bool isPrefetchDisablingRequired(const HardwareInfo &hwInfo) const = 0;
|
2021-09-20 12:05:09 +00:00
|
|
|
virtual bool isNewResidencyModelSupported() const = 0;
|
2021-11-22 12:49:26 +00:00
|
|
|
virtual bool isDirectSubmissionSupported(const HardwareInfo &hwInfo) const = 0;
|
2022-02-04 15:43:17 +00:00
|
|
|
virtual std::pair<bool, bool> isPipeControlPriorToNonPipelinedStateCommandsWARequired(const HardwareInfo &hwInfo, bool isRcs) const = 0;
|
2021-09-21 13:34:25 +00:00
|
|
|
virtual bool heapInLocalMem(const HardwareInfo &hwInfo) const = 0;
|
2021-09-22 14:39:01 +00:00
|
|
|
virtual void setCapabilityCoherencyFlag(const HardwareInfo &hwInfo, bool &coherencyFlag) = 0;
|
2021-09-23 15:08:41 +00:00
|
|
|
virtual bool isAdditionalMediaSamplerProgrammingRequired() const = 0;
|
|
|
|
|
virtual bool isInitialFlagsProgrammingRequired() const = 0;
|
|
|
|
|
virtual bool isReturnedCmdSizeForMediaSamplerAdjustmentRequired() const = 0;
|
2021-09-23 17:46:36 +00:00
|
|
|
virtual bool extraParametersInvalid(const HardwareInfo &hwInfo) const = 0;
|
2021-09-24 14:29:49 +00:00
|
|
|
virtual bool pipeControlWARequired(const HardwareInfo &hwInfo) const = 0;
|
|
|
|
|
virtual bool imagePitchAlignmentWARequired(const HardwareInfo &hwInfo) const = 0;
|
|
|
|
|
virtual bool isForceEmuInt32DivRemSPWARequired(const HardwareInfo &hwInfo) const = 0;
|
|
|
|
|
virtual bool is3DPipelineSelectWARequired() const = 0;
|
2021-09-28 10:54:52 +00:00
|
|
|
virtual bool isStorageInfoAdjustmentRequired() const = 0;
|
2021-10-13 13:30:45 +00:00
|
|
|
virtual bool isBlitterForImagesSupported() const = 0;
|
2021-10-15 15:24:03 +00:00
|
|
|
virtual bool isTile64With3DSurfaceOnBCSSupported(const HardwareInfo &hwInfo) const = 0;
|
2021-12-20 14:37:33 +00:00
|
|
|
virtual bool isDcFlushAllowed() const = 0;
|
2021-11-30 10:19:27 +00:00
|
|
|
virtual uint32_t computeMaxNeededSubSliceSpace(const HardwareInfo &hwInfo) const = 0;
|
2021-11-26 09:40:06 +00:00
|
|
|
virtual bool getUuid(Device *device, std::array<uint8_t, HwInfoConfig::uuidSize> &uuid) const = 0;
|
2022-02-17 21:44:55 +00:00
|
|
|
virtual bool isFlushTaskAllowed() const = 0;
|
2022-03-07 14:31:53 +00:00
|
|
|
virtual bool programAllStateComputeCommandFields() const = 0;
|
2022-03-09 15:39:57 +00:00
|
|
|
virtual bool isSpecialPipelineSelectModeChanged(const HardwareInfo &hwInfo) const = 0;
|
|
|
|
|
virtual bool isSystolicModeConfigurable(const HardwareInfo &hwInfo) const = 0;
|
2022-03-24 08:59:17 +00:00
|
|
|
virtual bool isGlobalFenceInCommandStreamRequired(const HardwareInfo &hwInfo) const = 0;
|
2022-03-09 15:39:57 +00:00
|
|
|
virtual bool isComputeDispatchAllWalkerEnableInComputeWalkerRequired(const HardwareInfo &hwInfo) const = 0;
|
|
|
|
|
virtual bool isAdjustProgrammableIdPreferredSlmSizeRequired(const HardwareInfo &hwInfo) const = 0;
|
2022-03-21 17:44:02 +00:00
|
|
|
virtual uint32_t getThreadEuRatioForScratch(const HardwareInfo &hwInfo) const = 0;
|
2022-03-09 15:39:57 +00:00
|
|
|
virtual bool isComputeDispatchAllWalkerEnableInCfeStateRequired(const HardwareInfo &hwInfo) const = 0;
|
|
|
|
|
|
2021-12-20 12:58:34 +00:00
|
|
|
MOCKABLE_VIRTUAL ~HwInfoConfig() = default;
|
2021-08-17 12:00:35 +00:00
|
|
|
|
2021-09-09 12:27:41 +00:00
|
|
|
protected:
|
|
|
|
|
virtual LocalMemoryAccessMode getDefaultLocalMemoryAccessMode(const HardwareInfo &hwInfo) const = 0;
|
|
|
|
|
|
|
|
|
|
public:
|
2022-01-12 15:32:07 +00:00
|
|
|
uint32_t threadsPerEu = 0u;
|
2017-12-21 00:45:38 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
template <PRODUCT_FAMILY gfxProduct>
|
|
|
|
|
class HwInfoConfigHw : public HwInfoConfig {
|
|
|
|
|
public:
|
|
|
|
|
static HwInfoConfig *get() {
|
|
|
|
|
static HwInfoConfigHw<gfxProduct> instance;
|
|
|
|
|
return &instance;
|
|
|
|
|
}
|
|
|
|
|
int configureHardwareCustom(HardwareInfo *hwInfo, OSInterface *osIface) override;
|
2020-11-20 10:45:15 +01:00
|
|
|
void adjustPlatformForProductFamily(HardwareInfo *hwInfo) override;
|
2021-04-06 12:35:03 +00:00
|
|
|
void adjustSamplerState(void *sampler, const HardwareInfo &hwInfo) override;
|
2020-05-19 12:46:31 +02:00
|
|
|
uint64_t getHostMemCapabilities(const HardwareInfo *hwInfo) override;
|
2020-01-31 10:05:51 +01:00
|
|
|
uint64_t getDeviceMemCapabilities() override;
|
|
|
|
|
uint64_t getSingleDeviceSharedMemCapabilities() override;
|
|
|
|
|
uint64_t getCrossDeviceSharedMemCapabilities() override;
|
2021-12-01 15:14:07 +00:00
|
|
|
uint64_t getSharedSystemMemCapabilities(const HardwareInfo *hwInfo) override;
|
2021-03-26 09:57:36 +00:00
|
|
|
void getKernelExtendedProperties(uint32_t *fp16, uint32_t *fp32, uint32_t *fp64) override;
|
2022-03-07 17:00:26 +00:00
|
|
|
std::vector<int32_t> getKernelSupportedThreadArbitrationPolicies() override;
|
2021-01-26 14:31:39 +00:00
|
|
|
void convertTimestampsFromOaToCsDomain(uint64_t ×tampData) override;
|
2021-04-19 11:31:20 +00:00
|
|
|
uint32_t getDeviceMemoryMaxClkRate(const HardwareInfo *hwInfo) override;
|
2021-06-23 13:34:56 +00:00
|
|
|
bool isAdditionalStateBaseAddressWARequired(const HardwareInfo &hwInfo) const override;
|
2021-07-06 10:14:23 +00:00
|
|
|
bool isMaxThreadsForWorkgroupWARequired(const HardwareInfo &hwInfo) const override;
|
|
|
|
|
uint32_t getMaxThreadsForWorkgroupInDSSOrSS(const HardwareInfo &hwInfo, uint32_t maxNumEUsPerSubSlice, uint32_t maxNumEUsPerDualSubSlice) const override;
|
|
|
|
|
uint32_t getMaxThreadsForWorkgroup(const HardwareInfo &hwInfo, uint32_t maxNumEUsPerSubSlice) const override;
|
2021-07-06 13:29:10 +00:00
|
|
|
void setForceNonCoherent(void *const commandPtr, const StateComputeModeProperties &properties) override;
|
2021-08-17 12:00:35 +00:00
|
|
|
bool obtainBlitterPreference(const HardwareInfo &hwInfo) const override;
|
2021-10-27 20:22:31 +00:00
|
|
|
bool isBlitterFullySupported(const HardwareInfo &hwInfo) const override;
|
2021-08-19 11:06:49 +00:00
|
|
|
bool isPageTableManagerSupported(const HardwareInfo &hwInfo) const override;
|
2021-11-30 12:43:06 +00:00
|
|
|
bool overrideGfxPartitionLayoutForWsl() const override;
|
2021-08-20 15:41:43 +00:00
|
|
|
uint32_t getHwRevIdFromStepping(uint32_t stepping, const HardwareInfo &hwInfo) const override;
|
2022-03-10 17:27:38 +00:00
|
|
|
PRODUCT_CONFIG getProductConfigFromHwInfo(const HardwareInfo &hwInfo) const override;
|
2021-08-27 13:30:39 +00:00
|
|
|
uint32_t getSteppingFromHwRevId(const HardwareInfo &hwInfo) const override;
|
|
|
|
|
uint32_t getAubStreamSteppingFromHwRevId(const HardwareInfo &hwInfo) const override;
|
2021-08-31 15:48:56 +00:00
|
|
|
void setAdditionalPipelineSelectFields(void *pipelineSelectCmd, const PipelineSelectArgs &pipelineSelectArgs, const HardwareInfo &hwInfo) override;
|
2021-09-02 11:11:39 +00:00
|
|
|
bool isDefaultEngineTypeAdjustmentRequired(const HardwareInfo &hwInfo) const override;
|
2021-08-31 15:17:18 +00:00
|
|
|
std::string getDeviceMemoryName() const override;
|
2021-09-06 10:34:34 +00:00
|
|
|
bool isDisableOverdispatchAvailable(const HardwareInfo &hwInfo) const override;
|
2021-12-03 13:52:16 +00:00
|
|
|
bool allowCompression(const HardwareInfo &hwInfo) const override;
|
2021-09-08 15:07:46 +00:00
|
|
|
bool allowStatelessCompression(const HardwareInfo &hwInfo) const override;
|
2021-09-09 12:27:41 +00:00
|
|
|
LocalMemoryAccessMode getLocalMemoryAccessMode(const HardwareInfo &hwInfo) const override;
|
2021-09-14 14:57:43 +00:00
|
|
|
bool isAllocationSizeAdjustmentRequired(const HardwareInfo &hwInfo) const override;
|
2021-09-15 09:53:12 +00:00
|
|
|
bool isPrefetchDisablingRequired(const HardwareInfo &hwInfo) const override;
|
2021-09-20 12:05:09 +00:00
|
|
|
bool isNewResidencyModelSupported() const override;
|
2021-11-22 12:49:26 +00:00
|
|
|
bool isDirectSubmissionSupported(const HardwareInfo &hwInfo) const override;
|
2022-02-04 15:43:17 +00:00
|
|
|
std::pair<bool, bool> isPipeControlPriorToNonPipelinedStateCommandsWARequired(const HardwareInfo &hwInfo, bool isRcs) const override;
|
2021-09-21 13:34:25 +00:00
|
|
|
bool heapInLocalMem(const HardwareInfo &hwInfo) const override;
|
2021-09-22 14:39:01 +00:00
|
|
|
void setCapabilityCoherencyFlag(const HardwareInfo &hwInfo, bool &coherencyFlag) override;
|
2021-09-23 15:08:41 +00:00
|
|
|
bool isAdditionalMediaSamplerProgrammingRequired() const override;
|
|
|
|
|
bool isInitialFlagsProgrammingRequired() const override;
|
|
|
|
|
bool isReturnedCmdSizeForMediaSamplerAdjustmentRequired() const override;
|
2021-09-23 17:46:36 +00:00
|
|
|
bool extraParametersInvalid(const HardwareInfo &hwInfo) const override;
|
2021-09-24 14:29:49 +00:00
|
|
|
bool pipeControlWARequired(const HardwareInfo &hwInfo) const override;
|
|
|
|
|
bool imagePitchAlignmentWARequired(const HardwareInfo &hwInfo) const override;
|
|
|
|
|
bool isForceEmuInt32DivRemSPWARequired(const HardwareInfo &hwInfo) const override;
|
|
|
|
|
bool is3DPipelineSelectWARequired() const override;
|
2021-09-28 10:54:52 +00:00
|
|
|
bool isStorageInfoAdjustmentRequired() const override;
|
2021-10-13 13:30:45 +00:00
|
|
|
bool isBlitterForImagesSupported() const override;
|
2021-10-15 15:24:03 +00:00
|
|
|
bool isTile64With3DSurfaceOnBCSSupported(const HardwareInfo &hwInfo) const override;
|
2021-12-20 14:37:33 +00:00
|
|
|
bool isDcFlushAllowed() const override;
|
2021-11-30 10:19:27 +00:00
|
|
|
uint32_t computeMaxNeededSubSliceSpace(const HardwareInfo &hwInfo) const override;
|
2021-11-26 09:40:06 +00:00
|
|
|
bool getUuid(Device *device, std::array<uint8_t, HwInfoConfig::uuidSize> &uuid) const override;
|
2022-02-17 21:44:55 +00:00
|
|
|
bool isFlushTaskAllowed() const override;
|
2022-03-07 14:31:53 +00:00
|
|
|
bool programAllStateComputeCommandFields() const override;
|
2022-03-09 15:39:57 +00:00
|
|
|
bool isSpecialPipelineSelectModeChanged(const HardwareInfo &hwInfo) const override;
|
|
|
|
|
bool isSystolicModeConfigurable(const HardwareInfo &hwInfo) const override;
|
|
|
|
|
bool isComputeDispatchAllWalkerEnableInComputeWalkerRequired(const HardwareInfo &hwInfo) const override;
|
2022-03-24 08:59:17 +00:00
|
|
|
bool isGlobalFenceInCommandStreamRequired(const HardwareInfo &hwInfo) const override;
|
2022-03-09 15:39:57 +00:00
|
|
|
bool isAdjustProgrammableIdPreferredSlmSizeRequired(const HardwareInfo &hwInfo) const override;
|
2022-03-21 17:44:02 +00:00
|
|
|
uint32_t getThreadEuRatioForScratch(const HardwareInfo &hwInfo) const override;
|
2022-03-09 15:39:57 +00:00
|
|
|
bool isComputeDispatchAllWalkerEnableInCfeStateRequired(const HardwareInfo &hwInfo) const override;
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
|
protected:
|
2020-11-21 15:50:18 +00:00
|
|
|
HwInfoConfigHw() = default;
|
|
|
|
|
|
2021-12-03 13:52:16 +00:00
|
|
|
void enableCompression(HardwareInfo *hwInfo);
|
2020-11-21 15:50:18 +00:00
|
|
|
void enableBlitterOperationsSupport(HardwareInfo *hwInfo);
|
2020-11-26 08:31:10 +00:00
|
|
|
uint64_t getHostMemCapabilitiesValue();
|
|
|
|
|
bool getHostMemCapabilitiesSupported(const HardwareInfo *hwInfo);
|
2021-09-09 12:27:41 +00:00
|
|
|
LocalMemoryAccessMode getDefaultLocalMemoryAccessMode(const HardwareInfo &hwInfo) const override;
|
2017-12-21 00:45:38 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
template <PRODUCT_FAMILY gfxProduct>
|
2018-03-15 15:03:51 +01:00
|
|
|
struct EnableProductHwInfoConfig {
|
2017-12-21 00:45:38 +01:00
|
|
|
typedef typename HwMapper<gfxProduct>::GfxProduct GfxProduct;
|
|
|
|
|
|
2018-03-15 15:03:51 +01:00
|
|
|
EnableProductHwInfoConfig() {
|
2017-12-21 00:45:38 +01:00
|
|
|
HwInfoConfig *pHwInfoConfig = HwInfoConfigHw<gfxProduct>::get();
|
|
|
|
|
hwInfoConfigFactory[gfxProduct] = pHwInfoConfig;
|
|
|
|
|
pHwInfoConfig->threadsPerEu = GfxProduct::threadsPerEu;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
2019-03-26 11:59:46 +01:00
|
|
|
} // namespace NEO
|