mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-29 10:13:54 +00:00
ddc367ded7
Const-stabilizes: - `write` - `write_bytes` - `write_unaligned` In the following paths: - `core::ptr` - `core::ptr::NonNull` - pointer `<*mut T>` Const-stabilizes the internal `core::intrinsics`: - `write_bytes` - `write_via_move`
36 lines
1.1 KiB
Rust
36 lines
1.1 KiB
Rust
//@ run-pass
|
|
|
|
// issue: https://github.com/rust-lang/rust/issues/69488
|
|
// Loads of partially-initialized data could produce completely-uninitialized results.
|
|
// Test to make sure that we no longer do such a "deinitializing" load.
|
|
|
|
// Or, equivalently: `MaybeUninit`.
|
|
pub union BagOfBits<T: Copy> {
|
|
uninit: (),
|
|
_storage: T,
|
|
}
|
|
|
|
pub const fn make_1u8_bag<T: Copy>() -> BagOfBits<T> {
|
|
assert!(core::mem::size_of::<T>() >= 1);
|
|
let mut bag = BagOfBits { uninit: () };
|
|
unsafe { (&mut bag as *mut _ as *mut u8).write(1); };
|
|
bag
|
|
}
|
|
|
|
pub fn check_bag<T: Copy>(bag: &BagOfBits<T>) {
|
|
let val = unsafe { (bag as *const _ as *const u8).read() };
|
|
assert_eq!(val, 1);
|
|
}
|
|
|
|
fn main() {
|
|
check_bag(&make_1u8_bag::<[usize; 1]>()); // Fine
|
|
check_bag(&make_1u8_bag::<usize>()); // Fine
|
|
|
|
const CONST_ARRAY_BAG: BagOfBits<[usize; 1]> = make_1u8_bag();
|
|
check_bag(&CONST_ARRAY_BAG); // Fine.
|
|
const CONST_USIZE_BAG: BagOfBits<usize> = make_1u8_bag();
|
|
|
|
// Used to panic since CTFE would make the entire `BagOfBits<usize>` uninit
|
|
check_bag(&CONST_USIZE_BAG);
|
|
}
|