//===------- Offload API tests - olGetEventElapsedTime --------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #include "../common/Fixtures.hpp" #include "llvm/Support/MemoryBuffer.h" #include #include namespace { struct olGetEventElapsedTimeTest : OffloadQueueTest { void SetUp() override { RETURN_ON_FATAL_FAILURE(OffloadQueueTest::SetUp()); ASSERT_TRUE(TestEnvironment::loadDeviceBinary("foo", Device, DeviceBin)); ASSERT_SUCCESS(olCreateProgram(Device, DeviceBin->getBufferStart(), DeviceBin->getBufferSize(), &Program)); ASSERT_SUCCESS(olGetSymbol(Program, "foo", OL_SYMBOL_KIND_KERNEL, &Kernel)); LaunchArgs.Dimensions = 1; LaunchArgs.GroupSize = {64, 1, 1}; LaunchArgs.NumGroups = {1, 1, 1}; LaunchArgs.DynSharedMemory = 0; ASSERT_SUCCESS(olMemAlloc(Device, OL_ALLOC_TYPE_MANAGED, LaunchArgs.GroupSize.x * sizeof(uint32_t), &Mem)); } void TearDown() override { if (Mem) ASSERT_SUCCESS(olMemFree(Mem)); if (Program) ASSERT_SUCCESS(olDestroyProgram(Program)); RETURN_ON_FATAL_FAILURE(OffloadQueueTest::TearDown()); } void launchFoo() { struct { void *Mem; } Args{Mem}; ASSERT_SUCCESS(olLaunchKernel(Queue, Device, Kernel, &Args, sizeof(Args), &LaunchArgs)); } std::unique_ptr DeviceBin; ol_program_handle_t Program = nullptr; ol_symbol_handle_t Kernel = nullptr; ol_kernel_launch_size_args_t LaunchArgs{}; void *Mem = nullptr; }; OFFLOAD_TESTS_INSTANTIATE_DEVICE_FIXTURE(olGetEventElapsedTimeTest); TEST_P(olGetEventElapsedTimeTest, Success) { ol_event_handle_t StartEvent = nullptr; ol_event_handle_t EndEvent = nullptr; ASSERT_SUCCESS(olCreateEvent(Queue, &StartEvent)); ASSERT_NE(StartEvent, nullptr); launchFoo(); ASSERT_SUCCESS(olCreateEvent(Queue, &EndEvent)); ASSERT_NE(EndEvent, nullptr); ASSERT_SUCCESS(olSyncEvent(EndEvent)); float ElapsedTime = -1.0f; ASSERT_SUCCESS(olGetEventElapsedTime(StartEvent, EndEvent, &ElapsedTime)); ASSERT_GE(ElapsedTime, 0.0f); ASSERT_SUCCESS(olDestroyEvent(StartEvent)); ASSERT_SUCCESS(olDestroyEvent(EndEvent)); } TEST_P(olGetEventElapsedTimeTest, SuccessMultipleCalls) { ol_event_handle_t StartEvent = nullptr; ol_event_handle_t EndEvent = nullptr; ASSERT_SUCCESS(olCreateEvent(Queue, &StartEvent)); ASSERT_NE(StartEvent, nullptr); launchFoo(); ASSERT_SUCCESS(olCreateEvent(Queue, &EndEvent)); ASSERT_NE(EndEvent, nullptr); ASSERT_SUCCESS(olSyncEvent(EndEvent)); float ElapsedTimeA = -1.0f; float ElapsedTimeB = -1.0f; ASSERT_SUCCESS(olGetEventElapsedTime(StartEvent, EndEvent, &ElapsedTimeA)); ASSERT_SUCCESS(olGetEventElapsedTime(StartEvent, EndEvent, &ElapsedTimeB)); ASSERT_GE(ElapsedTimeA, 0.0f); ASSERT_GE(ElapsedTimeB, 0.0f); ASSERT_SUCCESS(olDestroyEvent(StartEvent)); ASSERT_SUCCESS(olDestroyEvent(EndEvent)); } TEST_P(olGetEventElapsedTimeTest, InvalidNullStartEvent) { ol_event_handle_t EndEvent = nullptr; ASSERT_SUCCESS(olCreateEvent(Queue, &EndEvent)); float ElapsedTime = 0.0f; ASSERT_ERROR(OL_ERRC_INVALID_NULL_HANDLE, olGetEventElapsedTime(nullptr, EndEvent, &ElapsedTime)); ASSERT_SUCCESS(olDestroyEvent(EndEvent)); } TEST_P(olGetEventElapsedTimeTest, InvalidNullEndEvent) { ol_event_handle_t StartEvent = nullptr; ASSERT_SUCCESS(olCreateEvent(Queue, &StartEvent)); float ElapsedTime = 0.0f; ASSERT_ERROR(OL_ERRC_INVALID_NULL_HANDLE, olGetEventElapsedTime(StartEvent, nullptr, &ElapsedTime)); ASSERT_SUCCESS(olDestroyEvent(StartEvent)); } TEST_P(olGetEventElapsedTimeTest, InvalidNullElapsedTime) { ol_event_handle_t StartEvent = nullptr; ol_event_handle_t EndEvent = nullptr; ASSERT_SUCCESS(olCreateEvent(Queue, &StartEvent)); ASSERT_SUCCESS(olCreateEvent(Queue, &EndEvent)); ASSERT_ERROR(OL_ERRC_INVALID_NULL_POINTER, olGetEventElapsedTime(StartEvent, EndEvent, nullptr)); ASSERT_SUCCESS(olDestroyEvent(StartEvent)); ASSERT_SUCCESS(olDestroyEvent(EndEvent)); } } // namespace