rust/tests/pass/ptr_int_casts.rs

74 lines
1.7 KiB
Rust
Raw Normal View History

// compile-flags: -Zmiri-permissive-provenance
use std::mem;
2019-05-26 14:47:37 +02:00
use std::ptr;
2017-06-05 15:18:40 -07:00
fn eq_ref<T>(x: &T, y: &T) -> bool {
x as *const _ == y as *const _
}
2017-06-04 10:42:02 -07:00
fn f() -> i32 {
42
}
2020-04-16 09:06:21 +02:00
fn ptr_int_casts() {
2017-06-04 10:42:02 -07:00
// int-ptr-int
assert_eq!(1 as *const i32 as usize, 1);
assert_eq!((1 as *const i32).wrapping_offset(4) as usize, 1 + 4 * 4);
2017-06-04 10:42:02 -07:00
2019-05-26 14:47:37 +02:00
// negative overflowing wrapping_offset (going through memory because
// this used to trigger an ICE on 32bit)
let val = &mut ptr::null();
*val = (1 as *const u8).wrapping_offset(-4);
assert_eq!(*val as usize, usize::MAX - 2);
2019-05-26 14:47:37 +02:00
2022-06-21 23:48:09 -07:00
// ptr-int-ptr
{
2017-06-05 15:18:40 -07:00
let x = 13;
let mut y = &x as &_ as *const _ as usize;
y += 13;
y -= 13;
2017-06-05 15:18:40 -07:00
let y = y as *const _;
assert!(eq_ref(&x, unsafe { &*y }));
}
2022-06-21 23:48:09 -07:00
// fnptr-int-fnptr
{
let x: fn() -> i32 = f;
let y: *mut u8 = unsafe { mem::transmute(x as fn() -> i32) };
let mut y = y as usize;
y += 13;
y -= 13;
let x: fn() -> i32 = unsafe { mem::transmute(y as *mut u8) };
assert_eq!(x(), 42);
}
2017-07-20 13:52:58 -07:00
// involving types other than usize
assert_eq!((-1i32) as usize as *const i32 as usize, (-1i32) as usize);
2017-06-04 10:42:02 -07:00
}
2020-04-16 09:06:21 +02:00
fn ptr_int_ops() {
let v = [1i16, 2];
let x = &v[1] as *const i16 as usize;
// arithmetic
let _y = x + 4;
let _y = 4 + x;
let _y = x - 2;
// bit-operations, covered by alignment
assert_eq!(x & 1, 0);
assert_eq!(x & 0, 0);
assert_eq!(1 & (x + 1), 1);
2020-04-16 09:06:21 +02:00
let _y = !1 & x;
let _y = !0 & x;
let _y = x & !1;
// remainder, covered by alignment
assert_eq!(x % 2, 0);
assert_eq!((x + 1) % 2, 1);
2020-04-16 09:06:21 +02:00
// remainder with 1 is always 0
assert_eq!(x % 1, 0);
}
fn main() {
ptr_int_casts();
ptr_int_ops();
}