8d5fd94e62
Tests added in cast-target-abi.rs, covering the single element, array, and prefix cases in `CastTarget::llvm_type`, and the Rust-is-larger/smaller cases in the Rust<->ABI copying code. ffi-out-of-bounds-loads.rs was overhauled to be runnable on any platform. Its alignment also increases due to the removal of a `min` in the previous commit; this was probably an insufficient workaround for this issue or similar. The higher alignment is fine, since the alloca is actually aligned to 8 bytes, as the test checks now confirm.
41 lines
908 B
Rust
41 lines
908 B
Rust
//@ revisions: linux apple
|
|
//@ compile-flags: -C opt-level=0 -C no-prepopulate-passes
|
|
|
|
//@[linux] compile-flags: --target x86_64-unknown-linux-gnu
|
|
//@[linux] needs-llvm-components: x86
|
|
//@[apple] compile-flags: --target x86_64-apple-darwin
|
|
//@[apple] needs-llvm-components: x86
|
|
|
|
// Regression test for #29988
|
|
|
|
#![feature(no_core, lang_items)]
|
|
#![crate_type = "lib"]
|
|
#![no_std]
|
|
#![no_core]
|
|
|
|
#[lang="sized"] trait Sized { }
|
|
#[lang="freeze"] trait Freeze { }
|
|
#[lang="copy"] trait Copy { }
|
|
|
|
#[repr(C)]
|
|
struct S {
|
|
f1: i32,
|
|
f2: i32,
|
|
f3: i32,
|
|
}
|
|
|
|
extern "C" {
|
|
fn foo(s: S);
|
|
}
|
|
|
|
// CHECK-LABEL: @test
|
|
#[no_mangle]
|
|
pub fn test() {
|
|
let s = S { f1: 1, f2: 2, f3: 3 };
|
|
unsafe {
|
|
// CHECK: [[ALLOCA:%.+]] = alloca { i64, i32 }, align 8
|
|
// CHECK: [[LOAD:%.+]] = load { i64, i32 }, ptr [[ALLOCA]], align 8
|
|
// CHECK: call void @foo({ i64, i32 } [[LOAD]])
|
|
foo(s);
|
|
}
|
|
}
|