summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/PowerPC/inline-asm-vsx-clobbers.ll
diff options
context:
space:
mode:
authorNemanja Ivanovic <nemanjai@ca.ibm.com>2019-11-25 09:32:28 -0600
committerNemanja Ivanovic <nemanjai@ca.ibm.com>2019-11-25 11:41:34 -0600
commit7fbaa8097ecc4309fec49db14fadac731ce53079 (patch)
treef4ca18f5e419994788a996906120fb4c4f591ef5 /llvm/test/CodeGen/PowerPC/inline-asm-vsx-clobbers.ll
parente85d2e4981b9db98798ce3e15078775eb50be854 (diff)
downloadbcm5719-llvm-7fbaa8097ecc4309fec49db14fadac731ce53079.tar.gz
bcm5719-llvm-7fbaa8097ecc4309fec49db14fadac731ce53079.zip
[PowerPC] Fix VSX clobbers of CSR registers
If an inline asm statement clobbers a VSX register that overlaps with a callee-saved Altivec register or FPR, we will not record the clobber and will therefore violate the ABI. This is clearly a bug so this patch fixes it. Differential revision: https://reviews.llvm.org/D68576
Diffstat (limited to 'llvm/test/CodeGen/PowerPC/inline-asm-vsx-clobbers.ll')
-rw-r--r--llvm/test/CodeGen/PowerPC/inline-asm-vsx-clobbers.ll32
1 files changed, 32 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/PowerPC/inline-asm-vsx-clobbers.ll b/llvm/test/CodeGen/PowerPC/inline-asm-vsx-clobbers.ll
new file mode 100644
index 00000000000..3cf0ce781ce
--- /dev/null
+++ b/llvm/test/CodeGen/PowerPC/inline-asm-vsx-clobbers.ll
@@ -0,0 +1,32 @@
+; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
+; RUN: llc -mcpu=pwr9 -mtriple=powerpc64le-unknown-unknown \
+; RUN: -verify-machineinstrs -ppc-vsr-nums-as-vr \
+; RUN: -ppc-asm-full-reg-names < %s | FileCheck %s
+
+define dso_local void @clobberVR(<4 x i32> %a, <4 x i32> %b) local_unnamed_addr {
+; CHECK-LABEL: clobberVR:
+; CHECK: # %bb.0: # %entry
+; CHECK-NEXT: stxv v22, -160(r1) # 16-byte Folded Spill
+; CHECK-NEXT: #APP
+; CHECK-NEXT: nop
+; CHECK-NEXT: #NO_APP
+; CHECK-NEXT: lxv v22, -160(r1) # 16-byte Folded Reload
+; CHECK-NEXT: blr
+entry:
+ tail call void asm sideeffect "nop", "~{vs54}"()
+ ret void
+}
+
+define dso_local void @clobberFPR(<4 x i32> %a, <4 x i32> %b) local_unnamed_addr {
+; CHECK-LABEL: clobberFPR:
+; CHECK: # %bb.0: # %entry
+; CHECK-NEXT: stfd f14, -144(r1) # 8-byte Folded Spill
+; CHECK-NEXT: #APP
+; CHECK-NEXT: nop
+; CHECK-NEXT: #NO_APP
+; CHECK-NEXT: lfd f14, -144(r1) # 8-byte Folded Reload
+; CHECK-NEXT: blr
+entry:
+ tail call void asm sideeffect "nop", "~{vs14}"()
+ ret void
+}
OpenPOWER on IntegriCloud