<html>
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  </head>
  <body>
    <p>+1 to the strategy and timeline.  This has been a long time in
      the works and I'm thrilled to see us approaching this major
      milestone.</p>
    <p>minor comment inline below<br>
    </p>
    <p>Philip<br>
    </p>
    <div class="moz-cite-prefix">On 1/26/21 9:17 AM, Arthur Eubanks via
      llvm-dev wrote:<br>
    </div>
    <blockquote type="cite"
cite="mid:CAPW48sqy2DAnjGd64WHtFv_quq=E4RwVj=oo_+A8+QFuSkuZEA@mail.gmail.com">
      <meta http-equiv="content-type" content="text/html; charset=UTF-8">
      <div dir="ltr">Hi all,<br>
        <br>
        We've been fixing the various remaining issues in order to turn
        on the new pass manager for the optimization pipeline, and it's
        about time to turn it on. (Thanks to everyone who has helped
        with testing and fixing the new pass manager!)<br>
        <br>
        <a href="https://reviews.llvm.org/D95380" moz-do-not-send="true">https://reviews.llvm.org/D95380</a>
        is the change that would happen, which sets the CMake flag
        -DENABLE_EXPERIMENTAL_NEW_PASS_MANAGER=ON by default. This
        affects anything that uses the LLVM_ENABLE_NEW_PASS_MANAGER
        macro, which includes opt's handling of the `opt -instcombine`
        syntax, clang, and ThinLTO in lld drivers. This does not affect
        the backend target-specific codegen pipeline since that's mostly
        not been ported to use the new PM infrastructure yet.<br>
        <br>
        <a href="https://bugs.llvm.org/show_bug.cgi?id=46649"
          moz-do-not-send="true">Here</a> is the umbrella bug for
        turning on the new PM with blockers. The main one is <a
          href="https://bugs.llvm.org/show_bug.cgi?id=48819"
          moz-do-not-send="true">loop unswitching on divergent loop
          conditions is unsafe</a>, which is being looked into. There's
        also the LLVM C API and bugpoint that still use the legacy PM,
        which can be ported later on and only block the removal of the
        legacy PM. The C API can be worked through (we may need to
        introduce replacements to the legacy pass manager APIs), but
        bugpoint will be tricky since it has so many legacy PM-specific
        hacks and we may need to trim it down if we want it to work with
        the new PM. Anyway, I don't think any of the remaining blockers
        are large enough to block the switch (but comments welcome).<br>
      </div>
    </blockquote>
    I see no problem with having these two remain on the legacy pass
    manager for the moment.  I do think we should expose a new C API for
    the NewPM and not try to shove the new one into the same API as the
    old one, but that's a weakly held opinion and easily discussed
    later. <br>
    <blockquote type="cite"
cite="mid:CAPW48sqy2DAnjGd64WHtFv_quq=E4RwVj=oo_+A8+QFuSkuZEA@mail.gmail.com">
      <div dir="ltr"><br>
        I'd like to turn on the new PM by default soonish, after the
        12.x branch. Perhaps roughly a week from now barring any major
        newly discovered regressions?<br>
        <br>
        As for potential issues only uncovered after the switch, if
        there is a large issue I will roll it back, but for smaller
        issues I'd rather ask users to pin to the legacy PM while we fix
        the issues, either via the CMake flag
        -DENABLE_EXPERIMENTAL_NEW_PASS_MANAGER=OFF, or the corresponding
        compiler flags, like -flegacy-pass-manager for clang.<br>
        <br>
        Any concerns/comments?<br>
      </div>
      <br>
      <fieldset class="mimeAttachmentHeader"></fieldset>
      <pre class="moz-quote-pre" wrap="">_______________________________________________
LLVM Developers mailing list
<a class="moz-txt-link-abbreviated" href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a>
<a class="moz-txt-link-freetext" href="https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev">https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a>
</pre>
    </blockquote>
  </body>
</html>