]> git.lizzy.rs Git - rust.git/blob - tests/ui/consts/ptr_comparisons.rs
Rollup merge of #106715 - BoxyUwU:new_solver_triagebot, r=lcnr
[rust.git] / tests / ui / consts / ptr_comparisons.rs
1 // compile-flags: --crate-type=lib
2 // normalize-stderr-32bit: "8 bytes" -> "$$TWO_WORDS bytes"
3 // normalize-stderr-64bit: "16 bytes" -> "$$TWO_WORDS bytes"
4 // normalize-stderr-32bit: "size 4" -> "size $$WORD"
5 // normalize-stderr-64bit: "size 8" -> "size $$WORD"
6
7 #![feature(
8     core_intrinsics,
9     const_raw_ptr_comparison,
10 )]
11
12 const FOO: &usize = &42;
13
14 macro_rules! check {
15     (eq, $a:expr, $b:expr) => {
16         pub const _: () =
17             assert!(std::intrinsics::ptr_guaranteed_cmp($a as *const u8, $b as *const u8) == 1);
18     };
19     (ne, $a:expr, $b:expr) => {
20         pub const _: () =
21             assert!(std::intrinsics::ptr_guaranteed_cmp($a as *const u8, $b as *const u8) == 0);
22     };
23     (!, $a:expr, $b:expr) => {
24         pub const _: () =
25             assert!(std::intrinsics::ptr_guaranteed_cmp($a as *const u8, $b as *const u8) == 2);
26     };
27 }
28
29 check!(eq, 0, 0);
30 check!(ne, 0, 1);
31 check!(ne, FOO as *const _, 0);
32 check!(ne, unsafe { (FOO as *const usize).offset(1) }, 0);
33 check!(ne, unsafe { (FOO as *const usize as *const u8).offset(3) }, 0);
34
35 // We want pointers to be equal to themselves, but aren't checking this yet because
36 // there are some open questions (e.g. whether function pointers to the same function
37 // compare equal, they don't necessarily at runtime).
38 // The case tested here should work eventually, but does not work yet.
39 check!(!, FOO as *const _, FOO as *const _);
40
41
42 ///////////////////////////////////////////////////////////////////////////////
43 // If any of the below start compiling, make sure to add a `check` test for it.
44 // These invocations exist as canaries so we don't forget to check that the
45 // behaviour of `guaranteed_eq` and `guaranteed_ne` is still correct.
46 // All of these try to obtain an out of bounds pointer in some manner. If we
47 // can create out of bounds pointers, we can offset a pointer far enough that
48 // at runtime it would be zero and at compile-time it would not be zero.
49
50 const _: *const usize = unsafe { (FOO as *const usize).offset(2) };
51
52 const _: *const u8 =
53     unsafe { std::ptr::addr_of!((*(FOO as *const usize as *const [u8; 1000]))[999]) };
54 //~^ ERROR evaluation of constant value failed
55 //~| out-of-bounds
56
57 const _: usize = unsafe { std::mem::transmute::<*const usize, usize>(FOO) + 4 };
58 //~^ ERROR evaluation of constant value failed
59 //~| unable to turn pointer into raw bytes
60
61 const _: usize = unsafe { *std::mem::transmute::<&&usize, &usize>(&FOO) + 4 };
62 //~^ ERROR evaluation of constant value failed
63 //~| unable to turn pointer into raw bytes