From 1f258e0ad308f7a00fca98819e9165d4e8cf1646 Mon Sep 17 00:00:00 2001 From: Ana Gainaru Date: Thu, 27 Jan 2022 21:46:56 -0500 Subject: [PATCH] Update the cuda example to use GPU buffers on the Read side --- examples/cuda/cudaWriteRead.cu | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/examples/cuda/cudaWriteRead.cu b/examples/cuda/cudaWriteRead.cu index 09661ca89b..043d44c154 100644 --- a/examples/cuda/cudaWriteRead.cu +++ b/examples/cuda/cudaWriteRead.cu @@ -66,6 +66,9 @@ int BPRead(const std::string fname, const size_t N, int nSteps) adios2::Engine bpReader = io.Open(fname, adios2::Mode::Read); unsigned int step = 0; + float *gpuSimData; + cudaMalloc(&gpuSimData, N * sizeof(float)); + cudaMemset(gpuSimData, 0, N); for (; bpReader.BeginStep() == adios2::StepStatus::OK; ++step) { auto data = io.InquireVariable("data"); @@ -77,8 +80,10 @@ int BPRead(const std::string fname, const size_t N, int nSteps) const adios2::Box sel(start, count); data.SetSelection(sel); - bpReader.Get(data, simData.data()); + data.SetMemorySpace(adios2::MemorySpace::CUDA); + bpReader.Get(data, gpuSimData, adios2::Mode::Deferred); bpReader.EndStep(); + cudaMemcpy(simData.data(), gpuSimData, N, cudaMemcpyDeviceToHost); std::cout << "Simualation step " << step << " : "; std::cout << simData.size() << " elements: " << simData[1] << std::endl; }