diff options
author | Chris Lattner <sabre@nondot.org> | 2008-01-07 01:56:04 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-01-07 01:56:04 +0000 |
commit | a98c679de05bedf3bb1bf7574abd1a84ce5041b1 (patch) | |
tree | 33f545cec3474907cff3c9be73e0600fd4214c8d /llvm/lib/Target/TargetInstrInfo.cpp | |
parent | 0ec92e9d648c9eb06a563bc84c211ec7329af507 (diff) | |
download | bcm5719-llvm-a98c679de05bedf3bb1bf7574abd1a84ce5041b1.tar.gz bcm5719-llvm-a98c679de05bedf3bb1bf7574abd1a84ce5041b1.zip |
Rename MachineInstr::getInstrDescriptor -> getDesc(), which reflects
that it is cheap and efficient to get.
Move a variety of predicates from TargetInstrInfo into
TargetInstrDescriptor, which makes it much easier to query a predicate
when you don't have TII around. Now you can use MI->getDesc()->isBranch()
instead of going through TII, and this is much more efficient anyway. Not
all of the predicates have been moved over yet.
Update old code that used MI->getInstrDescriptor()->Flags to use the
new predicates in many places.
llvm-svn: 45674
Diffstat (limited to 'llvm/lib/Target/TargetInstrInfo.cpp')
-rw-r--r-- | llvm/lib/Target/TargetInstrInfo.cpp | 19 |
1 files changed, 9 insertions, 10 deletions
diff --git a/llvm/lib/Target/TargetInstrInfo.cpp b/llvm/lib/Target/TargetInstrInfo.cpp index d8d1578c72d..ba56caa68e8 100644 --- a/llvm/lib/Target/TargetInstrInfo.cpp +++ b/llvm/lib/Target/TargetInstrInfo.cpp @@ -38,14 +38,13 @@ TargetInstrInfo::~TargetInstrInfo() { } bool TargetInstrInfo::isUnpredicatedTerminator(const MachineInstr *MI) const { - const TargetInstrDescriptor *TID = MI->getInstrDescriptor(); - if (TID->Flags & M_TERMINATOR_FLAG) { - // Conditional branch is a special case. - if ((TID->Flags & M_BRANCH_FLAG) != 0 && (TID->Flags & M_BARRIER_FLAG) == 0) - return true; - if ((TID->Flags & M_PREDICABLE) == 0) - return true; - return !isPredicated(MI); - } - return false; + const TargetInstrDescriptor *TID = MI->getDesc(); + if (!TID->isTerminator()) return false; + + // Conditional branch is a special case. + if (TID->isBranch() && !TID->isBarrier()) + return true; + if (!TID->isPredicable()) + return true; + return !isPredicated(MI); } |