[llvm] r275278 - PatchableFunction: Skip pseudos that do not create code
Matthias Braun via llvm-commits
llvm-commits at lists.llvm.org
Wed Jul 13 09:37:29 PDT 2016
Author: matze
Date: Wed Jul 13 11:37:29 2016
New Revision: 275278
URL: http://llvm.org/viewvc/llvm-project?rev=275278&view=rev
Log:
PatchableFunction: Skip pseudos that do not create code
This fixes http://llvm.org/PR28524
Modified:
llvm/trunk/lib/CodeGen/PatchableFunction.cpp
llvm/trunk/test/CodeGen/X86/patchable-prologue.ll
Modified: llvm/trunk/lib/CodeGen/PatchableFunction.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/PatchableFunction.cpp?rev=275278&r1=275277&r2=275278&view=diff
==============================================================================
--- llvm/trunk/lib/CodeGen/PatchableFunction.cpp (original)
+++ llvm/trunk/lib/CodeGen/PatchableFunction.cpp Wed Jul 13 11:37:29 2016
@@ -37,6 +37,22 @@ struct PatchableFunction : public Machin
};
}
+/// Returns true if instruction \p MI will not result in actual machine code
+/// instructions.
+static bool doesNotGeneratecode(const MachineInstr &MI) {
+ // TODO: Introduce an MCInstrDesc flag for this
+ switch (MI.getOpcode()) {
+ default: return false;
+ case TargetOpcode::IMPLICIT_DEF:
+ case TargetOpcode::KILL:
+ case TargetOpcode::CFI_INSTRUCTION:
+ case TargetOpcode::EH_LABEL:
+ case TargetOpcode::GC_LABEL:
+ case TargetOpcode::DBG_VALUE:
+ return true;
+ }
+}
+
bool PatchableFunction::runOnMachineFunction(MachineFunction &MF) {
if (!MF.getFunction()->hasFnAttribute("patchable-function"))
return false;
@@ -48,18 +64,20 @@ bool PatchableFunction::runOnMachineFunc
#endif
auto &FirstMBB = *MF.begin();
- auto &FirstMI = *FirstMBB.begin();
+ MachineBasicBlock::iterator FirstActualI = FirstMBB.begin();
+ for (; doesNotGeneratecode(*FirstActualI); ++FirstActualI)
+ assert(FirstActualI != FirstMBB.end());
auto *TII = MF.getSubtarget().getInstrInfo();
- auto MIB = BuildMI(FirstMBB, FirstMBB.begin(), FirstMI.getDebugLoc(),
+ auto MIB = BuildMI(FirstMBB, FirstActualI, FirstActualI->getDebugLoc(),
TII->get(TargetOpcode::PATCHABLE_OP))
.addImm(2)
- .addImm(FirstMI.getOpcode());
+ .addImm(FirstActualI->getOpcode());
- for (auto &MO : FirstMI.operands())
+ for (auto &MO : FirstActualI->operands())
MIB.addOperand(MO);
- FirstMI.eraseFromParent();
+ FirstActualI->eraseFromParent();
MF.ensureAlignment(4);
return true;
}
Modified: llvm/trunk/test/CodeGen/X86/patchable-prologue.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/X86/patchable-prologue.ll?rev=275278&r1=275277&r2=275278&view=diff
==============================================================================
--- llvm/trunk/test/CodeGen/X86/patchable-prologue.ll (original)
+++ llvm/trunk/test/CodeGen/X86/patchable-prologue.ll Wed Jul 13 11:37:29 2016
@@ -41,3 +41,27 @@ define void @f3() "patchable-function"="
; CHECK-ALIGN: _f3:
ret void
}
+
+; This testcase happens to produce a KILL instruction at the beginning of the
+; first basic block. In this case the 2nd instruction should be turned into a
+; patchable one.
+; CHECK-LABEL: f4:
+; CHECK-NEXT: 8b 0c 37 movl (%rdi,%rsi), %ecx
+define i32 @f4(i8* %arg1, i64 %arg2, i32 %arg3) "patchable-function"="prologue-short-redirect" {
+bb:
+ %tmp10 = getelementptr i8, i8* %arg1, i64 %arg2
+ %tmp11 = bitcast i8* %tmp10 to i32*
+ %tmp12 = load i32, i32* %tmp11, align 4
+ fence acquire
+ %tmp13 = add i32 %tmp12, %arg3
+ %tmp14 = cmpxchg i32* %tmp11, i32 %tmp12, i32 %tmp13 seq_cst monotonic
+ %tmp15 = extractvalue { i32, i1 } %tmp14, 1
+ br i1 %tmp15, label %bb21, label %bb16
+
+bb16:
+ br label %bb21
+
+bb21:
+ %tmp22 = phi i32 [ %tmp12, %bb ], [ %arg3, %bb16 ]
+ ret i32 %tmp22
+}
More information about the llvm-commits
mailing list