ml_cuda_utils.h
Go to the documentation of this file.
1 /*
2  * SPDX-FileCopyrightText: Copyright (c) 2019-2024, NVIDIA CORPORATION.
3  * SPDX-License-Identifier: Apache-2.0
4  */
5 
6 #pragma once
7 
8 #include <raft/util/cudart_utils.hpp>
9 
10 #include <cuda_runtime.h>
11 
12 namespace ML {
13 
14 inline int get_device(const void* ptr)
15 {
16  cudaPointerAttributes att;
17  cudaPointerGetAttributes(&att, ptr);
18  return att.device;
19 }
20 
21 inline cudaMemoryType memory_type(const void* p)
22 {
23  cudaPointerAttributes att;
24  cudaError_t err = cudaPointerGetAttributes(&att, p);
25  ASSERT(err == cudaSuccess || err == cudaErrorInvalidValue, "%s", cudaGetErrorString(err));
26 
27  if (err == cudaErrorInvalidValue) {
28  // Make sure the current thread error status has been reset
29  err = cudaGetLastError();
30  ASSERT(err == cudaErrorInvalidValue, "%s", cudaGetErrorString(err));
31  }
32  return att.type;
33 }
34 
35 inline bool is_device_or_managed_type(const void* p)
36 {
37  cudaMemoryType p_memory_type = memory_type(p);
38  return p_memory_type == cudaMemoryTypeDevice || p_memory_type == cudaMemoryTypeManaged;
39 }
40 
41 } // namespace ML
Definition: dbscan.hpp:18
bool is_device_or_managed_type(const void *p)
Definition: ml_cuda_utils.h:35
cudaMemoryType memory_type(const void *p)
Definition: ml_cuda_utils.h:21
int get_device(const void *ptr)
Definition: ml_cuda_utils.h:14