Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / CodeGen / PowerPC / 2007-05-14-InlineAsmSelectCrash.ll
blobe4e931492ac441358c9bc5b4eeda9910e001c6d4
1 ; RUN: llc < %s -march=ppc32
2 target datalayout = "E-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64"
3 target triple = "powerpc-apple-darwin8.8.0"
4         %struct..0anon = type { i32 }
5         %struct.A = type { %struct.anon }
6         %struct.anon = type <{  }>
8 define void @bork(%struct.A* %In0P) {
9 entry:
10         %tmp56 = bitcast %struct.A* %In0P to float*             ; <float*> [#uses=1]
11         br label %bb
13 bb:             ; preds = %bb, %entry
14         %i.035.0 = phi i32 [ 0, %entry ], [ %indvar.next, %bb ]         ; <i32> [#uses=2]
15         %tmp8 = getelementptr float* %tmp56, i32 %i.035.0               ; <float*> [#uses=2]
16         %tmp101112 = bitcast float* %tmp8 to i8*                ; <i8*> [#uses=1]
17         %tmp1617 = bitcast float* %tmp8 to i32*         ; <i32*> [#uses=1]
18         %tmp21 = tail call i32 asm "lwbrx $0, $2, $1", "=r,r,bO,*m"( i8* %tmp101112, i32 0, i32* %tmp1617 )             ; <i32> [#uses=0]
19         %indvar.next = add i32 %i.035.0, 1              ; <i32> [#uses=2]
20         %exitcond = icmp eq i32 %indvar.next, 4         ; <i1> [#uses=1]
21         br i1 %exitcond, label %return, label %bb
23 return:         ; preds = %bb
24         ret void