pub(crate) struct CguCoverageContext<'ll, 'tcx> {
pub(crate) pgo_func_name_var_map: RefCell<FxIndexMap<Instance<'tcx>, &'ll Value>>,
pub(crate) mcdc_condition_bitmap_map: RefCell<FxHashMap<Instance<'tcx>, Vec<&'ll Value>>>,
covfun_section_name: OnceCell<CString>,
}
Expand description
Extra per-CGU context/state needed for coverage instrumentation.
Fields§
§pgo_func_name_var_map: RefCell<FxIndexMap<Instance<'tcx>, &'ll Value>>
Associates function instances with an LLVM global that holds the function’s symbol name, as needed by LLVM coverage intrinsics.
Instances in this map are also considered “used” for the purposes of
emitting covfun records. Every covfun record holds a hash of its
symbol name, and llvm-cov
will exit fatally if it can’t resolve that
hash back to an entry in the binary’s __llvm_prf_names
linker section.
mcdc_condition_bitmap_map: RefCell<FxHashMap<Instance<'tcx>, Vec<&'ll Value>>>
§covfun_section_name: OnceCell<CString>
Implementations§
Source§impl<'ll, 'tcx> CguCoverageContext<'ll, 'tcx>
impl<'ll, 'tcx> CguCoverageContext<'ll, 'tcx>
pub(crate) fn new() -> Self
Sourcefn try_get_mcdc_condition_bitmap(
&self,
instance: &Instance<'tcx>,
decision_depth: u16,
) -> Option<&'ll Value>
fn try_get_mcdc_condition_bitmap( &self, instance: &Instance<'tcx>, decision_depth: u16, ) -> Option<&'ll Value>
LLVM use a temp value to record evaluated mcdc test vector of each decision, which is
called condition bitmap. In order to handle nested decisions, several condition bitmaps can
be allocated for a function body. These values are named mcdc.addr.{i}
and are a 32-bit
integers. They respectively hold the condition bitmaps for decisions with a depth of i
.
Sourcepub(crate) fn instances_used(&self) -> Vec<Instance<'tcx>>
pub(crate) fn instances_used(&self) -> Vec<Instance<'tcx>>
Returns the list of instances considered “used” in this CGU, as
inferred from the keys of pgo_func_name_var_map
.
Auto Trait Implementations§
impl<'ll, 'tcx> !DynSend for CguCoverageContext<'ll, 'tcx>
impl<'ll, 'tcx> !DynSync for CguCoverageContext<'ll, 'tcx>
impl<'ll, 'tcx> !Freeze for CguCoverageContext<'ll, 'tcx>
impl<'ll, 'tcx> !RefUnwindSafe for CguCoverageContext<'ll, 'tcx>
impl<'ll, 'tcx> !Send for CguCoverageContext<'ll, 'tcx>
impl<'ll, 'tcx> !Sync for CguCoverageContext<'ll, 'tcx>
impl<'ll, 'tcx> Unpin for CguCoverageContext<'ll, 'tcx>
impl<'ll, 'tcx> !UnwindSafe for CguCoverageContext<'ll, 'tcx>
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
Source§impl<T, R> CollectAndApply<T, R> for T
impl<T, R> CollectAndApply<T, R> for T
Source§impl<T> Filterable for T
impl<T> Filterable for T
Source§fn filterable(
self,
filter_name: &'static str,
) -> RequestFilterDataProvider<T, fn(DataRequest<'_>) -> bool>
fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(DataRequest<'_>) -> bool>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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 moreSource§impl<P> IntoQueryParam<P> for P
impl<P> IntoQueryParam<P> for P
fn into_query_param(self) -> P
Source§impl<T> MaybeResult<T> for T
impl<T> MaybeResult<T> for T
Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
Source§impl<I, T> UpcastFrom<I, T> for T
impl<I, T> UpcastFrom<I, T> for T
fn upcast_from(from: T, _tcx: I) -> T
Source§impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
default fn from_cycle_error( tcx: Tcx, cycle_error: &CycleError, _guar: ErrorGuaranteed, ) -> T
Source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
Source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
Source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<T> ErasedDestructor for Twhere
T: 'static,
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 120 bytes