mmtk::util::reference_processor

Struct ReferenceProcessors

source
pub struct ReferenceProcessors {
    soft: ReferenceProcessor,
    weak: ReferenceProcessor,
    phantom: ReferenceProcessor,
}
Expand description

Holds all reference processors for each weak reference Semantics. Currently this is based on Java’s weak reference semantics (soft/weak/phantom). We should make changes to make this general rather than Java specific.

Fields§

§soft: ReferenceProcessor§weak: ReferenceProcessor§phantom: ReferenceProcessor

Implementations§

source§

impl ReferenceProcessors

source

pub fn new() -> Self

source

pub fn get(&self, semantics: Semantics) -> &ReferenceProcessor

source

pub fn add_soft_candidate(&self, reff: ObjectReference)

source

pub fn add_weak_candidate(&self, reff: ObjectReference)

source

pub fn add_phantom_candidate(&self, reff: ObjectReference)

source

pub fn enqueue_refs<VM: VMBinding>(&self, tls: VMWorkerThread)

This will invoke enqueue for each reference processor, which will call back to the VM to enqueue references whose referents are cleared in this GC.

source

pub fn forward_refs<E: ProcessEdgesWork>( &self, trace: &mut E, mmtk: &'static MMTK<E::VM>, )

A separate reference forwarding step. Normally when we scan refs, we deal with forwarding. However, for some plans like mark compact, at the point we do ref scanning, we do not know the forwarding addresses yet, thus we cannot do forwarding during scan refs. And for those plans, this separate step is required.

source

pub fn retain_soft_refs<E: ProcessEdgesWork>( &self, trace: &mut E, mmtk: &'static MMTK<E::VM>, )

source

pub fn scan_soft_refs<VM: VMBinding>(&self, mmtk: &'static MMTK<VM>)

Scan soft references.

source

pub fn scan_weak_refs<VM: VMBinding>(&self, mmtk: &'static MMTK<VM>)

Scan weak references.

source

pub fn scan_phantom_refs<VM: VMBinding>(&self, mmtk: &'static MMTK<VM>)

Scan phantom references.

Trait Implementations§

source§

impl Default for ReferenceProcessors

source§

fn default() -> Self

Returns the “default value” for a type. 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
§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
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> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
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.