Add correct NEON encodings for the "multiple single elements" form of vld.
[oota-llvm.git] / test / Transforms / ScalarRepl / union-pointer.ll
index f54704cd499d5e9b5a9b73efa03db9cd49531a54..fe702fa21772369a3c8e80442420ca0f6652bfb1 100644 (file)
@@ -1,46 +1,41 @@
-; RUN: llvm-as < %s | opt -scalarrepl | llvm-dis | not grep alloca &&
-; RUN: llvm-as < %s | opt -scalarrepl | llvm-dis | grep 'ret sbyte'
-
 ; PR892
+; RUN: opt < %s -scalarrepl -S | \
+; RUN:   not grep alloca
+; RUN: opt < %s -scalarrepl -S | grep {ret i8}
 
-target endian = little
-target pointersize = 32
+target datalayout = "e-p:32:32"
 target triple = "i686-apple-darwin8.7.2"
-        
-%struct.Val = type { int*, int }
-
-implementation   ; Functions:
-
-sbyte* %test(short* %X) {
-        %X_addr = alloca short*
-        store short* %X, short** %X_addr
-        %X_addr = cast short** %X_addr to sbyte**
-        %tmp = load sbyte** %X_addr
-        ret sbyte* %tmp
+       %struct.Val = type { i32*, i32 }
+
+define i8* @test(i16* %X) {
+       %X_addr = alloca i16*           ; <i16**> [#uses=2]
+       store i16* %X, i16** %X_addr
+       %X_addr.upgrd.1 = bitcast i16** %X_addr to i8**         ; <i8**> [#uses=1]
+       %tmp = load i8** %X_addr.upgrd.1                ; <i8*> [#uses=1]
+       ret i8* %tmp
 }
 
-void %test2(long %Op.0) {
-        %tmp = alloca %struct.Val, align 8              
-        %tmp1 = alloca %struct.Val, align 8             
-        %tmp = call ulong %_Z3foov( )           
-        %tmp1 = cast %struct.Val* %tmp1 to ulong*               
-        store ulong %tmp, ulong* %tmp1
-        %tmp = getelementptr %struct.Val* %tmp, int 0, uint 0           
-        %tmp2 = getelementptr %struct.Val* %tmp1, int 0, uint 0         
-        %tmp = load int** %tmp2         
-        store int* %tmp, int** %tmp
-        %tmp3 = getelementptr %struct.Val* %tmp, int 0, uint 1          
-        %tmp4 = getelementptr %struct.Val* %tmp1, int 0, uint 1         
-        %tmp = load int* %tmp4          
-        store int %tmp, int* %tmp3
-        %tmp7 = cast %struct.Val* %tmp to { long }*             
-        %tmp8 = getelementptr { long }* %tmp7, int 0, uint 0            
-        %tmp9 = load long* %tmp8                
-        call void %_Z3bar3ValS_( long %Op.0, long %tmp9 )
-        ret void
+define void @test2(i64 %Op.0) {
+       %tmp = alloca %struct.Val, align 8              ; <%struct.Val*> [#uses=3]
+       %tmp1 = alloca %struct.Val, align 8             ; <%struct.Val*> [#uses=3]
+       %tmp.upgrd.2 = call i64 @_Z3foov( )             ; <i64> [#uses=1]
+       %tmp1.upgrd.3 = bitcast %struct.Val* %tmp1 to i64*              ; <i64*> [#uses=1]
+       store i64 %tmp.upgrd.2, i64* %tmp1.upgrd.3
+       %tmp.upgrd.4 = getelementptr %struct.Val* %tmp, i32 0, i32 0            ; <i32**> [#uses=1]
+       %tmp2 = getelementptr %struct.Val* %tmp1, i32 0, i32 0          ; <i32**> [#uses=1]
+       %tmp.upgrd.5 = load i32** %tmp2         ; <i32*> [#uses=1]
+       store i32* %tmp.upgrd.5, i32** %tmp.upgrd.4
+       %tmp3 = getelementptr %struct.Val* %tmp, i32 0, i32 1           ; <i32*> [#uses=1]
+       %tmp4 = getelementptr %struct.Val* %tmp1, i32 0, i32 1          ; <i32*> [#uses=1]
+       %tmp.upgrd.6 = load i32* %tmp4          ; <i32> [#uses=1]
+       store i32 %tmp.upgrd.6, i32* %tmp3
+       %tmp7 = bitcast %struct.Val* %tmp to { i64 }*           ; <{ i64 }*> [#uses=1]
+       %tmp8 = getelementptr { i64 }* %tmp7, i32 0, i32 0              ; <i64*> [#uses=1]
+       %tmp9 = load i64* %tmp8         ; <i64> [#uses=1]
+       call void @_Z3bar3ValS_( i64 %Op.0, i64 %tmp9 )
+       ret void
 }
 
-declare ulong %_Z3foov()
-
-declare void %_Z3bar3ValS_(long, long)
+declare i64 @_Z3foov()
 
+declare void @_Z3bar3ValS_(i64, i64)