<div dir="ltr"><div>Hey Stephan,</div><div><br></div><div>Code is all closed-source secret-sauce, but here is how we register our AA via the external AA callback:</div><div><br></div><div><span style="font-family:monospace">struct Functor final<br>{<br>    Functor() = default;<br>    Functor(const Functor& other)<br>    {<br>        // We don't actually copy any of our analysis because they should not have been initialized yet.<br>    }<br><br>    void operator()(llvm::Pass& pass, llvm::Function& function, llvm::AAResults& aliasAnalysis)<br>    {<br>        // Add our Unity Burst Alias Analysis tracking.<br>        ubaaAliasAnalysis.invalidate(function);<br>        aliasAnalysis.addAAResult(ubaaAliasAnalysis);<br>    }<br>    <br>private:<br>    UBAAAliasAnalysis ubaaAliasAnalysis;<br>};<br><br>llvm::Pass* burst_CreateExtraAliasAnalysisLegacyPass()<br>{<br>    std::function<void(llvm::Pass&, llvm::Function&, llvm::AAResults&)> func = Functor();<br>    return createExternalAAWrapperPass(func);<br>}</span></div><div><span style="font-family:monospace"><br></span></div><div><span style="font-family:monospace"><font face="arial,sans-serif">Hopefully that can help!</font></span></div><div><span style="font-family:monospace"><font face="arial,sans-serif"><br></font></span></div><div><span style="font-family:monospace"><font face="arial,sans-serif">Cheers,</font></span></div><div><span style="font-family:monospace"><font face="arial,sans-serif">-Neil.</font><br></span></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Tue, Aug 17, 2021 at 7:03 PM Stephan Diestelhorst <<a href="mailto:stephand@xilinx.com">stephand@xilinx.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Hi Neil,<br>
<br>
Thanks for the fast response, that looks like it is the right thing, however, I am still not getting my external AA pass invoked via the call-back.  There are a few things that I notice when looking at uses of llvm::LegacyAAGetter (in LLVM) vs my code:<br>
<br>
(1) Uses of it are usually wrapped in a function_ref<AAResults &(Function&)> which delays calling the functions, which I don’t know what it is used for<br>
(2) My code has a module pass querying another function pass result which in turn queries the AA pass<br>
(3) I am using the old-style of pass structure, instead of mixins<br>
<br>
Just for testing, I get rid of both (1) and (2) by simply calling LegacyAARResult(*this)(f).getModRefBehavior(<something>) from inside my ModulePass, but it does not get daisy chained to my MyAA / the call back registered with ExternalAAWrapper.  If I use the function_ref approach, I somehow get a segment violation (I think I don't understand some lifetime challenge here).<br>
<br>
Is the code you reference available somewhere for me to have a look or some other code that uses an external AA pass from the command line?  A quick look on GitHub didn't turn up too many (just a SCAF piece) results... otherwise, I will try to create a small example and post that here.<br>
<br>
Thanks,<br>
  Stephan<br>
<br>
From: Neil Henning <<a href="mailto:neil.henning@unity3d.com" target="_blank">neil.henning@unity3d.com</a>> <br>
Sent: 17 August 2021 08:27<br>
To: Stephan Diestelhorst <<a href="mailto:stephand@xilinx.com" target="_blank">stephand@xilinx.com</a>><br>
Cc: <a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
Subject: Re: [llvm-dev] Out-of-tree AA pass used from ModulePass<br>
<br>
CAUTION: This message has originated from an External Source. Please use proper judgment and caution when opening attachments, clicking links, or responding to this email.<br>
<br>
Hey Stephan,<br>
<br>
To get function-level AA results in a ModulePass with the legacy pass manager you should use `llvm::LegacyAARGetter`. Because AA results are per-function, you call this with the function you want alias results about. That should get you any AA you registered with the external AA wrapper (we use the same mechanism in Unity's HPC# Burst compiler for instance).<br>
<br>
Cheers,<br>
-Neil.<br>
<br>
On Mon, Aug 16, 2021 at 10:46 PM Stephan Diestelhorst via llvm-dev <mailto:<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br>
(Please keep me in CC, not sure my subscription request has made it through yet)<br>
Hi all,<br>
<br>
I am building a fairly extensive set of compiler passes out-of-tree with LLVM, and this all works nicely, except for tying my custom AA pass MyAA into the overall AA aggregator via AAResultsWrapper. As far as I can see, the ExternalAAWrapper does what I want and allows me to add an out-of-tree AA pass to the list of passes that is consulted when my other passes (let's say MyFuncPass) need an alias analysis result, by having registered a call-back in ExternalAAWrapper that will add MyAAResult into llvm::AAResult, which then gets consulted in AA queries if needed. This works for now (with some hacks).<br>
<br>
The problem is, however, when I convert MyFuncPass to a module pass, and I am then trying to get aa results for my functions.  The problem is that the call-back I registered (I see that happening!) with ExternalAAWrapper is never being run, so my AA results are not added to the mix.  I am using opt and the legacy pass managers, and I am struggling to understand how this should be used correctly, and why the call-back is not executed in time when turning my pass into a ModulePass.<br>
<br>
I am getting my aa results via getAnalysis<AAResultsWrapperPass>().getAAResults() in MyFuncPass, and with getAnalysis<AAResultsWrapperPass>(f).getAAResults() with f being the function I am currently looking into in the ModulePass.<br>
<br>
I am not really sure which passes I must specify with addRequired(..) or on the command line and it seems the documentation around AA in general and external AA specifically is somewhat outdated / sparse.<br>
<br>
Does this fairly high-level description ring any bells?  My code is pretty wild at this point, so it is not trivial to create a simple example, but I can do it if it would be helpful here.  Further, for various reasons (started this project a fair while ago) I am still on LLVM 8, but AFAICS, not much has changed in this area. That said, I don't have a great understanding how the whole (legacy) pass manager piece hangs together.<br>
<br>
Thanks,<br>
  Stephan<br>
--<br>
Stephan Diestelhorst<br>
System Architect<br>
Xilinx - Data Center Group<br>
Cambridge, UK<br>
<br>
This email and any attachments are intended for the sole use of the named recipient(s) and contain(s) confidential information that may be proprietary, privileged or copyrighted under applicable law. If you are not the intended recipient, do not read, copy, or forward this email message or any attachments. Delete this email message and any attachments immediately.<br>
_______________________________________________<br>
LLVM Developers mailing list<br>
mailto:<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
<a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
<br>
<br>
-- <br>
<br>
<br>
Neil Henning<br>
Senior Software Engineer Compiler<br>
<a href="http://unity.com" rel="noreferrer" target="_blank">http://unity.com</a><br>
<br>
</blockquote></div><br clear="all"><br>-- <br><div dir="ltr" class="gmail_signature"><div dir="ltr"><table style="border-collapse:collapse;border-spacing:0px;color:rgb(90,90,91);font-size:13px;margin:0px 0px 20px;padding:0px" width="100%" cellspacing="0" cellpadding="0" border="0"><tbody style="margin:0px;padding:0px"><tr style="margin:0px;padding:0px"><td style="border-collapse:collapse;font-size:0px;line-height:1.5em;padding:0px 0px 20px;vertical-align:top" align="left"><table style="border-collapse:collapse;border-spacing:0px;margin:0px;padding:0px" cellspacing="0" cellpadding="0" border="0" align="left"><tbody style="margin:0px;padding:0px"><tr style="margin:0px;padding:0px"><td style="border-collapse:collapse;font-size:1.12em;line-height:1.5em;padding:0px;vertical-align:top;width:64px"><img style="border: medium none; border-radius: 0px; display: block; font-size: 13px; height: auto; line-height: 100%; margin: 0px; max-width: 100%; outline-style: none; outline-width: medium; padding: 20px 0px 0px; width: 100%;" alt="" src="https://unity3d.com/profiles/unity3d/themes/unity/images/ui/other/unity-logo-dark-email.png" width="64" height="auto"></td></tr></tbody></table></td></tr><tr style="margin:0px;padding:0px"><td style="border-collapse:collapse;font-size:0px;line-height:1.5em;padding:0px;vertical-align:top" align="left"><div style="color:rgb(0,0,0);font-family:Roboto,Arial;font-size:14px;font-weight:600;line-height:15px;margin:0px;padding:0px">Neil Henning</div></td></tr><tr style="margin:0px;padding:0px"><td style="border-collapse:collapse;font-size:0px;line-height:1.5em;padding:0px;vertical-align:top" align="left"><div style="color:rgb(0,0,0);font-family:Roboto,Arial;font-size:14px;line-height:15px;margin:0px;padding:0px 0px 10px">Senior Software Engineer Compiler</div></td></tr><tr style="margin:0px;padding:0px"><td style="border-collapse:collapse;font-size:0px;line-height:1.5em;padding:0px;vertical-align:top" align="left"><div style="color:rgb(0,0,0);font-family:Roboto,Arial;font-size:12px;line-height:15px;margin:0px;padding:0px"><a href="http://unity.com" target="_blank">unity.com</a></div></td></tr></tbody></table></div></div>