|  | ; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 | grep "foos.s+5" && | 
|  | ; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 | grep "foos.s+1" && | 
|  | ; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 | grep "foos.s+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" | 
|  |  | 
|  | ; 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 | 
|  |  | 
|  | implementation   ; Functions: | 
|  |  | 
|  | int %foo() { | 
|  | 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 | 
|  | } | 
|  |  | 
|  | sbyte %bar() { | 
|  | 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 | 
|  | } |