diff options
| author | Evan Cheng <evan.cheng@apple.com> | 2009-04-25 20:20:15 +0000 |
|---|---|---|
| committer | Evan Cheng <evan.cheng@apple.com> | 2009-04-25 20:20:15 +0000 |
| commit | 80ad2e6b424a89fb5e2ec6df4941f49ed20699b7 (patch) | |
| tree | 4a84e66c00a6b2b39a360547842b76dd3fe308c1 /llvm/lib/CodeGen | |
| parent | 24061b532d7ff21b33ba811da11278c2af4afcda (diff) | |
| download | bcm5719-llvm-80ad2e6b424a89fb5e2ec6df4941f49ed20699b7.tar.gz bcm5719-llvm-80ad2e6b424a89fb5e2ec6df4941f49ed20699b7.zip | |
Reuse unused val#'s to avoid running out of memory in extreme cases.
llvm-svn: 70069
Diffstat (limited to 'llvm/lib/CodeGen')
| -rw-r--r-- | llvm/lib/CodeGen/LiveInterval.cpp | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/LiveInterval.cpp b/llvm/lib/CodeGen/LiveInterval.cpp index 39d66117ad4..0450c355dce 100644 --- a/llvm/lib/CodeGen/LiveInterval.cpp +++ b/llvm/lib/CodeGen/LiveInterval.cpp @@ -577,6 +577,7 @@ void LiveInterval::MergeInClobberRanges(const LiveInterval &Clobbers, if (Clobbers.empty()) return; DenseMap<VNInfo*, VNInfo*> ValNoMaps; + VNInfo *UnusedValNo = 0; iterator IP = begin(); for (const_iterator I = Clobbers.begin(), E = Clobbers.end(); I != E; ++I) { // For every val# in the Clobbers interval, create a new "unknown" val#. @@ -584,8 +585,10 @@ void LiveInterval::MergeInClobberRanges(const LiveInterval &Clobbers, DenseMap<VNInfo*, VNInfo*>::iterator VI = ValNoMaps.find(I->valno); if (VI != ValNoMaps.end()) ClobberValNo = VI->second; + else if (UnusedValNo) + ClobberValNo = UnusedValNo; else { - ClobberValNo = getNextValue(~0U, 0, VNInfoAllocator); + UnusedValNo = ClobberValNo = getNextValue(~0U, 0, VNInfoAllocator); ValNoMaps.insert(std::make_pair(I->valno, ClobberValNo)); } @@ -623,6 +626,7 @@ void LiveInterval::MergeInClobberRanges(const LiveInterval &Clobbers, // Insert the clobber interval. IP = addRangeFrom(LiveRange(SubRangeStart, SubRangeEnd, ClobberValNo), IP); + UnusedValNo = 0; } } } |

