diff options
| author | Nemanja Ivanovic <nemanjai@ca.ibm.com> | 2019-11-25 09:32:28 -0600 |
|---|---|---|
| committer | Nemanja Ivanovic <nemanjai@ca.ibm.com> | 2019-11-25 11:41:34 -0600 |
| commit | 7fbaa8097ecc4309fec49db14fadac731ce53079 (patch) | |
| tree | f4ca18f5e419994788a996906120fb4c4f591ef5 /llvm/test/CodeGen/PowerPC/inline-asm-vsx-clobbers.ll | |
| parent | e85d2e4981b9db98798ce3e15078775eb50be854 (diff) | |
| download | bcm5719-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.ll | 32 |
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 +} |

