171 lines
3.7 KiB
Rust
171 lines
3.7 KiB
Rust
//@ run-pass
|
|
|
|
#![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);
|
|
}
|
|
}
|