llvm-ar: Clean up memory management with OwningPtr.
[oota-llvm.git] / test / Linker / testlink2.ll
index d243e3c7d1a30e1931f0ef8561ac95c0e34c9c31..ff8e5299869a566d6c5f42589f6c3202f958da8b 100644 (file)
@@ -2,40 +2,57 @@
 ;
 ; RUN: true
 
-@MyVar = global i32 4          ; <i32*> [#uses=2]
-@MyIntList = external global { \2*, i32 }              ; <{ \2*, i32 }*> [#uses=2]
-@AConst = constant i32 123             ; <i32*> [#uses=0]
+%intlist = type { %intlist*, i32 }
+
+
+%Ty1 = type { %Ty2* }
+%Ty2 = type opaque
+
+%VecSize = type { <10 x i32> }
+
+@GVTy1 = global %Ty1* null
+@GVTy2 = external global %Ty2*
+
+
+@MyVar = global i32 4
+@MyIntList = external global %intlist
+@AConst = constant i32 1234
 
 ;; Intern in both testlink[12].ll
-@Intern1 = internal constant i32 52            ; <i32*> [#uses=0]
+@Intern1 = internal constant i32 52
 
 ;; Intern in one but not in other
-@Intern2 = constant i32 12345          ; <i32*> [#uses=0]
+@Intern2 = constant i32 12345
+
+@MyIntListPtr = constant { %intlist* } { %intlist* @MyIntList }
+@MyVarPtr = linkonce global { i32* } { i32* @MyVar }
+@0 = constant i32 412
 
-@MyIntListPtr = constant { { \2*, i32 }* } { { \2*, i32 }* @MyIntList }                ; <{ { \2*, i32 }* }*> [#uses=0]
-@MyVarPtr = linkonce global { i32* } { i32* @MyVar }           ; <{ i32* }*> [#uses=0]
-constant i32 412               ; <i32*>:0 [#uses=1]
+; Provides definition of Struct1 and of S1GV.
+%Struct1 = type { i32 }
+@S1GV = global %Struct1* null
 
 define i32 @foo(i32 %blah) {
-       store i32 %blah, i32* @MyVar
-       %idx = getelementptr { \2*, i32 }* @MyIntList, i64 0, i32 1             ; <i32*> [#uses=1]
-       store i32 12, i32* %idx
-       %ack = load i32* @0             ; <i32> [#uses=1]
-       %fzo = add i32 %ack, %blah              ; <i32> [#uses=1]
-       ret i32 %fzo
+  store i32 %blah, i32* @MyVar
+  %idx = getelementptr %intlist* @MyIntList, i64 0, i32 1
+  store i32 12, i32* %idx
+  %ack = load i32* @0
+  %fzo = add i32 %ack, %blah
+  ret i32 %fzo
 }
 
 declare void @unimp(float, double)
 
 define internal void @testintern() {
-       ret void
+  ret void
 }
 
 define void @Testintern() {
-       ret void
+  ret void
 }
 
 define internal void @testIntern() {
-       ret void
+  ret void
 }
 
+declare void @VecSizeCrash1(%VecSize)