[MIParser] Set RegClassOrRegBank during instruction parsing
[llvm-complete.git] / test / CodeGen / PowerPC / 2007-09-08-unaligned.ll
blob86efa0217b6b2b69e7fff2fe046f52d23d702ef7
1 ; RUN: llc -verify-machineinstrs -mattr=-vsx < %s | FileCheck %s
2 ; ModuleID = 'foo.c'
4 target triple = "powerpc-unknown-linux-gnu"
6         %struct.anon = type <{ i8, float }>
7 @s = global %struct.anon <{ i8 3, float 0x4014666660000000 }>           ; <%struct.anon*> [#uses=1]
8 @u = global <{ i8, double }> <{ i8 3, double 5.100000e+00 }>            ; <<{ i8, double }>*> [#uses=1]
9 @t = weak global %struct.anon zeroinitializer           ; <%struct.anon*> [#uses=2]
10 @v = weak global <{ i8, double }> zeroinitializer               ; <<{ i8, double }>*> [#uses=2]
11 @.str = internal constant [8 x i8] c"%f %lf\0A\00"              ; <[8 x i8]*> [#uses=1]
13 ; CHECK: foo
14 ; CHECK: lfs
15 ; CHECK: lfd
16 ; CHECK: stfs
17 ; CHECK: stfd
18 ; CHECK: blr
19 define i32 @foo() {
20 entry:
21         %retval = alloca i32, align 4           ; <i32*> [#uses=1]
22         %"alloca point" = bitcast i32 0 to i32          ; <i32> [#uses=0]
23         %tmp = getelementptr %struct.anon, %struct.anon* @s, i32 0, i32 1               ; <float*> [#uses=1]
24         %tmp1 = load float, float* %tmp, align 1                ; <float> [#uses=1]
25         %tmp2 = getelementptr %struct.anon, %struct.anon* @t, i32 0, i32 1              ; <float*> [#uses=1]
26         store float %tmp1, float* %tmp2, align 1
27         %tmp3 = getelementptr <{ i8, double }>, <{ i8, double }>* @u, i32 0, i32 1              ; <double*> [#uses=1]
28         %tmp4 = load double, double* %tmp3, align 1             ; <double> [#uses=1]
29         %tmp5 = getelementptr <{ i8, double }>, <{ i8, double }>* @v, i32 0, i32 1              ; <double*> [#uses=1]
30         store double %tmp4, double* %tmp5, align 1
31         br label %return
33 return:         ; preds = %entry
34         %retval6 = load i32, i32* %retval               ; <i32> [#uses=1]
35         ret i32 %retval6
38 ; CHECK: main
39 ; CHECK: lfs
40 ; CHECK: lfd
41 ; CHECK: blr
42 define i32 @main() {
43 entry:
44         %retval = alloca i32, align 4           ; <i32*> [#uses=1]
45         %"alloca point" = bitcast i32 0 to i32          ; <i32> [#uses=0]
46         %tmp = call i32 @foo( )         ; <i32> [#uses=0]
47         %tmp1 = getelementptr %struct.anon, %struct.anon* @t, i32 0, i32 1              ; <float*> [#uses=1]
48         %tmp2 = load float, float* %tmp1, align 1               ; <float> [#uses=1]
49         %tmp23 = fpext float %tmp2 to double            ; <double> [#uses=1]
50         %tmp4 = getelementptr <{ i8, double }>, <{ i8, double }>* @v, i32 0, i32 1              ; <double*> [#uses=1]
51         %tmp5 = load double, double* %tmp4, align 1             ; <double> [#uses=1]
52         %tmp6 = getelementptr [8 x i8], [8 x i8]* @.str, i32 0, i32 0           ; <i8*> [#uses=1]
53         %tmp7 = call i32 (i8*, ...) @printf( i8* %tmp6, double %tmp23, double %tmp5 )           ; <i32> [#uses=0]
54         br label %return
56 return:         ; preds = %entry
57         %retval8 = load i32, i32* %retval               ; <i32> [#uses=1]
58         ret i32 %retval8
61 declare i32 @printf(i8*, ...)