2017-12-21 00:45:38 +01:00
|
|
|
/*
|
2019-02-27 11:39:32 +01:00
|
|
|
* Copyright (C) 2017-2019 Intel Corporation
|
2017-12-21 00:45:38 +01:00
|
|
|
*
|
2018-09-18 09:11:08 +02:00
|
|
|
* SPDX-License-Identifier: MIT
|
2017-12-21 00:45:38 +01:00
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include "runtime/command_queue/command_queue.h"
|
|
|
|
|
#include "unit_tests/api/cl_api_tests.h"
|
2019-02-27 11:39:32 +01:00
|
|
|
#include "unit_tests/fixtures/buffer_fixture.h"
|
|
|
|
|
|
2017-12-21 00:45:38 +01:00
|
|
|
#include <memory>
|
|
|
|
|
|
|
|
|
|
using namespace OCLRT;
|
|
|
|
|
|
|
|
|
|
typedef api_tests clEnqueueUnmapMemObjTests;
|
|
|
|
|
|
2018-02-01 13:40:30 +01:00
|
|
|
TEST_F(clEnqueueUnmapMemObjTests, givenValidAddressWhenUnmappingThenReturnSuccess) {
|
2017-12-21 00:45:38 +01:00
|
|
|
auto buffer = std::unique_ptr<Buffer>(BufferHelper<BufferUseHostPtr<>>::create(pContext));
|
2018-02-01 13:40:30 +01:00
|
|
|
cl_int retVal = CL_SUCCESS;
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2018-02-01 13:40:30 +01:00
|
|
|
auto mappedPtr = clEnqueueMapBuffer(pCommandQueue, buffer.get(), CL_TRUE, CL_MAP_READ, 0, 1, 0, nullptr, nullptr, &retVal);
|
|
|
|
|
EXPECT_EQ(CL_SUCCESS, retVal);
|
|
|
|
|
|
|
|
|
|
retVal = clEnqueueUnmapMemObject(
|
2017-12-21 00:45:38 +01:00
|
|
|
pCommandQueue,
|
|
|
|
|
buffer.get(),
|
2018-02-01 13:40:30 +01:00
|
|
|
mappedPtr,
|
2017-12-21 00:45:38 +01:00
|
|
|
0,
|
|
|
|
|
nullptr,
|
|
|
|
|
nullptr);
|
|
|
|
|
EXPECT_EQ(CL_SUCCESS, retVal);
|
|
|
|
|
}
|
2018-02-01 13:40:30 +01:00
|
|
|
|
2018-02-17 22:26:28 +01:00
|
|
|
TEST_F(clEnqueueUnmapMemObjTests, givenInvalidAddressWhenUnmappingOnCpuThenReturnError) {
|
2018-02-01 13:40:30 +01:00
|
|
|
auto buffer = std::unique_ptr<Buffer>(BufferHelper<BufferUseHostPtr<>>::create(pContext));
|
2018-02-17 22:26:28 +01:00
|
|
|
EXPECT_TRUE(buffer->mappingOnCpuAllowed());
|
2018-02-01 13:40:30 +01:00
|
|
|
cl_int retVal = CL_SUCCESS;
|
|
|
|
|
|
|
|
|
|
auto mappedPtr = clEnqueueMapBuffer(pCommandQueue, buffer.get(), CL_TRUE, CL_MAP_READ, 0, 1, 0, nullptr, nullptr, &retVal);
|
|
|
|
|
EXPECT_EQ(CL_SUCCESS, retVal);
|
|
|
|
|
|
|
|
|
|
retVal = clEnqueueUnmapMemObject(
|
|
|
|
|
pCommandQueue,
|
|
|
|
|
buffer.get(),
|
|
|
|
|
ptrOffset(mappedPtr, buffer->getSize() + 1),
|
|
|
|
|
0,
|
|
|
|
|
nullptr,
|
|
|
|
|
nullptr);
|
|
|
|
|
EXPECT_EQ(CL_INVALID_VALUE, retVal);
|
|
|
|
|
}
|
2018-02-08 22:59:03 +01:00
|
|
|
|
2018-02-17 22:26:28 +01:00
|
|
|
TEST_F(clEnqueueUnmapMemObjTests, givenInvalidAddressWhenUnmappingOnGpuThenReturnError) {
|
2018-02-08 22:59:03 +01:00
|
|
|
auto buffer = std::unique_ptr<Buffer>(BufferHelper<BufferUseHostPtr<>>::create(pContext));
|
2018-02-17 22:26:28 +01:00
|
|
|
buffer->setSharingHandler(new SharingHandler());
|
|
|
|
|
EXPECT_FALSE(buffer->mappingOnCpuAllowed());
|
2018-02-08 22:59:03 +01:00
|
|
|
cl_int retVal = CL_SUCCESS;
|
|
|
|
|
|
2018-02-17 22:26:28 +01:00
|
|
|
auto mappedPtr = clEnqueueMapBuffer(pCommandQueue, buffer.get(), CL_TRUE, CL_MAP_READ, 0, 1, 0, nullptr, nullptr, &retVal);
|
2018-02-08 22:59:03 +01:00
|
|
|
EXPECT_EQ(CL_SUCCESS, retVal);
|
|
|
|
|
|
|
|
|
|
retVal = clEnqueueUnmapMemObject(
|
|
|
|
|
pCommandQueue,
|
|
|
|
|
buffer.get(),
|
2018-02-17 22:26:28 +01:00
|
|
|
ptrOffset(mappedPtr, buffer->getSize() + 1),
|
2018-02-08 22:59:03 +01:00
|
|
|
0,
|
|
|
|
|
nullptr,
|
|
|
|
|
nullptr);
|
|
|
|
|
EXPECT_EQ(CL_INVALID_VALUE, retVal);
|
|
|
|
|
}
|