06749136b9
Catch2 tests for : hipStreamAddCallback, hipStreamCreateWithFlags, hipStreamCreateWithPriority, hipExtStreamCreateWithCUMask Change-Id: Ia99c06b1e97fc945f1a740e47710f4dcd70f38cd
606 baris
19 KiB
C++
606 baris
19 KiB
C++
/*
|
|
Copyright (c) 2021 Advanced Micro Devices, Inc. All rights reserved.
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
in the Software without restriction, including without limitation the rights
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
furnished to do so, subject to the following conditions:
|
|
The above copyright notice and this permission notice shall be included in
|
|
all copies or substantial portions of the Software.
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
THE SOFTWARE.
|
|
*/
|
|
|
|
/**
|
|
Testcase Scenarios :
|
|
|
|
1)Create streams with default flag for all available priority levels and
|
|
queue tasks in each of these streams, perform device synchronize and validate behavior.
|
|
|
|
2)Create streams with non-blocking flag for all available priority levels and
|
|
queue tasks in each of these streams, perform stream synchronize and validate behavior.
|
|
|
|
3)Create streams with default flag for all available priority levels and
|
|
queue tasks in each of these streams, perform stream synchronize and validate behavior.
|
|
|
|
4)Create streams with non-blocking flag for all available priority levels and
|
|
queue tasks in each of these streams, perform device synchronize and validate behavior.
|
|
|
|
5)Create a stream for each priority level with default flag, Launch memcpy and kernel
|
|
tasks on these streams from multiple threads. Validate all the results.
|
|
|
|
6)Create a stream for each priority level with non-blocking flag, Launch memcpy and
|
|
kernel tasks on these streams from multiple threads. Validate all the results.
|
|
|
|
7) Validate negative scenarios for hipStreamCreateWithPriority api.
|
|
|
|
8) Validate stream priorities with event after classifying them as low, medium, high.
|
|
*/
|
|
|
|
#include <hip_test_common.hh>
|
|
#include <hip_test_kernels.hh>
|
|
#include <atomic>
|
|
#include <vector>
|
|
|
|
#define MEMCPYSIZE 64*1024*1024
|
|
#define MEMCPYSIZE2 1024*1024
|
|
#define NUMITERS 2
|
|
#define GRIDSIZE 1024
|
|
#define BLOCKSIZE 256
|
|
#define TOTALTHREADS 16
|
|
|
|
namespace hipStreamCreateWithPriorityTest {
|
|
|
|
std::atomic<int> g_thTestPassed(1);
|
|
// helper rountine to initialize memory
|
|
template <typename T>
|
|
void mem_init(T* buf, size_t n) {
|
|
for (size_t i = 0; i < n; i++) {
|
|
buf[i] = i;
|
|
}
|
|
}
|
|
|
|
// kernel to copy n elements from src to dst
|
|
template <typename T>
|
|
__global__ void memcpy_kernel(T* dst, T* src, size_t n) {
|
|
int num = gridDim.x * blockDim.x;
|
|
int id = blockDim.x * blockIdx.x + threadIdx.x;
|
|
|
|
for (size_t i = id; i < n; i += num) {
|
|
dst[i] = src[i];
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Scenario: Create a stream for all available priority levels
|
|
* and queue tasks in each of these streams and default stream.
|
|
* Validate the calculated results.
|
|
*/
|
|
void funcTestsForAllPriorityLevelsWrtNullStrm(unsigned int flags,
|
|
bool deviceSynchronize) {
|
|
int priority;
|
|
int priority_low{};
|
|
int priority_high{};
|
|
size_t size = MEMCPYSIZE2*sizeof(int);
|
|
// Test is to get the Stream Priority Range
|
|
HIP_CHECK(hipDeviceGetStreamPriorityRange(&priority_low, &priority_high));
|
|
|
|
// Check if priorities are indeed supported
|
|
if (priority_low == priority_high) {
|
|
WARN("Stream priority range not supported. Skipping test.");
|
|
return;
|
|
}
|
|
|
|
int numOfPriorities = priority_low - priority_high;
|
|
INFO("numOfPriorities = " << numOfPriorities);
|
|
const int arr_size = numOfPriorities + 1;
|
|
// 0 idx is for default stream
|
|
hipStream_t *stream = reinterpret_cast<hipStream_t*>(
|
|
malloc(arr_size*sizeof(hipStream_t)));
|
|
REQUIRE(stream != nullptr);
|
|
stream[0] = 0;
|
|
int count = 1;
|
|
// Create a stream for each of the priority levels
|
|
for (priority = priority_high; priority < priority_low; priority++) {
|
|
HIP_CHECK(hipStreamCreateWithPriority(&stream[count++],
|
|
flags, priority));
|
|
}
|
|
// Allocate memory
|
|
int **A_d = reinterpret_cast<int**>(malloc(arr_size*sizeof(int*)));
|
|
int **C_d = reinterpret_cast<int**>(malloc(arr_size*sizeof(int*)));
|
|
int **A_h = reinterpret_cast<int**>(malloc(arr_size*sizeof(int*)));
|
|
int **C_h = reinterpret_cast<int**>(malloc(arr_size*sizeof(int*)));
|
|
|
|
REQUIRE(A_d != nullptr);
|
|
REQUIRE(C_d != nullptr);
|
|
REQUIRE(A_h != nullptr);
|
|
REQUIRE(C_h != nullptr);
|
|
|
|
for (int idx = 0; idx < arr_size; idx++) {
|
|
A_h[idx] = reinterpret_cast<int*>(malloc(size));
|
|
REQUIRE(A_h[idx] != nullptr);
|
|
C_h[idx] = reinterpret_cast<int*>(malloc(size));
|
|
REQUIRE(C_h[idx] != nullptr);
|
|
HIP_CHECK(hipMalloc(&A_d[idx], size));
|
|
HIP_CHECK(hipMalloc(&C_d[idx], size));
|
|
}
|
|
|
|
// Initialize host memory
|
|
constexpr int initVal = 2;
|
|
for (int idx = 0; idx < arr_size; idx++) {
|
|
for (int idy = 0; idy < MEMCPYSIZE2; idy++) {
|
|
A_h[idx][idy] = initVal;
|
|
}
|
|
}
|
|
|
|
// Launch task on each stream
|
|
for (int idx = 0; idx < arr_size; idx++) {
|
|
HIP_CHECK(hipMemcpyAsync(A_d[idx], A_h[idx], size,
|
|
hipMemcpyHostToDevice, stream[idx]));
|
|
hipLaunchKernelGGL((HipTest::vector_square), dim3(GRIDSIZE),
|
|
dim3(BLOCKSIZE), 0, stream[idx], A_d[idx],
|
|
C_d[idx], MEMCPYSIZE2);
|
|
HIP_CHECK(hipMemcpyAsync(C_h[idx], C_d[idx], size,
|
|
hipMemcpyDeviceToHost, stream[idx]));
|
|
}
|
|
|
|
if (deviceSynchronize) {
|
|
HIP_CHECK(hipDeviceSynchronize());
|
|
}
|
|
|
|
// Validate the output of each queue
|
|
for (int idx = 0; idx < arr_size; idx++) {
|
|
if (!deviceSynchronize) {
|
|
HIP_CHECK(hipStreamSynchronize(stream[idx]));
|
|
}
|
|
for (int idy = 0; idy < MEMCPYSIZE2; idy++) {
|
|
if (C_h[idx][idy] != A_h[idx][idy] * A_h[idx][idy]) {
|
|
INFO("Data mismatch at idx:" << idx << " idy:" << idy);
|
|
REQUIRE(false);
|
|
}
|
|
}
|
|
}
|
|
|
|
// Deallocate memory
|
|
for (int idx = 0; idx < arr_size; idx++) {
|
|
HIP_CHECK(hipFree(reinterpret_cast<void*>(C_d[idx])));
|
|
HIP_CHECK(hipFree(reinterpret_cast<void*>(A_d[idx])));
|
|
free(C_h[idx]);
|
|
free(A_h[idx]);
|
|
}
|
|
|
|
// Destroy the stream for each of the priority levels
|
|
count = 1;
|
|
for (priority = priority_high; priority < priority_low; priority++) {
|
|
HIP_CHECK(hipStreamDestroy(stream[count++]));
|
|
}
|
|
free(stream);
|
|
free(A_d);
|
|
free(C_d);
|
|
free(A_h);
|
|
free(C_h);
|
|
}
|
|
|
|
/**
|
|
* Scenario: Queue tasks in each of these streams and default stream.
|
|
* Validate the calculated results.
|
|
*/
|
|
void queueTasksInStreams(std::vector<hipStream_t> *stream,
|
|
const int arrsize) {
|
|
size_t size = MEMCPYSIZE2*sizeof(int);
|
|
// Allocate memory
|
|
int **A_d = reinterpret_cast<int**>(malloc(arrsize*sizeof(int *)));
|
|
int **C_d = reinterpret_cast<int**>(malloc(arrsize*sizeof(int *)));
|
|
int **A_h = reinterpret_cast<int**>(malloc(arrsize*sizeof(int *)));
|
|
int **C_h = reinterpret_cast<int**>(malloc(arrsize*sizeof(int *)));
|
|
|
|
HIPASSERT(A_d != nullptr);
|
|
HIPASSERT(C_d != nullptr);
|
|
HIPASSERT(A_h != nullptr);
|
|
HIPASSERT(C_h != nullptr);
|
|
|
|
for (int idx = 0; idx < arrsize; idx++) {
|
|
A_h[idx] = reinterpret_cast<int*>(malloc(size));
|
|
HIPASSERT(A_h[idx] != nullptr);
|
|
C_h[idx] = reinterpret_cast<int*>(malloc(size));
|
|
HIPASSERT(C_h[idx] != nullptr);
|
|
HIPCHECK(hipMalloc(&A_d[idx], size));
|
|
HIPCHECK(hipMalloc(&C_d[idx], size));
|
|
}
|
|
// Initialize host memory
|
|
constexpr int initVal = 2;
|
|
for (int idx = 0; idx < arrsize; idx++) {
|
|
for (int idy = 0; idy < MEMCPYSIZE2; idy++) {
|
|
A_h[idx][idy] = initVal;
|
|
}
|
|
}
|
|
// Launch task on each stream
|
|
for (int idx = 0; idx < arrsize; idx++) {
|
|
HIPCHECK(hipMemcpyAsync(A_d[idx], A_h[idx], size,
|
|
hipMemcpyHostToDevice, (*stream)[idx]));
|
|
hipLaunchKernelGGL((HipTest::vector_square), dim3(GRIDSIZE),
|
|
dim3(BLOCKSIZE), 0, (*stream)[idx], A_d[idx],
|
|
C_d[idx], MEMCPYSIZE2);
|
|
HIPCHECK(hipMemcpyAsync(C_h[idx], C_d[idx], size,
|
|
hipMemcpyDeviceToHost, (*stream)[idx]));
|
|
}
|
|
|
|
bool isPassed = true;
|
|
// Validate the output of each queue
|
|
for (int idx = 0; idx < arrsize; idx++) {
|
|
HIPCHECK(hipStreamSynchronize((*stream)[idx]));
|
|
for (int idy = 0; idy < MEMCPYSIZE2; idy++) {
|
|
if (C_h[idx][idy] != A_h[idx][idy] * A_h[idx][idy]) {
|
|
UNSCOPED_INFO("Data mismatch at idx:" << idx << " idy:" << idy);
|
|
isPassed = false;
|
|
break;
|
|
}
|
|
}
|
|
if (false == isPassed) break;
|
|
}
|
|
// Deallocate memory
|
|
for (int idx = 0; idx < arrsize; idx++) {
|
|
HIPCHECK(hipFree(reinterpret_cast<void*>(C_d[idx])));
|
|
HIPCHECK(hipFree(reinterpret_cast<void*>(A_d[idx])));
|
|
free(C_h[idx]);
|
|
free(A_h[idx]);
|
|
}
|
|
free(A_d);
|
|
free(C_d);
|
|
free(A_h);
|
|
free(C_h);
|
|
g_thTestPassed &= static_cast<int>(isPassed);
|
|
}
|
|
|
|
/**
|
|
* Scenario:
|
|
* Common streams used across multiple threads:Create a stream for each
|
|
* priority level (flag = hipStreamDefault/hipStreamNonBlocking)
|
|
* and 1 default stream.
|
|
* Launch memcpy and kernel tasks on these streams from multiple threads
|
|
* (use 16 threads). Validate all the results.
|
|
*/
|
|
bool runFuncTestsForAllPriorityLevelsMultThread(unsigned int flags) {
|
|
bool TestPassed = true;
|
|
std::thread T[TOTALTHREADS];
|
|
int priority;
|
|
int priority_low;
|
|
int priority_high;
|
|
// Test is to get the Stream Priority Range
|
|
HIP_CHECK(hipDeviceGetStreamPriorityRange(&priority_low, &priority_high));
|
|
|
|
// Check if priorities are indeed supported
|
|
if (priority_low == priority_high) {
|
|
WARN("Stream priority range not supported. Skipping test.");
|
|
return true;
|
|
}
|
|
|
|
int numOfPriorities = priority_low - priority_high;
|
|
INFO("numOfPriorities : " << numOfPriorities);
|
|
|
|
// 0 idx is for default stream
|
|
std::vector<hipStream_t> stream(numOfPriorities + 1);
|
|
stream[0] = 0;
|
|
|
|
// Create a stream for each of the priority levels
|
|
int count = 1;
|
|
for (priority = priority_high; priority < priority_low; priority++) {
|
|
HIP_CHECK(hipStreamCreateWithPriority(&stream[count++], flags,
|
|
priority));
|
|
}
|
|
|
|
for (int i = 0; i < TOTALTHREADS; i++) {
|
|
T[i] = std::thread(queueTasksInStreams,
|
|
&stream, numOfPriorities + 1);
|
|
}
|
|
|
|
for (int i=0; i < TOTALTHREADS; i++) {
|
|
T[i].join();
|
|
}
|
|
if (g_thTestPassed) {
|
|
TestPassed = true;
|
|
} else {
|
|
TestPassed = false;
|
|
}
|
|
|
|
// Destroy the stream for each of the priority levels
|
|
count = 1;
|
|
for (priority = priority_high; priority < priority_low; priority++) {
|
|
HIP_CHECK(hipStreamDestroy(stream[count++]));
|
|
}
|
|
return TestPassed;
|
|
}
|
|
|
|
|
|
template <typename T>
|
|
bool validateStreamPrioritiesWithEvents() {
|
|
size_t size = NUMITERS*MEMCPYSIZE;
|
|
|
|
// get the range of priorities available
|
|
#define OP(x) \
|
|
int priority_##x; \
|
|
bool enable_priority_##x = false;
|
|
OP(low)
|
|
OP(normal)
|
|
OP(high)
|
|
#undef OP
|
|
HIP_CHECK(hipDeviceGetStreamPriorityRange(&priority_low, &priority_high));
|
|
|
|
INFO("HIP stream priority range - low: " << priority_low << ",high: "
|
|
<< priority_high << ",normal: "
|
|
<< (priority_low + priority_high)/2);
|
|
// Check if priorities are indeed supported
|
|
if (priority_low == priority_high) {
|
|
WARN("Stream priority range not supported. Skipping test.");
|
|
return true;
|
|
}
|
|
|
|
// Enable/disable priorities based on number of available priority levels
|
|
enable_priority_low = true;
|
|
enable_priority_high = true;
|
|
if ((priority_low - priority_high) > 1) {
|
|
enable_priority_normal = true;
|
|
}
|
|
if (enable_priority_normal) {
|
|
priority_normal = ((priority_low + priority_high) / 2);
|
|
}
|
|
// create streams with highest and lowest available priorities
|
|
#define OP(x)\
|
|
hipStream_t stream_##x;\
|
|
if (enable_priority_##x) {\
|
|
HIP_CHECK(hipStreamCreateWithPriority(&stream_##x, \
|
|
hipStreamDefault, priority_##x));\
|
|
}
|
|
OP(low)
|
|
OP(normal)
|
|
OP(high)
|
|
#undef OP
|
|
|
|
// allocate and initialise host source and destination buffers
|
|
#define OP(x) \
|
|
T* src_h_##x; \
|
|
T* dst_h_##x; \
|
|
if (enable_priority_##x) { \
|
|
src_h_##x = reinterpret_cast<T*>(malloc(size)); \
|
|
REQUIRE(src_h_##x != nullptr); \
|
|
mem_init<T>(src_h_##x, (size / sizeof(T))); \
|
|
dst_h_##x = reinterpret_cast<T*>(malloc(size)); \
|
|
REQUIRE(dst_h_##x != nullptr); \
|
|
memset(dst_h_##x, 0, size); \
|
|
}
|
|
OP(low)
|
|
OP(normal)
|
|
OP(high)
|
|
#undef OP
|
|
|
|
// allocate and initialize device source and destination buffers
|
|
#define OP(x) \
|
|
T* src_d_##x; \
|
|
T* dst_d_##x; \
|
|
if (enable_priority_##x) { \
|
|
HIP_CHECK(hipMalloc(&src_d_##x, size)); \
|
|
HIP_CHECK( \
|
|
hipMemcpy(src_d_##x, src_h_##x, size, hipMemcpyHostToDevice)); \
|
|
HIP_CHECK(hipMalloc(&dst_d_##x, size)); \
|
|
}
|
|
OP(low)
|
|
OP(normal)
|
|
OP(high)
|
|
#undef OP
|
|
|
|
// create events for measuring time spent in kernel execution
|
|
#define OP(x) \
|
|
hipEvent_t event_start_##x; \
|
|
hipEvent_t event_end_##x; \
|
|
if (enable_priority_##x) { \
|
|
HIP_CHECK(hipEventCreate(&event_start_##x)); \
|
|
HIP_CHECK(hipEventCreate(&event_end_##x)); \
|
|
}
|
|
OP(low)
|
|
OP(normal)
|
|
OP(high)
|
|
#undef OP
|
|
|
|
// record start events for each of the priority streams
|
|
#define OP(x) \
|
|
if (enable_priority_##x) { \
|
|
HIP_CHECK(\
|
|
hipEventRecord(event_start_##x, stream_##x)); \
|
|
}
|
|
OP(low)
|
|
OP(normal)
|
|
OP(high)
|
|
#undef OP
|
|
|
|
// launch kernels repeatedly on each of the prioritiy streams
|
|
for (int i = 0; i < static_cast<int>(size); i += MEMCPYSIZE) {
|
|
int j = i / sizeof(T);
|
|
#define OP(x) \
|
|
if (enable_priority_##x) { \
|
|
hipLaunchKernelGGL((memcpy_kernel<T>), dim3(GRIDSIZE), \
|
|
dim3(BLOCKSIZE), 0, stream_##x, dst_d_##x + j, src_d_##x + j, \
|
|
(MEMCPYSIZE / sizeof(T))); \
|
|
}
|
|
OP(low)
|
|
OP(normal)
|
|
OP(high)
|
|
#undef OP
|
|
}
|
|
|
|
// record end events for each of the priority streams
|
|
#define OP(x) \
|
|
if (enable_priority_##x) { \
|
|
HIP_CHECK(hipEventRecord(event_end_##x, stream_##x)); \
|
|
}
|
|
OP(low)
|
|
OP(normal)
|
|
OP(high)
|
|
#undef OP
|
|
|
|
// synchronize events for each of the priority streams
|
|
#define OP(x) \
|
|
if (enable_priority_##x) { \
|
|
HIP_CHECK(hipEventSynchronize(event_end_##x)); \
|
|
}
|
|
OP(low)
|
|
OP(normal)
|
|
OP(high)
|
|
#undef OP
|
|
|
|
// compute time spent for memcpy in each stream
|
|
#define OP(x) \
|
|
float time_spent_##x; \
|
|
if (enable_priority_##x) { \
|
|
HIP_CHECK(hipEventElapsedTime(&time_spent_##x, \
|
|
event_start_##x, event_end_##x)); \
|
|
INFO("time spent for memcpy in " << #x << \
|
|
" priority stream: " << time_spent_##x << " ms"); \
|
|
}
|
|
OP(low)
|
|
OP(normal)
|
|
OP(high)
|
|
#undef OP
|
|
|
|
// sanity check
|
|
#define OP(x) \
|
|
if (enable_priority_##x) { \
|
|
HIP_CHECK(hipMemcpy(dst_h_##x, dst_d_##x, size, \
|
|
hipMemcpyDeviceToHost)); \
|
|
if (memcmp(dst_h_##x, src_h_##x, size) != 0) { \
|
|
REQUIRE(false); \
|
|
} \
|
|
}
|
|
OP(low)
|
|
OP(normal)
|
|
OP(high)
|
|
#undef OP
|
|
|
|
// validate that stream priorities are working as expected
|
|
#define OP(x, y) \
|
|
if (enable_priority_##x && enable_priority_##y) { \
|
|
if ((1.05f * time_spent_##x) < time_spent_##y) { \
|
|
INFO("time_spent_##x : " << time_spent_##x << \
|
|
"time_spent_##y : " << time_spent_##y); \
|
|
REQUIRE(false); \
|
|
} \
|
|
}
|
|
OP(low, normal)
|
|
OP(normal, high)
|
|
OP(low, high)
|
|
#undef OP
|
|
|
|
return true;
|
|
}
|
|
|
|
} // namespace hipStreamCreateWithPriorityTest
|
|
|
|
|
|
|
|
/**
|
|
Tests following scenarios.
|
|
1)Create streams with default flag for all available priority levels and
|
|
queue tasks in each of these streams, perform device synchronize and validate behavior.
|
|
2)Create streams with non-blocking flag for all available priority levels and
|
|
queue tasks in each of these streams, perform stream synchronize and validate behavior.
|
|
3)Create streams with default flag for all available priority levels and
|
|
queue tasks in each of these streams, perform stream synchronize and validate behavior.
|
|
4)Create streams with non-blocking flag for all available priority levels and
|
|
queue tasks in each of these streams, perform device synchronize and validate behavior.
|
|
*/
|
|
TEST_CASE("Unit_hipStreamCreateWithPriority_FunctionalForAllPriorities") {
|
|
SECTION("Default flag and device synchronize") {
|
|
hipStreamCreateWithPriorityTest::
|
|
funcTestsForAllPriorityLevelsWrtNullStrm(hipStreamDefault, true);
|
|
}
|
|
|
|
SECTION("Stream non-blocking flag and stream synchronize") {
|
|
hipStreamCreateWithPriorityTest::
|
|
funcTestsForAllPriorityLevelsWrtNullStrm(hipStreamNonBlocking, false);
|
|
}
|
|
|
|
SECTION("Default flag and stream synchronize") {
|
|
hipStreamCreateWithPriorityTest::
|
|
funcTestsForAllPriorityLevelsWrtNullStrm(hipStreamDefault, false);
|
|
}
|
|
|
|
SECTION("Stream non-blocking flag and device synchronize") {
|
|
hipStreamCreateWithPriorityTest::
|
|
funcTestsForAllPriorityLevelsWrtNullStrm(hipStreamNonBlocking, true);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Create a stream for each priority level with default flag, Launch memcpy and kernel
|
|
* tasks on these streams from multiple threads. Validate all the results.
|
|
*/
|
|
TEST_CASE("Unit_hipStreamCreateWithPriority_MulthreadDefaultflag") {
|
|
bool TestPassed = true;
|
|
TestPassed = hipStreamCreateWithPriorityTest::
|
|
runFuncTestsForAllPriorityLevelsMultThread(hipStreamDefault);
|
|
REQUIRE(TestPassed);
|
|
}
|
|
|
|
/**
|
|
* Create a stream for each priority level with non-blocking flag, Launch memcpy and
|
|
* kernel tasks on these streams from multiple threads. Validate all the results.
|
|
*/
|
|
TEST_CASE("Unit_hipStreamCreateWithPriority_MulthreadNonblockingflag") {
|
|
bool TestPassed = true;
|
|
TestPassed = hipStreamCreateWithPriorityTest::
|
|
runFuncTestsForAllPriorityLevelsMultThread(hipStreamNonBlocking);
|
|
REQUIRE(TestPassed);
|
|
}
|
|
|
|
|
|
/**
|
|
* Scenario1: Validates functionality of hipStreamCreateWithPriority when
|
|
stream = nullptr.
|
|
* Scenario2: Validates functionality of hipStreamCreateWithPriority when
|
|
flag = 0xffffffff.
|
|
*/
|
|
TEST_CASE("Unit_hipStreamCreateWithPriority_NegTst") {
|
|
hipStream_t stream;
|
|
int priority_low;
|
|
int priority_high;
|
|
hipError_t ret;
|
|
|
|
// Test is to get the Stream Priority Range
|
|
HIP_CHECK(
|
|
hipDeviceGetStreamPriorityRange(&priority_low, &priority_high));
|
|
// Check if priorities are indeed supported
|
|
if (priority_low == priority_high) {
|
|
WARN("Stream priority range not supported. Skipping test.");
|
|
return; // exit the test since priorities are not supported
|
|
}
|
|
|
|
SECTION("stream = nullptr test") {
|
|
ret = hipStreamCreateWithPriority(nullptr, hipStreamDefault,
|
|
priority_low);
|
|
|
|
REQUIRE(ret != hipSuccess);
|
|
}
|
|
|
|
SECTION("flag value invalid test") {
|
|
ret = hipStreamCreateWithPriority(&stream, 0xffffffff,
|
|
priority_low);
|
|
|
|
REQUIRE(ret != hipSuccess);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Validate stream priorities with event after classifying them as low, medium and high.
|
|
*/
|
|
TEST_CASE("Unit_hipStreamCreateWithPriority_ValidateWithEvents") {
|
|
bool TestPassed = true;
|
|
TestPassed = hipStreamCreateWithPriorityTest::
|
|
validateStreamPrioritiesWithEvents<int>();
|
|
REQUIRE(TestPassed);
|
|
}
|