From 6f7372bdd1ec2b96f00ec4ac6d1bcf9a7d408bef Mon Sep 17 00:00:00 2001 From: Josh Stone Date: Mon, 24 Feb 2020 16:21:22 -0800 Subject: [PATCH] Cherry-pick the LLVM fix for #69225 --- src/llvm-project | 2 +- .../issue-69225-SCEVAddExpr-wrap-flag.rs | 33 +++++++++++++++++++ 2 files changed, 34 insertions(+), 1 deletion(-) create mode 100644 src/test/ui/issues/issue-69225-SCEVAddExpr-wrap-flag.rs diff --git a/src/llvm-project b/src/llvm-project index d7cdb4359223b..73cf98d865673 160000 --- a/src/llvm-project +++ b/src/llvm-project @@ -1 +1 @@ -Subproject commit d7cdb4359223be265da34ebeaa00b92b7c5419fd +Subproject commit 73cf98d8656736781e3ea667011d2aefc21f521e diff --git a/src/test/ui/issues/issue-69225-SCEVAddExpr-wrap-flag.rs b/src/test/ui/issues/issue-69225-SCEVAddExpr-wrap-flag.rs new file mode 100644 index 0000000000000..6e030f1cc4875 --- /dev/null +++ b/src/test/ui/issues/issue-69225-SCEVAddExpr-wrap-flag.rs @@ -0,0 +1,33 @@ +// run-fail +// compile-flags: -C opt-level=3 +// error-pattern: index out of bounds: the len is 0 but the index is 16777216 +// ignore-wasm no panic or subprocess support +// ignore-emscripten no panic or subprocess support + +fn do_test(x: usize) { + let mut arr = vec![vec![0u8; 3]]; + + let mut z = vec![0]; + for arr_ref in arr.iter_mut() { + for y in 0..x { + for _ in 0..1 { + z.reserve_exact(x); + let iterator = std::iter::repeat(0).take(x); + let mut cnt = 0; + iterator.for_each(|_| { + z[0] = 0; + cnt += 1; + }); + let a = y * x; + let b = (y + 1) * x - 1; + let slice = &mut arr_ref[a..b]; + slice[1 << 24] += 1; + } + } + } +} + +fn main() { + do_test(1); + do_test(2); +}