diff options
| author | Derek Schuff <dschuff@google.com> | 2016-03-28 17:05:30 +0000 | 
|---|---|---|
| committer | Derek Schuff <dschuff@google.com> | 2016-03-28 17:05:30 +0000 | 
| commit | ad154c837e4428842cfe5c0f9dbfcc42ba7a1454 (patch) | |
| tree | d2814494f2f8e2c72605d033d9ef6b566fa6e223 /llvm/lib/CodeGen/MachineFunctionPass.cpp | |
| parent | 77e2128580e0fdaf6091454d8f04277e8abf74f7 (diff) | |
| download | bcm5719-llvm-ad154c837e4428842cfe5c0f9dbfcc42ba7a1454.tar.gz bcm5719-llvm-ad154c837e4428842cfe5c0f9dbfcc42ba7a1454.zip | |
Introduce MachineFunctionProperties and the AllVRegsAllocated property
MachineFunctionProperties represents a set of properties that a MachineFunction
can have at particular points in time. Existing examples of this idea are
MachineRegisterInfo::isSSA() and MachineRegisterInfo::tracksLiveness() which
will eventually be switched to use this mechanism.
This change introduces the AllVRegsAllocated property; i.e. the property that
all virtual registers have been allocated and there are no VReg operands
left.
With this mechanism, passes can declare that they require a particular property
to be set, or that they set or clear properties by implementing e.g.
MachineFunctionPass::getRequiredProperties(). The MachineFunctionPass base class
verifies that the requirements are met, and handles the setting and clearing
based on the delcarations. Passes can also directly query and update the current
properties of the MF if they want to have conditional behavior.
This change annotates the target-independent post-regalloc passes; future
changes will also annotate target-specific ones.
Reviewers: qcolombet, hfinkel
Differential Revision: http://reviews.llvm.org/D18421
llvm-svn: 264593
Diffstat (limited to 'llvm/lib/CodeGen/MachineFunctionPass.cpp')
| -rw-r--r-- | llvm/lib/CodeGen/MachineFunctionPass.cpp | 13 | 
1 files changed, 12 insertions, 1 deletions
| diff --git a/llvm/lib/CodeGen/MachineFunctionPass.cpp b/llvm/lib/CodeGen/MachineFunctionPass.cpp index 1913d99a781..bd0b11a8cb5 100644 --- a/llvm/lib/CodeGen/MachineFunctionPass.cpp +++ b/llvm/lib/CodeGen/MachineFunctionPass.cpp @@ -21,11 +21,13 @@  #include "llvm/Analysis/MemoryDependenceAnalysis.h"  #include "llvm/Analysis/ScalarEvolution.h"  #include "llvm/Analysis/ScalarEvolutionAliasAnalysis.h" +#include "llvm/CodeGen/MachineFunction.h"  #include "llvm/CodeGen/MachineFunctionAnalysis.h"  #include "llvm/CodeGen/Passes.h"  #include "llvm/CodeGen/StackProtector.h"  #include "llvm/IR/Dominators.h"  #include "llvm/IR/Function.h" +  using namespace llvm;  Pass *MachineFunctionPass::createPrinterPass(raw_ostream &O, @@ -40,7 +42,16 @@ bool MachineFunctionPass::runOnFunction(Function &F) {      return false;    MachineFunction &MF = getAnalysis<MachineFunctionAnalysis>().getMF(); -  return runOnMachineFunction(MF); +  MachineFunctionProperties &MFProps = MF.getProperties(); + +  assert(MFProps.verifyRequiredProperties(RequiredProperties) && +         "Properties required by the pass are not met by the function"); + +  bool RV = runOnMachineFunction(MF); + +  MFProps.set(SetProperties); +  MFProps.clear(ClearedProperties); +  return RV;  }  void MachineFunctionPass::getAnalysisUsage(AnalysisUsage &AU) const { | 

