-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathhamr_buffer_allocator.h
134 lines (120 loc) · 3.9 KB
/
hamr_buffer_allocator.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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
#ifndef hamr_buffer_allocator_h
#define hamr_buffer_allocator_h
///@file
#include "hamr_config.h"
#include <cassert>
namespace hamr
{
/// allocator types that may be used with hamr::buffer
enum class buffer_allocator
{
same = -2, ///< propagate the current allocator
none = -1, ///< no allocator specified
cpp = 0, ///< allocates memory with new
malloc = 1, ///< allocates memory with malloc
cuda = 2, ///< allocates memory with cudaMalloc
cuda_async = 3,///< allocates memory with cudaMallocAsync
cuda_uva = 4, ///< allocates memory with cudaMallocManaged
cuda_host = 5, ///< allocates memory with cudaMallocHost
hip = 6, ///< allocates memory with hipMalloc
hip_uva = 7, ///< allocates memory with hipMallocManaged
openmp = 8 ///< allocates memory with OpenMP device offload API
};
/// return the human readable name of the allocator
HAMR_EXPORT
const char *get_allocator_name(buffer_allocator alloc);
/// @returns true if the allocator creates host accessible memory
inline
HAMR_EXPORT
int host_accessible(buffer_allocator alloc)
{
return (alloc == buffer_allocator::cpp) ||
(alloc == buffer_allocator::malloc) ||
(alloc == buffer_allocator::cuda_uva) ||
(alloc == buffer_allocator::cuda_host) ||
(alloc == buffer_allocator::hip_uva);
}
/// @returns true if the allocator creates CUDA accessible memory
inline
HAMR_EXPORT
int cuda_accessible(buffer_allocator alloc)
{
return (alloc == buffer_allocator::cuda) ||
(alloc == buffer_allocator::cuda_async) ||
(alloc == buffer_allocator::cuda_uva) ||
(alloc == buffer_allocator::hip) ||
(alloc == buffer_allocator::hip_uva) ||
(alloc == buffer_allocator::openmp);
}
/// @returns true if the allocator creates HIP accessible memory
inline
HAMR_EXPORT
int hip_accessible(buffer_allocator alloc)
{
return (alloc == buffer_allocator::cuda) ||
(alloc == buffer_allocator::cuda_async) ||
(alloc == buffer_allocator::cuda_uva) ||
(alloc == buffer_allocator::hip) ||
(alloc == buffer_allocator::hip_uva);
}
/// @returns true if the allocator creates OPENMP accessible memory
inline
HAMR_EXPORT
int openmp_accessible(buffer_allocator alloc)
{
return (alloc == buffer_allocator::cuda) ||
(alloc == buffer_allocator::cuda_async) ||
(alloc == buffer_allocator::cuda_uva) ||
(alloc == buffer_allocator::openmp);
}
/// asserts that the passed value is one of the known allocators
inline
HAMR_EXPORT
void assert_valid_allocator(buffer_allocator alloc)
{
(void) alloc;
assert((alloc == buffer_allocator::cpp)
|| (alloc == buffer_allocator::malloc)
#if defined(HAMR_ENABLE_CUDA)
|| (alloc == buffer_allocator::cuda)
|| (alloc == buffer_allocator::cuda_async)
|| (alloc == buffer_allocator::cuda_uva)
|| (alloc == buffer_allocator::cuda_host)
#endif
#if defined(HAMR_ENABLE_HIP)
|| (alloc == buffer_allocator::hip)
|| (alloc == buffer_allocator::hip_uva)
#endif
#if defined(HAMR_ENABLE_OPENMP)
|| (alloc == buffer_allocator::openmp)
#endif
);
}
/// get the allocator type most suitable for the current build configuration.
inline HAMR_EXPORT buffer_allocator get_device_allocator()
{
#if defined(HAMR_ENABLE_CUDA)
return buffer_allocator::cuda_async;
#elif defined(HAMR_ENABLE_HIP)
return buffer_allocator::hip;
#elif defined(HAMR_ENABLE_OPENMP)
return buffer_allocator::openmp;
#else
return buffer_allocator::malloc;
#endif
}
/// get the allocator type most suitable for the current build configuration.
inline HAMR_EXPORT buffer_allocator get_host_allocator()
{
#if defined(HAMR_ENABLE_CUDA)
return buffer_allocator::cuda_host;
#elif defined(HAMR_ENABLE_HIP)
return buffer_allocator::malloc;
#elif defined(HAMR_ENABLE_OPENMP)
return buffer_allocator::malloc;
#else
return buffer_allocator::malloc;
#endif
}
}
#endif