summaryrefslogtreecommitdiffstats
path: root/tests/ui/issues/issue-2470-bounds-check-overflow.rs
diff options
context:
space:
mode:
Diffstat (limited to 'tests/ui/issues/issue-2470-bounds-check-overflow.rs')
-rw-r--r--tests/ui/issues/issue-2470-bounds-check-overflow.rs27
1 files changed, 27 insertions, 0 deletions
diff --git a/tests/ui/issues/issue-2470-bounds-check-overflow.rs b/tests/ui/issues/issue-2470-bounds-check-overflow.rs
new file mode 100644
index 000000000..f0e8e185e
--- /dev/null
+++ b/tests/ui/issues/issue-2470-bounds-check-overflow.rs
@@ -0,0 +1,27 @@
+// run-fail
+// error-pattern:index out of bounds
+// ignore-emscripten no processes
+
+use std::mem;
+
+fn main() {
+
+ // This should cause a bounds-check panic, but may not if we do our
+ // bounds checking by comparing the scaled index to the vector's
+ // address-bounds, since we've scaled the index to wrap around to the
+ // address of the 0th cell in the array (even though the index is
+ // huge).
+
+ let x = vec![1_usize, 2_usize, 3_usize];
+
+ let base = x.as_ptr() as usize;
+ let idx = base / mem::size_of::<usize>();
+ println!("ov1 base = 0x{:x}", base);
+ println!("ov1 idx = 0x{:x}", idx);
+ println!("ov1 sizeof::<usize>() = 0x{:x}", mem::size_of::<usize>());
+ println!("ov1 idx * sizeof::<usize>() = 0x{:x}",
+ idx * mem::size_of::<usize>());
+
+ // This should panic.
+ println!("ov1 0x{:x}", x[idx]);
+}