2020-01-17 08:56:05 +01:00
|
|
|
/*
|
2021-01-21 13:10:13 +01:00
|
|
|
* Copyright (C) 2020-2021 Intel Corporation
|
2020-01-17 08:56:05 +01:00
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#pragma once
|
2020-02-23 22:44:01 +01:00
|
|
|
#include "shared/source/kernel/dispatch_kernel_encoder_interface.h"
|
2020-04-07 14:07:31 +02:00
|
|
|
#include "shared/source/kernel/kernel_descriptor.h"
|
2021-01-21 13:10:13 +01:00
|
|
|
#include "shared/test/common/mocks/mock_graphics_allocation.h"
|
2020-01-17 08:56:05 +01:00
|
|
|
|
|
|
|
|
#include "gmock/gmock.h"
|
|
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
|
|
namespace NEO {
|
|
|
|
|
class GraphicsAllocation;
|
|
|
|
|
|
|
|
|
|
struct MockDispatchKernelEncoder : public DispatchKernelEncoderI {
|
|
|
|
|
public:
|
|
|
|
|
MockDispatchKernelEncoder();
|
2020-04-07 14:07:31 +02:00
|
|
|
|
2020-07-06 22:55:37 +02:00
|
|
|
MOCK_METHOD(const KernelDescriptor &, getKernelDescriptor, (), (const, override));
|
2020-04-07 14:07:31 +02:00
|
|
|
|
2020-07-06 22:55:37 +02:00
|
|
|
MOCK_METHOD(const uint32_t *, getGroupSize, (), (const, override));
|
|
|
|
|
MOCK_METHOD(uint32_t, getSlmTotalSize, (), (const, override));
|
2020-04-07 14:07:31 +02:00
|
|
|
|
2020-07-06 22:55:37 +02:00
|
|
|
MOCK_METHOD(const uint8_t *, getCrossThreadData, (), (const, override));
|
|
|
|
|
MOCK_METHOD(uint32_t, getCrossThreadDataSize, (), (const, override));
|
2020-04-07 14:07:31 +02:00
|
|
|
|
2020-07-06 22:55:37 +02:00
|
|
|
MOCK_METHOD(uint32_t, getThreadExecutionMask, (), (const, override));
|
|
|
|
|
|
|
|
|
|
MOCK_METHOD(const uint8_t *, getPerThreadData, (), (const, override));
|
|
|
|
|
MOCK_METHOD(uint32_t, getPerThreadDataSize, (), (const, override));
|
|
|
|
|
|
|
|
|
|
MOCK_METHOD(uint32_t, getPerThreadDataSizeForWholeThreadGroup, (), (const, override));
|
|
|
|
|
|
|
|
|
|
MOCK_METHOD(const uint8_t *, getSurfaceStateHeapData, (), (const, override));
|
|
|
|
|
MOCK_METHOD(uint32_t, getSurfaceStateHeapDataSize, (), (const, override));
|
|
|
|
|
|
|
|
|
|
MOCK_METHOD(GraphicsAllocation *, getIsaAllocation, (), (const, override));
|
|
|
|
|
MOCK_METHOD(const uint8_t *, getDynamicStateHeapData, (), (const, override));
|
|
|
|
|
|
|
|
|
|
MOCK_METHOD(bool, requiresGenerationOfLocalIdsByRuntime, (), (const, override));
|
|
|
|
|
|
2020-11-06 23:32:45 -08:00
|
|
|
MOCK_METHOD(SlmPolicy, getSlmPolicy, (), (const, override));
|
|
|
|
|
|
2020-07-06 22:55:37 +02:00
|
|
|
uint32_t getRequiredWorkgroupOrder() const override {
|
|
|
|
|
return requiredWalkGroupOrder;
|
|
|
|
|
}
|
2020-08-04 14:18:31 +02:00
|
|
|
uint32_t getNumThreadsPerThreadGroup() const override {
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
2020-01-17 08:56:05 +01:00
|
|
|
void expectAnyMockFunctionCall();
|
|
|
|
|
|
|
|
|
|
::testing::NiceMock<MockGraphicsAllocation> mockAllocation;
|
|
|
|
|
static constexpr uint32_t crossThreadSize = 0x40;
|
|
|
|
|
static constexpr uint32_t perThreadSize = 0x20;
|
|
|
|
|
uint8_t dataCrossThread[crossThreadSize];
|
|
|
|
|
uint8_t dataPerThread[perThreadSize];
|
2020-04-07 14:07:31 +02:00
|
|
|
KernelDescriptor kernelDescriptor;
|
2020-07-06 22:55:37 +02:00
|
|
|
|
|
|
|
|
uint32_t groupSizes[3];
|
|
|
|
|
bool localIdGenerationByRuntime = true;
|
|
|
|
|
uint32_t requiredWalkGroupOrder = 0x0u;
|
2020-01-17 08:56:05 +01:00
|
|
|
};
|
2020-07-15 17:59:37 +02:00
|
|
|
} // namespace NEO
|