1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
|
/*
* Copyright (C) 2017-2020 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#include "opencl/source/context/context.h"
#include "opencl/test/unit_test/fixtures/device_host_queue_fixture.h"
using namespace NEO;
using namespace DeviceHostQueue;
class GetDeviceQueueInfoTest : public DeviceHostQueueFixture<DeviceQueue> {
public:
using BaseClass = DeviceHostQueueFixture<DeviceQueue>;
void SetUp() override {
BaseClass::SetUp();
REQUIRE_DEVICE_ENQUEUE_OR_SKIP(pContext);
deviceQueue = createQueueObject(deviceQueueProperties::allProperties);
ASSERT_NE(deviceQueue, nullptr);
}
void TearDown() override {
if (deviceQueue)
delete deviceQueue;
BaseClass::TearDown();
}
DeviceQueue *deviceQueue = nullptr;
};
HWCMDTEST_F(IGFX_GEN8_CORE, GetDeviceQueueInfoTest, context) {
cl_context contextReturned = nullptr;
retVal = deviceQueue->getCommandQueueInfo(
CL_QUEUE_CONTEXT,
sizeof(contextReturned),
&contextReturned,
nullptr);
ASSERT_EQ(CL_SUCCESS, retVal);
EXPECT_EQ((cl_context)pContext, contextReturned);
}
HWCMDTEST_F(IGFX_GEN8_CORE, GetDeviceQueueInfoTest, device) {
cl_device_id deviceExpected = testedClDevice;
cl_device_id deviceIdReturned = nullptr;
retVal = deviceQueue->getCommandQueueInfo(
CL_QUEUE_DEVICE,
sizeof(deviceIdReturned),
&deviceIdReturned,
nullptr);
ASSERT_EQ(CL_SUCCESS, retVal);
EXPECT_EQ(deviceExpected, deviceIdReturned);
}
HWCMDTEST_F(IGFX_GEN8_CORE, GetDeviceQueueInfoTest, queueProperties) {
cl_command_queue_properties propertiesReturned = 0;
retVal = deviceQueue->getCommandQueueInfo(
CL_QUEUE_PROPERTIES,
sizeof(propertiesReturned),
&propertiesReturned,
nullptr);
ASSERT_EQ(CL_SUCCESS, retVal);
EXPECT_EQ(deviceQueueProperties::allProperties[1], propertiesReturned);
}
HWCMDTEST_F(IGFX_GEN8_CORE, GetDeviceQueueInfoTest, queueSize) {
cl_uint queueSizeReturned = 0;
retVal = deviceQueue->getCommandQueueInfo(
CL_QUEUE_SIZE,
sizeof(queueSizeReturned),
&queueSizeReturned,
nullptr);
ASSERT_EQ(CL_SUCCESS, retVal);
EXPECT_EQ(deviceQueue->getQueueSize(), queueSizeReturned);
}
// OCL 2.1
HWCMDTEST_F(IGFX_GEN8_CORE, GetDeviceQueueInfoTest, queueDeviceDefault) {
cl_command_queue commandQueueReturned = nullptr;
retVal = deviceQueue->getCommandQueueInfo(
CL_QUEUE_DEVICE_DEFAULT,
sizeof(commandQueueReturned),
&commandQueueReturned,
nullptr);
EXPECT_EQ(CL_SUCCESS, retVal);
// 1 device queue is supported which is default
EXPECT_EQ(deviceQueue, commandQueueReturned);
}
HWCMDTEST_F(IGFX_GEN8_CORE, GetDeviceQueueInfoTest, profiling) {
EXPECT_TRUE(deviceQueue->isProfilingEnabled());
}
HWCMDTEST_F(IGFX_GEN8_CORE, GetDeviceQueueInfoTest, invalidParameter) {
uint32_t tempValue = 0;
retVal = deviceQueue->getCommandQueueInfo(
static_cast<cl_command_queue_info>(0),
sizeof(tempValue),
&tempValue,
nullptr);
EXPECT_EQ(tempValue, 0u);
EXPECT_EQ(CL_INVALID_VALUE, retVal);
}
|