| //@ normalize-stderr-test: "(\n)ALLOC \(.*\) \{\n(.*\n)*\}(\n)" -> "${1}ALLOC DUMP${3}" |
| //@ normalize-stderr-test: "\[0x[0-9a-z]..0x[0-9a-z]\]" -> "[0xX..0xY]" |
| |
| use std::mem; |
| |
| // We have three fields to avoid the ScalarPair optimization. |
| #[allow(unused)] |
| enum E { |
| None, |
| Some(&'static (), &'static (), usize), |
| } |
| |
| fn main() { |
| unsafe { |
| let mut p: mem::MaybeUninit<E> = mem::MaybeUninit::zeroed(); |
| // The copy when `E` is returned from `transmute` should destroy padding |
| // (even when we use `write_unaligned`, which under the hood uses an untyped copy). |
| p.as_mut_ptr().write_unaligned(mem::transmute((0usize, 0usize, 0usize))); |
| // This is a `None`, so everything but the discriminant is padding. |
| assert!(matches!(*p.as_ptr(), E::None)); |
| |
| // Turns out the discriminant is (currently) stored |
| // in the 1st pointer, so the second half is padding. |
| let c = &p as *const _ as *const u8; |
| let padding_offset = mem::size_of::<&'static ()>(); |
| // Read a padding byte. |
| let _val = *c.add(padding_offset); |
| //~^ERROR: uninitialized |
| } |
| } |