|
- /**
- * \file dnn/test/cuda/megcore/computing.cpp
- * MegEngine is Licensed under the Apache License, Version 2.0 (the "License")
- *
- * Copyright (c) 2014-2021 Megvii Inc. All rights reserved.
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- */
- #include "megcore.h"
- #include "megcore_cuda.h"
-
- #include <cuda_runtime_api.h>
- #include "./fixture.h"
- #include "test/common/utils.h"
- #include "test/cuda/utils.h"
-
- TEST_F(MegcoreCUDA, COMPUTING) {
- for (int id = -1; id < std::min(nr_devices(), 2); ++id) {
- megcoreDeviceHandle_t devHandle;
- megcoreCreateDeviceHandle(&devHandle, megcorePlatformCUDA, id, 0);
- megcoreActivate(devHandle);
-
- megcoreComputingHandle_t compHandle;
- megcoreCreateComputingHandle(&compHandle, devHandle, 0);
-
- megcoreDeviceHandle_t devHandle2;
- megcoreGetDeviceHandle(compHandle, &devHandle2);
- ASSERT_EQ(devHandle, devHandle2);
-
- unsigned int flags;
- megcoreGetComputingFlags(compHandle, &flags);
- ASSERT_EQ(0u, flags);
-
- unsigned char *src, *dst;
- static const size_t N = 5;
- unsigned char src_host[N], dst_host[N];
- megcoreMalloc(devHandle, (void**)&src, N);
- megcoreMalloc(devHandle, (void**)&dst, N);
- megcoreMemset(compHandle, src, 0x0F, N);
- megcoreMemset(compHandle, dst, 0xF0, N);
- megcoreMemcpy(compHandle, src_host, src, N, megcoreMemcpyDeviceToHost);
- megcoreMemcpy(compHandle, dst_host, dst, N, megcoreMemcpyDeviceToHost);
- megcoreSynchronize(compHandle);
- for (size_t i = 0; i < N; ++i) {
- ASSERT_EQ(0x0F, src_host[i]);
- ASSERT_EQ(0xF0, dst_host[i]);
- }
- megcoreMemcpy(compHandle, dst, src, N, megcoreMemcpyDeviceToDevice);
- megcoreMemcpy(compHandle, src_host, src, N, megcoreMemcpyDeviceToHost);
- megcoreMemcpy(compHandle, dst_host, dst, N, megcoreMemcpyDeviceToHost);
- megcoreSynchronize(compHandle);
- for (size_t i = 0; i < N; ++i) {
- ASSERT_EQ(dst_host[i], src_host[i]);
- }
- megcoreFree(devHandle, src);
- megcoreFree(devHandle, dst);
-
- megcoreDestroyComputingHandle(compHandle);
- megcoreDestroyDeviceHandle(devHandle);
- }
- }
-
- TEST_F(MegcoreCUDA, STREAM) {
- megcoreDeviceHandle_t devHandle;
- megcoreCreateDeviceHandle(&devHandle, megcorePlatformCUDA, 0, 0);
- megcoreActivate(devHandle);
-
- cudaStream_t stream;
- cuda_check(cudaStreamCreateWithFlags(&stream, cudaStreamNonBlocking));
-
- megcoreComputingHandle_t compHandle;
- megcoreCreateComputingHandleWithCUDAStream(&compHandle, devHandle, 0, stream);
- {
- cudaStream_t stream2;
- megcoreGetCUDAStream(compHandle, &stream2);
- ASSERT_EQ(stream, stream2);
- }
-
- megcoreDeviceHandle_t devHandle2;
- megcoreGetDeviceHandle(compHandle, &devHandle2);
- ASSERT_EQ(devHandle, devHandle2);
-
- unsigned int flags;
- megcoreGetComputingFlags(compHandle, &flags);
- ASSERT_EQ(0u, flags);
-
- unsigned char *src, *dst;
- static const size_t N = 5;
- unsigned char src_host[N], dst_host[N];
- megcoreMalloc(devHandle, (void**)&src, N);
- megcoreMalloc(devHandle, (void**)&dst, N);
- megcoreMemset(compHandle, src, 0x0F, N);
- megcoreMemset(compHandle, dst, 0xF0, N);
- megcoreMemcpy(compHandle, src_host, src, N, megcoreMemcpyDeviceToHost);
- megcoreMemcpy(compHandle, dst_host, dst, N, megcoreMemcpyDeviceToHost);
- megcoreSynchronize(compHandle);
- for (size_t i = 0; i < N; ++i) {
- ASSERT_EQ(0x0F, src_host[i]);
- ASSERT_EQ(0xF0, dst_host[i]);
- }
- megcoreMemcpy(compHandle, dst, src, N, megcoreMemcpyDeviceToDevice);
- megcoreMemcpy(compHandle, src_host, src, N, megcoreMemcpyDeviceToHost);
- megcoreMemcpy(compHandle, dst_host, dst, N, megcoreMemcpyDeviceToHost);
- megcoreSynchronize(compHandle);
- for (size_t i = 0; i < N; ++i) {
- ASSERT_EQ(dst_host[i], src_host[i]);
- }
- megcoreFree(devHandle, src);
- megcoreFree(devHandle, dst);
-
- megcoreDestroyComputingHandle(compHandle);
- megcoreDestroyDeviceHandle(devHandle);
-
- cuda_check(cudaStreamDestroy(stream));
- }
-
- // vim: syntax=cpp.doxygen
|