aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNick Lewycky <nicholas@mxc.ca>2010-05-13 06:00:14 +0000
committerNick Lewycky <nicholas@mxc.ca>2010-05-13 06:00:14 +0000
commit3b165a2217a74c924aca21446e11ea34a5167cee (patch)
tree1c4fad19f740c0cce5a0add19ce43e6585badbac
parentc798190224b9009b912564ef757004817782d182 (diff)
downloadexternal_llvm-3b165a2217a74c924aca21446e11ea34a5167cee.zip
external_llvm-3b165a2217a74c924aca21446e11ea34a5167cee.tar.gz
external_llvm-3b165a2217a74c924aca21446e11ea34a5167cee.tar.bz2
Add testcase for r103653.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@103699 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--test/Transforms/Inline/2010-05-12-ValueMap.ll28
1 files changed, 28 insertions, 0 deletions
diff --git a/test/Transforms/Inline/2010-05-12-ValueMap.ll b/test/Transforms/Inline/2010-05-12-ValueMap.ll
new file mode 100644
index 0000000..2863e71
--- /dev/null
+++ b/test/Transforms/Inline/2010-05-12-ValueMap.ll
@@ -0,0 +1,28 @@
+; RUN: opt -inline -mergefunc -disable-output
+
+; This tests for a bug where the inliner kept the functions in a ValueMap after
+; it had completed and a ModulePass started to run. LLVM would crash deleting
+; a function that was still a key in the ValueMap.
+
+define internal fastcc void @list_Cdr1918() nounwind inlinehint {
+ unreachable
+}
+
+define internal fastcc void @list_PairSecond1927() nounwind inlinehint {
+ call fastcc void @list_Cdr1918() nounwind inlinehint
+ unreachable
+}
+
+define internal fastcc void @list_Cdr3164() nounwind inlinehint {
+ unreachable
+}
+
+define internal fastcc void @list_Nconc3167() nounwind inlinehint {
+ call fastcc void @list_Cdr3164() nounwind inlinehint
+ unreachable
+}
+
+define void @term_Equal() nounwind {
+ call fastcc void @list_Cdr3164() nounwind inlinehint
+ unreachable
+}