forked from cms-patatrack/pixeltrack-standalone
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCUDAHostAllocator.h
49 lines (40 loc) · 1.25 KB
/
CUDAHostAllocator.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
#ifndef HeterogeneousCore_CUDAUtilities_CUDAHostAllocator_h
#define HeterogeneousCore_CUDAUtilities_CUDAHostAllocator_h
#include <memory>
#include <new>
#include <cuda_runtime.h>
class cuda_bad_alloc : public std::bad_alloc {
public:
cuda_bad_alloc(cudaError_t error) noexcept : error_(error) {}
const char* what() const noexcept override { return cudaGetErrorString(error_); }
private:
cudaError_t error_;
};
template <typename T, unsigned int FLAGS = cudaHostAllocDefault>
class CUDAHostAllocator {
public:
using value_type = T;
template <typename U>
struct rebind {
using other = CUDAHostAllocator<U, FLAGS>;
};
T* allocate(std::size_t n) const __attribute__((warn_unused_result)) __attribute__((malloc))
__attribute__((returns_nonnull)) {
void* ptr = nullptr;
cudaError_t status = cudaMallocHost(&ptr, n * sizeof(T), FLAGS);
if (status != cudaSuccess) {
throw cuda_bad_alloc(status);
}
if (ptr == nullptr) {
throw std::bad_alloc();
}
return static_cast<T*>(ptr);
}
void deallocate(T* p, std::size_t n) const {
cudaError_t status = cudaFreeHost(p);
if (status != cudaSuccess) {
throw cuda_bad_alloc(status);
}
}
};
#endif // HeterogeneousCore_CUDAUtilities_CUDAHostAllocator_h