| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5 |
| ; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \ |
| ; RUN: -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr -mcpu=future < %s | \ |
| ; RUN: FileCheck %s |
| ; RUN: llc -verify-machineinstrs -mtriple=powerpc64-ibm-aix-xcoff \ |
| ; RUN: -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr -mcpu=future < %s | \ |
| ; RUN: FileCheck %s --check-prefix=AIX |
| |
| ; Test for load/store to/from v4i32. |
| |
| define <4 x i32> @testLXVRL(ptr %a, i64 %b) { |
| ; CHECK-LABEL: testLXVRL: |
| ; CHECK: # %bb.0: # %entry |
| ; CHECK-NEXT: lxvrl v2, r3, r4 |
| ; CHECK-NEXT: blr |
| ; |
| ; AIX-LABEL: testLXVRL: |
| ; AIX: # %bb.0: # %entry |
| ; AIX-NEXT: lxvrl v2, r3, r4 |
| ; AIX-NEXT: blr |
| entry: |
| %0 = tail call <4 x i32> @llvm.ppc.vsx.lxvrl(ptr %a, i64 %b) |
| ret <4 x i32> %0 |
| } |
| declare <4 x i32> @llvm.ppc.vsx.lxvrl(ptr, i64) |
| |
| define <4 x i32> @testLXVRLL(ptr %a, i64 %b) { |
| ; CHECK-LABEL: testLXVRLL: |
| ; CHECK: # %bb.0: # %entry |
| ; CHECK-NEXT: lxvrll v2, r3, r4 |
| ; CHECK-NEXT: blr |
| ; |
| ; AIX-LABEL: testLXVRLL: |
| ; AIX: # %bb.0: # %entry |
| ; AIX-NEXT: lxvrll v2, r3, r4 |
| ; AIX-NEXT: blr |
| entry: |
| %0 = tail call <4 x i32> @llvm.ppc.vsx.lxvrll(ptr %a, i64 %b) |
| ret <4 x i32> %0 |
| } |
| declare <4 x i32> @llvm.ppc.vsx.lxvrll(ptr, i64) |
| |
| define void @testSTXVRL(<4 x i32> %a, ptr %b, i64 %c) { |
| ; CHECK-LABEL: testSTXVRL: |
| ; CHECK: # %bb.0: # %entry |
| ; CHECK-NEXT: stxvrl v2, r5, r6 |
| ; CHECK-NEXT: blr |
| ; |
| ; AIX-LABEL: testSTXVRL: |
| ; AIX: # %bb.0: # %entry |
| ; AIX-NEXT: stxvrl v2, r3, r4 |
| ; AIX-NEXT: blr |
| entry: |
| tail call void @llvm.ppc.vsx.stxvrl(<4 x i32> %a, ptr %b, i64 %c) |
| ret void |
| } |
| declare void @llvm.ppc.vsx.stxvrl(<4 x i32>, ptr, i64) |
| |
| define void @testSTXVRLL(<4 x i32> %a, ptr %b, i64 %c) { |
| ; CHECK-LABEL: testSTXVRLL: |
| ; CHECK: # %bb.0: # %entry |
| ; CHECK-NEXT: stxvrll v2, r5, r6 |
| ; CHECK-NEXT: blr |
| ; |
| ; AIX-LABEL: testSTXVRLL: |
| ; AIX: # %bb.0: # %entry |
| ; AIX-NEXT: stxvrll v2, r3, r4 |
| ; AIX-NEXT: blr |
| entry: |
| tail call void @llvm.ppc.vsx.stxvrll(<4 x i32> %a, ptr %b, i64 %c) |
| ret void |
| } |
| declare void @llvm.ppc.vsx.stxvrll(<4 x i32>, ptr, i64) |
| |
| ; Test for load/store vectore pair. |
| |
| define <256 x i1> @testLXVPRL(ptr %vpp, i64 %b) { |
| ; CHECK-LABEL: testLXVPRL: |
| ; CHECK: # %bb.0: # %entry |
| ; CHECK-NEXT: lxvprl vsp34, r4, r5 |
| ; CHECK-NEXT: stxv v2, 16(r3) |
| ; CHECK-NEXT: stxv v3, 0(r3) |
| ; CHECK-NEXT: blr |
| ; |
| ; AIX-LABEL: testLXVPRL: |
| ; AIX: # %bb.0: # %entry |
| ; AIX-NEXT: lxvprl vsp34, r4, r5 |
| ; AIX-NEXT: stxv v3, 16(r3) |
| ; AIX-NEXT: stxv v2, 0(r3) |
| ; AIX-NEXT: blr |
| entry: |
| %0 = tail call <256 x i1> @llvm.ppc.vsx.lxvprl(ptr %vpp, i64 %b) |
| ret <256 x i1> %0 |
| } |
| declare <256 x i1> @llvm.ppc.vsx.lxvprl(ptr, i64) |
| |
| define <256 x i1> @testLXVPRLL(ptr %vpp, i64 %b) { |
| ; CHECK-LABEL: testLXVPRLL: |
| ; CHECK: # %bb.0: # %entry |
| ; CHECK-NEXT: lxvprll vsp34, r4, r5 |
| ; CHECK-NEXT: stxv v2, 16(r3) |
| ; CHECK-NEXT: stxv v3, 0(r3) |
| ; CHECK-NEXT: blr |
| ; |
| ; AIX-LABEL: testLXVPRLL: |
| ; AIX: # %bb.0: # %entry |
| ; AIX-NEXT: lxvprll vsp34, r4, r5 |
| ; AIX-NEXT: stxv v3, 16(r3) |
| ; AIX-NEXT: stxv v2, 0(r3) |
| ; AIX-NEXT: blr |
| entry: |
| %0 = tail call <256 x i1> @llvm.ppc.vsx.lxvprll(ptr %vpp, i64 %b) |
| ret <256 x i1> %0 |
| } |
| declare <256 x i1> @llvm.ppc.vsx.lxvprll(ptr, i64) |
| |
| define void @testSTXVPRL(ptr %v, ptr %vp, i64 %len) { |
| ; CHECK-LABEL: testSTXVPRL: |
| ; CHECK: # %bb.0: # %entry |
| ; CHECK-NEXT: lxv v2, 16(r3) |
| ; CHECK-NEXT: lxv v3, 0(r3) |
| ; CHECK-NEXT: stxvprl vsp34, r4, r5 |
| ; CHECK-NEXT: blr |
| ; |
| ; AIX-LABEL: testSTXVPRL: |
| ; AIX: # %bb.0: # %entry |
| ; AIX-NEXT: lxv v2, 0(r3) |
| ; AIX-NEXT: lxv v3, 16(r3) |
| ; AIX-NEXT: stxvprl vsp34, r4, r5 |
| ; AIX-NEXT: blr |
| entry: |
| %0 = load <256 x i1>, ptr %v, align 32 |
| tail call void @llvm.ppc.vsx.stxvprl(<256 x i1> %0, ptr %vp, i64 %len) |
| ret void |
| } |
| declare void @llvm.ppc.vsx.stxvprl(<256 x i1>, ptr, i64) |
| |
| define void @testSTXVPRLL(ptr %v, ptr %vp, i64 %len) { |
| ; CHECK-LABEL: testSTXVPRLL: |
| ; CHECK: # %bb.0: # %entry |
| ; CHECK-NEXT: lxv v2, 16(r3) |
| ; CHECK-NEXT: lxv v3, 0(r3) |
| ; CHECK-NEXT: stxvprll vsp34, r4, r5 |
| ; CHECK-NEXT: blr |
| ; |
| ; AIX-LABEL: testSTXVPRLL: |
| ; AIX: # %bb.0: # %entry |
| ; AIX-NEXT: lxv v2, 0(r3) |
| ; AIX-NEXT: lxv v3, 16(r3) |
| ; AIX-NEXT: stxvprll vsp34, r4, r5 |
| ; AIX-NEXT: blr |
| entry: |
| %0 = load <256 x i1>, ptr %v, align 32 |
| tail call void @llvm.ppc.vsx.stxvprll(<256 x i1> %0, ptr %vp, i64 %len) |
| ret void |
| } |
| declare void @llvm.ppc.vsx.stxvprll(<256 x i1>, ptr, i64) |