LLVM 23.0.0git
PatchableFunction.cpp
Go to the documentation of this file.
1//===-- PatchableFunction.cpp - Patchable prologues for LLVM -------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file implements edits function bodies in place to support the
10// "patchable-function" attribute.
11//
12//===----------------------------------------------------------------------===//
13
21#include "llvm/Pass.h"
22#include "llvm/PassRegistry.h"
23
24using namespace llvm;
25
26namespace {
27struct PatchableFunction {
28 bool run(MachineFunction &F);
29};
30
31struct PatchableFunctionLegacy : public MachineFunctionPass {
32 static char ID;
33 PatchableFunctionLegacy() : MachineFunctionPass(ID) {}
34 bool runOnMachineFunction(MachineFunction &F) override {
35 return PatchableFunction().run(F);
36 }
37
38 MachineFunctionProperties getRequiredProperties() const override {
39 return MachineFunctionProperties().setNoVRegs();
40 }
41};
42
43} // namespace
44
48 MFPropsModifier _(*this, MF);
49 if (!PatchableFunction().run(MF))
52}
53
54bool PatchableFunction::run(MachineFunction &MF) {
55 MachineBasicBlock &FirstMBB = *MF.begin();
56
57 if (MF.getFunction().hasFnAttribute("patchable-function-entry")) {
59 // The initial .loc covers PATCHABLE_FUNCTION_ENTER.
60 BuildMI(FirstMBB, FirstMBB.begin(), DebugLoc(),
61 TII->get(TargetOpcode::PATCHABLE_FUNCTION_ENTER));
62 return true;
63 } else if (MF.getFunction().hasFnAttribute("patchable-function")) {
64#ifndef NDEBUG
65 Attribute PatchAttr = MF.getFunction().getFnAttribute("patchable-function");
66 StringRef PatchType = PatchAttr.getValueAsString();
67 assert(PatchType == "prologue-short-redirect" && "Only possibility today!");
68#endif
69 auto *TII = MF.getSubtarget().getInstrInfo();
70 BuildMI(FirstMBB, FirstMBB.begin(), DebugLoc(),
71 TII->get(TargetOpcode::PATCHABLE_OP))
72 .addImm(2);
73 MF.ensureAlignment(Align(16));
74 return true;
75 }
76 return false;
77}
78
79char PatchableFunctionLegacy::ID = 0;
80char &llvm::PatchableFunctionID = PatchableFunctionLegacy::ID;
81INITIALIZE_PASS(PatchableFunctionLegacy, "patchable-function",
82 "Implement the 'patchable-function' attribute", false, false)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
const HexagonInstrInfo * TII
#define _
#define F(x, y, z)
Definition MD5.cpp:54
#define INITIALIZE_PASS(passName, arg, name, cfg, analysis)
Definition PassSupport.h:56
Functions, function parameters, and return types can have attributes to indicate how they should be t...
Definition Attributes.h:103
LLVM_ABI StringRef getValueAsString() const
Return the attribute's value as a string.
A debug info location.
Definition DebugLoc.h:123
Attribute getFnAttribute(Attribute::AttrKind Kind) const
Return the attribute for the given attribute kind.
Definition Function.cpp:764
bool hasFnAttribute(Attribute::AttrKind Kind) const
Return true if the function has the attribute.
Definition Function.cpp:729
An RAII based helper class to modify MachineFunctionProperties when running pass.
MachineFunctionPass - This class adapts the FunctionPass interface to allow convenient creation of pa...
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
void ensureAlignment(Align A)
ensureAlignment - Make sure the function is at least A bytes aligned.
Function & getFunction()
Return the LLVM function that this machine code represents.
const MachineInstrBuilder & addImm(int64_t Val) const
Add a new immediate operand.
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
A set of analyses that are preserved following a run of a transformation pass.
Definition Analysis.h:112
static PreservedAnalyses all()
Construct a special preserved set that preserves all passes.
Definition Analysis.h:118
StringRef - Represent a constant reference to a string, i.e.
Definition StringRef.h:55
TargetInstrInfo - Interface to description of machine instruction set.
virtual const TargetInstrInfo * getInstrInfo() const
PointerTypeMap run(const Module &M)
Compute the PointerTypeMap for the module M.
This is an optimization pass for GlobalISel generic memory operations.
Definition Types.h:26
MachineInstrBuilder BuildMI(MachineFunction &MF, const MIMetadata &MIMD, const MCInstrDesc &MCID)
Builder interface. Specify how to create the initial instruction itself.
LLVM_ABI char & PatchableFunctionID
This pass implements the "patchable-function" attribute.
AnalysisManager< MachineFunction > MachineFunctionAnalysisManager
LLVM_ABI PreservedAnalyses getMachineFunctionPassPreservedAnalyses()
Returns the minimum set of Analyses that all machine function passes must preserve.
This struct is a compact representation of a valid (non-zero power of two) alignment.
Definition Alignment.h:39