diff options
author | Pierre Moreau <dev@pmoreau.org> | 2017-02-08 22:50:58 +0100 |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2017-02-10 13:47:05 -0500 |
commit | 166b3393875e4f6752907b9b06c2518dce0432e9 (patch) | |
tree | 9a1484f0b5c34c34decbc8dc4ae6796a4a43f911 /Tests/Cuda | |
parent | cbe4d5957b526f9a9bb6954d0c6944ad7642bb90 (diff) | |
download | cmake-166b3393875e4f6752907b9b06c2518dce0432e9.tar.gz |
Tests/Cuda: Select a CUDA device supporting compute 3.0
Diffstat (limited to 'Tests/Cuda')
-rw-r--r-- | Tests/Cuda/Complex/dynamic.cu | 40 | ||||
-rw-r--r-- | Tests/Cuda/Complex/main.cpp | 6 |
2 files changed, 46 insertions, 0 deletions
diff --git a/Tests/Cuda/Complex/dynamic.cu b/Tests/Cuda/Complex/dynamic.cu index 0206bb4fde..2b04ac97cd 100644 --- a/Tests/Cuda/Complex/dynamic.cu +++ b/Tests/Cuda/Complex/dynamic.cu @@ -22,6 +22,46 @@ void DetermineIfValidCudaDevice() { } +EXPORT int choose_cuda_device() +{ + int nDevices = 0; + cudaError_t err = cudaGetDeviceCount(&nDevices); + if (err != cudaSuccess) + { + std::cerr << "Failed to retrieve the number of CUDA enabled devices" + << std::endl; + return 1; + } + for (int i = 0; i < nDevices; ++i) + { + cudaDeviceProp prop; + cudaError_t err = cudaGetDeviceProperties(&prop, i); + if (err != cudaSuccess) + { + std::cerr << "Could not retrieve properties from CUDA device " << i + << std::endl; + return 1; + } + if (prop.major >= 4) + { + err = cudaSetDevice(i); + if (err != cudaSuccess) + { + std::cout << "Could not select CUDA device " << i << std::endl; + } + else + { + return 0; + } + } + } + + std::cout << "Could not find a CUDA enabled card supporting compute >=3.0" + << std::endl; + + return 1; +} + EXPORT void cuda_dynamic_lib_func() { DetermineIfValidCudaDevice <<<1,1>>> (); diff --git a/Tests/Cuda/Complex/main.cpp b/Tests/Cuda/Complex/main.cpp index 92d1fb0f1f..2498235351 100644 --- a/Tests/Cuda/Complex/main.cpp +++ b/Tests/Cuda/Complex/main.cpp @@ -9,11 +9,17 @@ #define IMPORT #endif +IMPORT int choose_cuda_device(); IMPORT int call_cuda_seperable_code(int x); IMPORT int mixed_launch_kernel(int x); int main(int argc, char** argv) { + int ret = choose_cuda_device(); + if (ret) { + return 0; + } + int r1 = call_cuda_seperable_code(42); int r2 = mixed_launch_kernel(42); return (r1 == 42 || r2 == 42) ? 1 : 0; |