138 lines
5.3 KiB
C++
138 lines
5.3 KiB
C++
/*
|
|
* Copyright (C) 2017-2018 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#include "runtime/built_ins/builtins_dispatch_builder.h"
|
|
#include "runtime/memory_manager/svm_memory_manager.h"
|
|
#include "unit_tests/fixtures/device_fixture.h"
|
|
#include "unit_tests/command_queue/command_queue_fixture.h"
|
|
#include "unit_tests/mocks/mock_builtin_dispatch_info_builder.h"
|
|
#include "test.h"
|
|
|
|
using namespace OCLRT;
|
|
|
|
struct EnqueueSvmMemFillTest : public DeviceFixture,
|
|
public CommandQueueHwFixture,
|
|
public ::testing::TestWithParam<size_t> {
|
|
typedef CommandQueueHwFixture CommandQueueFixture;
|
|
|
|
EnqueueSvmMemFillTest() {
|
|
}
|
|
|
|
void SetUp() override {
|
|
DeviceFixture::SetUp();
|
|
CommandQueueFixture::SetUp(pDevice, 0);
|
|
patternSize = (size_t)GetParam();
|
|
ASSERT_TRUE((0 < patternSize) && (patternSize <= 128));
|
|
svmPtr = context->getSVMAllocsManager()->createSVMAlloc(256, true, false);
|
|
ASSERT_NE(nullptr, svmPtr);
|
|
svmAlloc = context->getSVMAllocsManager()->getSVMAlloc(svmPtr);
|
|
ASSERT_NE(nullptr, svmAlloc);
|
|
}
|
|
|
|
void TearDown() override {
|
|
context->getSVMAllocsManager()->freeSVMAlloc(svmPtr);
|
|
CommandQueueFixture::TearDown();
|
|
DeviceFixture::TearDown();
|
|
}
|
|
|
|
const uint64_t pattern[16] = {0x0011223344556677, 0x8899AABBCCDDEEFF, 0xFFEEDDCCBBAA9988, 0x7766554433221100,
|
|
0xFFEEDDCCBBAA9988, 0x7766554433221100, 0x0011223344556677, 0x8899AABBCCDDEEFF};
|
|
size_t patternSize = 0;
|
|
void *svmPtr = nullptr;
|
|
GraphicsAllocation *svmAlloc = nullptr;
|
|
};
|
|
|
|
HWTEST_P(EnqueueSvmMemFillTest, givenEnqueueSVMMemFillWhenUsingFillBufferBuilderThenItIsConfiguredWithBuitinOpParamsAndProducesDispatchInfo) {
|
|
struct MockFillBufferBuilder : MockBuiltinDispatchInfoBuilder {
|
|
MockFillBufferBuilder(BuiltIns &kernelLib, BuiltinDispatchInfoBuilder *origBuilder, const void *pattern, size_t patternSize)
|
|
: MockBuiltinDispatchInfoBuilder(kernelLib, origBuilder),
|
|
pattern(pattern), patternSize(patternSize) {
|
|
}
|
|
void validateInput(const BuiltinOpParams &conf) const override {
|
|
auto patternAllocation = conf.srcMemObj->getGraphicsAllocation();
|
|
EXPECT_EQ(patternSize, patternAllocation->getUnderlyingBufferSize());
|
|
EXPECT_EQ(0, memcmp(pattern, patternAllocation->getUnderlyingBuffer(), patternSize));
|
|
};
|
|
const void *pattern;
|
|
size_t patternSize;
|
|
};
|
|
|
|
auto &builtIns = *pCmdQ->getDevice().getExecutionEnvironment()->getBuiltIns();
|
|
|
|
// retrieve original builder
|
|
auto &origBuilder = builtIns.getBuiltinDispatchInfoBuilder(
|
|
EBuiltInOps::FillBuffer,
|
|
pCmdQ->getContext(),
|
|
pCmdQ->getDevice());
|
|
ASSERT_NE(nullptr, &origBuilder);
|
|
|
|
// substitute original builder with mock builder
|
|
auto oldBuilder = builtIns.setBuiltinDispatchInfoBuilder(
|
|
EBuiltInOps::FillBuffer,
|
|
pCmdQ->getContext(),
|
|
pCmdQ->getDevice(),
|
|
std::unique_ptr<OCLRT::BuiltinDispatchInfoBuilder>(new MockFillBufferBuilder(builtIns, &origBuilder, pattern, patternSize)));
|
|
EXPECT_EQ(&origBuilder, oldBuilder.get());
|
|
|
|
// call enqueue on mock builder
|
|
auto retVal = pCmdQ->enqueueSVMMemFill(
|
|
svmPtr, // void *svm_ptr
|
|
pattern, // const void *pattern
|
|
patternSize, // size_t pattern_size
|
|
256, // size_t size
|
|
0, // cl_uint num_events_in_wait_list
|
|
nullptr, // cl_event *event_wait_list
|
|
nullptr // cL_event *event
|
|
);
|
|
EXPECT_EQ(CL_SUCCESS, retVal);
|
|
|
|
// restore original builder and retrieve mock builder
|
|
auto newBuilder = builtIns.setBuiltinDispatchInfoBuilder(
|
|
EBuiltInOps::FillBuffer,
|
|
pCmdQ->getContext(),
|
|
pCmdQ->getDevice(),
|
|
std::move(oldBuilder));
|
|
EXPECT_NE(nullptr, newBuilder);
|
|
|
|
// check if original builder is restored correctly
|
|
auto &restoredBuilder = builtIns.getBuiltinDispatchInfoBuilder(
|
|
EBuiltInOps::FillBuffer,
|
|
pCmdQ->getContext(),
|
|
pCmdQ->getDevice());
|
|
EXPECT_EQ(&origBuilder, &restoredBuilder);
|
|
|
|
// use mock builder to validate builder's input / output
|
|
auto mockBuilder = static_cast<MockFillBufferBuilder *>(newBuilder.get());
|
|
|
|
// validate builder's input - builtin ops
|
|
auto params = mockBuilder->getBuiltinOpParams();
|
|
EXPECT_EQ(nullptr, params->srcPtr);
|
|
EXPECT_EQ(svmPtr, params->dstPtr);
|
|
EXPECT_NE(nullptr, params->srcMemObj);
|
|
EXPECT_EQ(nullptr, params->dstMemObj);
|
|
EXPECT_EQ(nullptr, params->srcSvmAlloc);
|
|
EXPECT_EQ(svmAlloc, params->dstSvmAlloc);
|
|
EXPECT_EQ(Vec3<size_t>(0, 0, 0), params->srcOffset);
|
|
EXPECT_EQ(Vec3<size_t>(0, 0, 0), params->dstOffset);
|
|
EXPECT_EQ(Vec3<size_t>(256, 0, 0), params->size);
|
|
|
|
// validate builder's output - multi dispatch info
|
|
auto mdi = mockBuilder->getMultiDispatchInfo();
|
|
EXPECT_EQ(1u, mdi->size());
|
|
|
|
auto di = mdi->begin();
|
|
size_t middleElSize = sizeof(uint32_t);
|
|
EXPECT_EQ(Vec3<size_t>(256 / middleElSize, 1, 1), di->getGWS());
|
|
|
|
auto kernel = di->getKernel();
|
|
EXPECT_STREQ("FillBufferMiddle", kernel->getKernelInfo().name.c_str());
|
|
}
|
|
|
|
INSTANTIATE_TEST_CASE_P(size_t,
|
|
EnqueueSvmMemFillTest,
|
|
::testing::Values(1, 2, 4, 8, 16, 32, 64, 128));
|