From b11d9944d9eca98a0a343483611b671b98ac4fe4 Mon Sep 17 00:00:00 2001 From: Rafael Espindola Date: Thu, 23 Oct 2014 18:52:46 +0000 Subject: [PATCH] Make this test a bit stricter. This now: * Forces the linker to include the internal definition. * Checks the full output. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@220495 91177308-0d34-0410-b5e6-96231b3b80d8 --- test/Linker/2003-05-31-LinkerRename.ll | 29 +++++++++++-------- test/Linker/Inputs/2003-05-31-LinkerRename.ll | 5 ++++ 2 files changed, 22 insertions(+), 12 deletions(-) create mode 100644 test/Linker/Inputs/2003-05-31-LinkerRename.ll diff --git a/test/Linker/2003-05-31-LinkerRename.ll b/test/Linker/2003-05-31-LinkerRename.ll index 2e734beba6d..0261fe3a920 100644 --- a/test/Linker/2003-05-31-LinkerRename.ll +++ b/test/Linker/2003-05-31-LinkerRename.ll @@ -1,18 +1,23 @@ -; The funcresolve pass will (intentionally) llvm-link an _internal_ function -; body with an external declaration. Because of this, if we LINK an internal -; function body into a program that already has an external declaration for -; the function name, we must rename the internal function to something that -; does not conflict. - -; RUN: echo " define internal i32 @foo() { ret i32 7 } " | llvm-as > %t.1.bc -; RUN: llvm-as < %s > %t.2.bc +; RUN: llvm-as %S/Inputs/2003-05-31-LinkerRename.ll -o %t.1.bc +; RUN: llvm-as %s -o %t.2.bc ; RUN: llvm-link %t.1.bc %t.2.bc -S | FileCheck %s -; CHECK: internal {{.*}} @foo{{[0-9]}}( -declare i32 @foo() +; CHECK: @bar = global i32 ()* @foo2 -define i32 @test() { +; CHECK: define internal i32 @foo2() { +; CHECK-NEXT: ret i32 7 +; CHECK-NEXT: } + +; CHECK: declare i32 @foo() + +; CHECK: define i32 @test() { +; CHECK-NEXT: %X = call i32 @foo() +; CHECK-NEXT: ret i32 %X +; CHECK-NEXT: } + +declare i32 @foo() + +define i32 @test() { %X = call i32 @foo() ret i32 %X } - diff --git a/test/Linker/Inputs/2003-05-31-LinkerRename.ll b/test/Linker/Inputs/2003-05-31-LinkerRename.ll new file mode 100644 index 00000000000..dcd0bf5d217 --- /dev/null +++ b/test/Linker/Inputs/2003-05-31-LinkerRename.ll @@ -0,0 +1,5 @@ +@bar = global i32()* @foo + +define internal i32 @foo() { + ret i32 7 +}