summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Analysis
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2002-10-02 06:24:36 +0000
committerChris Lattner <sabre@nondot.org>2002-10-02 06:24:36 +0000
commitc4d2ad21bf10fbbb20c79215d37ecc167109e9a9 (patch)
tree9ff80e3e4983f101ecafd1c5cd3ee8053bbb4b90 /llvm/lib/Analysis
parentbe9f70e342895bd4e104edfd4651bb6d10f86e81 (diff)
downloadbcm5719-llvm-c4d2ad21bf10fbbb20c79215d37ecc167109e9a9.tar.gz
bcm5719-llvm-c4d2ad21bf10fbbb20c79215d37ecc167109e9a9.zip
* Implement fully general merging of array subscripts on demand! This
does not handle the initial pointer index case yet though. llvm-svn: 4012
Diffstat (limited to 'llvm/lib/Analysis')
-rw-r--r--llvm/lib/Analysis/DataStructure/Local.cpp30
1 files changed, 27 insertions, 3 deletions
diff --git a/llvm/lib/Analysis/DataStructure/Local.cpp b/llvm/lib/Analysis/DataStructure/Local.cpp
index 509825172ed..d1c24a699e2 100644
--- a/llvm/lib/Analysis/DataStructure/Local.cpp
+++ b/llvm/lib/Analysis/DataStructure/Local.cpp
@@ -283,10 +283,34 @@ void GraphBuilder::visitGetElementPtrInst(GetElementPtrInst &GEP) {
for (unsigned i = 1, e = GEP.getNumOperands(); i != e; ++i)
if (GEP.getOperand(i)->getType() == Type::LongTy) {
- if (GEP.getOperand(i) != Constant::getNullValue(Type::LongTy)) {
- std::cerr << "Array indexing not handled yet!\n";
+ // Get the type indexing into...
+ const SequentialType *STy = cast<SequentialType>(CurTy);
+ CurTy = STy->getElementType();
+ if (ConstantSInt *CS = dyn_cast<ConstantSInt>(GEP.getOperand(i))) {
+ if (isa<PointerType>(STy))
+ std::cerr << "Pointer indexing not handled yet!\n";
+ else
+ Offset += CS->getValue()*TD.getTypeSize(CurTy);
+ } else {
+ // Variable index into a node. We must merge all of the elements of the
+ // sequential type here.
+ if (isa<PointerType>(STy))
+ std::cerr << "Pointer indexing not handled yet!\n";
+ else {
+ const ArrayType *ATy = cast<ArrayType>(STy);
+ unsigned ElSize = TD.getTypeSize(CurTy);
+ DSNode *N = Value.getNode();
+ assert(N && "Value must have a node!");
+ unsigned RawOffset = Offset+Value.getOffset();
+
+ // Loop over all of the elements of the array, merging them into the
+ // zero'th element.
+ for (unsigned i = 1, e = ATy->getNumElements(); i != e; ++i)
+ // Merge all of the byte components of this array element
+ for (unsigned j = 0; j != ElSize; ++j)
+ N->mergeIndexes(RawOffset+j, RawOffset+i*ElSize+j);
+ }
}
- CurTy = cast<SequentialType>(CurTy)->getElementType();
} else if (GEP.getOperand(i)->getType() == Type::UByteTy) {
unsigned FieldNo = cast<ConstantUInt>(GEP.getOperand(i))->getValue();
const StructType *STy = cast<StructType>(CurTy);
OpenPOWER on IntegriCloud