summaryrefslogtreecommitdiffstats
path: root/src/test/ui/issues/issue-2470-bounds-check-overflow.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
commit698f8c2f01ea549d77d7dc3338a12e04c11057b9 (patch)
tree173a775858bd501c378080a10dca74132f05bc50 /src/test/ui/issues/issue-2470-bounds-check-overflow.rs
parentInitial commit. (diff)
downloadrustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.tar.xz
rustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.zip
Adding upstream version 1.64.0+dfsg1.upstream/1.64.0+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/test/ui/issues/issue-2470-bounds-check-overflow.rs')
-rw-r--r--src/test/ui/issues/issue-2470-bounds-check-overflow.rs27
1 files changed, 27 insertions, 0 deletions
diff --git a/src/test/ui/issues/issue-2470-bounds-check-overflow.rs b/src/test/ui/issues/issue-2470-bounds-check-overflow.rs
new file mode 100644
index 000000000..f0e8e185e
--- /dev/null
+++ b/src/test/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]);
+}