8 #include <rmm/detail/aligned.hpp>
9 #include <rmm/detail/cccl_adaptors.hpp>
10 #include <rmm/detail/cuda_memory_resource.hpp>
11 #include <rmm/detail/error.hpp>
12 #include <rmm/detail/export.hpp>
13 #include <rmm/detail/nvtx/ranges.hpp>
17 namespace RMM_NAMESPACE {
95 #ifdef RMM_ENABLE_LEGACY_MR_INTERFACE
117 return do_allocate(bytes, stream);
136 void deallocate(
void* ptr,
141 do_deallocate(ptr, bytes, stream);
159 void* allocate(std::size_t bytes, [[maybe_unused]] std::size_t alignment)
162 return do_allocate(bytes, cuda_stream_view{});
178 void deallocate(
void* ptr, std::size_t bytes, [[maybe_unused]] std::size_t alignment) noexcept
181 do_deallocate(ptr, bytes, cuda_stream_view{});
200 void* allocate_async(std::size_t bytes,
201 [[maybe_unused]] std::size_t alignment,
202 cuda_stream_view stream)
205 return do_allocate(bytes, stream);
223 void* allocate_async(std::size_t bytes, cuda_stream_view stream)
226 return do_allocate(bytes, stream);
243 void deallocate_async(
void* ptr,
245 [[maybe_unused]] std::size_t alignment,
246 cuda_stream_view stream) noexcept
249 do_deallocate(ptr, bytes, stream);
265 void deallocate_async(
void* ptr, std::size_t bytes, cuda_stream_view stream) noexcept
268 do_deallocate(ptr, bytes, stream);
288 "Alignment must be less than or equal to 256 and a power of two",
328 "Alignment must be less than or equal to 256 and a power of two",
330 return do_allocate(bytes, stream);
347 do_deallocate(ptr, bytes, stream);
365 return do_is_equal(other);
377 return do_is_equal(other);
389 return !do_is_equal(other);
425 virtual void do_deallocate(
void* ptr, std::size_t bytes,
cuda_stream_view stream) noexcept = 0;
443 return this == &other;
448 static_assert(rmm::detail::polyfill::resource<device_memory_resource>);
449 static_assert(rmm::detail::polyfill::async_resource<device_memory_resource>);
451 rmm::detail::polyfill::resource_with<device_memory_resource, cuda::mr::device_accessible>);
453 rmm::detail::polyfill::async_resource_with<device_memory_resource, cuda::mr::device_accessible>);
Exception thrown when an RMM allocation fails.
Definition: error.hpp:44
Strongly-typed non-owning wrapper for CUDA streams with default constructor.
Definition: cuda_stream_view.hpp:28
Base class for all librmm device memory allocation.
Definition: device_memory_resource.hpp:83
void * allocate_sync(std::size_t bytes, std::size_t alignment=rmm::CUDA_ALLOCATION_ALIGNMENT)
Allocates memory of size at least bytes.
Definition: device_memory_resource.hpp:284
friend void get_property(device_memory_resource const &, cuda::mr::device_accessible) noexcept
Enables the cuda::mr::device_accessible property.
Definition: device_memory_resource.hpp:397
device_memory_resource(device_memory_resource &&) noexcept=default
Default move constructor.
void deallocate(cuda_stream_view stream, void *ptr, std::size_t bytes, [[maybe_unused]] std::size_t alignment=rmm::CUDA_ALLOCATION_ALIGNMENT) noexcept
Deallocate memory pointed to by ptr on the specified stream.
Definition: device_memory_resource.hpp:342
void * allocate(cuda_stream_view stream, std::size_t bytes, std::size_t alignment=rmm::CUDA_ALLOCATION_ALIGNMENT)
Allocates memory of size at least bytes on the specified stream.
Definition: device_memory_resource.hpp:322
void deallocate_sync(void *ptr, std::size_t bytes, [[maybe_unused]] std::size_t alignment=rmm::CUDA_ALLOCATION_ALIGNMENT) noexcept
Deallocate memory pointed to by p.
Definition: device_memory_resource.hpp:301
bool operator==(device_memory_resource const &other) const noexcept
Comparison operator with another device_memory_resource.
Definition: device_memory_resource.hpp:375
bool operator!=(device_memory_resource const &other) const noexcept
Comparison operator with another device_memory_resource.
Definition: device_memory_resource.hpp:387
device_memory_resource(device_memory_resource const &)=default
Default copy constructor.
bool is_equal(device_memory_resource const &other) const noexcept
Compare this resource to another.
Definition: device_memory_resource.hpp:363
static constexpr std::size_t CUDA_ALLOCATION_ALIGNMENT
Default alignment used for CUDA memory allocation.
Definition: aligned.hpp:31
bool is_supported_alignment(std::size_t alignment) noexcept
Returns whether or not alignment is a valid memory alignment.