Home | History | Annotate | Download | only in ARM
      1 ; RUN: llc < %s -mtriple=thumbv7-apple-darwin10 -relocation-model=pic -disable-fp-elim -disable-cgp-delete-dead-blocks -mcpu=cortex-a8 | FileCheck %s
      2 
      3 ; Do not form Thumb2 ldrd / strd if the offset is not multiple of 4.
      4 ; rdar://9133587
      5 
      6 %struct.Outer = type { i32, [2 x %"struct.Outer::Inner"] }
      7 %"struct.Outer::Inner" = type { i32, i32, i8, i8 }
      8 
      9 @oStruct = external global %struct.Outer, align 4
     10 
     11 define void @main() nounwind {
     12 ; CHECK: main:
     13 ; CHECK-NOT: ldrd
     14 ; CHECK: mul
     15 for.body.lr.ph:
     16   br label %for.body
     17 
     18 for.body:                                         ; preds = %_Z14printIsNotZeroi.exit17.for.body_crit_edge, %for.body.lr.ph
     19   %tmp3 = phi i1 [ false, %for.body.lr.ph ], [ %phitmp27, %_Z14printIsNotZeroi.exit17.for.body_crit_edge ]
     20   %i.022 = phi i32 [ 0, %for.body.lr.ph ], [ %inc, %_Z14printIsNotZeroi.exit17.for.body_crit_edge ]
     21   %x = getelementptr %struct.Outer* @oStruct, i32 0, i32 1, i32 %i.022, i32 0
     22   %y = getelementptr %struct.Outer* @oStruct, i32 0, i32 1, i32 %i.022, i32 1
     23   %inc = add i32 %i.022, 1
     24   br i1 %tmp3, label %_Z14printIsNotZeroi.exit, label %if.then.i
     25 
     26 if.then.i:                                        ; preds = %for.body
     27   unreachable
     28 
     29 _Z14printIsNotZeroi.exit:                         ; preds = %for.body
     30   %tmp8 = load i32* %x, align 4, !tbaa !0
     31   %tmp11 = load i32* %y, align 4, !tbaa !0
     32   %mul = mul nsw i32 %tmp11, %tmp8
     33   %tobool.i14 = icmp eq i32 %mul, 0
     34   br i1 %tobool.i14, label %_Z14printIsNotZeroi.exit17, label %if.then.i16
     35 
     36 if.then.i16:                                      ; preds = %_Z14printIsNotZeroi.exit
     37   unreachable
     38 
     39 _Z14printIsNotZeroi.exit17:                       ; preds = %_Z14printIsNotZeroi.exit
     40   br i1 undef, label %_Z14printIsNotZeroi.exit17.for.body_crit_edge, label %for.end
     41 
     42 _Z14printIsNotZeroi.exit17.for.body_crit_edge:    ; preds = %_Z14printIsNotZeroi.exit17
     43   %b.phi.trans.insert = getelementptr %struct.Outer* @oStruct, i32 0, i32 1, i32 %inc, i32 3
     44   %tmp3.pre = load i8* %b.phi.trans.insert, align 1, !tbaa !3
     45   %phitmp27 = icmp eq i8 undef, 0
     46   br label %for.body
     47 
     48 for.end:                                          ; preds = %_Z14printIsNotZeroi.exit17
     49   ret void
     50 }
     51 
     52 !0 = metadata !{metadata !"int", metadata !1}
     53 !1 = metadata !{metadata !"omnipotent char", metadata !2}
     54 !2 = metadata !{metadata !"Simple C/C++ TBAA", null}
     55 !3 = metadata !{metadata !"bool", metadata !1}
     56