From: Matt Arsenault Date: Fri, 1 Jul 2016 23:15:06 +0000 (+0000) Subject: PeepholeOptimizer: Relax assert X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=db64d82b7405da5c2b71113284f7606d22bab92c;p=llvm PeepholeOptimizer: Relax assert Allow implicit defs git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@274402 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/PeepholeOptimizer.cpp b/lib/CodeGen/PeepholeOptimizer.cpp index d521ae8f958..11ff79cb9f3 100644 --- a/lib/CodeGen/PeepholeOptimizer.cpp +++ b/lib/CodeGen/PeepholeOptimizer.cpp @@ -1887,8 +1887,10 @@ ValueTrackerResult ValueTracker::getNextSourceImpl() { assert(Def && "This method needs a valid definition"); assert( - (DefIdx < Def->getDesc().getNumDefs() || Def->getDesc().isVariadic()) && - Def->getOperand(DefIdx).isDef() && "Invalid DefIdx"); + (Def->getOperand(DefIdx).isDef() && + (DefIdx < Def->getDesc().getNumDefs() || Def->getDesc().isVariadic()) || + Def->getOperand(DefIdx).isImplicit()) && + "Invalid DefIdx"); if (Def->isCopy()) return getNextSourceFromCopy(); if (Def->isBitcast())