Fix rmm build (#7973)
- Optionally switch to c++17 - Use rmm CMake target. - Workaround compiler errors. - Fix GPUMetric inheritance. - Run death tests even if it's built with RMM support. Co-authored-by: jakirkham <jakirkham@gmail.com>
This commit is contained in:
@@ -13,10 +13,7 @@ RUN \
|
||||
apt-get install -y wget unzip bzip2 libgomp1 build-essential ninja-build git && \
|
||||
# Python
|
||||
wget -O Miniconda3.sh https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh && \
|
||||
bash Miniconda3.sh -b -p /opt/python && \
|
||||
# CMake
|
||||
wget -nv -nc https://cmake.org/files/v3.14/cmake-3.14.0-Linux-x86_64.sh --no-check-certificate && \
|
||||
bash cmake-3.14.0-Linux-x86_64.sh --skip-license --prefix=/usr
|
||||
bash Miniconda3.sh -b -p /opt/python
|
||||
|
||||
# NCCL2 (License: https://docs.nvidia.com/deeplearning/sdk/nccl-sla/index.html)
|
||||
RUN \
|
||||
@@ -30,7 +27,7 @@ ENV PATH=/opt/python/bin:$PATH
|
||||
# Create new Conda environment with RMM
|
||||
RUN \
|
||||
conda create -n gpu_test -c rapidsai-nightly -c rapidsai -c nvidia -c conda-forge -c defaults \
|
||||
python=3.8 rmm=21.10* cudatoolkit=$CUDA_VERSION_ARG
|
||||
python=3.9 rmm=22.06* cudatoolkit=$CUDA_VERSION_ARG cmake
|
||||
|
||||
ENV GOSU_VERSION 1.10
|
||||
|
||||
|
||||
@@ -252,7 +252,7 @@ __global__ void TestLastStaticKernel(Span<float> _span) {
|
||||
_span.last(static_cast<Span<float>::index_type>(-1));
|
||||
}
|
||||
|
||||
TEST(GPUSpan, FirstLast) {
|
||||
TEST(GPUSpanDeathTest, FirstLast) {
|
||||
// We construct vectors multiple times since thrust can not recover from
|
||||
// death test.
|
||||
auto lambda_first_dy = []() {
|
||||
@@ -312,40 +312,37 @@ TEST(GPUSpan, FirstLast) {
|
||||
output = testing::internal::GetCapturedStdout();
|
||||
}
|
||||
|
||||
__global__ void TestFrontKernel(Span<float> _span) {
|
||||
_span.front();
|
||||
}
|
||||
|
||||
__global__ void TestBackKernel(Span<float> _span) {
|
||||
_span.back();
|
||||
}
|
||||
|
||||
TEST(GPUSpan, FrontBack) {
|
||||
dh::safe_cuda(cudaSetDevice(0));
|
||||
|
||||
namespace {
|
||||
void TestFrontBack() {
|
||||
Span<float> s;
|
||||
auto lambda_test_front = [=]() {
|
||||
// make sure the termination happens inside this test.
|
||||
try {
|
||||
TestFrontKernel<<<1, 1>>>(s);
|
||||
dh::safe_cuda(cudaDeviceSynchronize());
|
||||
dh::safe_cuda(cudaGetLastError());
|
||||
} catch (dmlc::Error const& e) {
|
||||
std::terminate();
|
||||
}
|
||||
};
|
||||
EXPECT_DEATH(lambda_test_front(), "");
|
||||
EXPECT_DEATH(
|
||||
{
|
||||
// make sure the termination happens inside this test.
|
||||
try {
|
||||
dh::LaunchN(1, [=] __device__(size_t) { s.front(); });
|
||||
dh::safe_cuda(cudaDeviceSynchronize());
|
||||
dh::safe_cuda(cudaGetLastError());
|
||||
} catch (dmlc::Error const& e) {
|
||||
std::terminate();
|
||||
}
|
||||
},
|
||||
"");
|
||||
EXPECT_DEATH(
|
||||
{
|
||||
try {
|
||||
dh::LaunchN(1, [=] __device__(size_t) { s.back(); });
|
||||
dh::safe_cuda(cudaDeviceSynchronize());
|
||||
dh::safe_cuda(cudaGetLastError());
|
||||
} catch (dmlc::Error const& e) {
|
||||
std::terminate();
|
||||
}
|
||||
},
|
||||
"");
|
||||
}
|
||||
} // namespace
|
||||
|
||||
auto lambda_test_back = [=]() {
|
||||
try {
|
||||
TestBackKernel<<<1, 1>>>(s);
|
||||
dh::safe_cuda(cudaDeviceSynchronize());
|
||||
dh::safe_cuda(cudaGetLastError());
|
||||
} catch (dmlc::Error const& e) {
|
||||
std::terminate();
|
||||
}
|
||||
};
|
||||
EXPECT_DEATH(lambda_test_back(), "");
|
||||
TEST(GPUSpanDeathTest, FrontBack) {
|
||||
TestFrontBack();
|
||||
}
|
||||
|
||||
__global__ void TestSubspanDynamicKernel(Span<float> _span) {
|
||||
@@ -354,7 +351,7 @@ __global__ void TestSubspanDynamicKernel(Span<float> _span) {
|
||||
__global__ void TestSubspanStaticKernel(Span<float> _span) {
|
||||
_span.subspan<16>();
|
||||
}
|
||||
TEST(GPUSpan, Subspan) {
|
||||
TEST(GPUSpanDeathTest, Subspan) {
|
||||
auto lambda_subspan_dynamic = []() {
|
||||
thrust::host_vector<float> h_vec (4);
|
||||
InitializeRange(h_vec.begin(), h_vec.end());
|
||||
|
||||
Reference in New Issue
Block a user