rust/tests/ui/union/union-packed.rs
2023-01-11 09:32:08 +00:00

174 lines
3.8 KiB
Rust

// run-pass
// revisions: mirunsafeck thirunsafeck
// [thirunsafeck]compile-flags: -Z thir-unsafeck
#![allow(dead_code)]
#![allow(non_snake_case)]
use std::mem::{size_of, size_of_val, align_of, align_of_val};
struct S {
a: u16,
b: [u8; 3],
}
#[repr(packed)]
struct Sp1 {
a: u16,
b: [u8; 3],
}
#[repr(packed(2))]
struct Sp2 {
a: u16,
b: [u8; 3],
}
union U {
a: u16,
b: [u8; 3],
}
#[repr(packed)]
union Up1 {
a: u16,
b: [u8; 3],
}
#[repr(packed(2))]
union Up2 {
a: u16,
b: [u8; 3],
}
#[repr(C, packed(4))]
union Up4c {
a: u16,
b: [u8; 3],
}
const CS: S = S { a: 0, b: [0, 0, 0] };
const CSP1: Sp1 = Sp1 { a: 0, b: [0, 0, 0] };
const CSP2: Sp2 = Sp2 { a: 0, b: [0, 0, 0] };
const CU: U = U { b: [0, 0, 0] };
const CUP1: Up1 = Up1 { b: [0, 0, 0] };
const CUP2: Up2 = Up2 { b: [0, 0, 0] };
const CUP4C: Up4c = Up4c { b: [0, 0, 0] };
fn main() {
let s = S { a: 0, b: [0, 0, 0] };
assert_eq!(size_of::<S>(), 6);
assert_eq!(size_of_val(&s), 6);
assert_eq!(size_of_val(&CS), 6);
assert_eq!(align_of::<S>(), 2);
assert_eq!(align_of_val(&s), 2);
assert_eq!(align_of_val(&CS), 2);
let sp1 = Sp1 { a: 0, b: [0, 0, 0] };
assert_eq!(size_of::<Sp1>(), 5);
assert_eq!(size_of_val(&sp1), 5);
assert_eq!(size_of_val(&CSP1), 5);
assert_eq!(align_of::<Sp1>(), 1);
assert_eq!(align_of_val(&sp1), 1);
assert_eq!(align_of_val(&CSP1), 1);
let sp2 = Sp2 { a: 0, b: [0, 0, 0] };
assert_eq!(size_of::<Sp2>(), 6);
assert_eq!(size_of_val(&sp2), 6);
assert_eq!(size_of_val(&CSP2), 6);
assert_eq!(align_of::<Sp2>(), 2);
assert_eq!(align_of_val(&sp2), 2);
assert_eq!(align_of_val(&CSP2), 2);
let u = U { b: [0, 0, 0] };
assert_eq!(size_of::<U>(), 4);
assert_eq!(size_of_val(&u), 4);
assert_eq!(size_of_val(&CU), 4);
assert_eq!(align_of::<U>(), 2);
assert_eq!(align_of_val(&u), 2);
assert_eq!(align_of_val(&CU), 2);
let Up1 = Up1 { b: [0, 0, 0] };
assert_eq!(size_of::<Up1>(), 3);
assert_eq!(size_of_val(&Up1), 3);
assert_eq!(size_of_val(&CUP1), 3);
assert_eq!(align_of::<Up1>(), 1);
assert_eq!(align_of_val(&Up1), 1);
assert_eq!(align_of_val(&CUP1), 1);
let up2 = Up2 { b: [0, 0, 0] };
assert_eq!(size_of::<Up2>(), 4);
assert_eq!(size_of_val(&up2), 4);
assert_eq!(size_of_val(&CUP2), 4);
assert_eq!(align_of::<Up2>(), 2);
assert_eq!(align_of_val(&up2), 2);
assert_eq!(align_of_val(&CUP2), 2);
let up4c = Up4c { b: [0, 0, 0] };
assert_eq!(size_of::<Up4c>(), 4);
assert_eq!(size_of_val(&up4c), 4);
assert_eq!(size_of_val(&CUP4C), 4);
assert_eq!(align_of::<Up4c>(), 2);
assert_eq!(align_of_val(&up4c), 2);
assert_eq!(align_of_val(&CUP4C), 2);
hybrid::check_hybrid();
}
mod hybrid {
use std::mem::{size_of, align_of};
#[repr(packed)]
#[derive(Copy, Clone)]
struct S1 {
a: u16,
b: u8,
}
#[repr(packed)]
union U {
s: S1,
c: u16,
}
#[repr(packed)]
struct S2 {
d: u8,
u: U,
}
#[repr(C, packed(2))]
struct S1C {
a: u16,
b: u8,
}
#[repr(C, packed(2))]
union UC {
s: S1,
c: u16,
}
#[repr(C, packed(2))]
struct S2C {
d: u8,
u: UC,
}
pub fn check_hybrid() {
assert_eq!(align_of::<S1>(), 1);
assert_eq!(size_of::<S1>(), 3);
assert_eq!(align_of::<U>(), 1);
assert_eq!(size_of::<U>(), 3);
assert_eq!(align_of::<S2>(), 1);
assert_eq!(size_of::<S2>(), 4);
assert_eq!(align_of::<S1C>(), 2);
assert_eq!(size_of::<S1C>(), 4);
assert_eq!(align_of::<UC>(), 2);
assert_eq!(size_of::<UC>(), 4);
assert_eq!(align_of::<S2C>(), 2);
assert_eq!(size_of::<S2C>(), 6);
}
}