pub struct StopMutators<C: GCWorkContext> {
skip_mutator_roots: bool,
flush_mutator: bool,
phantom: PhantomData<C>,
}Expand description
Stop all mutators
TODO: Smaller work granularity
Fields§
§skip_mutator_roots: boolIf this is true, we skip creating ScanMutatorRoots work packets for mutators.
By default, this is false.
flush_mutator: boolFlush mutators once they are stopped. By default this is false. ScanMutatorRoots will flush mutators.
phantom: PhantomData<C>Implementations§
source§impl<C: GCWorkContext> StopMutators<C>
impl<C: GCWorkContext> StopMutators<C>
pub fn new() -> Self
sourcepub fn new_no_scan_roots() -> Self
pub fn new_no_scan_roots() -> Self
Create a StopMutators work packet that does not create ScanMutatorRoots work packets for mutators, and will simply flush mutators.
Trait Implementations§
source§impl<C: Default + GCWorkContext> Default for StopMutators<C>
impl<C: Default + GCWorkContext> Default for StopMutators<C>
source§fn default() -> StopMutators<C>
fn default() -> StopMutators<C>
Returns the “default value” for a type. Read more
source§impl<C: GCWorkContext> GCWork<<C as GCWorkContext>::VM> for StopMutators<C>
impl<C: GCWorkContext> GCWork<<C as GCWorkContext>::VM> for StopMutators<C>
source§fn do_work(&mut self, worker: &mut GCWorker<C::VM>, mmtk: &'static MMTK<C::VM>)
fn do_work(&mut self, worker: &mut GCWorker<C::VM>, mmtk: &'static MMTK<C::VM>)
Define the work for this packet. However, this is not supposed to be called directly.
Usually
do_work_with_stat() should be used. Read moresource§fn do_work_with_stat(
&mut self,
worker: &mut GCWorker<VM>,
mmtk: &'static MMTK<VM>,
)
fn do_work_with_stat( &mut self, worker: &mut GCWorker<VM>, mmtk: &'static MMTK<VM>, )
Do work and collect statistics. This internally calls
do_work(). In most cases,
this should be called rather than do_work() so that MMTk can correctly collect
statistics for the work packets.
If the feature “work_packet_stats” is not enabled, this call simply forwards the call
to do_work().source§fn get_type_name(&self) -> &'static str
fn get_type_name(&self) -> &'static str
Get the compile-time static type name for the work packet.
Auto Trait Implementations§
impl<C> Freeze for StopMutators<C>
impl<C> RefUnwindSafe for StopMutators<C>where
C: RefUnwindSafe,
impl<C> Send for StopMutators<C>
impl<C> Sync for StopMutators<C>where
C: Sync,
impl<C> Unpin for StopMutators<C>where
C: Unpin,
impl<C> UnwindSafe for StopMutators<C>where
C: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Converts
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Converts
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Converts
&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)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Converts
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.§impl<T> DowncastSend for T
impl<T> DowncastSend for T
§impl<T> DowncastSync for T
impl<T> DowncastSync for T
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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