2020-01-17 15:56:05 +08:00
|
|
|
/*
|
2024-03-29 14:44:27 +08:00
|
|
|
* Copyright (C) 2020-2024 Intel Corporation
|
2020-01-17 15:56:05 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
#include <cstdint>
|
|
|
|
|
|
|
|
namespace NEO {
|
|
|
|
class GraphicsAllocation;
|
2021-09-14 00:49:13 +08:00
|
|
|
struct ImplicitArgs;
|
2020-04-07 20:07:31 +08:00
|
|
|
struct KernelDescriptor;
|
2020-01-17 15:56:05 +08:00
|
|
|
|
2020-11-07 15:32:45 +08:00
|
|
|
enum class SlmPolicy {
|
2023-12-19 18:42:58 +08:00
|
|
|
slmPolicyNone,
|
|
|
|
slmPolicyLargeSlm,
|
|
|
|
slmPolicyLargeData
|
2020-11-07 15:32:45 +08:00
|
|
|
};
|
|
|
|
|
2020-01-17 15:56:05 +08:00
|
|
|
struct DispatchKernelEncoderI {
|
|
|
|
virtual ~DispatchKernelEncoderI() = default;
|
|
|
|
|
2020-04-07 20:07:31 +08:00
|
|
|
virtual const KernelDescriptor &getKernelDescriptor() const = 0;
|
|
|
|
virtual const uint32_t *getGroupSize() const = 0;
|
|
|
|
virtual uint32_t getSlmTotalSize() const = 0;
|
2020-11-07 15:32:45 +08:00
|
|
|
virtual SlmPolicy getSlmPolicy() const = 0;
|
2020-04-07 20:07:31 +08:00
|
|
|
|
|
|
|
virtual const uint8_t *getCrossThreadData() const = 0;
|
|
|
|
virtual uint32_t getCrossThreadDataSize() const = 0;
|
|
|
|
|
|
|
|
virtual uint32_t getThreadExecutionMask() const = 0;
|
|
|
|
virtual uint32_t getNumThreadsPerThreadGroup() const = 0;
|
|
|
|
virtual const uint8_t *getPerThreadData() const = 0;
|
|
|
|
virtual uint32_t getPerThreadDataSize() const = 0;
|
|
|
|
virtual uint32_t getPerThreadDataSizeForWholeThreadGroup() const = 0;
|
|
|
|
|
|
|
|
virtual const uint8_t *getSurfaceStateHeapData() const = 0;
|
|
|
|
virtual uint32_t getSurfaceStateHeapDataSize() const = 0;
|
|
|
|
|
|
|
|
virtual GraphicsAllocation *getIsaAllocation() const = 0;
|
2023-08-09 21:39:39 +08:00
|
|
|
virtual uint64_t getIsaOffsetInParentAllocation() const = 0;
|
2020-04-07 20:07:31 +08:00
|
|
|
virtual const uint8_t *getDynamicStateHeapData() const = 0;
|
2020-07-07 04:55:37 +08:00
|
|
|
|
|
|
|
virtual uint32_t getRequiredWorkgroupOrder() const = 0;
|
|
|
|
virtual bool requiresGenerationOfLocalIdsByRuntime() const = 0;
|
2021-09-14 00:49:13 +08:00
|
|
|
|
|
|
|
virtual ImplicitArgs *getImplicitArgs() const = 0;
|
2023-06-15 02:26:31 +08:00
|
|
|
virtual void patchBindlessOffsetsInCrossThreadData(uint64_t bindlessSurfaceStateBaseOffset) const = 0;
|
2024-03-29 14:44:27 +08:00
|
|
|
virtual void patchSamplerBindlessOffsetsInCrossThreadData(uint64_t samplerStateOffset) const = 0;
|
2020-01-17 15:56:05 +08:00
|
|
|
};
|
2020-11-07 15:32:45 +08:00
|
|
|
} // namespace NEO
|