2020-01-17 08:56:05 +01:00
|
|
|
/*
|
2023-01-05 16:57:56 +00:00
|
|
|
* Copyright (C) 2020-2023 Intel Corporation
|
2020-01-17 08:56:05 +01:00
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2020-02-23 22:44:01 +01:00
|
|
|
#include "shared/source/command_container/command_encoder.h"
|
|
|
|
|
#include "shared/source/gen11/hw_cmds_base.h"
|
2020-03-03 11:59:49 +01:00
|
|
|
#include "shared/source/gen11/reg_configs.h"
|
2020-02-24 10:22:30 +01:00
|
|
|
|
2022-03-08 14:18:31 +00:00
|
|
|
#include "reg_configs_common.h"
|
|
|
|
|
|
2022-07-25 15:30:11 +00:00
|
|
|
using Family = NEO::Gen11Family;
|
2020-01-17 08:56:05 +01:00
|
|
|
|
2020-07-31 08:40:52 +02:00
|
|
|
#include "shared/source/command_container/command_encoder.inl"
|
2021-08-03 11:48:35 +00:00
|
|
|
#include "shared/source/command_container/command_encoder_bdw_and_later.inl"
|
|
|
|
|
#include "shared/source/command_container/encode_compute_mode_bdw_and_later.inl"
|
|
|
|
|
#include "shared/source/command_container/image_surface_state/compression_params_bdw_and_later.inl"
|
2020-01-17 08:56:05 +01:00
|
|
|
|
2023-01-09 15:02:00 +00:00
|
|
|
#include "stream_properties.inl"
|
|
|
|
|
|
2020-07-31 08:40:52 +02:00
|
|
|
namespace NEO {
|
2020-10-07 14:22:26 +02:00
|
|
|
|
|
|
|
|
template <>
|
2022-09-13 12:47:58 +00:00
|
|
|
bool EncodeSurfaceState<Family>::isBindingTablePrefetchPreferred() {
|
2020-10-07 14:22:26 +02:00
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-29 10:17:10 +00:00
|
|
|
template <>
|
2023-07-18 11:48:29 +00:00
|
|
|
void EncodeSurfaceState<Family>::setAuxParamsForMCSCCS(R_SURFACE_STATE *surfaceState, const ReleaseHelper *releaseHelper) {
|
2021-01-29 10:17:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template <>
|
|
|
|
|
void EncodeSurfaceState<Family>::setClearColorParams(R_SURFACE_STATE *surfaceState, Gmm *gmm) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template <>
|
|
|
|
|
void EncodeSurfaceState<Family>::setFlagsForMediaCompression(R_SURFACE_STATE *surfaceState, Gmm *gmm) {
|
|
|
|
|
if (gmm->gmmResourceInfo->getResourceFlags()->Info.MediaCompressed) {
|
|
|
|
|
surfaceState->setAuxiliarySurfaceMode(Family::RENDER_SURFACE_STATE::AUXILIARY_SURFACE_MODE::AUXILIARY_SURFACE_MODE_AUX_NONE);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-03-08 14:18:31 +00:00
|
|
|
template <typename Family>
|
2023-01-23 14:08:25 +00:00
|
|
|
size_t EncodeComputeMode<Family>::getCmdSizeForComputeMode(const RootDeviceEnvironment &rootDeviceEnvironment, bool hasSharedHandles, bool isRcs) {
|
2022-03-08 14:18:31 +00:00
|
|
|
return sizeof(typename Family::PIPE_CONTROL) + 2u * sizeof(typename Family::MI_LOAD_REGISTER_IMM);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template <>
|
|
|
|
|
void EncodeComputeMode<Family>::programComputeModeCommand(LinearStream &csr, StateComputeModeProperties &properties,
|
2023-09-12 17:51:43 +00:00
|
|
|
const RootDeviceEnvironment &rootDeviceEnvironment) {
|
2022-03-08 14:18:31 +00:00
|
|
|
using PIPE_CONTROL = typename Family::PIPE_CONTROL;
|
|
|
|
|
|
|
|
|
|
if (properties.threadArbitrationPolicy.isDirty) {
|
2022-07-21 14:28:10 +00:00
|
|
|
PipeControlArgs args;
|
|
|
|
|
args.csStallOnly = true;
|
|
|
|
|
MemorySynchronizationCommands<Family>::addSingleBarrier(csr, args);
|
2022-03-08 14:18:31 +00:00
|
|
|
|
|
|
|
|
LriHelper<Family>::program(&csr,
|
|
|
|
|
RowChickenReg4::address,
|
|
|
|
|
RowChickenReg4::regDataForArbitrationPolicy[properties.threadArbitrationPolicy.value],
|
|
|
|
|
false);
|
|
|
|
|
}
|
|
|
|
|
if (properties.isCoherencyRequired.isDirty) {
|
|
|
|
|
auto nonCoherentEnable = !properties.isCoherencyRequired.value;
|
|
|
|
|
LriHelper<Family>::program(&csr,
|
|
|
|
|
gen11HdcModeRegister::address,
|
|
|
|
|
DwordBuilder::build(gen11HdcModeRegister::forceNonCoherentEnableBit, true, nonCoherentEnable),
|
|
|
|
|
false);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-01-17 08:56:05 +01:00
|
|
|
template struct EncodeDispatchKernel<Family>;
|
2023-11-23 13:58:58 +00:00
|
|
|
template void EncodeDispatchKernel<Family>::encodeAdditionalWalkerFields<Family::WALKER_TYPE>(const RootDeviceEnvironment &rootDeviceEnvironment, Family::WALKER_TYPE &walkerCmd, const EncodeWalkerArgs &walkerArgs);
|
|
|
|
|
template void EncodeDispatchKernel<Family>::adjustTimestampPacket<Family::WALKER_TYPE>(Family::WALKER_TYPE &walkerCmd, const HardwareInfo &hwInfo);
|
|
|
|
|
template void EncodeDispatchKernel<Family>::setGrfInfo<Family::INTERFACE_DESCRIPTOR_DATA>(Family::INTERFACE_DESCRIPTOR_DATA *pInterfaceDescriptor, uint32_t numGrf, const size_t &sizeCrossThreadData, const size_t &sizePerThreadData, const RootDeviceEnvironment &rootDeviceEnvironment);
|
|
|
|
|
template void EncodeDispatchKernel<Family>::appendAdditionalIDDFields<Family::INTERFACE_DESCRIPTOR_DATA>(Family::INTERFACE_DESCRIPTOR_DATA *pInterfaceDescriptor, const RootDeviceEnvironment &rootDeviceEnvironment, const uint32_t threadsPerThreadGroup, uint32_t slmTotalSize, SlmPolicy slmPolicy);
|
|
|
|
|
template void EncodeDispatchKernel<Family>::programBarrierEnable<Family::INTERFACE_DESCRIPTOR_DATA>(Family::INTERFACE_DESCRIPTOR_DATA &interfaceDescriptor, uint32_t value, const HardwareInfo &hwInfo);
|
|
|
|
|
template void EncodeDispatchKernel<Family>::adjustInterfaceDescriptorData<Family::WALKER_TYPE, Family::INTERFACE_DESCRIPTOR_DATA>(Family::INTERFACE_DESCRIPTOR_DATA &interfaceDescriptor, const Device &device, const HardwareInfo &hwInfo, const uint32_t threadGroupCount, const uint32_t numGrf, Family::WALKER_TYPE &walkerCmd);
|
|
|
|
|
template void EncodeDispatchKernel<Family>::setupPostSyncMocs<Family::WALKER_TYPE>(Family::WALKER_TYPE &walkerCmd, const RootDeviceEnvironment &rootDeviceEnvironment, bool dcFlush);
|
|
|
|
|
|
2020-01-17 08:56:05 +01:00
|
|
|
template struct EncodeStates<Family>;
|
2020-02-25 10:23:04 -08:00
|
|
|
template struct EncodeMath<Family>;
|
2020-01-17 08:56:05 +01:00
|
|
|
template struct EncodeMathMMIO<Family>;
|
|
|
|
|
template struct EncodeIndirectParams<Family>;
|
|
|
|
|
template struct EncodeSetMMIO<Family>;
|
|
|
|
|
template struct EncodeL3State<Family>;
|
|
|
|
|
template struct EncodeMediaInterfaceDescriptorLoad<Family>;
|
|
|
|
|
template struct EncodeStateBaseAddress<Family>;
|
|
|
|
|
template struct EncodeStoreMMIO<Family>;
|
|
|
|
|
template struct EncodeSurfaceState<Family>;
|
2020-01-24 14:58:15 +01:00
|
|
|
template struct EncodeAtomic<Family>;
|
2023-03-10 13:49:06 +00:00
|
|
|
template struct EncodeSemaphore<Family>;
|
2020-01-28 13:50:19 +01:00
|
|
|
template struct EncodeBatchBufferStartOrEnd<Family>;
|
2020-02-21 15:35:08 +01:00
|
|
|
template struct EncodeMiFlushDW<Family>;
|
2022-11-08 11:05:43 +00:00
|
|
|
template struct EncodeMiPredicate<Family>;
|
2020-04-03 17:38:09 +02:00
|
|
|
template struct EncodeMemoryPrefetch<Family>;
|
2020-07-31 08:40:52 +02:00
|
|
|
template struct EncodeWA<Family>;
|
2020-11-16 17:12:08 +00:00
|
|
|
template struct EncodeMiArbCheck<Family>;
|
2021-05-18 02:46:21 +00:00
|
|
|
template struct EncodeComputeMode<Family>;
|
2021-02-26 22:02:57 +00:00
|
|
|
template struct EncodeEnableRayTracing<Family>;
|
2021-11-17 22:36:00 +00:00
|
|
|
template struct EncodeNoop<Family>;
|
2021-12-02 14:17:45 +00:00
|
|
|
template struct EncodeStoreMemory<Family>;
|
2022-04-06 14:41:45 +00:00
|
|
|
template struct EncodeMemoryFence<Family>;
|
2023-07-27 12:36:00 +00:00
|
|
|
template struct EnodeUserInterrupt<Family>;
|
2020-01-24 14:58:15 +01:00
|
|
|
} // namespace NEO
|