summaryrefslogtreecommitdiff
path: root/lib/CodeGen/AggressiveAntiDepBreaker.h
diff options
context:
space:
mode:
authorDavid Goodwin <david_goodwin@apple.com>2009-11-10 00:15:47 +0000
committerDavid Goodwin <david_goodwin@apple.com>2009-11-10 00:15:47 +0000
commit0855dee564f80160abf95497475306af38ab7f84 (patch)
tree0b07c7034b3af24eac2c7e57b66f78efd4f66bdc /lib/CodeGen/AggressiveAntiDepBreaker.h
parent210c5d4880b525e064088b6fec713260128c16eb (diff)
downloadllvm-0855dee564f80160abf95497475306af38ab7f84.tar.gz
llvm-0855dee564f80160abf95497475306af38ab7f84.tar.bz2
llvm-0855dee564f80160abf95497475306af38ab7f84.tar.xz
Allow targets to specify register classes whose member registers should not be renamed to break anti-dependencies.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@86628 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/AggressiveAntiDepBreaker.h')
-rw-r--r--lib/CodeGen/AggressiveAntiDepBreaker.h6
1 files changed, 4 insertions, 2 deletions
diff --git a/lib/CodeGen/AggressiveAntiDepBreaker.h b/lib/CodeGen/AggressiveAntiDepBreaker.h
index c5121682bd..fb5b869fcb 100644
--- a/lib/CodeGen/AggressiveAntiDepBreaker.h
+++ b/lib/CodeGen/AggressiveAntiDepBreaker.h
@@ -23,6 +23,7 @@
#include "llvm/CodeGen/MachineFunction.h"
#include "llvm/CodeGen/MachineRegisterInfo.h"
#include "llvm/CodeGen/ScheduleDAG.h"
+#include "llvm/Target/TargetSubtarget.h"
#include "llvm/Target/TargetRegisterInfo.h"
#include "llvm/ADT/BitVector.h"
#include "llvm/ADT/SmallSet.h"
@@ -112,7 +113,7 @@ namespace llvm {
/// AllocatableSet - The set of allocatable registers.
/// We'll be ignoring anti-dependencies on non-allocatable registers,
/// because they may not be safe to break.
- const BitVector AllocatableSet;
+ BitVector AllocatableSet;
/// State - The state used to identify and rename anti-dependence
/// registers.
@@ -124,7 +125,8 @@ namespace llvm {
AggressiveAntiDepState *SavedState;
public:
- AggressiveAntiDepBreaker(MachineFunction& MFi);
+ AggressiveAntiDepBreaker(MachineFunction& MFi,
+ TargetSubtarget::ExcludedRCVector& ExcludedRCs);
~AggressiveAntiDepBreaker();
/// GetMaxTrials - As anti-dependencies are broken, additional