[AVX512] Enabling bit logic lowering
[oota-llvm.git] / test / CodeGen / X86 / packed_struct.ll
index 172d0812b9a98da140e41730fb2bfd248cc0f1cd..da6e8f8745fef8e72a647c9d0ddab45061e4201b 100644 (file)
@@ -1,38 +1,34 @@
-; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 | grep "foos+5" &&
-; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 | grep "foos+1" &&
-; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 | grep "foos+9" &&
-; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 | grep "bara+19" &&
-; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 | grep "bara+4"
+; RUN: llc < %s -march=x86 > %t
+; RUN: grep foos+5 %t
+; RUN: grep foos+1 %t
+; RUN: grep foos+9 %t
+; RUN: grep bara+19 %t
+; RUN: grep bara+4 %t
 
 ; make sure we compute the correct offset for a packed structure
 
 ;Note: codegen for this could change rendering the above checks wrong
 
-; ModuleID = 'foo.c'
 target datalayout = "e-p:32:32"
-target endian = little
-target pointersize = 32
 target triple = "i686-pc-linux-gnu"
-       %struct.anon = type <{ sbyte, int, int, int }>
-%foos = external global %struct.anon
-%bara = weak global [4 x <{ int, sbyte }>] zeroinitializer
+       %struct.anon = type <{ i8, i32, i32, i32 }>
+@foos = external global %struct.anon           ; <%struct.anon*> [#uses=3]
+@bara = weak global [4 x <{ i32, i8 }>] zeroinitializer                ; <[4 x <{ i32, i8 }>]*> [#uses=2]
 
-implementation   ; Functions:
-
-int %foo() {
+define i32 @foo() nounwind {
 entry:
-       %tmp = load int*  getelementptr (%struct.anon* %foos, int 0, uint 1)
-       %tmp3 = load int* getelementptr (%struct.anon* %foos, int 0, uint 2)
-       %tmp6 = load int* getelementptr (%struct.anon* %foos, int 0, uint 3)
-       %tmp4 = add int %tmp3, %tmp
-       %tmp7 = add int %tmp4, %tmp6
-       ret int %tmp7
+       %tmp = load i32* getelementptr (%struct.anon* @foos, i32 0, i32 1)              ; <i32> [#uses=1]
+       %tmp3 = load i32* getelementptr (%struct.anon* @foos, i32 0, i32 2)             ; <i32> [#uses=1]
+       %tmp6 = load i32* getelementptr (%struct.anon* @foos, i32 0, i32 3)             ; <i32> [#uses=1]
+       %tmp4 = add i32 %tmp3, %tmp             ; <i32> [#uses=1]
+       %tmp7 = add i32 %tmp4, %tmp6            ; <i32> [#uses=1]
+       ret i32 %tmp7
 }
 
-sbyte %bar() {
+define i8 @bar() nounwind {
 entry:
-       %tmp = load sbyte* getelementptr([4 x <{ int, sbyte }>]* %bara, int 0, int 0, uint 1 )
-       %tmp4 = load sbyte* getelementptr ([4 x <{ int, sbyte }>]* %bara, int 0, int 3, uint 1)
-       %tmp5 = add sbyte %tmp4, %tmp
-       ret sbyte %tmp5
+       %tmp = load i8* getelementptr ([4 x <{ i32, i8 }>]* @bara, i32 0, i32 0, i32 1)         ; <i8> [#uses=1]
+       %tmp4 = load i8* getelementptr ([4 x <{ i32, i8 }>]* @bara, i32 0, i32 3, i32 1)                ; <i8> [#uses=1]
+       %tmp5 = add i8 %tmp4, %tmp              ; <i8> [#uses=1]
+       ret i8 %tmp5
 }