diff options
author | Zhongxing Xu <xuzhongxing@gmail.com> | 2008-10-21 05:27:10 +0000 |
---|---|---|
committer | Zhongxing Xu <xuzhongxing@gmail.com> | 2008-10-21 05:27:10 +0000 |
commit | 511191ce8920160525611be2be754c32a0724c3e (patch) | |
tree | 902a0a6a4b15a67d8058c98f42320cbff4534b06 /lib/Analysis/MemRegion.cpp | |
parent | 1714b2b83e446bb0f72a0ce16485fb2f40160105 (diff) |
Add ElementRegion to represent memory chunks for array elements.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@57891 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/MemRegion.cpp')
-rw-r--r-- | lib/Analysis/MemRegion.cpp | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/lib/Analysis/MemRegion.cpp b/lib/Analysis/MemRegion.cpp index d8efef2e67..cae053f595 100644 --- a/lib/Analysis/MemRegion.cpp +++ b/lib/Analysis/MemRegion.cpp @@ -65,6 +65,16 @@ void SymbolicRegion::Profile(llvm::FoldingSetNodeID& ID) const { SymbolicRegion::ProfileRegion(ID, sym); } +void ElementRegion::ProfileRegion(llvm::FoldingSetNodeID& ID, SVal Idx, + const MemRegion* superRegion) { + ID.AddInteger(MemRegion::ElementRegionKind); + ID.AddPointer(superRegion); + Idx.Profile(ID); +} + +void ElementRegion::Profile(llvm::FoldingSetNodeID& ID) const { + ElementRegion::ProfileRegion(ID, Index, superRegion); +} //===----------------------------------------------------------------------===// // Region pretty-printing. //===----------------------------------------------------------------------===// @@ -141,6 +151,24 @@ VarRegion* MemRegionManager::getVarRegion(const VarDecl* d, return R; } +ElementRegion* MemRegionManager::getElementRegion(SVal Idx, + const MemRegion* superRegion){ + llvm::FoldingSetNodeID ID; + ElementRegion::ProfileRegion(ID, Idx, superRegion); + + void* InsertPos; + MemRegion* data = Regions.FindNodeOrInsertPos(ID, InsertPos); + ElementRegion* R = cast_or_null<ElementRegion>(data); + + if (!R) { + R = (ElementRegion*) A.Allocate<ElementRegion>(); + new (R) ElementRegion(Idx, superRegion); + Regions.InsertNode(R, InsertPos); + } + + return R; +} + /// getSymbolicRegion - Retrieve or create a "symbolic" memory region. SymbolicRegion* MemRegionManager::getSymbolicRegion(const SymbolID sym) { |