Files
compute-runtime/shared/source/command_stream/scratch_space_controller_xehp_plus.h
Bartosz Dunajski 96d14967ac Partial support for XE_HP_SDV
Signed-off-by: Bartosz Dunajski <bartosz.dunajski@intel.com>
2021-06-24 18:35:54 +02:00

81 lines
3.5 KiB
C++

/*
* Copyright (C) 2021 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#pragma once
#include "shared/source/command_stream/scratch_space_controller.h"
#include <cstdint>
#include <limits>
namespace NEO {
class ScratchSpaceControllerXeHPPlus : public ScratchSpaceController {
public:
ScratchSpaceControllerXeHPPlus(uint32_t rootDeviceIndex,
ExecutionEnvironment &environment,
InternalAllocationStorage &allocationStorage);
void setNewSshPtr(void *newSsh, bool &cfeDirty, bool changeId);
void setRequiredScratchSpace(void *sshBaseAddress,
uint32_t scratchSlot,
uint32_t requiredPerThreadScratchSize,
uint32_t requiredPerThreadPrivateScratchSize,
uint32_t currentTaskCount,
OsContext &osContext,
bool &stateBaseAddressDirty,
bool &vfeStateDirty) override;
uint64_t calculateNewGSH() override;
uint64_t getScratchPatchAddress() override;
void reserveHeap(IndirectHeap::Type heapType, IndirectHeap *&indirectHeap) override;
void programHeaps(HeapContainer &heapContainer,
uint32_t scratchSlot,
uint32_t requiredPerThreadScratchSize,
uint32_t requiredPerThreadPrivateScratchSize,
uint32_t currentTaskCount,
OsContext &osContext,
bool &stateBaseAddressDirty,
bool &vfeStateDirty) override;
void programBindlessSurfaceStateForScratch(BindlessHeapsHelper *heapsHelper,
uint32_t requiredPerThreadScratchSize,
uint32_t requiredPerThreadPrivateScratchSize,
uint32_t currentTaskCount,
OsContext &osContext,
bool &stateBaseAddressDirty,
bool &vfeStateDirty,
NEO::CommandStreamReceiver *csr) override;
protected:
MOCKABLE_VIRTUAL void programSurfaceState();
MOCKABLE_VIRTUAL void programSurfaceStateAtPtr(void *surfaceStateForScratchAllocation);
MOCKABLE_VIRTUAL void prepareScratchAllocation(uint32_t requiredPerThreadScratchSize,
uint32_t requiredPerThreadPrivateScratchSize,
uint32_t currentTaskCount,
OsContext &osContext,
bool &stateBaseAddressDirty,
bool &scratchSurfaceDirty,
bool &vfeStateDirty);
size_t getOffsetToSurfaceState(uint32_t requiredSlotCount) const;
bool updateSlots = true;
uint32_t stateSlotsCount = 16;
static const uint32_t scratchType = 6;
bool privateScratchSpaceSupported = true;
char *surfaceStateHeap = nullptr;
size_t singleSurfaceStateSize = 0;
uint32_t slotId = 0;
uint32_t perThreadScratchSize = 0;
uint32_t perThreadPrivateScratchSize = 0;
uint32_t sshOffset = 0;
SurfaceStateInHeapInfo bindlessSS = {};
};
} // namespace NEO