Rollup merge of #72547 - alex:patch-1, r=oli-obk
Added a codegen test for a recent optimization for overflow-checks=on Closes #58692
This commit is contained in:
commit
05229f7be3
1 changed files with 26 additions and 0 deletions
26
src/test/codegen/integer-overflow.rs
Normal file
26
src/test/codegen/integer-overflow.rs
Normal file
|
|
@ -0,0 +1,26 @@
|
|||
// no-system-llvm
|
||||
// compile-flags: -O -C overflow-checks=on
|
||||
|
||||
#![crate_type = "lib"]
|
||||
|
||||
|
||||
pub struct S1<'a> {
|
||||
data: &'a [u8],
|
||||
position: usize,
|
||||
}
|
||||
|
||||
// CHECK-LABEL: @slice_no_index_order
|
||||
#[no_mangle]
|
||||
pub fn slice_no_index_order<'a>(s: &'a mut S1, n: usize) -> &'a [u8] {
|
||||
// CHECK-NOT: slice_index_order_fail
|
||||
let d = &s.data[s.position..s.position+n];
|
||||
s.position += n;
|
||||
return d;
|
||||
}
|
||||
|
||||
// CHECK-LABEL: @test_check
|
||||
#[no_mangle]
|
||||
pub fn test_check<'a>(s: &'a mut S1, x: usize, y: usize) -> &'a [u8] {
|
||||
// CHECK: slice_index_order_fail
|
||||
&s.data[x..y]
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue