Index: llvm/trunk/lib/Transforms/Scalar/NewGVN.cpp =================================================================== --- llvm/trunk/lib/Transforms/Scalar/NewGVN.cpp +++ llvm/trunk/lib/Transforms/Scalar/NewGVN.cpp @@ -1936,6 +1936,12 @@ IBlock = I->getParent(); VD.LocalNum = InstrDFS.lookup(I); } + + // Skip uses in unreachable blocks, as we're going + // to delete them. + if (ReachableBlocks.count(IBlock) == 0) + continue; + DomTreeNode *DomNode = DT->getNode(IBlock); VD.DFSIn = DomNode->getDFSNumIn(); VD.DFSOut = DomNode->getDFSNumOut(); Index: llvm/trunk/test/Transforms/NewGVN/pr31758.ll =================================================================== --- llvm/trunk/test/Transforms/NewGVN/pr31758.ll +++ llvm/trunk/test/Transforms/NewGVN/pr31758.ll @@ -0,0 +1,37 @@ +; RUN: opt -newgvn %s -S -o - | FileCheck %s + +%struct.dipsy = type {} +%struct.fluttershy = type { %struct.dipsy* } +%struct.patatino = type {} + +define void @tinkywinky() { +bb: + br label %bb90 + +bb90: + %tmp = getelementptr inbounds %struct.fluttershy, %struct.fluttershy* undef, i64 0, i32 0 + %tmp91 = bitcast %struct.dipsy** %tmp to %struct.patatino** + %tmp92 = load %struct.patatino*, %struct.patatino** %tmp91, align 8 + %tmp99 = getelementptr inbounds %struct.patatino, %struct.patatino* %tmp92 + %tmp134 = getelementptr inbounds %struct.fluttershy, %struct.fluttershy* undef, i64 0, i32 0 + %tmp135 = bitcast %struct.dipsy** %tmp134 to %struct.patatino** + %tmp136 = load %struct.patatino*, %struct.patatino** %tmp135, align 8 + br label %bb90 + +bb138: + %tmp139 = getelementptr inbounds %struct.patatino, %struct.patatino* %tmp136 + br label %bb138 +} + +; CHECK-LABEL: tinkywinky +; CHECK-NEXT: bb: +; CHECK-NEXT: br label %bb90 +; CHECK-NEXT +; CHECK: bb90: +; CHECK: %tmp91 = bitcast %struct.dipsy** undef to %struct.patatino** +; CHECK-NEXT: %tmp92 = load %struct.patatino*, %struct.patatino** %tmp91, align 8 +; CHECK-NEXT: %tmp136 = load %struct.patatino*, %struct.patatino** %tmp91, align 8 +; CHECK-NEXT: br label %bb90 +; CHECK: bb138: +; CHECK-NEXT: br label %bb138 +; CHECK-NEXT: }