forked from OSchip/llvm-project
fold gep undef, ... -> undef
This comes up many times in perlbmk and probably others. llvm-svn: 17100
This commit is contained in:
parent
107c15c33d
commit
f60137501f
|
|
@ -1011,8 +1011,15 @@ Constant *llvm::ConstantFoldGetElementPtr(const Constant *C,
|
||||||
if (IdxList.size() == 0 ||
|
if (IdxList.size() == 0 ||
|
||||||
(IdxList.size() == 1 && cast<Constant>(IdxList[0])->isNullValue()))
|
(IdxList.size() == 1 && cast<Constant>(IdxList[0])->isNullValue()))
|
||||||
return const_cast<Constant*>(C);
|
return const_cast<Constant*>(C);
|
||||||
Constant *Idx0 = cast<Constant>(IdxList[0]);
|
|
||||||
|
|
||||||
|
if (isa<UndefValue>(C)) {
|
||||||
|
const Type *Ty = GetElementPtrInst::getIndexedType(C->getType(), IdxList,
|
||||||
|
true);
|
||||||
|
assert(Ty != 0 && "Invalid indices for GEP!");
|
||||||
|
return UndefValue::get(PointerType::get(Ty));
|
||||||
|
}
|
||||||
|
|
||||||
|
Constant *Idx0 = cast<Constant>(IdxList[0]);
|
||||||
if (C->isNullValue()) {
|
if (C->isNullValue()) {
|
||||||
bool isNull = true;
|
bool isNull = true;
|
||||||
for (unsigned i = 0, e = IdxList.size(); i != e; ++i)
|
for (unsigned i = 0, e = IdxList.size(); i != e; ++i)
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue