/* * Copyright (C) 2017-2021 Intel Corporation * * SPDX-License-Identifier: MIT * */ #include "shared/source/helpers/ptr_math.h" #include "opencl/test/unit_test/api/cl_api_tests.h" #include "opencl/test/unit_test/mocks/mock_platform.h" using namespace NEO; typedef api_tests clCreateContextTests; namespace ClCreateContextTests { static int cbInvoked = 0; void CL_CALLBACK eventCallBack(const char *, const void *, size_t, void *) { cbInvoked++; } TEST_F(clCreateContextTests, GivenValidParamsWhenCreatingContextThenContextIsCreated) { auto context = clCreateContext(nullptr, 1u, &testedClDevice, nullptr, nullptr, &retVal); ASSERT_EQ(CL_SUCCESS, retVal); ASSERT_NE(nullptr, context); EXPECT_NE(nullptr, context->dispatch.icdDispatch); EXPECT_NE(nullptr, context->dispatch.crtDispatch); retVal = clReleaseContext(context); EXPECT_EQ(CL_SUCCESS, retVal); } TEST_F(clCreateContextTests, GivenNullptrRetValWhenCreatingContextThenContextIsCreated) { auto context = clCreateContext(nullptr, 1u, &testedClDevice, nullptr, nullptr, nullptr); ASSERT_NE(nullptr, context); EXPECT_NE(nullptr, context->dispatch.icdDispatch); EXPECT_NE(nullptr, context->dispatch.crtDispatch); retVal = clReleaseContext(context); EXPECT_EQ(CL_SUCCESS, retVal); } TEST_F(clCreateContextTests, GivenZeroDevicesWhenCreatingContextThenInvalidValueErrorIsReturned) { auto context = clCreateContext(nullptr, 0, &testedClDevice, nullptr, nullptr, &retVal); ASSERT_EQ(nullptr, context); ASSERT_EQ(CL_INVALID_VALUE, retVal); } TEST_F(clCreateContextTests, GivenInvalidUserDataWhenCreatingContextThenInvalidValueErrorIsReturned) { cl_int someData = 25; auto context = clCreateContext(nullptr, 1u, &testedClDevice, nullptr, &someData, &retVal); ASSERT_EQ(nullptr, context); ASSERT_EQ(CL_INVALID_VALUE, retVal); } TEST_F(clCreateContextTests, GivenInvalidDeviceListWhenCreatingContextThenInvalidDeviceErrorIsReturned) { cl_device_id devList[2]; devList[0] = testedClDevice; devList[1] = (cl_device_id)ptrGarbage; auto context = clCreateContext(nullptr, 2, devList, nullptr, nullptr, &retVal); ASSERT_EQ(nullptr, context); ASSERT_EQ(CL_INVALID_DEVICE, retVal); } TEST_F(clCreateContextTests, GivenNullDeviceListWhenCreatingContextThenInvalidValueErrorIsReturned) { auto context = clCreateContext(nullptr, 2, nullptr, nullptr, nullptr, &retVal); ASSERT_EQ(nullptr, context); ASSERT_EQ(CL_INVALID_VALUE, retVal); } TEST_F(clCreateContextTests, GivenNullUserDataWhenCreatingContextThenContextIsCreated) { auto context = clCreateContext(nullptr, 1u, &testedClDevice, eventCallBack, nullptr, &retVal); ASSERT_NE(nullptr, context); retVal = clReleaseContext(context); EXPECT_EQ(CL_SUCCESS, retVal); } TEST_F(clCreateContextTests, givenMultipleRootDevicesWhenCreateContextThenOutOrHostMemoryErrorIsReturned) { UltClDeviceFactory deviceFactory{2, 0}; cl_device_id devices[] = {deviceFactory.rootDevices[0], deviceFactory.rootDevices[1]}; auto context = clCreateContext(nullptr, 2u, devices, eventCallBack, nullptr, &retVal); EXPECT_EQ(nullptr, context); EXPECT_EQ(CL_OUT_OF_HOST_MEMORY, retVal); } TEST_F(clCreateContextTests, givenEnabledMultipleRootDeviceSupportWhenCreateContextWithMultipleRootDevicesThenContextIsCreated) { UltClDeviceFactory deviceFactory{2, 0}; DebugManager.flags.EnableMultiRootDeviceContexts.set(true); cl_device_id devices[] = {deviceFactory.rootDevices[0], deviceFactory.rootDevices[1]}; auto context = clCreateContext(nullptr, 2u, devices, eventCallBack, nullptr, &retVal); EXPECT_NE(nullptr, context); EXPECT_EQ(CL_SUCCESS, retVal); clReleaseContext(context); } TEST_F(clCreateContextTests, givenMultipleRootDevicesWhenCreateContextThenRootDeviceIndicesSetIsFilled) { UltClDeviceFactory deviceFactory{3, 2}; DebugManager.flags.EnableMultiRootDeviceContexts.set(true); cl_device_id devices[] = {deviceFactory.rootDevices[0], deviceFactory.rootDevices[1], deviceFactory.rootDevices[2]}; auto context = clCreateContext(nullptr, 3u, devices, eventCallBack, nullptr, &retVal); EXPECT_NE(nullptr, context); EXPECT_EQ(CL_SUCCESS, retVal); auto pContext = castToObject(context); auto rootDeviceIndices = pContext->getRootDeviceIndices(); for (auto numDevice = 0u; numDevice < pContext->getNumDevices(); numDevice++) { auto rootDeviceIndex = rootDeviceIndices.find(pContext->getDevice(numDevice)->getRootDeviceIndex()); EXPECT_EQ(*rootDeviceIndex, pContext->getDevice(numDevice)->getRootDeviceIndex()); } clReleaseContext(context); } TEST_F(clCreateContextTests, givenMultipleRootDevicesWhenCreateContextThenMaxRootDeviceIndexIsProperlyFilled) { UltClDeviceFactory deviceFactory{3, 0}; DebugManager.flags.EnableMultiRootDeviceContexts.set(true); cl_device_id devices[] = {deviceFactory.rootDevices[0], deviceFactory.rootDevices[2]}; auto context = clCreateContext(nullptr, 2u, devices, eventCallBack, nullptr, &retVal); EXPECT_NE(nullptr, context); EXPECT_EQ(CL_SUCCESS, retVal); auto pContext = castToObject(context); EXPECT_EQ(2u, pContext->getMaxRootDeviceIndex()); clReleaseContext(context); } TEST_F(clCreateContextTests, givenMultipleRootDevicesWhenCreateContextThenSpecialQueueIsProperlyFilled) { UltClDeviceFactory deviceFactory{3, 0}; DebugManager.flags.EnableMultiRootDeviceContexts.set(true); cl_device_id devices[] = {deviceFactory.rootDevices[0], deviceFactory.rootDevices[2]}; auto context = clCreateContext(nullptr, 2u, devices, eventCallBack, nullptr, &retVal); EXPECT_NE(nullptr, context); EXPECT_EQ(CL_SUCCESS, retVal); auto pContext = castToObject(context); auto rootDeviceIndices = pContext->getRootDeviceIndices(); EXPECT_EQ(2u, pContext->getMaxRootDeviceIndex()); StackVec specialQueues; specialQueues.resize(pContext->getMaxRootDeviceIndex()); for (auto numDevice = 0u; numDevice < pContext->getNumDevices(); numDevice++) { auto rootDeviceIndex = rootDeviceIndices.find(pContext->getDevice(numDevice)->getRootDeviceIndex()); EXPECT_EQ(*rootDeviceIndex, pContext->getDevice(numDevice)->getRootDeviceIndex()); EXPECT_EQ(*rootDeviceIndex, pContext->getSpecialQueue(*rootDeviceIndex)->getDevice().getRootDeviceIndex()); specialQueues[numDevice] = pContext->getSpecialQueue(*rootDeviceIndex); } EXPECT_EQ(2u, specialQueues.size()); clReleaseContext(context); } TEST_F(clCreateContextTests, givenInvalidContextCreationPropertiesThenContextCreationFails) { cl_context_properties invalidProperties[3] = {CL_CONTEXT_PLATFORM, (cl_context_properties) nullptr, 0}; auto context = clCreateContext(invalidProperties, 1u, &testedClDevice, nullptr, nullptr, &retVal); EXPECT_EQ(CL_INVALID_PLATFORM, retVal); EXPECT_EQ(nullptr, context); } TEST_F(clCreateContextTests, GivenNonDefaultPlatformInContextCreationPropertiesWhenCreatingContextThenSuccessIsReturned) { auto nonDefaultPlatform = std::make_unique(); nonDefaultPlatform->initializeWithNewDevices(); cl_platform_id nonDefaultPlatformCl = nonDefaultPlatform.get(); cl_device_id clDevice = nonDefaultPlatform->getClDevice(0); cl_context_properties properties[3] = {CL_CONTEXT_PLATFORM, reinterpret_cast(nonDefaultPlatformCl), 0}; auto clContext = clCreateContext(properties, 1, &clDevice, nullptr, nullptr, &retVal); EXPECT_EQ(CL_SUCCESS, retVal); EXPECT_NE(nullptr, clContext); clReleaseContext(clContext); } TEST_F(clCreateContextTests, GivenNonDefaultPlatformWithInvalidIcdDispatchInContextCreationPropertiesWhenCreatingContextThenInvalidPlatformErrorIsReturned) { auto nonDefaultPlatform = std::make_unique(); nonDefaultPlatform->initializeWithNewDevices(); cl_platform_id nonDefaultPlatformCl = nonDefaultPlatform.get(); nonDefaultPlatformCl->dispatch.icdDispatch = reinterpret_cast(nonDefaultPlatform.get()); cl_device_id clDevice = nonDefaultPlatform->getClDevice(0); cl_context_properties properties[3] = {CL_CONTEXT_PLATFORM, reinterpret_cast(nonDefaultPlatformCl), 0}; auto clContext = clCreateContext(properties, 1, &clDevice, nullptr, nullptr, &retVal); EXPECT_EQ(CL_INVALID_PLATFORM, retVal); EXPECT_EQ(nullptr, clContext); } TEST_F(clCreateContextTests, GivenDeviceNotAssociatedToPlatformInPropertiesWhenCreatingContextThenInvalidDeviceErrorIsReturned) { auto nonDefaultPlatform = std::make_unique(); nonDefaultPlatform->initializeWithNewDevices(); cl_device_id clDevice = platform()->getClDevice(0); cl_platform_id nonDefaultPlatformCl = nonDefaultPlatform.get(); cl_context_properties properties[3] = {CL_CONTEXT_PLATFORM, reinterpret_cast(nonDefaultPlatformCl), 0}; auto clContext = clCreateContext(properties, 1, &clDevice, nullptr, nullptr, &retVal); EXPECT_EQ(CL_INVALID_DEVICE, retVal); EXPECT_EQ(nullptr, clContext); } TEST_F(clCreateContextTests, GivenDevicesFromDifferentPlatformsWhenCreatingContextWithoutSpecifiedPlatformThenInvalidDeviceErrorIsReturned) { auto platform1 = std::make_unique(); auto platform2 = std::make_unique(); platform1->initializeWithNewDevices(); platform2->initializeWithNewDevices(); cl_device_id clDevices[] = {platform1->getClDevice(0), platform2->getClDevice(0)}; auto clContext = clCreateContext(nullptr, 2, clDevices, nullptr, nullptr, &retVal); EXPECT_EQ(CL_INVALID_DEVICE, retVal); EXPECT_EQ(nullptr, clContext); } TEST_F(clCreateContextTests, GivenDevicesFromDifferentPlatformsWhenCreatingContextWithSpecifiedPlatformThenInvalidDeviceErrorIsReturned) { auto platform1 = std::make_unique(); auto platform2 = std::make_unique(); platform1->initializeWithNewDevices(); platform2->initializeWithNewDevices(); cl_device_id clDevices[] = {platform1->getClDevice(0), platform2->getClDevice(0)}; cl_platform_id clPlatform = platform1.get(); cl_context_properties properties[3] = {CL_CONTEXT_PLATFORM, reinterpret_cast(clPlatform), 0}; auto clContext = clCreateContext(properties, 2, clDevices, nullptr, nullptr, &retVal); EXPECT_EQ(CL_INVALID_DEVICE, retVal); EXPECT_EQ(nullptr, clContext); } } // namespace ClCreateContextTests