diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2015-05-27 18:44:32 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2015-05-27 18:44:32 +0000 | 
| commit | 5a5ac124e1efaf208671f01c46edb15f29ed2a0b (patch) | |
| tree | a6140557876943cdd800ee997c9317283394b22c /lib/CodeGen/StackMapLivenessAnalysis.cpp | |
| parent | f03b5bed27d0d2eafd68562ce14f8b5e3f1f0801 (diff) | |
Notes
Diffstat (limited to 'lib/CodeGen/StackMapLivenessAnalysis.cpp')
| -rw-r--r-- | lib/CodeGen/StackMapLivenessAnalysis.cpp | 64 | 
1 files changed, 52 insertions, 12 deletions
| diff --git a/lib/CodeGen/StackMapLivenessAnalysis.cpp b/lib/CodeGen/StackMapLivenessAnalysis.cpp index 767f43a420fd..d88be575d56c 100644 --- a/lib/CodeGen/StackMapLivenessAnalysis.cpp +++ b/lib/CodeGen/StackMapLivenessAnalysis.cpp @@ -14,24 +14,24 @@  //===----------------------------------------------------------------------===//  #include "llvm/ADT/Statistic.h" +#include "llvm/CodeGen/LivePhysRegs.h"  #include "llvm/CodeGen/MachineFrameInfo.h"  #include "llvm/CodeGen/MachineFunction.h"  #include "llvm/CodeGen/MachineFunctionAnalysis.h" +#include "llvm/CodeGen/MachineFunctionPass.h"  #include "llvm/CodeGen/Passes.h" -#include "llvm/CodeGen/StackMapLivenessAnalysis.h"  #include "llvm/Support/CommandLine.h"  #include "llvm/Support/Debug.h" +#include "llvm/Support/raw_ostream.h"  #include "llvm/Target/TargetSubtargetInfo.h"  using namespace llvm;  #define DEBUG_TYPE "stackmaps" -namespace llvm { -cl::opt<bool> EnablePatchPointLiveness("enable-patchpoint-liveness", -  cl::Hidden, cl::init(true), -  cl::desc("Enable PatchPoint Liveness Analysis Pass")); -} +static cl::opt<bool> EnablePatchPointLiveness( +    "enable-patchpoint-liveness", cl::Hidden, cl::init(true), +    cl::desc("Enable PatchPoint Liveness Analysis Pass"));  STATISTIC(NumStackMapFuncVisited, "Number of functions visited");  STATISTIC(NumStackMapFuncSkipped, "Number of functions skipped"); @@ -39,6 +39,46 @@ STATISTIC(NumBBsVisited,          "Number of basic blocks visited");  STATISTIC(NumBBsHaveNoStackmap,   "Number of basic blocks with no stackmap");  STATISTIC(NumStackMaps,           "Number of StackMaps visited"); +namespace { +/// \brief This pass calculates the liveness information for each basic block in +/// a function and attaches the register live-out information to a patchpoint +/// intrinsic if present. +/// +/// This pass can be disabled via the -enable-patchpoint-liveness=false flag. +/// The pass skips functions that don't have any patchpoint intrinsics. The +/// information provided by this pass is optional and not required by the +/// aformentioned intrinsic to function. +class StackMapLiveness : public MachineFunctionPass { +  MachineFunction *MF; +  const TargetRegisterInfo *TRI; +  LivePhysRegs LiveRegs; + +public: +  static char ID; + +  /// \brief Default construct and initialize the pass. +  StackMapLiveness(); + +  /// \brief Tell the pass manager which passes we depend on and what +  /// information we preserve. +  void getAnalysisUsage(AnalysisUsage &AU) const override; + +  /// \brief Calculate the liveness information for the given machine function. +  bool runOnMachineFunction(MachineFunction &MF) override; + +private: +  /// \brief Performs the actual liveness calculation for the function. +  bool calculateLiveness(); + +  /// \brief Add the current register live set to the instruction. +  void addLiveOutSetToMI(MachineInstr &MI); + +  /// \brief Create a register mask and initialize it with the registers from +  /// the register live set. +  uint32_t *createRegisterMask() const; +}; +} // namespace +  char StackMapLiveness::ID = 0;  char &llvm::StackMapLivenessID = StackMapLiveness::ID;  INITIALIZE_PASS(StackMapLiveness, "stackmap-liveness", @@ -60,18 +100,18 @@ void StackMapLiveness::getAnalysisUsage(AnalysisUsage &AU) const {  }  /// Calculate the liveness information for the given machine function. -bool StackMapLiveness::runOnMachineFunction(MachineFunction &_MF) { +bool StackMapLiveness::runOnMachineFunction(MachineFunction &MF) {    if (!EnablePatchPointLiveness)      return false; -  DEBUG(dbgs() << "********** COMPUTING STACKMAP LIVENESS: " -               << _MF.getName() << " **********\n"); -  MF = &_MF; -  TRI = MF->getSubtarget().getRegisterInfo(); +  DEBUG(dbgs() << "********** COMPUTING STACKMAP LIVENESS: " << MF.getName() +               << " **********\n"); +  this->MF = &MF; +  TRI = MF.getSubtarget().getRegisterInfo();    ++NumStackMapFuncVisited;    // Skip this function if there are no patchpoints to process. -  if (!MF->getFrameInfo()->hasPatchPoint()) { +  if (!MF.getFrameInfo()->hasPatchPoint()) {      ++NumStackMapFuncSkipped;      return false;    } | 
