[PATCH] D133766: [LLVM][AArch64] Explain why X16 is reserved when Speculative Load Hardening is in use
    David Spickett via Phabricator via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Tue Sep 13 03:37:36 PDT 2022
    
    
  
DavidSpickett updated this revision to Diff 459708.
DavidSpickett added a comment.
Add comment to clarify test purpose.
clang-format.
Repository:
  rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D133766/new/
https://reviews.llvm.org/D133766
Files:
  llvm/lib/Target/AArch64/AArch64RegisterInfo.cpp
  llvm/test/CodeGen/AArch64/inline-asm-clobber-slh-taint.ll
Index: llvm/test/CodeGen/AArch64/inline-asm-clobber-slh-taint.ll
===================================================================
--- /dev/null
+++ llvm/test/CodeGen/AArch64/inline-asm-clobber-slh-taint.ll
@@ -0,0 +1,23 @@
+; RUN: llc -mtriple=aarch64-none-linux-gnu %s 2>&1 | FileCheck %s
+
+; Check that not only do we warn about X16 being reserved, we also print an explanation note.
+
+; CHECK: warning: inline asm clobber list contains reserved registers: X16
+; CHECK-NEXT: note: Reserved registers on the clobber list may not be preserved across the asm statement, and clobbering them may lead to undefined behaviour.
+; CHECK-NEXT: note: X16 is used as the taint register for Speculative Load Hardening.
+
+define void @fx() speculative_load_hardening {
+entry:
+  call void asm sideeffect "nop", "~{x16}"()
+  ret void
+}
+
+; CHECK: warning: inline asm clobber list contains reserved registers: W16
+; CHECK-NEXT: note: Reserved registers on the clobber list may not be preserved across the asm statement, and clobbering them may lead to undefined behaviour.
+; CHECK-NEXT: note: X16 is used as the taint register for Speculative Load Hardening.
+
+define void @fw() speculative_load_hardening {
+entry:
+  call void asm sideeffect "nop", "~{w16}"()
+  ret void
+}
Index: llvm/lib/Target/AArch64/AArch64RegisterInfo.cpp
===================================================================
--- llvm/lib/Target/AArch64/AArch64RegisterInfo.cpp
+++ llvm/lib/Target/AArch64/AArch64RegisterInfo.cpp
@@ -312,6 +312,9 @@
 llvm::Optional<std::string>
 AArch64RegisterInfo::explainReservedReg(const MachineFunction &MF,
                                         MCRegister PhysReg) const {
+  // In cases like this where the clobber might be a W register, the message
+  // always uses the X name because the purpose it is reserved for uses the full
+  // 64 bits.
   if (hasBasePointer(MF) && MCRegisterInfo::regsOverlap(PhysReg, AArch64::X19))
     return std::string("X19 is used as the frame base pointer register.");
 
@@ -333,6 +336,11 @@
              " is clobbered by asynchronous signals when using Arm64EC.";
   }
 
+  if (MF.getFunction().hasFnAttribute(Attribute::SpeculativeLoadHardening) &&
+      MCRegisterInfo::regsOverlap(PhysReg, AArch64::X16))
+    return std::string(
+        "X16 is used as the taint register for Speculative Load Hardening.");
+
   return {};
 }
 
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D133766.459708.patch
Type: text/x-patch
Size: 2391 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20220913/a1492c7f/attachment.bin>
    
    
More information about the llvm-commits
mailing list