aboutsummaryrefslogtreecommitdiff
path: root/lib/Analysis/MemRegion.cpp
diff options
context:
space:
mode:
authorZhongxing Xu <xuzhongxing@gmail.com>2008-10-21 05:27:10 +0000
committerZhongxing Xu <xuzhongxing@gmail.com>2008-10-21 05:27:10 +0000
commit511191ce8920160525611be2be754c32a0724c3e (patch)
tree902a0a6a4b15a67d8058c98f42320cbff4534b06 /lib/Analysis/MemRegion.cpp
parent1714b2b83e446bb0f72a0ce16485fb2f40160105 (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.cpp28
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) {