<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></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 Sep 10, 2015, at 5:30 PM, Chandler Carruth <<a href="mailto:chandlerc@gmail.com" class="">chandlerc@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class="">I think '-load' is going to have to work *fundamentally* differently with the new pass manager, but I'm confident it will work there.</div></div></blockquote>Oh yeah, I’m not surprised it’ll be different from the current code. Given that you know what you’re writing much more than the rest of us, I trust you when you say it will work.<br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class=""><br class=""></div><div class="">The idea is that when you load a pass as a plugin, you get a callback that allows you to add your own passes to the pass manager. The pass manager is already doing full type erasure so it can have passes in it which it has never seen before.</div></div></div></blockquote>So I hate to write this, but this sounds very similar to the current pass initializer scheme, just that you are using a callback instead of a static initializer. Why have the difference? I mean why not use the callback for all passes? Then the code is the same regardless of dynamic loading, and it seems to me like that would reduce the amount of code you had to put in SROA.h for example.</div><div><br class=""></div><div>But, it would also make pass registration just like what we have now, which isn’t necessarily a good thing.<br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class=""><br class=""></div><div class="">I was planning on building any plugin support at the very end, because it isn't an important use case to me. </div></div></div></blockquote>Makes sense. I’d do the same if i was writing the new PM.<br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class="">It'd be great if people that are actually using this could contribute it, as otherwise I'm much more likely to focus on essentially all the other use cases until it comes time to try to rip *out* the old pass manager.</div></div></div></blockquote>I might try. I honestly don’t use dynamically loaded passes either, or not often, but they are still useful to have.</div><div><br class=""></div><div>Pete<br class=""><blockquote type="cite" class=""><div class=""><br class=""><div class="gmail_quote"><div dir="ltr" class="">On Thu, Sep 10, 2015 at 4:50 PM Pete Cooper <<a href="mailto:peter_cooper@apple.com" class="">peter_cooper@apple.com</a>> wrote:<br class=""></div><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="">Hey Chandler<div class=""><br class=""></div><div class="">Its a shame to expose the internal details of passes in the header, but the only alternative I can think of is an extra layer of indirection to an Impl, and I don’t think thats really any better. So in terms of that I can’t offer any help.</div><div class=""><br class=""></div><div class="">However, one thing I would like to make sure is that whatever solution we agree on here will work for ‘-load’ passes. We certainly don’t want to refactor a huge number of passes then have to do it all again because of that constraint. Are you confident that the SROA change here would work if SROA is loaded dynamically? Perhaps its worth fixing the LLVMHello.dylib pass before proceeding to any other passes after SROA.</div><div class=""><br class=""></div><div class="">Cheers,</div><div class="">Pete</div></div><div style="word-wrap:break-word" class=""><div class=""><div class=""><blockquote type="cite" class=""><div class="">On Sep 10, 2015, at 4:18 PM, Sean Silva via llvm-commits <<a href="mailto:llvm-commits@lists.llvm.org" target="_blank" class="">llvm-commits@lists.llvm.org</a>> wrote:</div><br class=""><div class=""><div dir="ltr" class=""><br class=""><div class="gmail_extra"><br class=""><div class="gmail_quote">On Thu, Sep 10, 2015 at 4:13 PM, Chandler Carruth <span dir="ltr" class=""><<a href="mailto:chandlerc@gmail.com" target="_blank" class="">chandlerc@gmail.com</a>></span> wrote:<br class=""><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr" class=""><div class="gmail_quote"><span class=""><div dir="ltr" class="">On Thu, Sep 10, 2015 at 3:26 PM Sean Silva <<a href="mailto:chisophugis@gmail.com" target="_blank" class="">chisophugis@gmail.com</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr" class="">In `[LLVMdev] Heads up: Pass Manager changes will be starting shortly` one of the goals was "I'm going to build a bridge so that an existing Pass can be inserted into the new pass manager with some adaptors and everything will just work".<div class=""><br class=""></div><div class="">My reading of this is that there would be an incremental step where we have fully transitioned to using the new pass manager, but existing passes are using wrappers. We would then incrementally move each pass to "natively" use the new pass manager as needed (e.g. for the inliner). So I'm surprised that we are porting SROA so early.</div><div class=""><br class=""></div><div class="">Did I miss/forget something? I've noticed that in last fall's devmtg talk it looked like you have "port the existing pass pipeline" as a blocking item, so I assume there was some sort of realization in the interim. Could you elaborate on this (or point to a thread I missed?).</div></div></blockquote><div class=""><br class=""></div></span><div class="">I'm not sure which thread, but there was an update at one point where I essentially explained that I could find no clear way to have a packaged bridge that Just Worked. The cleanest solution I have found is to be able to share all the business logic, while having essentially two entry points, and to make the entry points as small and share as much code as possible. The wrappers for the legacy pass manager try to do this, but the pattern for doing it is exactly what I wanted feedback on here.</div></div></div></blockquote><div class=""><br class=""></div><div class="">Okay, makes sense.</div><div class=""><br class=""></div><div class="">-- Sean Silva</div><div class=""> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr" class=""><div class="gmail_quote"><div class=""><div class=""><div class=""> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr" class=""><div class=""><div class=""><br class=""></div><div class="">-- Sean Silva</div></div></div><div class="gmail_extra"><br class=""><div class="gmail_quote">On Thu, Sep 10, 2015 at 2:02 PM, Chandler Carruth via llvm-commits <span dir="ltr" class=""><<a href="mailto:llvm-commits@lists.llvm.org" target="_blank" class="">llvm-commits@lists.llvm.org</a>></span> wrote:<br class=""><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">chandlerc created this revision.<br class="">
chandlerc added reviewers: dexonsmith, bogner.<br class="">
chandlerc added a subscriber: llvm-commits.<br class="">
<br class="">
In some ways this is a very boring port to the new pass manager as there<br class="">
are no interesting analyses or dependencies or other oddities.<br class="">
<br class="">
However, this does introduce the first good example of a transformation<br class="">
pass with non-trivial state porting to the new pass manager. I've tried<br class="">
to carve out patterns here to replicate elsewhere, and would appreciate<br class="">
comments on whether folks like these patterns:<br class="">
<br class="">
- A common need in the new pass manager is to effectively lift the pass<br class="">
class and some of its state into a public header file. Prior to this,<br class="">
LLVM used anonymous namespaces to provide "module private" types and<br class="">
utilities, but that doesn't scale to cases where a public header file<br class="">
is needed and the new pass manager will exacerbate that. The pattern<br class="">
I've adopted here is to use the namespace-cased-name of the core pass<br class="">
(what would be a module if we had them) as a module-private namespace.<br class="">
Then utility and other code can be declared and defined in this<br class="">
namespace. At some point in the future, we could even have<br class="">
(conditionally compiled) code that used modules features when<br class="">
available to do the same basic thing.<br class="">
<br class="">
- I've split the actual pass run method in two in order to expose<br class="">
a private method usable by the old pass manager to wrap the new class<br class="">
with a minimum of duplicated code. I actually looked at a bunch of<br class="">
ways to automate or generate these, but they are all quite terrible<br class="">
IMO. The fundamental need is to extract the set of analyses which need<br class="">
to cross this interface boundary, and that will end up being too<br class="">
unpredictable to effectively encapsulate IMO. This is also<br class="">
a relatively small amount of boiler plate that will live a relatively<br class="">
short time, so I'm not too worried about the fact that it is boiler<br class="">
plate.<br class="">
<br class="">
The rest of the patch is totally boring but results in a massive diff<br class="">
(sorry). It just moves code around and removes or adds qualifiers to<br class="">
reflect the new name and nesting structure.<br class="">
<br class="">
<a href="http://reviews.llvm.org/D12773" rel="noreferrer" target="_blank" class="">http://reviews.llvm.org/D12773</a><br class="">
<br class="">
Files:<br class="">
include/llvm/InitializePasses.h<br class="">
include/llvm/Transforms/Scalar/SROA.h<br class="">
lib/LTO/LTOCodeGenerator.cpp<br class="">
lib/Transforms/Scalar/SROA.cpp<br class="">
lib/Transforms/Scalar/Scalar.cpp<br class="">
<br class="">
<br class="">_______________________________________________<br class="">
llvm-commits mailing list<br class="">
<a href="mailto:llvm-commits@lists.llvm.org" target="_blank" class="">llvm-commits@lists.llvm.org</a><br class="">
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" rel="noreferrer" target="_blank" class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits</a><br class="">
<br class=""></blockquote></div><br class=""></div>
</blockquote></div></div></div></div>
</blockquote></div><br class=""></div></div>
_______________________________________________<br class="">llvm-commits mailing list<br class=""><a href="mailto:llvm-commits@lists.llvm.org" target="_blank" class="">llvm-commits@lists.llvm.org</a><br class=""><a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" target="_blank" class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits</a><br class=""></div></blockquote></div><br class=""></div></div></blockquote></div>
</div></blockquote></div><br class=""></body></html>