blob: f0f9943e901ecbf47cfbba1560ed7f3d12e3134c [file] [log] [blame] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 6
; RUN: llc -verify-machineinstrs -mcpu=pwr10 \
; RUN: -mtriple=powerpc64le-unknown-unknown < %s | FileCheck %s
; RUN: llc -verify-machineinstrs -mcpu=future \
; RUN: -mtriple=powerpc64le-unknown-unknown < %s | FileCheck -check-prefix=FUTURE %s
; RUN: llc -verify-machineinstrs -mcpu=pwr10 \
; RUN: -mtriple=powerpc64-unknown-unknown < %s | FileCheck %s
; RUN: llc -verify-machineinstrs -mcpu=future \
; RUN: -mtriple=powerpc64-unknown-unknown < %s | FileCheck --check-prefix=FUTURE %s
; Function Attrs: nounwind readnone
define void @stxvl1(<16 x i8> %a, ptr %b, i64 %c) {
; CHECK-LABEL: stxvl1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: sldi 3, 6, 56
; CHECK-NEXT: stxvl 34, 5, 3
; CHECK-NEXT: blr
;
; FUTURE-LABEL: stxvl1:
; FUTURE: # %bb.0: # %entry
; FUTURE-NEXT: stxvrl 34, 5, 6
; FUTURE-NEXT: blr
entry:
%cconv = trunc i64 %c to i32
tail call void @llvm.vp.store.v16i8.p0(<16 x i8> %a, ptr %b, <16 x i1> splat (i1 true), i32 %cconv)
ret void
}
; Function Attrs: nounwind readnone
define void @stxvl2(<8 x i16> %a, ptr %b, i64 %c) {
; CHECK-LABEL: stxvl2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: sldi 3, 6, 57
; CHECK-NEXT: stxvl 34, 5, 3
; CHECK-NEXT: blr
;
; FUTURE-LABEL: stxvl2:
; FUTURE: # %bb.0: # %entry
; FUTURE-NEXT: sldi 3, 6, 1
; FUTURE-NEXT: stxvrl 34, 5, 3
; FUTURE-NEXT: blr
entry:
%cconv = trunc i64 %c to i32
tail call void @llvm.vp.store.v8i16.p0(<8 x i16> %a, ptr %b, <8 x i1> splat (i1 true), i32 %cconv)
ret void
}
; Function Attrs: nounwind readnone
define void @stxvl4(<4 x i32> %a, ptr %b, i64 %c) {
; CHECK-LABEL: stxvl4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: sldi 3, 6, 58
; CHECK-NEXT: stxvl 34, 5, 3
; CHECK-NEXT: blr
;
; FUTURE-LABEL: stxvl4:
; FUTURE: # %bb.0: # %entry
; FUTURE-NEXT: sldi 3, 6, 2
; FUTURE-NEXT: stxvrl 34, 5, 3
; FUTURE-NEXT: blr
entry:
%cconv = trunc i64 %c to i32
tail call void @llvm.vp.store.v4i32.p0(<4 x i32> %a, ptr %b, <4 x i1> splat (i1 true), i32 %cconv)
ret void
}
; Function Attrs: nounwind readnone
define void @stxvl8(<2 x i64> %a, ptr %b, i64 %c) {
; CHECK-LABEL: stxvl8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: sldi 3, 6, 59
; CHECK-NEXT: stxvl 34, 5, 3
; CHECK-NEXT: blr
;
; FUTURE-LABEL: stxvl8:
; FUTURE: # %bb.0: # %entry
; FUTURE-NEXT: sldi 3, 6, 3
; FUTURE-NEXT: stxvrl 34, 5, 3
; FUTURE-NEXT: blr
entry:
%cconv = trunc i64 %c to i32
tail call void @llvm.vp.store.v2i64.p0(<2 x i64> %a, ptr %b, <2 x i1> splat (i1 true), i32 %cconv)
ret void
}
; Function Attrs: nounwind readnone
define <16 x i8> @lxvl1(ptr %a, i64 %b) {
; CHECK-LABEL: lxvl1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: sldi 4, 4, 56
; CHECK-NEXT: lxvl 34, 3, 4
; CHECK-NEXT: blr
;
; FUTURE-LABEL: lxvl1:
; FUTURE: # %bb.0: # %entry
; FUTURE-NEXT: lxvrl 34, 3, 4
; FUTURE-NEXT: blr
entry:
%bconv = trunc i64 %b to i32
%0 = tail call <16 x i8> @llvm.vp.load.v16i8.p0(ptr %a, <16 x i1> splat (i1 true), i32 %bconv)
ret <16 x i8> %0
}
; Function Attrs: nounwind readnone
define <8 x i16> @lxvl2(ptr %a, i64 %b) {
; CHECK-LABEL: lxvl2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: sldi 4, 4, 57
; CHECK-NEXT: lxvl 34, 3, 4
; CHECK-NEXT: blr
;
; FUTURE-LABEL: lxvl2:
; FUTURE: # %bb.0: # %entry
; FUTURE-NEXT: sldi 4, 4, 1
; FUTURE-NEXT: lxvrl 34, 3, 4
; FUTURE-NEXT: blr
entry:
%bconv = trunc i64 %b to i32
%0 = tail call <8 x i16> @llvm.vp.load.v8i16.p0(ptr %a, <8 x i1> splat (i1 true), i32 %bconv)
ret <8 x i16> %0
}
; Function Attrs: nounwind readnone
define <4 x i32> @lxvl4(ptr %a, i64 %b) {
; CHECK-LABEL: lxvl4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: sldi 4, 4, 58
; CHECK-NEXT: lxvl 34, 3, 4
; CHECK-NEXT: blr
;
; FUTURE-LABEL: lxvl4:
; FUTURE: # %bb.0: # %entry
; FUTURE-NEXT: sldi 4, 4, 2
; FUTURE-NEXT: lxvrl 34, 3, 4
; FUTURE-NEXT: blr
entry:
%bconv = trunc i64 %b to i32
%0 = tail call <4 x i32> @llvm.vp.load.v4i32.p0(ptr %a, <4 x i1> splat (i1 true), i32 %bconv)
ret <4 x i32> %0
}
; Function Attrs: nounwind readnone
define <2 x i64> @lxvl8(ptr %a, i64 %b) {
; CHECK-LABEL: lxvl8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: sldi 4, 4, 59
; CHECK-NEXT: lxvl 34, 3, 4
; CHECK-NEXT: blr
;
; FUTURE-LABEL: lxvl8:
; FUTURE: # %bb.0: # %entry
; FUTURE-NEXT: sldi 4, 4, 3
; FUTURE-NEXT: lxvrl 34, 3, 4
; FUTURE-NEXT: blr
entry:
%bconv = trunc i64 %b to i32
%0 = tail call <2 x i64> @llvm.vp.load.v2i64.p0(ptr %a, <2 x i1> splat (i1 true), i32 %bconv)
ret <2 x i64> %0
}