2018-12-06 22:33:02 +08:00
|
|
|
/*
|
2020-01-23 22:52:49 +08:00
|
|
|
* Copyright (C) 2018-2020 Intel Corporation
|
2018-12-06 22:33:02 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2020-02-24 20:10:44 +08:00
|
|
|
#include "shared/source/built_ins/built_ins.h"
|
|
|
|
|
2020-02-23 05:50:57 +08:00
|
|
|
#include "opencl/source/helpers/hardware_commands_helper.h"
|
|
|
|
#include "opencl/source/kernel/kernel.h"
|
2020-02-23 22:20:22 +08:00
|
|
|
#include "opencl/test/unit_test/fixtures/built_in_fixture.h"
|
2020-05-28 20:05:12 +08:00
|
|
|
#include "opencl/test/unit_test/fixtures/cl_device_fixture.h"
|
2020-02-23 22:20:22 +08:00
|
|
|
#include "opencl/test/unit_test/fixtures/context_fixture.h"
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_context.h"
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_graphics_allocation.h"
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_kernel.h"
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_program.h"
|
2019-02-27 18:39:32 +08:00
|
|
|
#include "test.h"
|
2018-12-06 22:33:02 +08:00
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
using namespace NEO;
|
2018-12-06 22:33:02 +08:00
|
|
|
|
2020-05-28 20:05:12 +08:00
|
|
|
struct HardwareCommandsTest : ClDeviceFixture,
|
2019-06-12 15:13:06 +08:00
|
|
|
ContextFixture,
|
|
|
|
BuiltInFixture,
|
|
|
|
::testing::Test {
|
2018-12-06 22:33:02 +08:00
|
|
|
|
|
|
|
using BuiltInFixture::SetUp;
|
|
|
|
using ContextFixture::SetUp;
|
|
|
|
|
|
|
|
void SetUp() override;
|
|
|
|
void TearDown() override;
|
|
|
|
|
|
|
|
void addSpaceForSingleKernelArg();
|
|
|
|
|
|
|
|
size_t sizeRequiredCS;
|
|
|
|
size_t sizeRequiredISH;
|
|
|
|
|
|
|
|
std::unique_ptr<MockKernelWithInternals> mockKernelWithInternal;
|
|
|
|
Kernel::SimpleKernelArgInfo kernelArgInfo = {};
|
|
|
|
std::vector<Kernel::SimpleKernelArgInfo> kernelArguments;
|
2020-01-23 22:52:49 +08:00
|
|
|
|
|
|
|
template <typename GfxFamily>
|
|
|
|
size_t pushBindingTableAndSurfaceStates(IndirectHeap &dstHeap, const Kernel &srcKernel) {
|
|
|
|
return HardwareCommandsHelper<GfxFamily>::pushBindingTableAndSurfaceStates(dstHeap, (srcKernel.getKernelInfo().patchInfo.bindingTableState != nullptr) ? srcKernel.getKernelInfo().patchInfo.bindingTableState->Count : 0,
|
|
|
|
srcKernel.getSurfaceStateHeap(), srcKernel.getSurfaceStateHeapSize(),
|
|
|
|
srcKernel.getNumberOfBindingTableStates(), srcKernel.getBindingTableOffset());
|
|
|
|
}
|
2018-12-06 22:33:02 +08:00
|
|
|
};
|