From 2cbb7543b27fbaa4e9125cfe17d7ece4e09decf7 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Wed, 19 Nov 2003 01:03:16 +0000 Subject: [PATCH] New testcase for PR 130 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@10076 91177308-0d34-0410-b5e6-96231b3b80d8 --- test/Linker/2003-11-18-TypeResolution.ll | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) create mode 100644 test/Linker/2003-11-18-TypeResolution.ll diff --git a/test/Linker/2003-11-18-TypeResolution.ll b/test/Linker/2003-11-18-TypeResolution.ll new file mode 100644 index 00000000000..946c6a268fd --- /dev/null +++ b/test/Linker/2003-11-18-TypeResolution.ll @@ -0,0 +1,23 @@ +; Linking these two translation units causes there to be two LLVM values in the +; symbol table with the same name and same type. When this occurs, the symbol +; table class is DROPPING one of the values, instead of renaming it like a nice +; little symbol table. This is causing llvm-link to die, at no fault of its +; own. + +; RUN: llvm-as < %s > %t.out2.bc +; RUN: echo "%T1 = type opaque %GVar = external global %T1*" | llvm-as > %t.out1.bc +; RUN: llvm-link %t.out[12].bc + + %T1 = type opaque + %T2 = type int + +%GVar = global %T2 * null + +implementation + +void %foo(%T2 * %X) { + %X = cast %T2* %X to %T1 * + ret void +} + + -- 2.34.1