From 12b927bad0992fd55bddb6ffb53e4c48320f3a11 Mon Sep 17 00:00:00 2001 From: Nick Lewycky Date: Thu, 13 May 2010 06:00:14 +0000 Subject: [PATCH] Add testcase for r103653. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@103699 91177308-0d34-0410-b5e6-96231b3b80d8 --- test/Transforms/Inline/2010-05-12-ValueMap.ll | 28 +++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 test/Transforms/Inline/2010-05-12-ValueMap.ll 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 00000000000..2863e715506 --- /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 +}