diff options
Diffstat (limited to 'test/CodeGen/ARM/vdup.ll')
-rw-r--r-- | test/CodeGen/ARM/vdup.ll | 35 |
1 files changed, 34 insertions, 1 deletions
diff --git a/test/CodeGen/ARM/vdup.ll b/test/CodeGen/ARM/vdup.ll index b24be26..89f355c 100644 --- a/test/CodeGen/ARM/vdup.ll +++ b/test/CodeGen/ARM/vdup.ll @@ -1,4 +1,5 @@ -; RUN: llc < %s -march=arm -mattr=+neon | FileCheck %s +; RUN: llc -mtriple=arm-eabi -float-abi=soft -mattr=+neon -verify-machineinstrs %s -o - \ +; RUN: | FileCheck %s define <8 x i8> @v_dup8(i8 %A) nounwind { ;CHECK-LABEL: v_dup8: @@ -331,3 +332,35 @@ define <8 x i8> @check_i8(<16 x i8> %v) nounwind { %2 = insertelement <8 x i8> %1, i8 %x, i32 1 ret <8 x i8> %2 } + +; Check that an SPR splat produces a vdup. + +define <2 x float> @check_spr_splat2(<2 x float> %p, i16 %q) { +;CHECK-LABEL: check_spr_splat2: +;CHECK: vdup.32 d + %conv = sitofp i16 %q to float + %splat.splatinsert = insertelement <2 x float> undef, float %conv, i32 0 + %splat.splat = shufflevector <2 x float> %splat.splatinsert, <2 x float> undef, <2 x i32> zeroinitializer + %sub = fsub <2 x float> %splat.splat, %p + ret <2 x float> %sub +} + +define <4 x float> @check_spr_splat4(<4 x float> %p, i16 %q) { +;CHECK-LABEL: check_spr_splat4: +;CHECK: vdup.32 q + %conv = sitofp i16 %q to float + %splat.splatinsert = insertelement <4 x float> undef, float %conv, i32 0 + %splat.splat = shufflevector <4 x float> %splat.splatinsert, <4 x float> undef, <4 x i32> zeroinitializer + %sub = fsub <4 x float> %splat.splat, %p + ret <4 x float> %sub +} + +define <4 x float> @check_spr_splat4_lane1(<4 x float> %p, i16 %q) { +;CHECK-LABEL: check_spr_splat4_lane1: +;CHECK: vdup.32 q{{.*}}, d{{.*}}[1] + %conv = sitofp i16 %q to float + %splat.splatinsert = insertelement <4 x float> undef, float %conv, i32 1 + %splat.splat = shufflevector <4 x float> %splat.splatinsert, <4 x float> undef, <4 x i32> <i32 1, i32 1, i32 1, i32 1> + %sub = fsub <4 x float> %splat.splat, %p + ret <4 x float> %sub +} |