mirror of
https://github.com/intel/compute-runtime.git
synced 2025-12-22 10:17:01 +08:00
- prepare bindful ssh when kernel requires ssh heap and SurfaceStateBaseAddress - remove lastAppendedKernelBindlesMode - local ssh heap may be needed for bindless kernels with scratch or misaligned buffer args - use ssh heap gpu address to program SurfaceStateBaseAddress, global base is used for BindlessSurfaceState and DynamicState Related-To: NEO-7063 Signed-off-by: Mateusz Hoppe <mateusz.hoppe@intel.com>
39 lines
927 B
C++
39 lines
927 B
C++
/*
|
|
* Copyright (C) 2024 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "shared/source/indirect_heap/indirect_heap.h"
|
|
|
|
namespace NEO {
|
|
|
|
inline uint64_t getStateBaseAddress(const IndirectHeap &heap, const bool useGlobalHeaps) {
|
|
if (useGlobalHeaps) {
|
|
return heap.getGraphicsAllocation()->getGpuBaseAddress();
|
|
} else {
|
|
return heap.getHeapGpuBase();
|
|
}
|
|
}
|
|
|
|
inline size_t getStateSize(const IndirectHeap &heap, const bool useGlobalHeaps) {
|
|
if (useGlobalHeaps) {
|
|
return MemoryConstants::sizeOf4GBinPageEntities;
|
|
} else {
|
|
return heap.getHeapSizeInPages();
|
|
}
|
|
}
|
|
|
|
inline uint64_t getStateBaseAddressForSsh(const IndirectHeap &heap, const bool useGlobalHeaps) {
|
|
return heap.getHeapGpuBase();
|
|
}
|
|
|
|
inline size_t getStateSizeForSsh(const IndirectHeap &heap, const bool useGlobalHeaps) {
|
|
return heap.getHeapSizeInPages();
|
|
}
|
|
|
|
} // namespace NEO
|