xref: /aosp_15_r20/external/llvm/test/CodeGen/Thumb2/ifcvt-neon.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=thumb-eabi -mcpu=cortex-a8 %s -o - | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; rdar://7368193
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Worker@a = common global float 0.000000e+00             ; <float*> [#uses=2]
5*9880d681SAndroid Build Coastguard Worker@b = common global float 0.000000e+00             ; <float*> [#uses=1]
6*9880d681SAndroid Build Coastguard Worker
7*9880d681SAndroid Build Coastguard Workerdefine float @t(i32 %c) nounwind {
8*9880d681SAndroid Build Coastguard Workerentry:
9*9880d681SAndroid Build Coastguard Worker  %0 = icmp sgt i32 %c, 1                         ; <i1> [#uses=1]
10*9880d681SAndroid Build Coastguard Worker  %1 = load float, float* @a, align 4                    ; <float> [#uses=2]
11*9880d681SAndroid Build Coastguard Worker  %2 = load float, float* @b, align 4                    ; <float> [#uses=2]
12*9880d681SAndroid Build Coastguard Worker  br i1 %0, label %bb, label %bb1
13*9880d681SAndroid Build Coastguard Worker
14*9880d681SAndroid Build Coastguard Workerbb:                                               ; preds = %entry
15*9880d681SAndroid Build Coastguard Worker; CHECK:      vsub.f32
16*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: vadd.f32
17*9880d681SAndroid Build Coastguard Worker; CHECK:      it gt
18*9880d681SAndroid Build Coastguard Worker  %3 = fadd float %1, %2                          ; <float> [#uses=1]
19*9880d681SAndroid Build Coastguard Worker  br label %bb2
20*9880d681SAndroid Build Coastguard Worker
21*9880d681SAndroid Build Coastguard Workerbb1:                                              ; preds = %entry
22*9880d681SAndroid Build Coastguard Worker  %4 = fsub float %1, %2                          ; <float> [#uses=1]
23*9880d681SAndroid Build Coastguard Worker  br label %bb2
24*9880d681SAndroid Build Coastguard Worker
25*9880d681SAndroid Build Coastguard Workerbb2:                                              ; preds = %bb1, %bb
26*9880d681SAndroid Build Coastguard Worker  %storemerge = phi float [ %4, %bb1 ], [ %3, %bb ] ; <float> [#uses=2]
27*9880d681SAndroid Build Coastguard Worker  store float %storemerge, float* @a
28*9880d681SAndroid Build Coastguard Worker  ret float %storemerge
29*9880d681SAndroid Build Coastguard Worker}
30