<html><head><meta http-equiv="Content-Type" content="text/html charset=us-ascii"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><br class=""><div><blockquote type="cite" class=""><div class="">On May 17, 2017, at 6:53 PM, Jatin Bhateja <<a href="mailto:jatin.bhateja@gmail.com" class="">jatin.bhateja@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class="">Please see my replies embedded.<div class=""><br class=""></div><div class="">Thanks,</div><div class="">Jatin<br class=""><br class="">On Thursday, May 18, 2017, Matthias Braun <<a href="mailto:mbraun@apple.com" class="">mbraun@apple.com</a>> wrote:<br class=""><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word" class=""><div class="">- Please do not add any more uses of the LiveVariables pass! It is deprecated and only kept around for one last pass that isn't converted. All new code should use LiveIntervalAnalysis!</div><div class="">- Kill flags are optional: If they are present they must be correct, but it is legal to have a value die without having a kill flag on the operand. So often a simple fix is to clear out the kill flags from instructions you touch instead of recomputing them. The only downside is that some later passes will only perform the maximum amount of optimization will kill flags present [1]</div><div class=""><br class=""></div></div></blockquote><div class=""> </div><div class="">PMDataManager keeps tracks of analysis requirements explicitely set by a perticular pass by calling getAnaysisUsage for that pass i.e to either run a specified analysis if its needed or preserve already performed analysis through the execution of the pass if transformation is sure about not dirtying the already computed analysis or simply allow invalidation of analysis.</div><div class=""><br class=""></div><div class="">Once a pass in the optimization pipeline does not preserve already computed analysis by calling setPreservedAll then any transformation occuring later down the pipeline must recompute the required analysis.</div><div class=""><br class=""></div><div class="">However, if a pass does not call setPreserveAll then it does not own the responsibility of updating the already computed analysis if it dirty it as a side effect of some other transformation. This is exactly what is happening in this case.  Livevariable analysis was called up the pipeline so that MachineCSE could use the needed analysis. Peephole optimization which is called later in the pipeline does not preserve not requires live variables and dirty the liveness information as a side effect.</div><div class=""><br class=""></div><div class="">All is correct nothing wrong in the flow as if any other pass in pipeline which need liveness will mention the same in its getAnalysisUsage and since perticular analysis is not preserved by pass ahead of it in the optimization pipeline hence it will get recomputed during schedulePass.</div></div></div></blockquote><blockquote type="cite" class=""><div class=""><div class=""><div class=""><br class=""></div><div class="">Now, MachineInstrVerifier pass which is a dumb validation pass always check for consistency of liveness information attached to IR even if transformation which ran just before it does not either require or preserve i.e may invalidate liveness as a side effect.</div></div></div></blockquote><div>Sure. However:</div><div><br class=""></div><div>- The result of an analysis pass is part of that pass instance. I.e. accessing LiveVariables::getVarInfo() is clearly getting you the result of LiveVariables.</div><div>- However as far as I understand you this is about kill flags on machine operands? They are part of the normal MI representation. I don't consider those to be the result of the LiveVariables analysis but a part of MI that should always be correct (I know in practices things are somewhat messy as the big number of addPass(XXX, false) invocations in TargetPassConfig demonstrates...)</div><div><br class=""></div><div>- Matthias</div><div><br class=""></div></div></body></html>