diff options
| author | Duncan Sands <baldrick@free.fr> | 2012-01-11 12:20:08 +0000 |
|---|---|---|
| committer | Duncan Sands <baldrick@free.fr> | 2012-01-11 12:20:08 +0000 |
| commit | 0bf46b536397f4e4b50ba928f5120d27dc0f1ea5 (patch) | |
| tree | b08cc1a0f28a4fa4d9936be9117f0b24c922cbf7 /llvm | |
| parent | 9bc48e521518407efb7910ac81be022cf66c91f6 (diff) | |
| download | bcm5719-llvm-0bf46b536397f4e4b50ba928f5120d27dc0f1ea5.tar.gz bcm5719-llvm-0bf46b536397f4e4b50ba928f5120d27dc0f1ea5.zip | |
Don't try to create a GEP when the pointee type is unsized (such GEPs
are invalid). Fixes a crash on array1.C from the GCC testsuite when
compiled with dragonegg.
llvm-svn: 147946
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/VMCore/ConstantFold.cpp | 3 | ||||
| -rw-r--r-- | llvm/test/Transforms/InstCombine/2012-01-11-OpaqueBitcastCrash.ll | 12 |
2 files changed, 14 insertions, 1 deletions
diff --git a/llvm/lib/VMCore/ConstantFold.cpp b/llvm/lib/VMCore/ConstantFold.cpp index 4d7a857de5c..62ef25b6430 100644 --- a/llvm/lib/VMCore/ConstantFold.cpp +++ b/llvm/lib/VMCore/ConstantFold.cpp @@ -104,7 +104,8 @@ static Constant *FoldBitCast(Constant *V, Type *DestTy) { // the first element. If so, return the appropriate GEP instruction. if (PointerType *PTy = dyn_cast<PointerType>(V->getType())) if (PointerType *DPTy = dyn_cast<PointerType>(DestTy)) - if (PTy->getAddressSpace() == DPTy->getAddressSpace()) { + if (PTy->getAddressSpace() == DPTy->getAddressSpace() + && DPTy->getElementType()->isSized()) { SmallVector<Value*, 8> IdxList; Value *Zero = Constant::getNullValue(Type::getInt32Ty(DPTy->getContext())); diff --git a/llvm/test/Transforms/InstCombine/2012-01-11-OpaqueBitcastCrash.ll b/llvm/test/Transforms/InstCombine/2012-01-11-OpaqueBitcastCrash.ll new file mode 100644 index 00000000000..abab9dc5702 --- /dev/null +++ b/llvm/test/Transforms/InstCombine/2012-01-11-OpaqueBitcastCrash.ll @@ -0,0 +1,12 @@ +; RUN: opt < %s -instcombine -disable-output + +%opaque_struct = type opaque + +@G = external global [0 x %opaque_struct] + +declare void @foo(%opaque_struct*) + +define void @bar() { + call void @foo(%opaque_struct* bitcast ([0 x %opaque_struct]* @G to %opaque_struct*)) + ret void +} |

