[PATCH] D142797: [X86] Make `prefetchit{0/1}` emit an assembler warning if the operand is not rip-rel

Noah Goldstein via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Fri Jan 27 19:40:09 PST 2023


goldstein.w.n created this revision.
Herald added subscribers: pengfei, hiraditya.
Herald added a project: All.
goldstein.w.n requested review of this revision.
Herald added a project: LLVM.
Herald added a subscriber: llvm-commits.

Without a rip-rel operand, `prefetchit{0/1}` is a nop. This is a
reasonable mistake for someone to make and is almost certainly not
what they are after.


Repository:
  rG LLVM Github Monorepo

https://reviews.llvm.org/D142797

Files:
  llvm/lib/Target/X86/MCTargetDesc/X86AsmBackend.cpp
  llvm/test/CodeGen/X86/prefetchi-warning.ll


Index: llvm/test/CodeGen/X86/prefetchi-warning.ll
===================================================================
--- /dev/null
+++ llvm/test/CodeGen/X86/prefetchi-warning.ll
@@ -0,0 +1,18 @@
+; -filetype=obj as the warning is from the assembler
+; RUN: llc -filetype=obj -mtriple=x86_64-- -mattr=+prefetchi < %s 2>&1 | FileCheck %s
+
+;CHECK: prefetchit1 is nop without RIP-relative memory operand
+define dso_local void @invalid_ptrt1(ptr %ptr) nounwind  {
+entry:
+  tail call void @llvm.prefetch(ptr %ptr, i32 0, i32 2, i32 0)
+  ret void
+}
+
+;CHECK: prefetchit0 is nop without RIP-relative memory operand
+define dso_local void @invalid_ptrt0(ptr %ptr) nounwind  {
+entry:
+  tail call void @llvm.prefetch(ptr %ptr, i32 0, i32 3, i32 0)
+  ret void
+}
+
+declare void @llvm.prefetch(ptr, i32, i32, i32) nounwind
Index: llvm/lib/Target/X86/MCTargetDesc/X86AsmBackend.cpp
===================================================================
--- llvm/lib/Target/X86/MCTargetDesc/X86AsmBackend.cpp
+++ llvm/lib/Target/X86/MCTargetDesc/X86AsmBackend.cpp
@@ -515,6 +515,16 @@
 /// Insert BoundaryAlignFragment before instructions to align branches.
 void X86AsmBackend::emitInstructionBegin(MCObjectStreamer &OS,
                                          const MCInst &Inst, const MCSubtargetInfo &STI) {
+  if ((Inst.getOpcode() == X86::PREFETCHIT0 ||
+       Inst.getOpcode() == X86::PREFETCHIT1) &&
+      !isRIPRelative(Inst, *MCII)) {
+    OS.getAssembler().getContext().reportWarning(
+        Inst.getLoc(),
+        Twine((Inst.getOpcode() == X86::PREFETCHIT0 ? "prefetchit0"
+                                                    : "prefetchit1")) +
+            " is nop without RIP-relative memory operand");
+  }
+
   CanPadInst = canPadInst(Inst, OS);
 
   if (!canPadBranches(OS))


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D142797.492969.patch
Type: text/x-patch
Size: 1797 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20230128/a7a8a8b0/attachment.bin>


More information about the llvm-commits mailing list