LLVM  8.0.1
Public Member Functions | List of all members
llvm::AggressiveAntiDepBreaker Class Reference

#include "CodeGen/AggressiveAntiDepBreaker.h"

Inheritance diagram for llvm::AggressiveAntiDepBreaker:
Inheritance graph
[legend]
Collaboration diagram for llvm::AggressiveAntiDepBreaker:
Collaboration graph
[legend]

Public Member Functions

 AggressiveAntiDepBreaker (MachineFunction &MFi, const RegisterClassInfo &RCI, TargetSubtargetInfo::RegClassVector &CriticalPathRCs)
 
 ~AggressiveAntiDepBreaker () override
 
void StartBlock (MachineBasicBlock *BB) override
 Initialize anti-dep breaking for a new basic block. More...
 
unsigned BreakAntiDependencies (const std::vector< SUnit > &SUnits, MachineBasicBlock::iterator Begin, MachineBasicBlock::iterator End, unsigned InsertPosIndex, DbgValueVector &DbgValues) override
 Identifiy anti-dependencies along the critical path of the ScheduleDAG and break them by renaming registers. More...
 
void Observe (MachineInstr &MI, unsigned Count, unsigned InsertPosIndex) override
 Update liveness information to account for the current instruction, which will not be scheduled. More...
 
void FinishBlock () override
 Finish anti-dep breaking for a basic block. More...
 
- Public Member Functions inherited from llvm::AntiDepBreaker
virtual ~AntiDepBreaker ()
 
void UpdateDbgValue (MachineInstr &MI, unsigned OldReg, unsigned NewReg)
 Update DBG_VALUE if dependency breaker is updating other machine instruction to use NewReg. More...
 
void UpdateDbgValues (const DbgValueVector &DbgValues, MachineInstr *ParentMI, unsigned OldReg, unsigned NewReg)
 Update all DBG_VALUE instructions that may be affected by the dependency breaker's update of ParentMI to use NewReg. More...
 

Additional Inherited Members

- Public Types inherited from llvm::AntiDepBreaker
using DbgValueVector = std::vector< std::pair< MachineInstr *, MachineInstr * > >
 

Detailed Description

Definition at line 117 of file AggressiveAntiDepBreaker.h.

Constructor & Destructor Documentation

◆ AggressiveAntiDepBreaker()

AggressiveAntiDepBreaker::AggressiveAntiDepBreaker ( MachineFunction MFi,
const RegisterClassInfo RCI,
TargetSubtargetInfo::RegClassVector CriticalPathRCs 
)

◆ ~AggressiveAntiDepBreaker()

AggressiveAntiDepBreaker::~AggressiveAntiDepBreaker ( )
override

Definition at line 149 of file AggressiveAntiDepBreaker.cpp.

Member Function Documentation

◆ BreakAntiDependencies()

unsigned AggressiveAntiDepBreaker::BreakAntiDependencies ( const std::vector< SUnit > &  SUnits,
MachineBasicBlock::iterator  Begin,
MachineBasicBlock::iterator  End,
unsigned  InsertPosIndex,
DbgValueVector DbgValues 
)
overridevirtual

Identifiy anti-dependencies along the critical path of the ScheduleDAG and break them by renaming registers.

BreakAntiDependencies - Identifiy anti-dependencies within the ScheduleDAG and break them by renaming registers.

Implements llvm::AntiDepBreaker.

Definition at line 754 of file AggressiveAntiDepBreaker.cpp.

◆ FinishBlock()

void AggressiveAntiDepBreaker::FinishBlock ( )
overridevirtual

Finish anti-dep breaking for a basic block.

Implements llvm::AntiDepBreaker.

Definition at line 192 of file AggressiveAntiDepBreaker.cpp.

◆ Observe()

void AggressiveAntiDepBreaker::Observe ( MachineInstr MI,
unsigned  Count,
unsigned  InsertPosIndex 
)
overridevirtual

◆ StartBlock()

void AggressiveAntiDepBreaker::StartBlock ( MachineBasicBlock BB)
overridevirtual

The documentation for this class was generated from the following files: