<html>
  <head>
    <meta http-equiv="Content-Type" content="text/html;
      charset=windows-1252">
  </head>
  <body>
    <p><font face="Hack Nerd Font Mono">Hi Kelvin,</font></p>
    <p><font face="Hack Nerd Font Mono"><br>
      </font></p>
    <p><font face="Hack Nerd Font Mono">recently it came up twice that
        we might want to have alias information looking something like
        this:</font></p>
    <p><font face="Hack Nerd Font Mono">`llvm.assume(i1 true)
        ['noalias'(%ptrA, %ptrB)]`</font></p>
    <p><font face="Hack Nerd Font Mono">Which is supposed to mean that
        under the control condition of the `llvm.assume`,</font></p>
    <p><font face="Hack Nerd Font Mono">anything derived from `%ptrA`
        will not alias anything derived from `%ptrB`.</font></p>
    <p><font face="Hack Nerd Font Mono"> We will have a separate RFC for
        this but I was wondering if it might benefit your use case.</font></p>
    <p><font face="Hack Nerd Font Mono"><br>
      </font></p>
    <p><font face="Hack Nerd Font Mono">Let me know if you need more
        information :)</font></p>
    <p><font face="Hack Nerd Font Mono"><br>
      </font></p>
    <p><font face="Hack Nerd Font Mono">Looking forward to your
        thoughts!</font></p>
    <p><font face="Hack Nerd Font Mono"><br>
      </font></p>
    <p><font face="Hack Nerd Font Mono">Cheers,<br>
      </font></p>
    <p><font face="Hack Nerd Font Mono">  Johannes<br>
      </font></p>
    <p><font face="Hack Nerd Font Mono"></font><br>
    </p>
    <div class="moz-cite-prefix">On 4/14/20 1:21 PM, Kelvin Li via
      llvm-dev wrote:<br>
    </div>
    <blockquote type="cite"
cite="mid:OF61357B01.99800180-ON8525854A.0052153B-8525854A.0064CD05@notes.na.collabserv.com">
      <pre class="moz-quote-pre" wrap="">Hi,

We, IBM XL Fortran compiler team, is interested in representing Fortran 
alias information in LLVM IR.  We use the XL Fortran frontend to emit LLVM 
IR that includes alias information to feed to the LLVM in order to create 
object files.  For the Fortran alias representation in LLVM IR, we 
considered both TBAA and ScopeAlias/NoAlias metadata approaches, we think 
that the ScopeAlias/NoAlias metadata is more appropriate for refined alias 
information for Fortran.  The XL Fortran frontend emits the alias info in 
terms of what other symbols that a symbol alias to.  We experiment a 
scheme that represents the alias relation in terms of noalias and scope 
alias metadata in LLVM IR.  An example is shown in the attached slides and 
the full .ll file for the example is also attached.

In this experiment, we observe that the performance gain varies from 
workload to workload, and the extent can be from a few percent to 2X.  The 
compile time and the size of the IR increase as well.

We briefly investigated the possible causes of the long compile time and 
the large IR size issues.  For the compile-time performance, we observe:
- Each alias query (ScopedNoAliasAAResult::mayAliasInScopes) involves 
partitioning a metadata set based on the domains of the metadata elements. 
 One possible solution is that pre-partitioning the metadata sets and 
maintaining the partitions on updates can help.
- Intersection of noalias sets is O(n^2) as metadata elements do not have 
any ordering. Defining some order on the elements can help significantly.
- Some optimizations do not scale well when the size of the working 
instruction set increases, e.g. SCEV functions.

For the size of LLVM IR, the noalias metadata requires a flattened set of 
metadata nodes.  A hierarchical representation can reduce memory 
footprint.

With these findings, we would like to start a thread to discuss how to 
express Fortran alias in LLVM IR.  Any comments and information regarding 
any previous approaches are welcome.





Thanks,
Kelvin Li
Tarique Islam






</pre>
      <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>