Resource that uses Upstream
to allocate memory and limits the total allocations possible.
More...
#include <limiting_resource_adaptor.hpp>
Public Member Functions | |
limiting_resource_adaptor (Upstream *upstream, std::size_t allocation_limit, std::size_t alignment=rmm::detail::CUDA_ALLOCATION_ALIGNMENT) | |
Construct a new limiting resource adaptor using upstream to satisfy allocation requests and limiting the total allocation amount possible. More... | |
limiting_resource_adaptor (limiting_resource_adaptor const &)=delete | |
limiting_resource_adaptor (limiting_resource_adaptor &&) noexcept=default | |
Default move constructor. | |
limiting_resource_adaptor & | operator= (limiting_resource_adaptor const &)=delete |
limiting_resource_adaptor & | operator= (limiting_resource_adaptor &&) noexcept=default |
Default move assignment operator. More... | |
Upstream * | get_upstream () const noexcept |
Pointer to the upstream resource. More... | |
bool | supports_streams () const noexcept override |
Checks whether the upstream resource supports streams. More... | |
bool | supports_get_mem_info () const noexcept override |
Query whether the resource supports the get_mem_info API. More... | |
std::size_t | get_allocated_bytes () const |
Query the number of bytes that have been allocated. Note that this can not be used to know how large of an allocation is possible due to both possible fragmentation and also internal page sizes and alignment that is not tracked by this allocator. More... | |
std::size_t | get_allocation_limit () const |
Query the maximum number of bytes that this allocator is allowed to allocate. This is the limit on the allocator and not a representation of the underlying device. The device may not be able to support this limit. More... | |
![]() | |
device_memory_resource (device_memory_resource const &)=default | |
Default copy constructor. | |
device_memory_resource (device_memory_resource &&) noexcept=default | |
Default move constructor. | |
device_memory_resource & | operator= (device_memory_resource const &)=default |
Default copy assignment operator. More... | |
device_memory_resource & | operator= (device_memory_resource &&) noexcept=default |
Default move assignment operator. More... | |
void * | allocate (std::size_t bytes, cuda_stream_view stream=cuda_stream_view{}) |
Allocates memory of size at least bytes . More... | |
void | deallocate (void *ptr, std::size_t bytes, cuda_stream_view stream=cuda_stream_view{}) |
Deallocate memory pointed to by p . More... | |
bool | is_equal (device_memory_resource const &other) const noexcept |
Compare this resource to another. More... | |
std::pair< std::size_t, std::size_t > | get_mem_info (cuda_stream_view stream) const |
Queries the amount of free and total memory for the resource. More... | |
Resource that uses Upstream
to allocate memory and limits the total allocations possible.
An instance of this resource can be constructed with an existing, upstream resource in order to satisfy allocation requests, but any existing allocations will be untracked. Atomics are used to make this thread-safe, but note that the get_allocated_bytes
may not include in-flight allocations.
Upstream | Type of the upstream resource used for allocation/deallocation. |
|
inline |
Construct a new limiting resource adaptor using upstream
to satisfy allocation requests and limiting the total allocation amount possible.
<tt>rmm::logic_error</tt> | if upstream == nullptr |
upstream | The resource used for allocating/deallocating device memory |
allocation_limit | Maximum memory allowed for this allocator |
alignment | Alignment in bytes for the start of each allocated buffer |
|
inline |
Query the number of bytes that have been allocated. Note that this can not be used to know how large of an allocation is possible due to both possible fragmentation and also internal page sizes and alignment that is not tracked by this allocator.
|
inline |
Query the maximum number of bytes that this allocator is allowed to allocate. This is the limit on the allocator and not a representation of the underlying device. The device may not be able to support this limit.
|
inlinenoexcept |
Pointer to the upstream resource.
|
defaultnoexcept |
Default move assignment operator.
|
inlineoverridevirtualnoexcept |
Query whether the resource supports the get_mem_info API.
Implements rmm::mr::device_memory_resource.
|
inlineoverridevirtualnoexcept |
Checks whether the upstream resource supports streams.
Implements rmm::mr::device_memory_resource.