2018-09-06 14:41:12 +02:00
|
|
|
// run-pass
|
2021-05-13 10:42:25 -04:00
|
|
|
// revisions: mirunsafeck thirunsafeck
|
|
|
|
// [thirunsafeck]compile-flags: -Z thir-unsafeck
|
|
|
|
|
2018-09-25 23:51:35 +02:00
|
|
|
#![allow(dead_code)]
|
2018-09-06 14:41:12 +02:00
|
|
|
|
2017-07-17 00:44:13 +10:00
|
|
|
use std::mem::{size_of, size_of_val, align_of, align_of_val};
|
|
|
|
|
|
|
|
#[repr(align(16))]
|
|
|
|
pub union U16 {
|
|
|
|
a: u8,
|
|
|
|
b: u32
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
assert_eq!(align_of::<U16>(), 16);
|
|
|
|
assert_eq!(size_of::<U16>(), 16);
|
|
|
|
let u = U16 { a: 10 };
|
|
|
|
unsafe {
|
|
|
|
assert_eq!(align_of_val(&u.a), 1);
|
|
|
|
assert_eq!(size_of_val(&u.a), 1);
|
|
|
|
assert_eq!(u.a, 10);
|
|
|
|
}
|
|
|
|
|
|
|
|
let u = U16 { b: 11 };
|
|
|
|
unsafe {
|
|
|
|
assert_eq!(align_of_val(&u.b), 4);
|
|
|
|
assert_eq!(size_of_val(&u.b), 4);
|
|
|
|
assert_eq!(u.b, 11);
|
|
|
|
}
|
|
|
|
|
|
|
|
hybrid::check_hybrid();
|
|
|
|
}
|
|
|
|
|
|
|
|
mod hybrid {
|
|
|
|
use std::mem::{size_of, align_of};
|
|
|
|
|
|
|
|
#[repr(align(16))]
|
2020-10-04 22:24:14 +02:00
|
|
|
#[derive(Copy, Clone)]
|
2017-07-17 00:44:13 +10:00
|
|
|
struct S1 {
|
|
|
|
a: u16,
|
|
|
|
b: u8,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(align(32))]
|
|
|
|
union U {
|
|
|
|
s: S1,
|
|
|
|
c: u16,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(align(64))]
|
|
|
|
struct S2 {
|
|
|
|
d: u8,
|
|
|
|
u: U,
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn check_hybrid() {
|
|
|
|
assert_eq!(align_of::<S1>(), 16);
|
|
|
|
assert_eq!(size_of::<S1>(), 16);
|
|
|
|
assert_eq!(align_of::<U>(), 32);
|
|
|
|
assert_eq!(size_of::<U>(), 32);
|
|
|
|
assert_eq!(align_of::<S2>(), 64);
|
|
|
|
assert_eq!(size_of::<S2>(), 64);
|
|
|
|
}
|
|
|
|
}
|