summaryrefslogtreecommitdiff
path: root/test/CodeGen/X86/2011-08-29-InitOrder.ll
diff options
context:
space:
mode:
authorDuncan Sands <baldrick@free.fr>2011-08-28 13:17:22 +0000
committerDuncan Sands <baldrick@free.fr>2011-08-28 13:17:22 +0000
commitfd9c4f76f4a1ec06891a3405198fc907f8253958 (patch)
tree369ddc615b65c280e5f5628ef4408a4a2e1e5ff0 /test/CodeGen/X86/2011-08-29-InitOrder.ll
parentc98da24bed617b9264db8df5f378cccd2a95e792 (diff)
downloadllvm-fd9c4f76f4a1ec06891a3405198fc907f8253958.tar.gz
llvm-fd9c4f76f4a1ec06891a3405198fc907f8253958.tar.bz2
llvm-fd9c4f76f4a1ec06891a3405198fc907f8253958.tar.xz
Fix PR5329: pay attention to constructor/destructor priority
when outputting them. With this, the entire LLVM testsuite passes when built with dragonegg. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@138724 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGen/X86/2011-08-29-InitOrder.ll')
-rw-r--r--test/CodeGen/X86/2011-08-29-InitOrder.ll21
1 files changed, 21 insertions, 0 deletions
diff --git a/test/CodeGen/X86/2011-08-29-InitOrder.ll b/test/CodeGen/X86/2011-08-29-InitOrder.ll
new file mode 100644
index 0000000000..4bec03c85c
--- /dev/null
+++ b/test/CodeGen/X86/2011-08-29-InitOrder.ll
@@ -0,0 +1,21 @@
+; RUN: llc < %s -mtriple=i386-linux-gnu | FileCheck %s
+; PR5329
+
+@llvm.global_ctors = appending global [3 x { i32, void ()* }] [{ i32, void ()* } { i32 2000, void ()* @construct_2 }, { i32, void ()* } { i32 3000, void ()* @construct_3 }, { i32, void ()* } { i32 1000, void ()* @construct_1 }]
+; CHECK: ctors
+; CHECK: construct_3
+; CHECK: construct_2
+; CHECK: construct_1
+
+@llvm.global_dtors = appending global [3 x { i32, void ()* }] [{ i32, void ()* } { i32 2000, void ()* @destruct_2 }, { i32, void ()* } { i32 1000, void ()* @destruct_1 }, { i32, void ()* } { i32 3000, void ()* @destruct_3 }]
+; CHECK: dtors
+; CHECK: destruct_3
+; CHECK: destruct_2
+; CHECK: destruct_1
+
+declare void @construct_1()
+declare void @construct_2()
+declare void @construct_3()
+declare void @destruct_1()
+declare void @destruct_2()
+declare void @destruct_3()