72800d3b89
Except for `simd-intrinsic/`, which has a lot of files containing multiple types like `u8x64` which really are better when hand-formatted. There is a surprising amount of two-space indenting in this directory. Non-trivial changes: - `rustfmt::skip` needed in `debug-column.rs` to preserve meaning of the test. - `rustfmt::skip` used in a few places where hand-formatting read more nicely: `enum/enum-match.rs` - Line number adjustments needed for the expected output of `debug-column.rs` and `coroutine-debug.rs`.
35 lines
1.1 KiB
Rust
35 lines
1.1 KiB
Rust
//@ compile-flags: -C no-prepopulate-passes
|
|
//
|
|
|
|
#![crate_type = "lib"]
|
|
|
|
pub struct Bytes {
|
|
a: u8,
|
|
b: u8,
|
|
c: u8,
|
|
d: u8,
|
|
}
|
|
|
|
// CHECK-LABEL: small_array_alignment
|
|
// The array is stored as i32, but its alignment is lower, go with 1 byte to avoid target
|
|
// dependent alignment
|
|
#[no_mangle]
|
|
pub fn small_array_alignment(x: &mut [i8; 4], y: [i8; 4]) {
|
|
// CHECK: [[TMP:%.+]] = alloca [4 x i8], align 4
|
|
// CHECK: %y = alloca [4 x i8], align 1
|
|
// CHECK: store i32 %0, ptr [[TMP]]
|
|
// CHECK: call void @llvm.memcpy.{{.*}}(ptr align 1 {{.+}}, ptr align 4 {{.+}}, i{{[0-9]+}} 4, i1 false)
|
|
*x = y;
|
|
}
|
|
|
|
// CHECK-LABEL: small_struct_alignment
|
|
// The struct is stored as i32, but its alignment is lower, go with 1 byte to avoid target
|
|
// dependent alignment
|
|
#[no_mangle]
|
|
pub fn small_struct_alignment(x: &mut Bytes, y: Bytes) {
|
|
// CHECK: [[TMP:%.+]] = alloca [4 x i8], align 4
|
|
// CHECK: %y = alloca [4 x i8], align 1
|
|
// CHECK: store i32 %0, ptr [[TMP]]
|
|
// CHECK: call void @llvm.memcpy.{{.*}}(ptr align 1 {{.+}}, ptr align 4 {{.+}}, i{{[0-9]+}} 4, i1 false)
|
|
*x = y;
|
|
}
|