[ARM] More MVE compare vector splat combines for ANDs
[llvm-complete.git] / test / CodeGen / ARM / 2009-08-29-TooLongSplat.ll
blob4655962978dcd1d9e0dcf22b10aa5badbeea74f4
1 ; RUN: llc < %s -mattr=+neon
2 target datalayout = "e-p:32:32:32-i1:8:32-i8:8:32-i16:16:32-i32:32:32-i64:32:32-f32:32:32-f64:32:32-v64:64:64-v128:128:128-a0:0:32"
3 target triple = "thumbv7-elf"
5 define void @aaa() nounwind {
6 entry:
7   %0 = fmul <4 x float> undef, <float 1.000000e+00, float 1.000000e+01, float 1.000000e+02, float 0x3EB0C6F7A0000000> ; <<4 x float>> [#uses=1]
8   %tmp31 = extractelement <4 x float> %0, i32 0   ; <float> [#uses=1]
9   %1 = fpext float %tmp31 to double               ; <double> [#uses=1]
10   %2 = fsub double 1.000000e+00, %1               ; <double> [#uses=1]
11   %3 = fdiv double %2, 1.000000e+00               ; <double> [#uses=1]
12   %4 = tail call double @fabs(double %3) nounwind readnone ; <double> [#uses=1]
13   %5 = fcmp ogt double %4, 1.000000e-05           ; <i1> [#uses=1]
14   br i1 %5, label %bb, label %bb7
16 bb:                                               ; preds = %entry
17   unreachable
19 bb7:                                              ; preds = %entry
20   unreachable
23 declare double @fabs(double)