pub enum MmapAnnotation<'a> {
Space {
name: &'a str,
},
SideMeta {
space: &'a str,
meta: &'a str,
},
Test {
file: &'a str,
line: u32,
},
Misc {
name: &'a str,
},
}
Expand description
Annotation for an mmap entry.
Invocations of mmap_fixed
and other functions that may transitively call mmap_fixed
require an annotation that indicates the purpose of the memory mapping.
This is for debugging. On Linux, mmtk-core will use prctl
with PR_SET_VMA
to set the
human-readable name for the given mmap region. The annotation is ignored on other platforms.
Note that when using Map32
(even when running on 64-bit architectures), the discontiguous
memory range is shared between different spaces. Spaces may use mmap
to map new chunks, but
the same chunk may later be reused by other spaces. The annotation only applies when mmap
is
called for a chunk for the first time, which reflects which space first attempted the mmap, not
which space is currently using the chunk. Use crate::policy::space::print_vm_map
to print a
more accurate mapping between address ranges and spaces.
On 32-bit architecture, side metadata are allocated in a chunked fasion. One single mmap
region will contain many different metadata. In that case, we simply annotate the whole region
with a MmapAnnotation::SideMeta
where meta
is "all"
.
Variants§
Space
The mmap is for a space.
SideMeta
The mmap is for a side metadata.
Test
The mmap is for a test case. Usually constructed using the mmap_anno_test!
macro.
Misc
For all other use cases.
Trait Implementations§
Auto Trait Implementations§
impl<'a> Freeze for MmapAnnotation<'a>
impl<'a> RefUnwindSafe for MmapAnnotation<'a>
impl<'a> Send for MmapAnnotation<'a>
impl<'a> Sync for MmapAnnotation<'a>
impl<'a> Unpin for MmapAnnotation<'a>
impl<'a> UnwindSafe for MmapAnnotation<'a>
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