diff options
Diffstat (limited to 'test/CodeGen/PowerPC/vsx-partword-int-loads-and-stores.ll')
| -rw-r--r-- | test/CodeGen/PowerPC/vsx-partword-int-loads-and-stores.ll | 1132 |
1 files changed, 0 insertions, 1132 deletions
diff --git a/test/CodeGen/PowerPC/vsx-partword-int-loads-and-stores.ll b/test/CodeGen/PowerPC/vsx-partword-int-loads-and-stores.ll deleted file mode 100644 index 67146e40db0e..000000000000 --- a/test/CodeGen/PowerPC/vsx-partword-int-loads-and-stores.ll +++ /dev/null @@ -1,1132 +0,0 @@ -; RUN: llc -mcpu=pwr9 -mtriple=powerpc64le-unknown-unknown < %s | FileCheck %s -; RUN: llc -mcpu=pwr9 -mtriple=powerpc64-unknown-unknown < %s | FileCheck %s \ -; RUN: --check-prefix=CHECK-BE -; Function Attrs: norecurse nounwind readonly -define <16 x i8> @vecucuc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %splat.splatinsert = insertelement <16 x i8> undef, i8 %0, i32 0 - %splat.splat = shufflevector <16 x i8> %splat.splatinsert, <16 x i8> undef, <16 x i32> zeroinitializer - ret <16 x i8> %splat.splat -; CHECK-LABEL: vecucuc -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vspltb 2, 2, 7 -; CHECK-BE-LABEL: vecucuc -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: vspltb 2, 2, 7 -} - -; Function Attrs: norecurse nounwind readonly -define <8 x i16> @vecusuc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = zext i8 %0 to i16 - %splat.splatinsert = insertelement <8 x i16> undef, i16 %conv, i32 0 - %splat.splat = shufflevector <8 x i16> %splat.splatinsert, <8 x i16> undef, <8 x i32> zeroinitializer - ret <8 x i16> %splat.splat -; CHECK-LABEL: vecusuc -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vsplth 2, 2, 3 -; CHECK-BE-LABEL: vecusuc -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: vsplth 2, 2, 3 -} - -; Function Attrs: norecurse nounwind readonly -define <4 x i32> @vecuiuc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = zext i8 %0 to i32 - %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 - %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer - ret <4 x i32> %splat.splat -; CHECK-LABEL: vecuiuc -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: xxspltw 34, 34, 1 -; CHECK-BE-LABEL: vecuiuc -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: xxspltw 34, 34, 1 -} - -; Function Attrs: norecurse nounwind readonly -define <2 x i64> @veculuc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = zext i8 %0 to i64 - %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 - %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer - ret <2 x i64> %splat.splat -; CHECK-LABEL: veculuc -; CHECK: lxsibzx 0, 0, 3 -; CHECK-NEXT: xxspltd 34, 0, 0 -; CHECK-BE-LABEL: veculuc -; CHECK-BE: lxsibzx 0, 0, 3 -; CHECK-BE-NEXT: xxspltd 34, 0, 0 -} - -; Function Attrs: norecurse nounwind readonly -define <16 x i8> @vecscuc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %splat.splatinsert = insertelement <16 x i8> undef, i8 %0, i32 0 - %splat.splat = shufflevector <16 x i8> %splat.splatinsert, <16 x i8> undef, <16 x i32> zeroinitializer - ret <16 x i8> %splat.splat -; CHECK-LABEL: vecscuc -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vspltb 2, 2, 7 -; CHECK-BE-LABEL: vecscuc -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: vspltb 2, 2, 7 -} - -; Function Attrs: norecurse nounwind readonly -define <8 x i16> @vecssuc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = zext i8 %0 to i16 - %splat.splatinsert = insertelement <8 x i16> undef, i16 %conv, i32 0 - %splat.splat = shufflevector <8 x i16> %splat.splatinsert, <8 x i16> undef, <8 x i32> zeroinitializer - ret <8 x i16> %splat.splat -; CHECK-LABEL: vecssuc -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vsplth 2, 2, 3 -; CHECK-BE-LABEL: vecssuc -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: vsplth 2, 2, 3 -} - -; Function Attrs: norecurse nounwind readonly -define <4 x i32> @vecsiuc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = zext i8 %0 to i32 - %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 - %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer - ret <4 x i32> %splat.splat -; CHECK-LABEL: vecsiuc -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: xxspltw 34, 34, 1 -; CHECK-BE-LABEL: vecsiuc -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: xxspltw 34, 34, 1 -} - -; Function Attrs: norecurse nounwind readonly -define <2 x i64> @vecsluc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = zext i8 %0 to i64 - %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 - %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer - ret <2 x i64> %splat.splat -; CHECK-LABEL: vecsluc -; CHECK: lxsibzx 0, 0, 3 -; CHECK-NEXT: xxspltd 34, 0, 0 -; CHECK-BE-LABEL: vecsluc -; CHECK-BE: lxsibzx 0, 0, 3 -; CHECK-BE-NEXT: xxspltd 34, 0, 0 -} - -; Function Attrs: norecurse nounwind readonly -define <4 x float> @vecfuc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = uitofp i8 %0 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 - ret <4 x float> %splat.splat -; CHECK-LABEL: vecfuc -; CHECK: lxsibzx [[LD:[0-9]+]], 0, 3 -; CHECK-NEXT: xscvuxdsp [[CONVD:[0-9]+]], [[LD]] -; CHECK-NEXT: xscvdpspn [[CONVS:[0-9]+]], [[CONVD]] -; CHECK-NEXT: xxspltw 34, [[CONVS]], 0 -; CHECK-BE-LABEL: vecfuc -; CHECK-BE: lxsibzx [[LD:[0-9]+]], 0, 3 -; CHECK-BE-NEXT: xscvuxdsp [[CONVD:[0-9]+]], [[LD]] -; CHECK-BE-NEXT: xscvdpspn [[CONVS:[0-9]+]], [[CONVD]] -; CHECK-BE-NEXT: xxspltw 34, [[CONVS]], 0 -} - -; Function Attrs: norecurse nounwind readonly -define <2 x double> @vecduc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = uitofp i8 %0 to double - %splat.splatinsert = insertelement <2 x double> undef, double %conv, i32 0 - %splat.splat = shufflevector <2 x double> %splat.splatinsert, <2 x double> undef, <2 x i32> zeroinitializer - ret <2 x double> %splat.splat -; CHECK-LABEL: vecduc -; CHECK: lxsibzx [[LD:[0-9]+]], 0, 3 -; CHECK-NEXT: xscvuxddp [[CONVD:[0-9]+]], [[LD]] -; CHECK-NEXT: xxspltd 34, [[CONVD]], 0 -; CHECK-BE-LABEL: vecduc -; CHECK-BE: lxsibzx [[LD:[0-9]+]], 0, 3 -; CHECK-BE-NEXT: xscvuxddp [[CONVD:[0-9]+]], [[LD]] -; CHECK-BE-NEXT: xxspltd 34, [[CONVD]], 0 -} - -; Function Attrs: norecurse nounwind readonly -define <16 x i8> @vecucsc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %splat.splatinsert = insertelement <16 x i8> undef, i8 %0, i32 0 - %splat.splat = shufflevector <16 x i8> %splat.splatinsert, <16 x i8> undef, <16 x i32> zeroinitializer - ret <16 x i8> %splat.splat -; CHECK-LABEL: vecucsc -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vspltb 2, 2, 7 -; CHECK-BE-LABEL: vecucsc -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: vspltb 2, 2, 7 -} - -; Function Attrs: norecurse nounwind readonly -define <4 x i32> @vecuisc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = sext i8 %0 to i32 - %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 - %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer - ret <4 x i32> %splat.splat -; CHECK-LABEL: vecuisc -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vextsb2w 2, 2 -; CHECK-NEXT: xxspltw 34, 34, 1 -; CHECK-BE-LABEL: vecuisc -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: vextsb2w 2, 2 -; CHECK-BE-NEXT: xxspltw 34, 34, 1 -} - -; Function Attrs: norecurse nounwind readonly -define <2 x i64> @veculsc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = sext i8 %0 to i64 - %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 - %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer - ret <2 x i64> %splat.splat -; CHECK-LABEL: veculsc -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vextsb2d 2, 2 -; CHECK-NEXT: xxspltd 34, 34, 0 -; CHECK-BE-LABEL: veculsc -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: vextsb2d 2, 2 -; CHECK-BE-NEXT: xxspltd 34, 34, 0 -} - -; Function Attrs: norecurse nounwind readonly -define <16 x i8> @vecscsc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %splat.splatinsert = insertelement <16 x i8> undef, i8 %0, i32 0 - %splat.splat = shufflevector <16 x i8> %splat.splatinsert, <16 x i8> undef, <16 x i32> zeroinitializer - ret <16 x i8> %splat.splat -; CHECK-LABEL: vecscsc -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vspltb 2, 2, 7 -; CHECK-BE-LABEL: vecscsc -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: vspltb 2, 2, 7 -} - -; Function Attrs: norecurse nounwind readonly -define <4 x i32> @vecsisc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = sext i8 %0 to i32 - %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 - %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer - ret <4 x i32> %splat.splat -; CHECK-LABEL: vecsisc -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vextsb2w 2, 2 -; CHECK-NEXT: xxspltw 34, 34, 1 -; CHECK-BE-LABEL: vecsisc -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: vextsb2w 2, 2 -; CHECK-BE-NEXT: xxspltw 34, 34, 1 -} - -; Function Attrs: norecurse nounwind readonly -define <2 x i64> @vecslsc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = sext i8 %0 to i64 - %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 - %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer - ret <2 x i64> %splat.splat -; CHECK-LABEL: vecslsc -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vextsb2d 2, 2 -; CHECK-NEXT: xxspltd 34, 34, 0 -; CHECK-BE-LABEL: vecslsc -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: vextsb2d 2, 2 -; CHECK-BE-NEXT: xxspltd 34, 34, 0 -} - -; Function Attrs: norecurse nounwind readonly -define <4 x float> @vecfsc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = sitofp i8 %0 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 - ret <4 x float> %splat.splat -; CHECK-LABEL: vecfsc -; CHECK: lxsibzx -; CHECK-NEXT: vextsb2d -; CHECK-NEXT: xscvsxdsp [[CONVD:[0-9]+]], -; CHECK-NEXT: xscvdpspn [[CONVS:[0-9]+]], [[CONVD]] -; CHECK-NEXT: xxspltw 34, [[CONVS]], 0 -; CHECK-BE-LABEL: vecfsc -; CHECK-BE: lxsibzx [[LD:[0-9]+]], 0, 3 -; CHECK-BE-NEXT: vextsb2d -; CHECK-BE-NEXT: xscvsxdsp [[CONVD:[0-9]+]], -; CHECK-BE-NEXT: xscvdpspn [[CONVS:[0-9]+]], [[CONVD]] -; CHECK-BE-NEXT: xxspltw 34, [[CONVS]], 0 -} - -; Function Attrs: norecurse nounwind readonly -define <2 x double> @vecdsc(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = sitofp i8 %0 to double - %splat.splatinsert = insertelement <2 x double> undef, double %conv, i32 0 - %splat.splat = shufflevector <2 x double> %splat.splatinsert, <2 x double> undef, <2 x i32> zeroinitializer - ret <2 x double> %splat.splat -; CHECK-LABEL: vecdsc -; CHECK: lxsibzx -; CHECK-NEXT: vextsb2d -; CHECK-NEXT: xscvsxddp [[CONVD:[0-9]+]], -; CHECK-NEXT: xxspltd 34, [[CONVD]], 0 -; CHECK-BE-LABEL: vecdsc -; CHECK-BE: lxsibzx -; CHECK-BE-NEXT: vextsb2d -; CHECK-BE-NEXT: xscvsxddp [[CONVD:[0-9]+]], -; CHECK-BE-NEXT: xxspltd 34, [[CONVD]], 0 -} - -; Function Attrs: norecurse nounwind readonly -define <16 x i8> @vecucus(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = trunc i16 %0 to i8 - %splat.splatinsert = insertelement <16 x i8> undef, i8 %conv, i32 0 - %splat.splat = shufflevector <16 x i8> %splat.splatinsert, <16 x i8> undef, <16 x i32> zeroinitializer - ret <16 x i8> %splat.splat -; CHECK-LABEL: vecucus -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vspltb 2, 2, 7 -; CHECK-BE-LABEL: vecucus -; CHECK-BE: li [[OFFSET:[0-9]+]], 1 -; CHECK-BE-NEXT: lxsibzx 34, 3, [[OFFSET]] -; CHECK-BE-NEXT: vspltb 2, 2, 7 -} - -; Function Attrs: norecurse nounwind readonly -define <8 x i16> @vecusus(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %splat.splatinsert = insertelement <8 x i16> undef, i16 %0, i32 0 - %splat.splat = shufflevector <8 x i16> %splat.splatinsert, <8 x i16> undef, <8 x i32> zeroinitializer - ret <8 x i16> %splat.splat -; CHECK-LABEL: vecusus -; CHECK: lxsihzx 34, 0, 3 -; CHECK-NEXT: vsplth 2, 2, 3 -; CHECK-BE-LABEL: vecusus -; CHECK-BE: lxsihzx 34, 0, 3 -; CHECK-BE-NEXT: vsplth 2, 2, 3 -} - -; Function Attrs: norecurse nounwind readonly -define <4 x i32> @vecuius(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = zext i16 %0 to i32 - %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 - %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer - ret <4 x i32> %splat.splat -; CHECK-LABEL: vecuius -; CHECK: lxsihzx 34, 0, 3 -; CHECK-NEXT: xxspltw 34, 34, 1 -; CHECK-BE-LABEL: vecuius -; CHECK-BE: lxsihzx 34, 0, 3 -; CHECK-BE-NEXT: xxspltw 34, 34, 1 -} - -; Function Attrs: norecurse nounwind readonly -define <2 x i64> @veculus(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = zext i16 %0 to i64 - %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 - %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer - ret <2 x i64> %splat.splat -; CHECK-LABEL: veculus -; CHECK: lxsihzx 0, 0, 3 -; CHECK-NEXT: xxspltd 34, 0, 0 -; CHECK-BE-LABEL: veculus -; CHECK-BE: lxsihzx 0, 0, 3 -; CHECK-BE-NEXT: xxspltd 34, 0, 0 -} - -; Function Attrs: norecurse nounwind readonly -define <16 x i8> @vecscus(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = trunc i16 %0 to i8 - %splat.splatinsert = insertelement <16 x i8> undef, i8 %conv, i32 0 - %splat.splat = shufflevector <16 x i8> %splat.splatinsert, <16 x i8> undef, <16 x i32> zeroinitializer - ret <16 x i8> %splat.splat -; CHECK-LABEL: vecscus -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vspltb 2, 2, 7 -; CHECK-BE-LABEL: vecscus -; CHECK-BE: li [[OFFSET:[0-9]+]], 1 -; CHECK-BE-NEXT: lxsibzx 34, 3, [[OFFSET]] -; CHECK-BE-NEXT: vspltb 2, 2, 7 -} - -; Function Attrs: norecurse nounwind readonly -define <8 x i16> @vecssus(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %splat.splatinsert = insertelement <8 x i16> undef, i16 %0, i32 0 - %splat.splat = shufflevector <8 x i16> %splat.splatinsert, <8 x i16> undef, <8 x i32> zeroinitializer - ret <8 x i16> %splat.splat -; CHECK-LABEL: vecssus -; CHECK: lxsihzx 34, 0, 3 -; CHECK-NEXT: vsplth 2, 2, 3 -; CHECK-BE-LABEL: vecssus -; CHECK-BE: lxsihzx 34, 0, 3 -; CHECK-BE-NEXT: vsplth 2, 2, 3 -} - -; Function Attrs: norecurse nounwind readonly -define <4 x i32> @vecsius(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = zext i16 %0 to i32 - %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 - %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer - ret <4 x i32> %splat.splat -; CHECK-LABEL: vecsius -; CHECK: lxsihzx 34, 0, 3 -; CHECK-NEXT: xxspltw 34, 34, 1 -; CHECK-BE-LABEL: vecsius -; CHECK-BE: lxsihzx 34, 0, 3 -; CHECK-BE-NEXT: xxspltw 34, 34, 1 -} - -; Function Attrs: norecurse nounwind readonly -define <2 x i64> @vecslus(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = zext i16 %0 to i64 - %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 - %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer - ret <2 x i64> %splat.splat -; CHECK-LABEL: vecslus -; CHECK: lxsihzx 0, 0, 3 -; CHECK-NEXT: xxspltd 34, 0, 0 -; CHECK-BE-LABEL: vecslus -; CHECK-BE: lxsihzx 0, 0, 3 -; CHECK-BE-NEXT: xxspltd 34, 0, 0 -} - -; Function Attrs: norecurse nounwind readonly -define <4 x float> @vecfus(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = uitofp i16 %0 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 - ret <4 x float> %splat.splat -; CHECK-LABEL: vecfus -; CHECK: lxsihzx [[LD:[0-9]+]], 0, 3 -; CHECK-NEXT: xscvuxdsp [[CONVD:[0-9]+]], [[LD]] -; CHECK-NEXT: xscvdpspn [[CONVS:[0-9]+]], [[CONVD]] -; CHECK-NEXT: xxspltw 34, [[CONVS]], 0 -; CHECK-BE-LABEL: vecfus -; CHECK-BE: lxsihzx [[LD:[0-9]+]], 0, 3 -; CHECK-BE-NEXT: xscvuxdsp [[CONVD:[0-9]+]], [[LD]] -; CHECK-BE-NEXT: xscvdpspn [[CONVS:[0-9]+]], [[CONVD]] -; CHECK-BE-NEXT: xxspltw 34, [[CONVS]], 0 -} - -; Function Attrs: norecurse nounwind readonly -define <2 x double> @vecdus(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = uitofp i16 %0 to double - %splat.splatinsert = insertelement <2 x double> undef, double %conv, i32 0 - %splat.splat = shufflevector <2 x double> %splat.splatinsert, <2 x double> undef, <2 x i32> zeroinitializer - ret <2 x double> %splat.splat -; CHECK-LABEL: vecdus -; CHECK: lxsihzx [[LD:[0-9]+]], 0, 3 -; CHECK-NEXT: xscvuxddp [[CONVD:[0-9]+]], [[LD]] -; CHECK-NEXT: xxspltd 34, [[CONVD]], 0 -; CHECK-BE-LABEL: vecdus -; CHECK-BE: lxsihzx [[LD:[0-9]+]], 0, 3 -; CHECK-BE-NEXT: xscvuxddp [[CONVD:[0-9]+]], [[LD]] -; CHECK-BE-NEXT: xxspltd 34, [[CONVD]], 0 -} - -; Function Attrs: norecurse nounwind readonly -define <16 x i8> @vecucss(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = trunc i16 %0 to i8 - %splat.splatinsert = insertelement <16 x i8> undef, i8 %conv, i32 0 - %splat.splat = shufflevector <16 x i8> %splat.splatinsert, <16 x i8> undef, <16 x i32> zeroinitializer - ret <16 x i8> %splat.splat -; CHECK-LABEL: vecucss -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vspltb 2, 2, 7 -; CHECK-BE-LABEL: vecucss -; CHECK-BE: li [[OFFSET:[0-9]+]], 1 -; CHECK-BE-NEXT: lxsibzx 34, 3, [[OFFSET]] -; CHECK-BE-NEXT: vspltb 2, 2, 7 -} - -; Function Attrs: norecurse nounwind readonly -define <4 x i32> @vecuiss(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = sext i16 %0 to i32 - %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 - %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer - ret <4 x i32> %splat.splat -; CHECK-LABEL: vecuiss -; CHECK: lxsihzx 34, 0, 3 -; CHECK-NEXT: vextsh2w 2, 2 -; CHECK-NEXT: xxspltw 34, 34, 1 -; CHECK-BE-LABEL: vecuiss -; CHECK-BE: lxsihzx 34, 0, 3 -; CHECK-BE-NEXT: vextsh2w 2, 2 -; CHECK-BE-NEXT: xxspltw 34, 34, 1 -} - -; Function Attrs: norecurse nounwind readonly -define <2 x i64> @veculss(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = sext i16 %0 to i64 - %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 - %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer - ret <2 x i64> %splat.splat -; CHECK-LABEL: veculss -; CHECK: lxsihzx 34, 0, 3 -; CHECK-NEXT: vextsh2d 2, 2 -; CHECK-NEXT: xxspltd 34, 34, 0 -; CHECK-BE-LABEL: veculss -; CHECK-BE: lxsihzx 34, 0, 3 -; CHECK-BE-NEXT: vextsh2d 2, 2 -; CHECK-BE-NEXT: xxspltd 34, 34, 0 -} - -; Function Attrs: norecurse nounwind readonly -define <16 x i8> @vecscss(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = trunc i16 %0 to i8 - %splat.splatinsert = insertelement <16 x i8> undef, i8 %conv, i32 0 - %splat.splat = shufflevector <16 x i8> %splat.splatinsert, <16 x i8> undef, <16 x i32> zeroinitializer - ret <16 x i8> %splat.splat -; CHECK-LABEL: vecscss -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vspltb 2, 2, 7 -; CHECK-BE-LABEL: vecscss -; CHECK-BE: li [[OFFSET:[0-9]+]], 1 -; CHECK-BE-NEXT: lxsibzx 34, 3, [[OFFSET]] -; CHECK-BE-NEXT: vspltb 2, 2, 7 -} - -; Function Attrs: norecurse nounwind readonly -define <4 x i32> @vecsiss(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = sext i16 %0 to i32 - %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 - %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer - ret <4 x i32> %splat.splat -; CHECK-LABEL: vecsiss -; CHECK: lxsihzx 34, 0, 3 -; CHECK-NEXT: vextsh2w 2, 2 -; CHECK-NEXT: xxspltw 34, 34, 1 -; CHECK-BE-LABEL: vecsiss -; CHECK-BE: lxsihzx 34, 0, 3 -; CHECK-BE-NEXT: vextsh2w 2, 2 -; CHECK-BE-NEXT: xxspltw 34, 34, 1 -} - -; Function Attrs: norecurse nounwind readonly -define <2 x i64> @vecslss(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = sext i16 %0 to i64 - %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 - %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer - ret <2 x i64> %splat.splat -; CHECK-LABEL: vecslss -; CHECK: lxsihzx 34, 0, 3 -; CHECK-NEXT: vextsh2d 2, 2 -; CHECK-NEXT: xxspltd 34, 34, 0 -; CHECK-BE-LABEL: vecslss -; CHECK-BE: lxsihzx 34, 0, 3 -; CHECK-BE-NEXT: vextsh2d 2, 2 -; CHECK-BE-NEXT: xxspltd 34, 34, 0 -} - -; Function Attrs: norecurse nounwind readonly -define <4 x float> @vecfss(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = sitofp i16 %0 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 - ret <4 x float> %splat.splat -; CHECK-LABEL: vecfss -; CHECK: lxsihzx -; CHECK-NEXT: vextsh2d -; CHECK-NEXT: xscvsxdsp [[CONVD:[0-9]+]], -; CHECK-NEXT: xscvdpspn [[CONVS:[0-9]+]], [[CONVD]] -; CHECK-NEXT: xxspltw 34, [[CONVS]], 0 -; CHECK-BE-LABEL: vecfss -; CHECK-BE: lxsihzx [[LD:[0-9]+]], 0, 3 -; CHECK-BE-NEXT: vextsh2d -; CHECK-BE-NEXT: xscvsxdsp [[CONVD:[0-9]+]], -; CHECK-BE-NEXT: xscvdpspn [[CONVS:[0-9]+]], [[CONVD]] -; CHECK-BE-NEXT: xxspltw 34, [[CONVS]], 0 -} - -; Function Attrs: norecurse nounwind readonly -define <2 x double> @vecdss(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = sitofp i16 %0 to double - %splat.splatinsert = insertelement <2 x double> undef, double %conv, i32 0 - %splat.splat = shufflevector <2 x double> %splat.splatinsert, <2 x double> undef, <2 x i32> zeroinitializer - ret <2 x double> %splat.splat -; CHECK-LABEL: vecdss -; CHECK: lxsihzx -; CHECK-NEXT: vextsh2d -; CHECK-NEXT: xscvsxddp [[CONVD:[0-9]+]], -; CHECK-NEXT: xxspltd 34, [[CONVD]], 0 -; CHECK-BE-LABEL: vecdss -; CHECK-BE: lxsihzx -; CHECK-BE-NEXT: vextsh2d -; CHECK-BE-NEXT: xscvsxddp [[CONVD:[0-9]+]], -; CHECK-BE-NEXT: xxspltd 34, [[CONVD]], 0 -} - -; Function Attrs: norecurse nounwind -define void @storefsc(float %f, i8* nocapture %ptr) { -entry: - %conv = fptosi float %f to i8 - store i8 %conv, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storefsc -; CHECK: xscvdpsxws 0, 1 -; CHECK: stxsibx 0, 0, 4 -; CHECK-BE-LABEL: storefsc -; CHECK-BE: xscvdpsxws 0, 1 -; CHECK-BE: stxsibx 0, 0, 4 -} - -; Function Attrs: norecurse nounwind -define void @storedsc(double %d, i8* nocapture %ptr) { -entry: - %conv = fptosi double %d to i8 - store i8 %conv, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storedsc -; CHECK: xscvdpsxws 0, 1 -; CHECK: stxsibx 0, 0, 4 -; CHECK-BE-LABEL: storedsc -; CHECK-BE: xscvdpsxws 0, 1 -; CHECK-BE: stxsibx 0, 0, 4 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc0(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 0 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc0 -; CHECK: vsldoi 2, 2, 2, 8 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc0 -; CHECK-BE: vsldoi 2, 2, 2, 9 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc1(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 1 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc1 -; CHECK: vsldoi 2, 2, 2, 7 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc1 -; CHECK-BE: vsldoi 2, 2, 2, 10 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc2(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 2 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc2 -; CHECK: vsldoi 2, 2, 2, 6 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc2 -; CHECK-BE: vsldoi 2, 2, 2, 11 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc3(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 3 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc3 -; CHECK: vsldoi 2, 2, 2, 5 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc3 -; CHECK-BE: vsldoi 2, 2, 2, 12 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc4(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 4 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc4 -; CHECK: vsldoi 2, 2, 2, 4 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc4 -; CHECK-BE: vsldoi 2, 2, 2, 13 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc5(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 5 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc5 -; CHECK: vsldoi 2, 2, 2, 3 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc5 -; CHECK-BE: vsldoi 2, 2, 2, 14 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc6(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 6 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc6 -; CHECK: vsldoi 2, 2, 2, 2 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc6 -; CHECK-BE: vsldoi 2, 2, 2, 15 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc7(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 7 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc7 -; CHECK: vsldoi 2, 2, 2, 1 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc7 -; CHECK-BE: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc8(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 8 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc8 -; CHECK: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc8 -; CHECK-BE: vsldoi 2, 2, 2, 1 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc9(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 9 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc9 -; CHECK: vsldoi 2, 2, 2, 15 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc9 -; CHECK-BE: vsldoi 2, 2, 2, 2 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc10(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 10 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc10 -; CHECK: vsldoi 2, 2, 2, 14 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc10 -; CHECK-BE: vsldoi 2, 2, 2, 3 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc11(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 11 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc11 -; CHECK: vsldoi 2, 2, 2, 13 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc11 -; CHECK-BE: vsldoi 2, 2, 2, 4 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc12(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 12 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc12 -; CHECK: vsldoi 2, 2, 2, 12 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc12 -; CHECK-BE: vsldoi 2, 2, 2, 5 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc13(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 13 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc13 -; CHECK: vsldoi 2, 2, 2, 11 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc13 -; CHECK-BE: vsldoi 2, 2, 2, 6 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc14(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 14 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc14 -; CHECK: vsldoi 2, 2, 2, 10 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc14 -; CHECK-BE: vsldoi 2, 2, 2, 7 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevcsc15(<16 x i8> %v, i8* nocapture %ptr) { -entry: - %vecext = extractelement <16 x i8> %v, i32 15 - store i8 %vecext, i8* %ptr, align 1 - ret void -; CHECK-LABEL: storevcsc15 -; CHECK: vsldoi 2, 2, 2, 9 -; CHECK-NEXT: stxsibx 34, 0, 5 -; CHECK-BE-LABEL: storevcsc15 -; CHECK-BE: vsldoi 2, 2, 2, 8 -; CHECK-BE-NEXT: stxsibx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storefss(float %f, i16* nocapture %ptr) { -entry: - %conv = fptosi float %f to i16 - store i16 %conv, i16* %ptr, align 2 - ret void -; CHECK-LABEL: storefss -; CHECK: xscvdpsxws 0, 1 -; CHECK: stxsihx 0, 0, 4 -; CHECK-BE-LABEL: storefss -; CHECK-BE: xscvdpsxws 0, 1 -; CHECK-BE: stxsihx 0, 0, 4 -} - -; Function Attrs: norecurse nounwind -define void @storedss(double %d, i16* nocapture %ptr) { -entry: - %conv = fptosi double %d to i16 - store i16 %conv, i16* %ptr, align 2 - ret void -; CHECK-LABEL: storedss -; CHECK: xscvdpsxws 0, 1 -; CHECK: stxsihx 0, 0, 4 -; CHECK-BE-LABEL: storedss -; CHECK-BE: xscvdpsxws 0, 1 -; CHECK-BE: stxsihx 0, 0, 4 -} - -; Function Attrs: norecurse nounwind -define void @storevsss0(<8 x i16> %v, i16* nocapture %ptr) { -entry: - %vecext = extractelement <8 x i16> %v, i32 0 - store i16 %vecext, i16* %ptr, align 2 - ret void -; CHECK-LABEL: storevsss0 -; CHECK: vsldoi 2, 2, 2, 8 -; CHECK-NEXT: stxsihx 34, 0, 5 -; CHECK-BE-LABEL: storevsss0 -; CHECK-BE: vsldoi 2, 2, 2, 10 -; CHECK-BE-NEXT: stxsihx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevsss1(<8 x i16> %v, i16* nocapture %ptr) { -entry: - %vecext = extractelement <8 x i16> %v, i32 1 - store i16 %vecext, i16* %ptr, align 2 - ret void -; CHECK-LABEL: storevsss1 -; CHECK: vsldoi 2, 2, 2, 6 -; CHECK-NEXT: stxsihx 34, 0, 5 -; CHECK-BE-LABEL: storevsss1 -; CHECK-BE: vsldoi 2, 2, 2, 12 -; CHECK-BE-NEXT: stxsihx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevsss2(<8 x i16> %v, i16* nocapture %ptr) { -entry: - %vecext = extractelement <8 x i16> %v, i32 2 - store i16 %vecext, i16* %ptr, align 2 - ret void -; CHECK-LABEL: storevsss2 -; CHECK: vsldoi 2, 2, 2, 4 -; CHECK-NEXT: stxsihx 34, 0, 5 -; CHECK-BE-LABEL: storevsss2 -; CHECK-BE: vsldoi 2, 2, 2, 14 -; CHECK-BE-NEXT: stxsihx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevsss3(<8 x i16> %v, i16* nocapture %ptr) { -entry: - %vecext = extractelement <8 x i16> %v, i32 3 - store i16 %vecext, i16* %ptr, align 2 - ret void -; CHECK-LABEL: storevsss3 -; CHECK: vsldoi 2, 2, 2, 2 -; CHECK-NEXT: stxsihx 34, 0, 5 -; CHECK-BE-LABEL: storevsss3 -; CHECK-BE: stxsihx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevsss4(<8 x i16> %v, i16* nocapture %ptr) { -entry: - %vecext = extractelement <8 x i16> %v, i32 4 - store i16 %vecext, i16* %ptr, align 2 - ret void -; CHECK-LABEL: storevsss4 -; CHECK: stxsihx 34, 0, 5 -; CHECK-BE-LABEL: storevsss4 -; CHECK-BE: vsldoi 2, 2, 2, 2 -; CHECK-BE-NEXT: stxsihx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevsss5(<8 x i16> %v, i16* nocapture %ptr) { -entry: - %vecext = extractelement <8 x i16> %v, i32 5 - store i16 %vecext, i16* %ptr, align 2 - ret void -; CHECK-LABEL: storevsss5 -; CHECK: vsldoi 2, 2, 2, 14 -; CHECK-NEXT: stxsihx 34, 0, 5 -; CHECK-BE-LABEL: storevsss5 -; CHECK-BE: vsldoi 2, 2, 2, 4 -; CHECK-BE-NEXT: stxsihx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevsss6(<8 x i16> %v, i16* nocapture %ptr) { -entry: - %vecext = extractelement <8 x i16> %v, i32 6 - store i16 %vecext, i16* %ptr, align 2 - ret void -; CHECK-LABEL: storevsss6 -; CHECK: vsldoi 2, 2, 2, 12 -; CHECK-NEXT: stxsihx 34, 0, 5 -; CHECK-BE-LABEL: storevsss6 -; CHECK-BE: vsldoi 2, 2, 2, 6 -; CHECK-BE-NEXT: stxsihx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind -define void @storevsss7(<8 x i16> %v, i16* nocapture %ptr) { -entry: - %vecext = extractelement <8 x i16> %v, i32 7 - store i16 %vecext, i16* %ptr, align 2 - ret void -; CHECK-LABEL: storevsss7 -; CHECK: vsldoi 2, 2, 2, 10 -; CHECK-NEXT: stxsihx 34, 0, 5 -; CHECK-BE-LABEL: storevsss7 -; CHECK-BE: vsldoi 2, 2, 2, 8 -; CHECK-BE-NEXT: stxsihx 34, 0, 5 -} - -; Function Attrs: norecurse nounwind readonly -define float @convscf(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = sitofp i8 %0 to float - ret float %conv -; CHECK-LABEL: convscf -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vextsb2d 2, 2 -; CHECK-NEXT: xscvsxdsp 1, 34 -; CHECK-BE-LABEL: convscf -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: vextsb2d 2, 2 -; CHECK-BE-NEXT: xscvsxdsp 1, 34 -} - -; Function Attrs: norecurse nounwind readonly -define float @convucf(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = uitofp i8 %0 to float - ret float %conv -; CHECK-LABEL: convucf -; CHECK: lxsibzx 0, 0, 3 -; CHECK-NEXT: xscvuxdsp 1, 0 -; CHECK-BE-LABEL: convucf -; CHECK-BE: lxsibzx 0, 0, 3 -; CHECK-BE-NEXT: xscvuxdsp 1, 0 -} - -; Function Attrs: norecurse nounwind readonly -define double @convscd(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = sitofp i8 %0 to double -; CHECK-LABEL: convscd -; CHECK: lxsibzx 34, 0, 3 -; CHECK-NEXT: vextsb2d 2, 2 -; CHECK-NEXT: xscvsxddp 1, 34 -; CHECK-BE-LABEL: convscd -; CHECK-BE: lxsibzx 34, 0, 3 -; CHECK-BE-NEXT: vextsb2d 2, 2 -; CHECK-BE-NEXT: xscvsxddp 1, 34 - ret double %conv -} - -; Function Attrs: norecurse nounwind readonly -define double @convucd(i8* nocapture readonly %ptr) { -entry: - %0 = load i8, i8* %ptr, align 1 - %conv = uitofp i8 %0 to double - ret double %conv -; CHECK-LABEL: convucd -; CHECK: lxsibzx 0, 0, 3 -; CHECK-NEXT: xscvuxddp 1, 0 -; CHECK-BE-LABEL: convucd -; CHECK-BE: lxsibzx 0, 0, 3 -; CHECK-BE-NEXT: xscvuxddp 1, 0 -} - -; Function Attrs: norecurse nounwind readonly -define float @convssf(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = sitofp i16 %0 to float - ret float %conv -; CHECK-LABEL: convssf -; CHECK: lxsihzx 34, 0, 3 -; CHECK-NEXT: vextsh2d 2, 2 -; CHECK-NEXT: xscvsxdsp 1, 34 -; CHECK-BE-LABEL: convssf -; CHECK-BE: lxsihzx 34, 0, 3 -; CHECK-BE-NEXT: vextsh2d 2, 2 -; CHECK-BE-NEXT: xscvsxdsp 1, 34 -} - -; Function Attrs: norecurse nounwind readonly -define float @convusf(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = uitofp i16 %0 to float - ret float %conv -; CHECK-LABEL: convusf -; CHECK: lxsihzx 0, 0, 3 -; CHECK-NEXT: xscvuxdsp 1, 0 -; CHECK-BE-LABEL: convusf -; CHECK-BE: lxsihzx 0, 0, 3 -; CHECK-BE-NEXT: xscvuxdsp 1, 0 -} - -; Function Attrs: norecurse nounwind readonly -define double @convssd(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = sitofp i16 %0 to double - ret double %conv -; CHECK-LABEL: convssd -; CHECK: lxsihzx 34, 0, 3 -; CHECK-NEXT: vextsh2d 2, 2 -; CHECK-NEXT: xscvsxddp 1, 34 -; CHECK-BE-LABEL: convssd -; CHECK-BE: lxsihzx 34, 0, 3 -; CHECK-BE-NEXT: vextsh2d 2, 2 -; CHECK-BE-NEXT: xscvsxddp 1, 34 -} - -; Function Attrs: norecurse nounwind readonly -define double @convusd(i16* nocapture readonly %ptr) { -entry: - %0 = load i16, i16* %ptr, align 2 - %conv = uitofp i16 %0 to double - ret double %conv -; CHECK-LABEL: convusd -; CHECK: lxsihzx 0, 0, 3 -; CHECK-NEXT: xscvuxddp 1, 0 -; CHECK-BE-LABEL: convusd -; CHECK-BE: lxsihzx 0, 0, 3 -; CHECK-BE-NEXT: xscvuxddp 1, 0 -} |
