diff options
| author | Rich Kadel <richkadel@google.com> | 2021-05-11 20:56:23 -0700 |
|---|---|---|
| committer | Rich Kadel <richkadel@google.com> | 2021-05-12 20:27:07 -0700 |
| commit | aed8ef5a4d81bb66917ca31a589d5922c9bcf065 (patch) | |
| tree | 5c31d374aa6e077cd28c98f23fd8a7a29baa19ca /compiler/rustc_mir/src/transform/coverage/mod.rs | |
| parent | 31f523ff94247fd030473979782dda90923da1ef (diff) | |
| download | rust-aed8ef5a4d81bb66917ca31a589d5922c9bcf065.tar.gz rust-aed8ef5a4d81bb66917ca31a589d5922c9bcf065.zip | |
`coverageinfo` query needs to use the same MIR as codegen
I ran into an error trying to fix dead block coverage and realized the `coverageinfo` query is getting a different MIR compared to the codegenned MIR, which can sometimes be a problem during mapgen. I changed that query to use the `InstandeDef` (which includes the generic parameter substitutions, prosibly specific to const params) instead of the `DefId` (without unknown/default const substitutions).
Diffstat (limited to 'compiler/rustc_mir/src/transform/coverage/mod.rs')
| -rw-r--r-- | compiler/rustc_mir/src/transform/coverage/mod.rs | 12 |
1 files changed, 1 insertions, 11 deletions
diff --git a/compiler/rustc_mir/src/transform/coverage/mod.rs b/compiler/rustc_mir/src/transform/coverage/mod.rs index dc21bfbb445..71c244fdd4a 100644 --- a/compiler/rustc_mir/src/transform/coverage/mod.rs +++ b/compiler/rustc_mir/src/transform/coverage/mod.rs @@ -156,16 +156,6 @@ impl<'a, 'tcx> Instrumentor<'a, 'tcx> { let fn_sig_span = self.fn_sig_span; let body_span = self.body_span; -<<<<<<< HEAD - debug!( - "instrumenting {:?}, fn sig span: {}, body span: {}", - def_id, - source_map.span_to_diagnostic_string(fn_sig_span), - source_map.span_to_diagnostic_string(body_span) - ); - -======= ->>>>>>> 476104d0f54 (Simplified body_span and filtered span code) let mut graphviz_data = debug::GraphvizData::new(); let mut debug_used_expressions = debug::UsedExpressions::new(); @@ -572,7 +562,7 @@ fn get_body_span<'tcx>( if expn_data.is_root() { break; } - if let ExpnKind::Macro{..} = expn_data.kind { + if let ExpnKind::Macro { .. } = expn_data.kind { body_span = expn_data.call_site; } else { break; |
