about summary refs log tree commit diff
path: root/tests/codegen/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/catch-unwind.rs
parented93c1783b404d728d4809973a0550eb33cd293f (diff)
downloadrust-a27f3e3fd1e4d16160f8885b6b06665b5319f56c.tar.gz
rust-a27f3e3fd1e4d16160f8885b6b06665b5319f56c.zip
Rename `tests/codegen` into `tests/codegen-llvm`
Diffstat (limited to 'tests/codegen/catch-unwind.rs')
-rw-r--r--tests/codegen/catch-unwind.rs32
1 files changed, 0 insertions, 32 deletions
diff --git a/tests/codegen/catch-unwind.rs b/tests/codegen/catch-unwind.rs
deleted file mode 100644
index d1ff55bcc28..00000000000
--- a/tests/codegen/catch-unwind.rs
+++ /dev/null
@@ -1,32 +0,0 @@
-//@ 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()
-}