Struct BumpAllocator

Source
pub struct BumpAllocator { /* private fields */ }
Expand description

The bump allocator used as the default rust heap when running programs.

Implementations§

Source§

impl BumpAllocator

Source

pub unsafe fn new(arena: &mut [u8]) -> Self

Creates the allocator tied to a provided slice. This will not initialize the provided memory, except for the first bytes where the pointer is stored.

§Safety

As long as BumpAllocator or any of its allocations are alive, writing into or deallocating the arena will cause UB.

Integer arithmetic in this global allocator implementation is safe when operating on the prescribed HEAP_START_ADDRESS and HEAP_LENGTH. Any other use may overflow and is thus unsupported and at one’s own risk.

Source

pub const unsafe fn with_fixed_address_range(start: usize, len: usize) -> Self

Creates the allocator tied to specific range of addresses.

§Safety

This is unsafe in most situations, unless you are totally sure that the provided start address and length can be written to by the allocator, and that the memory will be usable for the lifespan of the allocator.

For Solana on-chain programs, a certain address range is reserved, so the allocator can be given those addresses.

Trait Implementations§

Source§

impl GlobalAlloc for BumpAllocator

Integer arithmetic in this global allocator implementation is safe when operating on the prescribed HEAP_START_ADDRESS and HEAP_LENGTH. Any other use may overflow and is thus unsupported and at one’s own risk.

Source§

unsafe fn alloc(&self, layout: Layout) -> *mut u8

Allocates memory as described by the given layout. Read more
Source§

unsafe fn dealloc(&self, _: *mut u8, _: Layout)

Deallocates the block of memory at the given ptr pointer with the given layout. Read more
1.28.0 · Source§

unsafe fn alloc_zeroed(&self, layout: Layout) -> *mut u8

Behaves like alloc, but also ensures that the contents are set to zero before being returned. Read more
1.28.0 · Source§

unsafe fn realloc( &self, ptr: *mut u8, layout: Layout, new_size: usize, ) -> *mut u8

Shrinks or grows a block of memory to the given new_size in bytes. The block is described by the given ptr pointer and layout. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.