pub struct BasePlan<VM: VMBinding> {
pub(crate) global_state: Arc<GlobalState>,
pub options: Arc<Options>,
pub gc_trigger: Arc<GCTrigger<VM>>,
pub code_space: ImmortalSpace<VM>,
pub code_lo_space: ImmortalSpace<VM>,
pub ro_space: ImmortalSpace<VM>,
pub vm_space: VMSpace<VM>,
}
Expand description
BasePlan should contain all plan-related state and functions that are fundamental to all plans. These include VM-specific (but not plan-specific) features such as a code space or vm space, which are fundamental to all plans for a given VM. Features that are common to many (but not intrinsically all) plans should instead be included in CommonPlan.
Fields§
§global_state: Arc<GlobalState>
§options: Arc<Options>
§gc_trigger: Arc<GCTrigger<VM>>
§code_space: ImmortalSpace<VM>
§code_lo_space: ImmortalSpace<VM>
§ro_space: ImmortalSpace<VM>
§vm_space: VMSpace<VM>
A VM space is a space allocated and populated by the VM. Currently it is used by JikesRVM for boot image.
If VM space is present, it has some special interaction with the
memory_manager::is_mmtk_object
and the memory_manager::is_in_mmtk_spaces
functions.
-
The functions
is_mmtk_object
andfind_object_from_internal_pointer
require the valid object (VO) bit side metadata to identify objects. If the binding maintains the VO bit for objects in VM spaces, those functions will work accordingly. Otherwise, calling them is undefined behavior. -
The
is_in_mmtk_spaces
currently returnstrue
if the given object reference is in the VM space.
Implementations§
source§impl<VM: VMBinding> BasePlan<VM>
impl<VM: VMBinding> BasePlan<VM>
pub fn new(args: CreateSpecificPlanArgs<'_, VM>) -> BasePlan<VM>
pub fn get_used_pages(&self) -> usize
pub fn trace_object<Q: ObjectQueue>( &self, queue: &mut Q, object: ObjectReference, worker: &mut GCWorker<VM>, ) -> ObjectReference
pub fn prepare(&mut self, _tls: VMWorkerThread, _full_heap: bool)
pub fn release(&mut self, _tls: VMWorkerThread, _full_heap: bool)
pub(crate) fn collection_required<P: Plan>( &self, plan: &P, space_full: bool, ) -> bool
Trait Implementations§
source§impl<VM: VMBinding> PlanTraceObject<VM> for BasePlan<VM>
impl<VM: VMBinding> PlanTraceObject<VM> for BasePlan<VM>
source§fn trace_object<Q: ObjectQueue, const KIND: u8>(
&self,
__mmtk_queue: &mut Q,
__mmtk_objref: ObjectReference,
__mmtk_worker: &mut GCWorker<VM>,
) -> ObjectReference
fn trace_object<Q: ObjectQueue, const KIND: u8>( &self, __mmtk_queue: &mut Q, __mmtk_objref: ObjectReference, __mmtk_worker: &mut GCWorker<VM>, ) -> ObjectReference
source§fn post_scan_object(&self, __mmtk_objref: ObjectReference)
fn post_scan_object(&self, __mmtk_objref: ObjectReference)
VM::VMScanning::scan_object()
, and this function
will be called after the VM::VMScanning::scan_object()
as a hook to invoke possible policy post scan method.
If a plan does not have any policy that needs post scan, this method can be implemented as empty.
If a plan has a policy that has some policy specific behaviors for scanning (e.g. mark lines in Immix),
this method should also invoke those policy specific methods for objects in that space.source§fn may_move_objects<const KIND: u8>() -> bool
fn may_move_objects<const KIND: u8>() -> bool
Auto Trait Implementations§
impl<VM> !Freeze for BasePlan<VM>
impl<VM> !RefUnwindSafe for BasePlan<VM>
impl<VM> Send for BasePlan<VM>
impl<VM> Sync for BasePlan<VM>
impl<VM> Unpin for BasePlan<VM>where
VM: Unpin,
impl<VM> !UnwindSafe for BasePlan<VM>
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
§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>
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>
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)
&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)
&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>
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>
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