Propagates assume

This commit is contained in:
dianqk 2026-01-02 22:15:40 +08:00
parent 0051e31f6f
commit e9a67c7472
No known key found for this signature in database
3 changed files with 82 additions and 0 deletions

View file

@ -140,6 +140,22 @@ impl<'tcx> MutVisitor<'tcx> for RangeSet<'tcx, '_, '_> {
};
}
fn visit_statement(&mut self, statement: &mut Statement<'tcx>, location: Location) {
self.super_statement(statement, location);
match &statement.kind {
StatementKind::Intrinsic(box NonDivergingIntrinsic::Assume(operand)) => {
if let Some(place) = operand.place()
&& self.is_ssa(place)
{
let successor = location.successor_within_block();
let range = WrappingRange { start: 1, end: 1 };
self.insert_range(place, successor, range);
}
}
_ => {}
}
}
fn visit_terminator(&mut self, terminator: &mut Terminator<'tcx>, location: Location) {
self.super_terminator(terminator, location);
match &terminator.kind {

View file

@ -0,0 +1,56 @@
- // MIR for `on_assume` before SsaRangePropagation
+ // MIR for `on_assume` after SsaRangePropagation
fn on_assume(_1: usize, _2: &[u8]) -> u8 {
debug i => _1;
debug v => _2;
let mut _0: u8;
let _3: ();
let _4: ();
let mut _5: bool;
let mut _6: usize;
let mut _7: usize;
let mut _8: &[u8];
let _9: usize;
let mut _10: usize;
let mut _11: bool;
scope 1 (inlined core::slice::<impl [u8]>::len) {
scope 2 (inlined std::ptr::metadata::<[u8]>) {
}
}
bb0: {
StorageLive(_3);
StorageLive(_4);
nop;
StorageLive(_6);
_6 = copy _1;
nop;
StorageLive(_8);
_8 = &(*_2);
_7 = PtrMetadata(copy _2);
StorageDead(_8);
_5 = Lt(copy _1, copy _7);
nop;
StorageDead(_6);
assume(copy _5);
nop;
StorageDead(_4);
_3 = const ();
StorageDead(_3);
StorageLive(_9);
_9 = copy _1;
_10 = copy _7;
- _11 = copy _5;
- assert(copy _5, "index out of bounds: the length is {} but the index is {}", copy _7, copy _1) -> [success: bb1, unwind unreachable];
+ _11 = const true;
+ assert(const true, "index out of bounds: the length is {} but the index is {}", copy _7, copy _1) -> [success: bb1, unwind unreachable];
}
bb1: {
_0 = copy (*_2)[_1];
StorageDead(_9);
return;
}
}

View file

@ -20,6 +20,16 @@ pub fn on_assert(i: usize, v: &[u8]) -> u8 {
v[i]
}
// EMIT_MIR ssa_range.on_assume.SsaRangePropagation.diff
pub fn on_assume(i: usize, v: &[u8]) -> u8 {
// CHECK-LABEL: fn on_assume(
// CHECK: assert(const true
unsafe {
std::intrinsics::assume(i < v.len());
}
v[i]
}
// EMIT_MIR ssa_range.on_match.SsaRangePropagation.diff
pub fn on_match(i: u8) -> u8 {
// CHECK-LABEL: fn on_match(