From: Hal Finkel Date: Sat, 19 Jul 2014 03:32:02 +0000 (+0000) Subject: Handle AddrSpaceCast in stripAndAccumulateInBoundsConstantOffsets X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=b8e7c736fba3150a6576cdc398bcd4ea1df9652e;p=platform%2Fupstream%2Fllvm.git Handle AddrSpaceCast in stripAndAccumulateInBoundsConstantOffsets All of the other similar functions in that part of the file look through addrspacecast in addition to bitcast, and I see no reason why stripAndAccumulateInBoundsConstantOffsets shouldn't do so also. llvm-svn: 213449 --- diff --git a/llvm/lib/IR/Value.cpp b/llvm/lib/IR/Value.cpp index 94f979a..1ab2183 100644 --- a/llvm/lib/IR/Value.cpp +++ b/llvm/lib/IR/Value.cpp @@ -455,7 +455,8 @@ Value *Value::stripAndAccumulateInBoundsConstantOffsets(const DataLayout &DL, return V; Offset = GEPOffset; V = GEP->getPointerOperand(); - } else if (Operator::getOpcode(V) == Instruction::BitCast) { + } else if (Operator::getOpcode(V) == Instruction::BitCast || + Operator::getOpcode(V) == Instruction::AddrSpaceCast) { V = cast(V)->getOperand(0); } else if (GlobalAlias *GA = dyn_cast(V)) { V = GA->getAliasee();