Struct tikv_jemalloc_sys::extent_hooks_s

source ·
#[repr(C)]
pub struct extent_hooks_s { pub alloc: Option<extent_alloc_t>, pub dalloc: Option<extent_dalloc_t>, pub destroy: Option<extent_destroy_t>, pub commit: Option<extent_commit_t>, pub decommit: Option<extent_decommit_t>, pub purge_lazy: Option<extent_purge_t>, pub purge_forced: Option<extent_purge_t>, pub split: Option<extent_split_t>, pub merge: Option<extent_merge_t>, }
Expand description

Extent lifetime management functions.

The extent_hooks_t structure comprises function pointers which are described individually below. jemalloc uses these functions to manage extent lifetime, which starts off with allocation of mapped committed memory, in the simplest case followed by deallocation. However, there are performance and platform reasons to retain extents for later reuse. Cleanup attempts cascade from deallocation to decommit to forced purging to lazy purging, which gives the extent management functions opportunities to reject the most permanent cleanup operations in favor of less permanent (and often less costly) operations. All operations except allocation can be universally opted out of by setting the hook pointers to NULL, or selectively opted out of by returning failure. Note that once the extent hook is set, the structure is accessed directly by the associated arenas, so it must remain valid for the entire lifetime of the arenas.

Fields§

§alloc: Option<extent_alloc_t>§dalloc: Option<extent_dalloc_t>§destroy: Option<extent_destroy_t>§commit: Option<extent_commit_t>§decommit: Option<extent_decommit_t>§purge_lazy: Option<extent_purge_t>§purge_forced: Option<extent_purge_t>§split: Option<extent_split_t>§merge: Option<extent_merge_t>

Trait Implementations§

source§

impl Clone for extent_hooks_s

source§

fn clone(&self) -> extent_hooks_s

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Default for extent_hooks_s

source§

fn default() -> extent_hooks_s

Returns the “default value” for a type. Read more
source§

impl Copy for extent_hooks_s

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> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> CloneToUninit for T
where T: Copy,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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, U> TryFrom<U> for T
where U: Into<T>,

§

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>,

§

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.