coverage: SSA doesn't need to know about instrprof_increment

This commit is contained in:
Zalathar 2024-10-25 13:57:46 +11:00
parent b3d65852c3
commit 8f07514520
3 changed files with 12 additions and 29 deletions

View File

@ -1725,16 +1725,6 @@ fn fptoui_sat(&mut self, val: RValue<'gcc>, dest_ty: Type<'gcc>) -> RValue<'gcc>
fn fptosi_sat(&mut self, val: RValue<'gcc>, dest_ty: Type<'gcc>) -> RValue<'gcc> { fn fptosi_sat(&mut self, val: RValue<'gcc>, dest_ty: Type<'gcc>) -> RValue<'gcc> {
self.fptoint_sat(true, val, dest_ty) self.fptoint_sat(true, val, dest_ty)
} }
fn instrprof_increment(
&mut self,
_fn_name: RValue<'gcc>,
_hash: RValue<'gcc>,
_num_counters: RValue<'gcc>,
_index: RValue<'gcc>,
) {
unimplemented!();
}
} }
impl<'a, 'gcc, 'tcx> Builder<'a, 'gcc, 'tcx> { impl<'a, 'gcc, 'tcx> Builder<'a, 'gcc, 'tcx> {

View File

@ -1165,17 +1165,6 @@ fn lifetime_end(&mut self, ptr: &'ll Value, size: Size) {
self.call_lifetime_intrinsic("llvm.lifetime.end.p0i8", ptr, size); self.call_lifetime_intrinsic("llvm.lifetime.end.p0i8", ptr, size);
} }
#[instrument(level = "debug", skip(self))]
fn instrprof_increment(
&mut self,
fn_name: &'ll Value,
hash: &'ll Value,
num_counters: &'ll Value,
index: &'ll Value,
) {
self.call_intrinsic("llvm.instrprof.increment", &[fn_name, hash, num_counters, index]);
}
fn call( fn call(
&mut self, &mut self,
llty: &'ll Type, llty: &'ll Type,
@ -1645,6 +1634,18 @@ fn kcfi_operand_bundle(
kcfi_bundle kcfi_bundle
} }
/// Emits a call to `llvm.instrprof.increment`. Used by coverage instrumentation.
#[instrument(level = "debug", skip(self))]
pub(crate) fn instrprof_increment(
&mut self,
fn_name: &'ll Value,
hash: &'ll Value,
num_counters: &'ll Value,
index: &'ll Value,
) {
self.call_intrinsic("llvm.instrprof.increment", &[fn_name, hash, num_counters, index]);
}
/// Emits a call to `llvm.instrprof.mcdc.parameters`. /// Emits a call to `llvm.instrprof.mcdc.parameters`.
/// ///
/// This doesn't produce any code directly, but is used as input by /// This doesn't produce any code directly, but is used as input by

View File

@ -437,14 +437,6 @@ fn atomic_rmw(
/// Called for `StorageDead` /// Called for `StorageDead`
fn lifetime_end(&mut self, ptr: Self::Value, size: Size); fn lifetime_end(&mut self, ptr: Self::Value, size: Size);
fn instrprof_increment(
&mut self,
fn_name: Self::Value,
hash: Self::Value,
num_counters: Self::Value,
index: Self::Value,
);
fn call( fn call(
&mut self, &mut self,
llty: Self::Type, llty: Self::Type,