compute-runtime/unit_tests/command_queue/enqueue_svm_mem_fill_tests.cpp

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));