Struct mmtk::scheduler::gc_work::ProcessRootNode
source · pub(crate) struct ProcessRootNode<VM: VMBinding, R2OPE: ProcessEdgesWork<VM = VM>, O2OPE: ProcessEdgesWork<VM = VM>> {
phantom: PhantomData<(VM, R2OPE, O2OPE)>,
roots: Vec<ObjectReference>,
bucket: WorkBucketStage,
}
Expand description
This work packet processes pinning roots.
The roots
member holds a list of ObjectReference
to objects directly pointed by roots.
These objects will be traced using R2OPE
(Root-to-Object Process Edges).
After that, it will create work packets for tracing their children. Those work packets (and
the work packets further created by them) will use O2OPE
(Object-to-Object Process Edges) as
their ProcessEdgesWork
implementations.
Because roots
are pinning roots, R2OPE
must be a ProcessEdgesWork
that never moves any
object.
The choice of O2OPE
determines whether the roots
are transitively pinning or not.
- If
O2OPE
is set to aProcessEdgesWork
that never moves objects, all descendents ofroots
will not be moved in this GC. That implements transitive pinning roots. - If
O2OPE
may move objects, then thisProcessRootsNode<VM, R2OPE, O2OPE>
work packet will only pin the objects inroots
(becauseR2OPE
must not move objects anyway), but not their descendents.
Fields§
§phantom: PhantomData<(VM, R2OPE, O2OPE)>
§roots: Vec<ObjectReference>
§bucket: WorkBucketStage
Implementations§
source§impl<VM: VMBinding, R2OPE: ProcessEdgesWork<VM = VM>, O2OPE: ProcessEdgesWork<VM = VM>> ProcessRootNode<VM, R2OPE, O2OPE>
impl<VM: VMBinding, R2OPE: ProcessEdgesWork<VM = VM>, O2OPE: ProcessEdgesWork<VM = VM>> ProcessRootNode<VM, R2OPE, O2OPE>
pub fn new(nodes: Vec<ObjectReference>, bucket: WorkBucketStage) -> Self
Trait Implementations§
source§impl<VM: VMBinding, R2OPE: ProcessEdgesWork<VM = VM>, O2OPE: ProcessEdgesWork<VM = VM>> GCWork<VM> for ProcessRootNode<VM, R2OPE, O2OPE>
impl<VM: VMBinding, R2OPE: ProcessEdgesWork<VM = VM>, O2OPE: ProcessEdgesWork<VM = VM>> GCWork<VM> for ProcessRootNode<VM, R2OPE, O2OPE>
source§fn do_work(&mut self, worker: &mut GCWorker<VM>, mmtk: &'static MMTK<VM>)
fn do_work(&mut self, worker: &mut GCWorker<VM>, mmtk: &'static MMTK<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<VM, R2OPE, O2OPE> RefUnwindSafe for ProcessRootNode<VM, R2OPE, O2OPE>
impl<VM, R2OPE, O2OPE> Send for ProcessRootNode<VM, R2OPE, O2OPE>
impl<VM, R2OPE, O2OPE> Sync for ProcessRootNode<VM, R2OPE, O2OPE>
impl<VM, R2OPE, O2OPE> Unpin for ProcessRootNode<VM, R2OPE, O2OPE>
impl<VM, R2OPE, O2OPE> UnwindSafe for ProcessRootNode<VM, R2OPE, O2OPE>
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>
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>
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)
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)
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
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