8 #include <rmm/detail/aligned.hpp>
9 #include <rmm/detail/export.hpp>
10 #include <rmm/error.hpp>
15 namespace RMM_NAMESPACE {
54 void* do_allocate(std::size_t bytes,
58 "Allocation alignment is not a power of 2.",
61 return rmm::detail::aligned_host_allocate(
62 bytes, alignment, [](std::size_t size) { return ::operator
new(size); });
78 void do_deallocate(
void* ptr,
82 rmm::detail::aligned_host_deallocate(
83 ptr, bytes, alignment, [](
void* ptr) { ::operator
delete(ptr); });
Exception thrown when an RMM allocation fails.
Definition: error.hpp:44
Base class for host memory allocation.
Definition: host_memory_resource.hpp:48
A host_memory_resource that uses the global operator new and operator delete to allocate host memory.
Definition: new_delete_resource.hpp:30
new_delete_resource & operator=(new_delete_resource &&)=default
Default move assignment operator.
new_delete_resource(new_delete_resource &&)=default
Default move constructor.
new_delete_resource(new_delete_resource const &)=default
Default copy constructor.
new_delete_resource & operator=(new_delete_resource const &)=default
Default copy assignment operator.
bool is_supported_alignment(std::size_t alignment) noexcept
Returns whether or not alignment is a valid memory alignment.
static constexpr std::size_t RMM_DEFAULT_HOST_ALIGNMENT
Default alignment used for host memory allocated by RMM.
Definition: aligned.hpp:25