xref: /aosp_15_r20/external/llvm/test/CodeGen/ARM/2012-04-10-DAGCombine.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=arm-eabi -mcpu=cortex-a9 -enable-unsafe-fp-math %s -o /dev/null
2*9880d681SAndroid Build Coastguard Worker;target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:64:128-a0:0:64-n32-S64"
3*9880d681SAndroid Build Coastguard Worker;target triple = "armv7-none-linux-gnueabi"
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Workerdefine arm_aapcs_vfpcc void @foo(<4 x float> %arg) nounwind align 2 {
6*9880d681SAndroid Build Coastguard Workerbb4:
7*9880d681SAndroid Build Coastguard Worker  %tmp = extractelement <2 x float> undef, i32 0
8*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %bb18, label %bb5
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Workerbb5:                                              ; preds = %bb4
11*9880d681SAndroid Build Coastguard Worker  %tmp6 = fadd float %tmp, -1.500000e+01
12*9880d681SAndroid Build Coastguard Worker  %tmp7 = fdiv float %tmp6, 2.000000e+01
13*9880d681SAndroid Build Coastguard Worker  %tmp8 = fadd float %tmp7, 1.000000e+00
14*9880d681SAndroid Build Coastguard Worker  %tmp9 = fdiv float 1.000000e+00, %tmp8
15*9880d681SAndroid Build Coastguard Worker  %tmp10 = fsub float 1.000000e+00, %tmp9
16*9880d681SAndroid Build Coastguard Worker  %tmp11 = fmul float %tmp10, 1.000000e+01
17*9880d681SAndroid Build Coastguard Worker  %tmp12 = fadd float %tmp11, 1.500000e+01
18*9880d681SAndroid Build Coastguard Worker  %tmp13 = fdiv float %tmp12, %tmp
19*9880d681SAndroid Build Coastguard Worker  %tmp14 = insertelement <2 x float> undef, float %tmp13, i32 0
20*9880d681SAndroid Build Coastguard Worker  %tmp15 = shufflevector <2 x float> %tmp14, <2 x float> undef, <4 x i32> zeroinitializer
21*9880d681SAndroid Build Coastguard Worker  %tmp16 = fmul <4 x float> zeroinitializer, %tmp15
22*9880d681SAndroid Build Coastguard Worker  %tmp17 = fadd <4 x float> %tmp16, %arg
23*9880d681SAndroid Build Coastguard Worker  store <4 x float> %tmp17, <4 x float>* undef, align 8
24*9880d681SAndroid Build Coastguard Worker  br label %bb18
25*9880d681SAndroid Build Coastguard Worker
26*9880d681SAndroid Build Coastguard Workerbb18:                                             ; preds = %bb5, %bb4
27*9880d681SAndroid Build Coastguard Worker  ret void
28*9880d681SAndroid Build Coastguard Worker}
29