diff options
| author | Nick Lewycky <nicholas@mxc.ca> | 2010-05-13 06:00:14 +0000 |
|---|---|---|
| committer | Nick Lewycky <nicholas@mxc.ca> | 2010-05-13 06:00:14 +0000 |
| commit | 3b165a2217a74c924aca21446e11ea34a5167cee (patch) | |
| tree | 1c4fad19f740c0cce5a0add19ce43e6585badbac | |
| parent | c798190224b9009b912564ef757004817782d182 (diff) | |
| download | external_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.ll | 28 |
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 +} |
