2020-01-17 15:56:05 +08:00
|
|
|
/*
|
2024-01-10 20:32:03 +08:00
|
|
|
* Copyright (C) 2020-2024 Intel Corporation
|
2020-01-17 15:56:05 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2020-02-24 05:44:01 +08:00
|
|
|
#include "shared/source/command_container/command_encoder.h"
|
|
|
|
#include "shared/source/gen8/hw_cmds_base.h"
|
2020-03-03 18:59:49 +08:00
|
|
|
#include "shared/source/gen8/reg_configs.h"
|
2020-01-17 15:56:05 +08:00
|
|
|
|
2022-07-25 23:30:11 +08:00
|
|
|
using Family = NEO::Gen8Family;
|
2020-01-17 15:56:05 +08:00
|
|
|
|
2020-07-31 14:40:52 +08:00
|
|
|
#include "shared/source/command_container/command_encoder.inl"
|
2021-08-03 19:48:35 +08: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 15:56:05 +08:00
|
|
|
|
2020-07-31 14:40:52 +08:00
|
|
|
namespace NEO {
|
2022-03-08 22:18:31 +08:00
|
|
|
|
2021-01-29 18:17:10 +08:00
|
|
|
template <>
|
2023-07-18 19:48:29 +08:00
|
|
|
void EncodeSurfaceState<Family>::setAuxParamsForMCSCCS(R_SURFACE_STATE *surfaceState, const ReleaseHelper *releaseHelper) {
|
2021-01-29 18:17:10 +08: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 22:18:31 +08:00
|
|
|
template <typename Family>
|
2023-01-23 22:08:25 +08:00
|
|
|
size_t EncodeComputeMode<Family>::getCmdSizeForComputeMode(const RootDeviceEnvironment &rootDeviceEnvironment, bool hasSharedHandles, bool isRcs) {
|
2022-03-08 22:18:31 +08:00
|
|
|
return 0u;
|
|
|
|
}
|
|
|
|
|
2024-03-09 08:00:20 +08:00
|
|
|
template <>
|
|
|
|
inline size_t EncodeComputeMode<Family>::getSizeForComputeMode() {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2022-03-08 22:18:31 +08:00
|
|
|
template <typename Family>
|
2023-09-13 01:51:43 +08:00
|
|
|
void EncodeComputeMode<Family>::programComputeModeCommand(LinearStream &csr, StateComputeModeProperties &properties, const RootDeviceEnvironment &rootDeviceEnvironment) {
|
2022-03-08 22:18:31 +08:00
|
|
|
}
|
|
|
|
|
2022-04-20 22:12:20 +08:00
|
|
|
template <>
|
|
|
|
void EncodeStateBaseAddress<Family>::setSbaAddressesForDebugger(NEO::Debugger::SbaAddresses &sbaAddress, const STATE_BASE_ADDRESS &sbaCmd) {
|
2023-04-28 17:38:31 +08:00
|
|
|
sbaAddress.indirectObjectBaseAddress = sbaCmd.getIndirectObjectBaseAddress();
|
|
|
|
sbaAddress.dynamicStateBaseAddress = sbaCmd.getDynamicStateBaseAddress();
|
|
|
|
sbaAddress.generalStateBaseAddress = sbaCmd.getGeneralStateBaseAddress();
|
|
|
|
sbaAddress.instructionBaseAddress = sbaCmd.getInstructionBaseAddress();
|
|
|
|
sbaAddress.surfaceStateBaseAddress = sbaCmd.getSurfaceStateBaseAddress();
|
2022-04-20 22:12:20 +08:00
|
|
|
}
|
|
|
|
|
2023-11-28 20:00:47 +08:00
|
|
|
template <>
|
|
|
|
void EncodeBatchBufferStartOrEnd<Family>::appendBatchBufferStart(MI_BATCH_BUFFER_START &cmd, bool indirect, bool predicate) {
|
|
|
|
}
|
|
|
|
|
2023-12-21 20:10:25 +08:00
|
|
|
} // namespace NEO
|
2023-11-23 21:58:58 +08:00
|
|
|
|
2023-12-21 20:10:25 +08:00
|
|
|
#include "shared/source/command_container/command_encoder_enablers.inl"
|
2023-12-21 21:16:43 +08:00
|
|
|
|
2023-12-21 20:10:25 +08:00
|
|
|
namespace NEO {
|
2020-01-17 15:56:05 +08:00
|
|
|
template struct EncodeL3State<Family>;
|
2022-04-06 22:41:45 +08:00
|
|
|
|
2023-12-21 20:10:25 +08:00
|
|
|
template void InOrderPatchCommandHelpers::PatchCmd<Family>::patchComputeWalker(uint64_t appendCounterValue);
|
2020-02-26 02:23:04 +08:00
|
|
|
} // namespace NEO
|
2023-12-22 23:59:55 +08:00
|
|
|
|
|
|
|
#include "shared/source/command_container/implicit_scaling_before_xe_hp.inl"
|