about summary refs log tree commit diff
path: root/src/test/codegen
diff options
context:
space:
mode:
authorkennytm <kennytm@gmail.com>2018-01-18 01:57:23 +0800
committerGitHub <noreply@github.com>2018-01-18 01:57:23 +0800
commitbe916ce584f508ad03e507dac8f65db06304cccb (patch)
tree5f0876a40de4e2a0eef178d5a24e6e45cff7126f /src/test/codegen
parent4b636d01654c8633f9d91dfaa4849a3dcfe14085 (diff)
parentdc44d41b984610406af00dc60d8e1903c9a6751b (diff)
downloadrust-be916ce584f508ad03e507dac8f65db06304cccb.tar.gz
rust-be916ce584f508ad03e507dac8f65db06304cccb.zip
Rollup merge of #47467 - arielb1:cleanup-shims, r=eddyb
remove noop landing pads in cleanup shims

No-op landing pads are already removed in the normal optimization pipeline - so also removing them on the shim pipeline should slightly improve codegen performance, as these cleanup blocks are known to hurt LLVM.

This un-regresses and is therefore a fix for #47442. However, the reporter of that issue should try using `-C panic=abort` instead of carefully avoiding panics.

r? @eddyb
Diffstat (limited to 'src/test/codegen')
-rw-r--r--src/test/codegen/issue-47442.rs32
1 files changed, 32 insertions, 0 deletions
diff --git a/src/test/codegen/issue-47442.rs b/src/test/codegen/issue-47442.rs
new file mode 100644
index 00000000000..d0c9932e4e2
--- /dev/null
+++ b/src/test/codegen/issue-47442.rs
@@ -0,0 +1,32 @@
+// Copyright 2017 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+// check that we don't emit unneeded `resume` cleanup blocks for every
+// destructor.
+
+// CHECK-NOT: Unwind
+
+#![feature(test)]
+#![crate_type="rlib"]
+
+extern crate test;
+
+struct Foo {}
+
+impl Drop for Foo {
+    fn drop(&mut self) {
+        test::black_box(());
+    }
+}
+
+#[no_mangle]
+pub fn foo() {
+    let _foo = Foo {};
+}