about summary refs log tree commit diff
path: root/tests/codegen-llvm/catch-unwind.rs
diff options
context:
space:
mode:
authorGuillaume Gomez <guillaume1.gomez@gmail.com>2025-07-21 14:34:12 +0200
committerGuillaume Gomez <guillaume1.gomez@gmail.com>2025-07-22 14:28:48 +0200
commita27f3e3fd1e4d16160f8885b6b06665b5319f56c (patch)
treeb033935392cbadf6f85d2dbddf433a88e323aeeb /tests/codegen-llvm/catch-unwind.rs
parented93c1783b404d728d4809973a0550eb33cd293f (diff)
downloadrust-a27f3e3fd1e4d16160f8885b6b06665b5319f56c.tar.gz
rust-a27f3e3fd1e4d16160f8885b6b06665b5319f56c.zip
Rename `tests/codegen` into `tests/codegen-llvm`
Diffstat (limited to 'tests/codegen-llvm/catch-unwind.rs')
-rw-r--r--tests/codegen-llvm/catch-unwind.rs32
1 files changed, 32 insertions, 0 deletions
diff --git a/tests/codegen-llvm/catch-unwind.rs b/tests/codegen-llvm/catch-unwind.rs
new file mode 100644
index 00000000000..d1ff55bcc28
--- /dev/null
+++ b/tests/codegen-llvm/catch-unwind.rs
@@ -0,0 +1,32 @@
+//@ compile-flags: -Copt-level=3
+
+// On x86 the closure is inlined in foo() producing something like
+// 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
+// On s390x the closure is also in another function
+//@ ignore-s390x FIXME
+// On loongarch64 the closure is also in another function
+//@ ignore-loongarch64 FIXME
+
+#![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()
+}