diff --git a/lib/Transforms/Scalar/GVN.cpp b/lib/Transforms/Scalar/GVN.cpp index 590227c27f9..498785e327a 100644 --- a/lib/Transforms/Scalar/GVN.cpp +++ b/lib/Transforms/Scalar/GVN.cpp @@ -808,10 +808,10 @@ Value *GVN::GetValueForBlock(BasicBlock *BB, LoadInst* orig, DenseMap::iterator V = Phis.find(BB); if (V != Phis.end() && !top_level) return V->second; - if (!getAnalysis().isReachableFromEntry(BB)) { - Phis[BB] = UndefValue::get(orig->getType()); - return UndefValue::get(orig->getType()); - } + // If the block is unreachable, just return undef, since this path + // can't actually occur at runtime. + if (!getAnalysis().isReachableFromEntry(BB)) + return Phis[BB] = UndefValue::get(orig->getType()); BasicBlock* singlePred = BB->getSinglePredecessor(); if (singlePred) {