Skip to content

Commit

Permalink
Fix use after drop in self-profile with llvm events
Browse files Browse the repository at this point in the history
  • Loading branch information
andjo403 committed Sep 29, 2021
1 parent 50f9f78 commit d90934c
Showing 1 changed file with 6 additions and 4 deletions.
10 changes: 6 additions & 4 deletions compiler/rustc_codegen_llvm/src/back/write.rs
Original file line number Diff line number Diff line change
Expand Up @@ -405,13 +405,15 @@ pub(crate) unsafe fn optimize_with_new_llvm_pass_manager(
None
};

let llvm_selfprofiler = if cgcx.prof.llvm_recording_enabled() {
let mut llvm_profiler = LlvmSelfProfiler::new(cgcx.prof.get_self_profiler().unwrap());
&mut llvm_profiler as *mut _ as *mut c_void
let mut llvm_profiler = if cgcx.prof.llvm_recording_enabled() {
Some(LlvmSelfProfiler::new(cgcx.prof.get_self_profiler().unwrap()))
} else {
std::ptr::null_mut()
None
};

let llvm_selfprofiler =
llvm_profiler.as_mut().map(|s| s as *mut _ as *mut c_void).unwrap_or(std::ptr::null_mut());

let extra_passes = config.passes.join(",");

// FIXME: NewPM doesn't provide a facility to pass custom InlineParams.
Expand Down

0 comments on commit d90934c

Please sign in to comment.