ConstProp: Remove const when rvalue check fails.
This commit is contained in:
parent
b1a6cf4a0e
commit
9121a41450
2 changed files with 7 additions and 3 deletions
|
@ -439,6 +439,7 @@ impl<'mir, 'tcx> ConstPropagator<'mir, 'tcx> {
|
||||||
|
|
||||||
// FIXME we need to revisit this for #67176
|
// FIXME we need to revisit this for #67176
|
||||||
if rvalue.has_param() {
|
if rvalue.has_param() {
|
||||||
|
trace!("skipping, has param");
|
||||||
return None;
|
return None;
|
||||||
}
|
}
|
||||||
if !rvalue
|
if !rvalue
|
||||||
|
@ -707,7 +708,11 @@ impl<'tcx> Visitor<'tcx> for ConstPropagator<'_, 'tcx> {
|
||||||
fn visit_assign(&mut self, place: &Place<'tcx>, rvalue: &Rvalue<'tcx>, location: Location) {
|
fn visit_assign(&mut self, place: &Place<'tcx>, rvalue: &Rvalue<'tcx>, location: Location) {
|
||||||
self.super_assign(place, rvalue, location);
|
self.super_assign(place, rvalue, location);
|
||||||
|
|
||||||
let Some(()) = self.check_rvalue(rvalue) else { return };
|
let Some(()) = self.check_rvalue(rvalue) else {
|
||||||
|
trace!("rvalue check failed, removing const");
|
||||||
|
Self::remove_const(&mut self.ecx, place.local);
|
||||||
|
return;
|
||||||
|
};
|
||||||
|
|
||||||
match self.ecx.machine.can_const_prop[place.local] {
|
match self.ecx.machine.can_const_prop[place.local] {
|
||||||
// Do nothing if the place is indirect.
|
// Do nothing if the place is indirect.
|
||||||
|
|
|
@ -12,8 +12,7 @@
|
||||||
StorageLive(_1);
|
StorageLive(_1);
|
||||||
_1 = const 0_usize;
|
_1 = const 0_usize;
|
||||||
_1 = const _;
|
_1 = const _;
|
||||||
- _0 = _1;
|
_0 = _1;
|
||||||
+ _0 = const 0_usize;
|
|
||||||
StorageDead(_1);
|
StorageDead(_1);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue