[ARM] More MVE compare vector splat combines for ANDs
[llvm-complete.git] / test / CodeGen / ARM / 2009-08-21-PostRAKill2.ll
blobd5570df717f59382581ea1f64de71352dd8bb908
1 ; RUN: llc < %s -asm-verbose=false -O3 -relocation-model=pic -frame-pointer=all -mtriple=thumbv7-apple-darwin -mcpu=cortex-a8 -post-RA-scheduler
3 ; ModuleID = '<stdin>'
4 target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:32-f32:32:32-f64:32:32-v64:64:64-v128:128:128-a0:0:64"
5 target triple = "armv7-apple-darwin9"
7 %struct.anon = type { [3 x double], double, %struct.node*, [64 x %struct.bnode*], [64 x %struct.bnode*] }
8 %struct.bnode = type { i16, double, [3 x double], i32, i32, [3 x double], [3 x double], [3 x double], double, %struct.bnode*, %struct.bnode* }
9 %struct.icstruct = type { [3 x i32], i16 }
10 %struct.node = type { i16, double, [3 x double], i32, i32 }
12 declare double @floor(double) nounwind readnone
14 define void @intcoord(%struct.icstruct* noalias nocapture sret %agg.result, i1 %a, double %b) {
15 entry:
16   br i1 %a, label %bb3, label %bb1
18 bb1:                                              ; preds = %entry
19   unreachable
21 bb3:                                              ; preds = %entry
22   br i1 %a, label %bb7, label %bb5
24 bb5:                                              ; preds = %bb3
25   unreachable
27 bb7:                                              ; preds = %bb3
28   br i1 %a, label %bb11, label %bb9
30 bb9:                                              ; preds = %bb7
31   %0 = tail call  double @floor(double %b) nounwind readnone ; <double> [#uses=0]
32   br label %bb11
34 bb11:                                             ; preds = %bb9, %bb7
35   %1 = getelementptr %struct.icstruct, %struct.icstruct* %agg.result, i32 0, i32 0, i32 0 ; <i32*> [#uses=1]
36   store i32 0, i32* %1
37   ret void