2024-02-16 20:02:50 +00:00
|
|
|
//@ compile-flags: -Zunleash-the-miri-inside-of-you
|
|
|
|
//@ normalize-stderr-test "(the raw bytes of the constant) \(size: [0-9]*, align: [0-9]*\)" -> "$1 (size: $$SIZE, align: $$ALIGN)"
|
|
|
|
//@ normalize-stderr-test "([0-9a-f][0-9a-f] |╾─*ALLOC[0-9]+(\+[a-z0-9]+)?(<imm>)?─*╼ )+ *│.*" -> "HEX_DUMP"
|
2019-12-16 15:23:42 +01:00
|
|
|
|
|
|
|
use std::sync::atomic::AtomicUsize;
|
|
|
|
use std::sync::atomic::Ordering;
|
|
|
|
|
2019-12-24 12:24:32 +01:00
|
|
|
const MUTATE_INTERIOR_MUT: usize = {
|
2019-12-16 15:23:42 +01:00
|
|
|
static FOO: AtomicUsize = AtomicUsize::new(0);
|
2022-09-21 13:05:20 +02:00
|
|
|
FOO.fetch_add(1, Ordering::Relaxed) //~ERROR evaluation of constant value failed
|
2019-12-16 15:23:42 +01:00
|
|
|
};
|
|
|
|
|
2019-12-24 12:24:32 +01:00
|
|
|
const READ_INTERIOR_MUT: usize = {
|
2019-12-16 15:23:42 +01:00
|
|
|
static FOO: AtomicUsize = AtomicUsize::new(0);
|
2022-09-21 13:05:20 +02:00
|
|
|
unsafe { *(&FOO as *const _ as *const usize) } //~ERROR evaluation of constant value failed
|
2019-12-16 15:23:42 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
static mut MUTABLE: u32 = 0;
|
2022-09-21 13:05:20 +02:00
|
|
|
const READ_MUT: u32 = unsafe { MUTABLE }; //~ERROR evaluation of constant value failed
|
|
|
|
|
2024-01-06 13:48:48 +01:00
|
|
|
// Evaluating this does not read anything mutable, but validation does, so this should error.
|
|
|
|
const REF_INTERIOR_MUT: &usize = { //~ ERROR undefined behavior
|
|
|
|
//~| encountered reference to mutable memory
|
2022-09-21 13:05:20 +02:00
|
|
|
static FOO: AtomicUsize = AtomicUsize::new(0);
|
|
|
|
unsafe { &*(&FOO as *const _ as *const usize) }
|
|
|
|
};
|
|
|
|
|
2024-01-06 13:48:48 +01:00
|
|
|
// Not actually reading from anything mutable, so these are fine.
|
2023-12-16 16:24:25 +01:00
|
|
|
static MY_STATIC: u8 = 4;
|
|
|
|
const REF_IMMUT: &u8 = &MY_STATIC;
|
2024-01-05 12:18:11 +01:00
|
|
|
const READ_IMMUT: u8 = *REF_IMMUT;
|
2023-12-16 16:24:25 +01:00
|
|
|
|
2022-09-21 13:05:20 +02:00
|
|
|
fn main() {}
|