2018-11-22 22:16:20 +08:00
|
|
|
/*
|
2021-01-11 19:30:28 +08:00
|
|
|
* Copyright (C) 2018-2021 Intel Corporation
|
2018-11-22 22:16:20 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
2020-02-24 05:44:01 +08:00
|
|
|
#include "shared/source/command_stream/scratch_space_controller.h"
|
2018-11-22 22:16:20 +08:00
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
namespace NEO {
|
2018-11-22 22:16:20 +08:00
|
|
|
|
|
|
|
class ScratchSpaceControllerBase : public ScratchSpaceController {
|
|
|
|
public:
|
2019-11-07 21:15:04 +08:00
|
|
|
ScratchSpaceControllerBase(uint32_t rootDeviceIndex, ExecutionEnvironment &environment, InternalAllocationStorage &allocationStorage);
|
2018-11-22 22:16:20 +08:00
|
|
|
|
|
|
|
void setRequiredScratchSpace(void *sshBaseAddress,
|
2020-10-05 17:39:15 +08:00
|
|
|
uint32_t scratchSlot,
|
2018-11-22 22:16:20 +08:00
|
|
|
uint32_t requiredPerThreadScratchSize,
|
2019-06-27 18:59:27 +08:00
|
|
|
uint32_t requiredPerThreadPrivateScratchSize,
|
2018-11-22 22:16:20 +08:00
|
|
|
uint32_t currentTaskCount,
|
2019-09-16 20:59:54 +08:00
|
|
|
OsContext &osContext,
|
2018-11-22 22:16:20 +08:00
|
|
|
bool &stateBaseAddressDirty,
|
|
|
|
bool &vfeStateDirty) override;
|
2020-12-07 23:38:12 +08:00
|
|
|
|
2018-11-22 22:16:20 +08:00
|
|
|
uint64_t calculateNewGSH() override;
|
|
|
|
uint64_t getScratchPatchAddress() override;
|
|
|
|
|
|
|
|
void reserveHeap(IndirectHeap::Type heapType, IndirectHeap *&indirectHeap) override;
|
2020-10-05 17:39:15 +08:00
|
|
|
void programHeaps(HeapContainer &heapContainer,
|
|
|
|
uint32_t scratchSlot,
|
|
|
|
uint32_t requiredPerThreadScratchSize,
|
|
|
|
uint32_t requiredPerThreadPrivateScratchSize,
|
|
|
|
uint32_t currentTaskCount,
|
|
|
|
OsContext &osContext,
|
|
|
|
bool &stateBaseAddressDirty,
|
|
|
|
bool &vfeStateDirty) override;
|
2020-12-07 23:38:12 +08:00
|
|
|
void programBindlessSurfaceStateForScratch(BindlessHeapsHelper *heapsHelper,
|
|
|
|
uint32_t requiredPerThreadScratchSize,
|
|
|
|
uint32_t requiredPerThreadPrivateScratchSize,
|
|
|
|
uint32_t currentTaskCount,
|
|
|
|
OsContext &osContext,
|
|
|
|
bool &stateBaseAddressDirty,
|
2021-01-11 19:30:28 +08:00
|
|
|
bool &vfeStateDirty,
|
|
|
|
ResidencyContainer &residency) override;
|
2018-11-22 22:16:20 +08:00
|
|
|
|
|
|
|
protected:
|
|
|
|
void createScratchSpaceAllocation();
|
|
|
|
};
|
2019-03-26 18:59:46 +08:00
|
|
|
} // namespace NEO
|