summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorJakob Stoklund Olesen <stoklund@2pi.dk>2011-04-12 18:11:31 +0000
committerJakob Stoklund Olesen <stoklund@2pi.dk>2011-04-12 18:11:31 +0000
commit0840f50b7652558f33fea38948592cf15857574a (patch)
treebfbaf82a8193c42a6fbbc9f5fe6bf10bd8cdcb83 /llvm/lib
parent68e84581c5155b238b455bea62314d92650e3787 (diff)
downloadbcm5719-llvm-0840f50b7652558f33fea38948592cf15857574a.tar.gz
bcm5719-llvm-0840f50b7652558f33fea38948592cf15857574a.zip
Add SplitKit API to query and select the current interval being worked on.
This makes it possible to target multiple registers in one pass. llvm-svn: 129374
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/CodeGen/SplitKit.cpp9
-rw-r--r--llvm/lib/CodeGen/SplitKit.h10
2 files changed, 17 insertions, 2 deletions
diff --git a/llvm/lib/CodeGen/SplitKit.cpp b/llvm/lib/CodeGen/SplitKit.cpp
index 6195ab0f206..f85d5d358ab 100644
--- a/llvm/lib/CodeGen/SplitKit.cpp
+++ b/llvm/lib/CodeGen/SplitKit.cpp
@@ -557,7 +557,7 @@ VNInfo *SplitEditor::defFromParent(unsigned RegIdx,
}
/// Create a new virtual register and live interval.
-void SplitEditor::openIntv() {
+unsigned SplitEditor::openIntv() {
assert(!OpenIdx && "Previous LI not closed before openIntv");
// Create the complement as index 0.
@@ -567,6 +567,13 @@ void SplitEditor::openIntv() {
// Create the open interval.
OpenIdx = Edit->size();
Edit->create(LIS, VRM);
+ return OpenIdx;
+}
+
+void SplitEditor::selectIntv(unsigned Idx) {
+ assert(Idx != 0 && "Cannot select the complement interval");
+ assert(Idx < Edit->size() && "Can only select previously opened interval");
+ OpenIdx = Idx;
}
SlotIndex SplitEditor::enterIntvBefore(SlotIndex Idx) {
diff --git a/llvm/lib/CodeGen/SplitKit.h b/llvm/lib/CodeGen/SplitKit.h
index f1ff501fbdd..fab56f70d9b 100644
--- a/llvm/lib/CodeGen/SplitKit.h
+++ b/llvm/lib/CodeGen/SplitKit.h
@@ -283,7 +283,15 @@ public:
void reset(LiveRangeEdit&);
/// Create a new virtual register and live interval.
- void openIntv();
+ /// Return the interval index, starting from 1. Interval index 0 is the
+ /// implicit complement interval.
+ unsigned openIntv();
+
+ /// currentIntv - Return the current interval index.
+ unsigned currentIntv() const { return OpenIdx; }
+
+ /// selectIntv - Select a previously opened interval index.
+ void selectIntv(unsigned Idx);
/// enterIntvBefore - Enter the open interval before the instruction at Idx.
/// If the parent interval is not live before Idx, a COPY is not inserted.
OpenPOWER on IntegriCloud