Only check packed ADT.
This commit is contained in:
parent
1c5f1762b7
commit
15a68610dd
3 changed files with 8 additions and 6 deletions
|
@ -40,7 +40,7 @@ where
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_within_packed<'tcx, L>(
|
pub fn is_within_packed<'tcx, L>(
|
||||||
tcx: TyCtxt<'tcx>,
|
tcx: TyCtxt<'tcx>,
|
||||||
local_decls: &L,
|
local_decls: &L,
|
||||||
place: Place<'tcx>,
|
place: Place<'tcx>,
|
||||||
|
|
|
@ -5,7 +5,7 @@ mod check_validity_requirement;
|
||||||
mod compare_types;
|
mod compare_types;
|
||||||
mod type_name;
|
mod type_name;
|
||||||
|
|
||||||
pub use self::alignment::is_disaligned;
|
pub use self::alignment::{is_disaligned, is_within_packed};
|
||||||
pub use self::check_validity_requirement::check_validity_requirement;
|
pub use self::check_validity_requirement::check_validity_requirement;
|
||||||
pub use self::compare_types::{is_equal_up_to_subtyping, is_subtype};
|
pub use self::compare_types::{is_equal_up_to_subtyping, is_subtype};
|
||||||
pub use self::type_name::type_name;
|
pub use self::type_name::type_name;
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
//! will still not cause any further changes.
|
//! will still not cause any further changes.
|
||||||
//!
|
//!
|
||||||
|
|
||||||
use crate::util::is_disaligned;
|
use crate::util::is_within_packed;
|
||||||
use rustc_index::bit_set::BitSet;
|
use rustc_index::bit_set::BitSet;
|
||||||
use rustc_middle::mir::visit::Visitor;
|
use rustc_middle::mir::visit::Visitor;
|
||||||
use rustc_middle::mir::*;
|
use rustc_middle::mir::*;
|
||||||
|
@ -32,8 +32,6 @@ pub fn eliminate<'tcx>(tcx: TyCtxt<'tcx>, body: &mut Body<'tcx>, borrowed: &BitS
|
||||||
.iterate_to_fixpoint()
|
.iterate_to_fixpoint()
|
||||||
.into_results_cursor(body);
|
.into_results_cursor(body);
|
||||||
|
|
||||||
let param_env = tcx.param_env_reveal_all_normalized(body.source.def_id());
|
|
||||||
|
|
||||||
// For blocks with a call terminator, if an argument copy can be turned into a move,
|
// For blocks with a call terminator, if an argument copy can be turned into a move,
|
||||||
// record it as (block, argument index).
|
// record it as (block, argument index).
|
||||||
let mut call_operands_to_move = Vec::new();
|
let mut call_operands_to_move = Vec::new();
|
||||||
|
@ -52,7 +50,11 @@ pub fn eliminate<'tcx>(tcx: TyCtxt<'tcx>, body: &mut Body<'tcx>, borrowed: &BitS
|
||||||
&& !place.is_indirect()
|
&& !place.is_indirect()
|
||||||
&& !borrowed.contains(place.local)
|
&& !borrowed.contains(place.local)
|
||||||
&& !state.contains(place.local)
|
&& !state.contains(place.local)
|
||||||
&& !is_disaligned(tcx, body, param_env, place)
|
// If `place` is a projection of a disaligned field in a packed ADT,
|
||||||
|
// the move may be codegened as a pointer to that field.
|
||||||
|
// Using that disaligned pointer may trigger UB in the callee,
|
||||||
|
// so do nothing.
|
||||||
|
&& is_within_packed(tcx, body, place).is_none()
|
||||||
{
|
{
|
||||||
call_operands_to_move.push((bb, index));
|
call_operands_to_move.push((bb, index));
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue