2019-12-26 10:37:48 -05:00
|
|
|
//@ compile-flags: -O
|
|
|
|
|
2022-03-16 20:12:30 +08:00
|
|
|
// On x86 the closure is inlined in foo() producing something like
|
2020-06-04 12:13:36 +01:00
|
|
|
// define i32 @foo() [...] {
|
|
|
|
// tail call void @bar() [...]
|
|
|
|
// ret i32 0
|
|
|
|
// }
|
|
|
|
// On riscv the closure is another function, placed before fn foo so CHECK can't
|
|
|
|
// find it
|
|
|
|
//@ ignore-riscv64 FIXME
|
2022-12-06 18:12:46 +01:00
|
|
|
// On s390x the closure is also in another function
|
|
|
|
//@ ignore-s390x FIXME
|
2023-04-14 17:42:08 +08:00
|
|
|
// On loongarch64 the closure is also in another function
|
|
|
|
//@ ignore-loongarch64 FIXME
|
2020-06-04 12:13:36 +01:00
|
|
|
|
2019-12-26 10:37:48 -05:00
|
|
|
#![crate_type = "lib"]
|
|
|
|
|
|
|
|
extern "C" {
|
|
|
|
fn bar();
|
|
|
|
}
|
|
|
|
|
|
|
|
// CHECK-LABEL: @foo
|
|
|
|
#[no_mangle]
|
|
|
|
pub unsafe fn foo() -> i32 {
|
|
|
|
// CHECK: call void @bar
|
|
|
|
// CHECK: ret i32 0
|
|
|
|
std::panic::catch_unwind(|| {
|
|
|
|
bar();
|
|
|
|
0
|
|
|
|
})
|
|
|
|
.unwrap()
|
|
|
|
}
|