Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / CodeGen / PowerPC / 2007-10-18-PtrArithmetic.ll
blob84fadd1b04615ae6edd65d13d459e89d7549d6f3
1 ; RUN: llc < %s -march=ppc64 -mattr=+altivec
2         %struct.inoutprops = type <{ i8, [3 x i8] }>
4 define void @bork(float* %argA, float* %argB, float* %res, i8 %inoutspec.0) {
5 entry:
6         %.mask = and i8 %inoutspec.0, -16               ; <i8> [#uses=1]
7         %tmp6 = icmp eq i8 %.mask, 16           ; <i1> [#uses=1]
8         br i1 %tmp6, label %cond_true, label %UnifiedReturnBlock
10 cond_true:              ; preds = %entry
11         %tmp89 = bitcast float* %res to <4 x i32>*              ; <<4 x i32>*> [#uses=1]
12         %tmp1011 = bitcast float* %argA to <4 x i32>*           ; <<4 x i32>*> [#uses=1]
13         %tmp14 = load <4 x i32>* %tmp1011, align 16             ; <<4 x i32>> [#uses=1]
14         %tmp1516 = bitcast float* %argB to <4 x i32>*           ; <<4 x i32>*> [#uses=1]
15         %tmp18 = load <4 x i32>* %tmp1516, align 16             ; <<4 x i32>> [#uses=1]
16         %tmp19 = sdiv <4 x i32> %tmp14, %tmp18          ; <<4 x i32>> [#uses=1]
17         store <4 x i32> %tmp19, <4 x i32>* %tmp89, align 16
18         ret void
20 UnifiedReturnBlock:             ; preds = %entry
21         ret void