<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="">Ultimately pushing a much stuff a possible to function attributes makes it the most natural. Think -ffast-math, -Os, -Oz, or subtargets attributes. Handling all this stuff at the function level has been proven the easiest to get straightfoward during LTO, and more flexible for “advanced” use-case when mixing modes in a single module.<div class=""><br class=""></div><div class="">The reasons to not address O1 vs O2 vs O3 is IMO that 1) it is complicated and 2) there isn’t much use-case for this, or I didn’t hear about anyone really caring a lot about it. So pragmatically, it makes sense to me to try to address first the low-hanging fruits and to solve what is valuable (I can’t build our kernel with ThinLTO because we don’t encode -ffreestanding correctly, etc.).</div><div class=""><br class=""></div><div class="">Now, if someone has a great idea on how to handle O1/O2/O3 consistently in a way that includes LTO, I’m willing to help on the implementation side!</div><div class=""><br class=""></div><div class="">— </div><div class="">Mehdi</div><div class=""><br class=""></div><div class=""><br class=""></div><div class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Jan 17, 2017, at 5:39 PM, Eric Christopher <<a href="mailto:echristo@gmail.com" class="">echristo@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class="">Honestly instead of optnone I'd prefer to do something else around storing optimization levels, but I think the connotations of that in LTO is going to be painful:<div class=""><br class=""></div><div class="">1) What does it mean to merge two modules of different optimization levels?</div><div class="">2) What does it mean to inline two functions of different optimization levels?</div><div class="">3) What code generator should be used?</div><div class=""><br class=""></div><div class="">Etc.</div><div class=""><br class=""></div><div class="">Honestly I think this is a lot of stuff we don't have any good ideas for and that the current LTO scope doesn't really have. If there's really a need for it though...</div><div class=""><br class=""></div><div class="">(Also, if we don't want to store the actual optimization levels then replace "different optimization levels" above with "optnone and not-optnone" :)</div><div class=""><br class=""></div><div class="">-eric</div><div class=""><br class=""><br class=""><div class="gmail_quote"><div dir="ltr" class="">On Wed, Jan 11, 2017 at 8:34 AM Robinson, Paul via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">In D28404, Mehdi wanted to use the 'optnone' attribute as a way to record<br class="gmail_msg">
"I was compiled with -O0" in the IR, because it seems like a good idea to<br class="gmail_msg">
remember that fact in an LTO compilation and there is no way to remember<br class="gmail_msg">
that fact currently.  A couple of people felt it might be better to have<br class="gmail_msg">
this idea discussed on the dev list, where it might get better exposure,<br class="gmail_msg">
so I'm volunteering to get that discussion started.<br class="gmail_msg">
<br class="gmail_msg">
While 'optnone' does cause lots of optimizations to bypass a function,<br class="gmail_msg">
exactly matching -O0 was not the motivation and never a hard requirement.<br class="gmail_msg">
The implementation makes a distinct effort to get close to the behavior<br class="gmail_msg">
of -O0, but it's not an exact match and for the intended purpose (allowing<br class="gmail_msg">
a given function to be un-optimized to help debugging) it worked fine.<br class="gmail_msg">
<br class="gmail_msg">
Using 'optnone' to convey -O0 to LTO is something of a redefinition, or<br class="gmail_msg">
at least a re-purposing, of the attribute.  To get there from here, I<br class="gmail_msg">
think we would need a couple of things to happen, separately from the<br class="gmail_msg">
minor grunt work of adding 'optnone' to function IR at -O0.<br class="gmail_msg">
<br class="gmail_msg">
1) Update the LangRef definition of 'optnone' to reflect this intent.<br class="gmail_msg">
The current definition doesn't provide a motivation, and the description<br class="gmail_msg">
is (deliberately) a bit vague.  If we want 'optnone' to intentionally<br class="gmail_msg">
match -O0, that should be tightened up.<br class="gmail_msg">
<br class="gmail_msg">
2) Make a concerted effort to teach 'optnone' to targets.  Currently<br class="gmail_msg">
I know the X86 target is aware of it, but I'm not so sure about others.<br class="gmail_msg">
<br class="gmail_msg">
3) Take another look at what 'optnone' currently does *not* turn off,<br class="gmail_msg">
and see if there is something we can do about that.  In some cases this<br class="gmail_msg">
will not be practical, and we may just have to live with that.<br class="gmail_msg">
<br class="gmail_msg">
(Okay, we need 3 things to happen.)<br class="gmail_msg">
<br class="gmail_msg">
I won't say this is blocking Mehdi's work, but it would remove a<br class="gmail_msg">
point of contention and allow the review to proceed more smoothly.<br class="gmail_msg">
--paulr<br class="gmail_msg">
<br class="gmail_msg">
_______________________________________________<br class="gmail_msg">
LLVM Developers mailing list<br class="gmail_msg">
<a href="mailto:llvm-dev@lists.llvm.org" class="gmail_msg" target="_blank">llvm-dev@lists.llvm.org</a><br class="gmail_msg">
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" class="gmail_msg" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br class="gmail_msg">
</blockquote></div></div></div>
</div></blockquote></div><br class=""></div></body></html>