172 rivejä
6.3 KiB
C++
172 rivejä
6.3 KiB
C++
/*
|
|
Copyright (c) 2022 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.
|
|
*/
|
|
|
|
#include "memcpy2d_tests_common.hh"
|
|
|
|
#include <hip_test_common.hh>
|
|
#include <hip/hip_runtime_api.h>
|
|
#include <resource_guards.hh>
|
|
#include <utils.hh>
|
|
|
|
TEST_CASE("Unit_hipMemcpy2D_Positive_Basic", "[multigpu]") {
|
|
CHECK_IMAGE_SUPPORT
|
|
constexpr bool async = false;
|
|
|
|
SECTION("Device to Host") { Memcpy2DDeviceToHostShell<async>(hipMemcpy2D); }
|
|
|
|
SECTION("Device to Device") {
|
|
SECTION("Peer access enabled") { Memcpy2DDeviceToDeviceShell<async, true>(hipMemcpy2D); }
|
|
}
|
|
|
|
SECTION("Host to Device") { Memcpy2DHostToDeviceShell<async>(hipMemcpy2D); }
|
|
|
|
SECTION("Host to Host") { Memcpy2DHostToHostShell<async>(hipMemcpy2D); }
|
|
}
|
|
|
|
TEST_CASE("Unit_hipMemcpy2D_Positive_Synchronization_Behavior") {
|
|
HIP_CHECK(hipDeviceSynchronize());
|
|
|
|
SECTION("Host to Device") { Memcpy2DHtoDSyncBehavior(hipMemcpy2D, true); }
|
|
|
|
SECTION("Device to Host") {
|
|
Memcpy2DDtoHPageableSyncBehavior(hipMemcpy2D, true);
|
|
Memcpy2DDtoHPinnedSyncBehavior(hipMemcpy2D, true);
|
|
}
|
|
|
|
SECTION("Device to Device") {
|
|
#if HT_NVIDIA
|
|
Memcpy2DDtoDSyncBehavior(hipMemcpy2D, false);
|
|
#else
|
|
Memcpy2DDtoDSyncBehavior(hipMemcpy2D, true);
|
|
#endif
|
|
}
|
|
|
|
#if HT_NVIDIA // Disabled on AMD due to defect - EXSWHTEC-232
|
|
SECTION("Host to Host") { Memcpy2DHtoHSyncBehavior(hipMemcpy2D, true); }
|
|
#endif
|
|
}
|
|
|
|
TEST_CASE("Unit_hipMemcpy2D_Positive_Parameters") {
|
|
CHECK_IMAGE_SUPPORT
|
|
constexpr bool async = false;
|
|
Memcpy2DZeroWidthHeight<async>(hipMemcpy2D);
|
|
}
|
|
|
|
TEST_CASE("Unit_hipMemcpy2D_Negative_Parameters") {
|
|
CHECK_IMAGE_SUPPORT
|
|
constexpr size_t cols = 128;
|
|
constexpr size_t rows = 128;
|
|
|
|
constexpr auto NegativeTests = [](void* dst, size_t dpitch, const void* src, size_t spitch,
|
|
size_t width, size_t height, hipMemcpyKind kind) {
|
|
SECTION("dst == nullptr") {
|
|
HIP_CHECK_ERROR(hipMemcpy2D(nullptr, dpitch, src, spitch, width, height, kind),
|
|
hipErrorInvalidValue);
|
|
}
|
|
|
|
SECTION("src == nullptr") {
|
|
HIP_CHECK_ERROR(hipMemcpy2D(dst, dpitch, nullptr, spitch, width, height, kind),
|
|
hipErrorInvalidValue);
|
|
}
|
|
|
|
SECTION("dpitch < width") {
|
|
HIP_CHECK_ERROR(hipMemcpy2D(dst, width - 1, src, spitch, width, height, kind),
|
|
hipErrorInvalidPitchValue);
|
|
}
|
|
|
|
SECTION("spitch < width") {
|
|
HIP_CHECK_ERROR(hipMemcpy2D(dst, dpitch, src, width - 1, width, height, kind),
|
|
hipErrorInvalidPitchValue);
|
|
}
|
|
|
|
SECTION("dpitch > max pitch") {
|
|
int attr = 0;
|
|
HIP_CHECK(hipDeviceGetAttribute(&attr, hipDeviceAttributeMaxPitch, 0));
|
|
HIP_CHECK_ERROR(
|
|
hipMemcpy2D(dst, static_cast<size_t>(attr) + 1, src, spitch, width, height, kind),
|
|
hipErrorInvalidValue);
|
|
}
|
|
|
|
SECTION("spitch > max pitch") {
|
|
int attr = 0;
|
|
HIP_CHECK(hipDeviceGetAttribute(&attr, hipDeviceAttributeMaxPitch, 0));
|
|
HIP_CHECK_ERROR(
|
|
hipMemcpy2D(dst, dpitch, src, static_cast<size_t>(attr) + 1, width, height, kind),
|
|
hipErrorInvalidValue);
|
|
}
|
|
|
|
#if HT_NVIDIA // Disabled on AMD due to defect - EXSWHTEC-234
|
|
SECTION("Invalid MemcpyKind") {
|
|
HIP_CHECK_ERROR(
|
|
hipMemcpy2D(dst, dpitch, src, spitch, width, height, static_cast<hipMemcpyKind>(-1)),
|
|
hipErrorInvalidMemcpyDirection);
|
|
}
|
|
#endif
|
|
};
|
|
|
|
SECTION("Host to Device") {
|
|
LinearAllocGuard2D<int> device_alloc(cols, rows);
|
|
LinearAllocGuard<int> host_alloc(LinearAllocs::hipHostMalloc, device_alloc.pitch() * rows);
|
|
NegativeTests(device_alloc.ptr(), device_alloc.pitch(), host_alloc.ptr(), device_alloc.pitch(),
|
|
device_alloc.width(), device_alloc.height(), hipMemcpyHostToDevice);
|
|
}
|
|
|
|
SECTION("Device to Host") {
|
|
LinearAllocGuard2D<int> device_alloc(cols, rows);
|
|
LinearAllocGuard<int> host_alloc(LinearAllocs::hipHostMalloc, device_alloc.pitch() * rows);
|
|
NegativeTests(host_alloc.ptr(), device_alloc.pitch(), device_alloc.ptr(), device_alloc.pitch(),
|
|
device_alloc.width(), device_alloc.height(), hipMemcpyDeviceToHost);
|
|
}
|
|
|
|
SECTION("Host to Host") {
|
|
LinearAllocGuard<int> src_alloc(LinearAllocs::hipHostMalloc, cols * rows * sizeof(int));
|
|
LinearAllocGuard<int> dst_alloc(LinearAllocs::hipHostMalloc, cols * rows * sizeof(int));
|
|
NegativeTests(dst_alloc.ptr(), cols * sizeof(int), src_alloc.ptr(), cols * sizeof(int),
|
|
cols * sizeof(int), rows, hipMemcpyHostToHost);
|
|
}
|
|
|
|
SECTION("Device to Device") {
|
|
LinearAllocGuard2D<int> src_alloc(cols, rows);
|
|
LinearAllocGuard2D<int> dst_alloc(cols, rows);
|
|
NegativeTests(dst_alloc.ptr(), dst_alloc.pitch(), src_alloc.ptr(), src_alloc.pitch(),
|
|
dst_alloc.width(), dst_alloc.height(), hipMemcpyDeviceToDevice);
|
|
}
|
|
}
|
|
|
|
TEST_CASE("Unit_hipMemcpy2D_Capture") {
|
|
CHECK_IMAGE_SUPPORT
|
|
|
|
constexpr size_t width = 16;
|
|
constexpr size_t height = 16;
|
|
|
|
LinearAllocGuard2D<int> device_alloc(width, height);
|
|
LinearAllocGuard<int> host_alloc(LinearAllocs::hipHostMalloc, device_alloc.pitch() * width);
|
|
|
|
hipError_t memcpy_err = hipSuccess;
|
|
BEGIN_CAPTURE_SYNC(memcpy_err, false);
|
|
HIP_CHECK_ERROR(
|
|
hipMemcpy2D(device_alloc.ptr(), device_alloc.pitch(), host_alloc.ptr(), device_alloc.pitch(),
|
|
device_alloc.width(), device_alloc.height(), hipMemcpyHostToDevice),
|
|
memcpy_err);
|
|
END_CAPTURE_SYNC(memcpy_err);
|
|
}
|