<div dir="ltr">On 8 April 2013 21:46, Iain Buclaw <span dir="ltr"><<a href="mailto:ibuclaw@ubuntu.com" target="_blank">ibuclaw@ubuntu.com</a>></span> wrote:<br><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div><div class="h5">On 8 April 2013 11:59, Manu <span dir="ltr"><<a href="mailto:turkeyman@gmail.com" target="_blank">turkeyman@gmail.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<div dir="ltr"><div><div>On 8 April 2013 19:41, Iain Buclaw <span dir="ltr"><<a href="mailto:ibuclaw@ubuntu.com" target="_blank">ibuclaw@ubuntu.com</a>></span> wrote:<br></div></div><div class="gmail_extra">
<div class="gmail_quote"><div><div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<div dir="ltr"><div><div><div class="gmail_extra"><div class="gmail_quote">On 8 April 2013 10:06, Timon Gehr <span dir="ltr"><<a href="mailto:timon.gehr@gmx.ch" target="_blank">timon.gehr@gmx.ch</a>></span> wrote:<br>


<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<div>On 04/08/2013 10:29 AM, Iain Buclaw 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"><div>
On 6 April 2013 12:09, bearophile <<a href="mailto:bearophileHUGS@lycos.com" target="_blank">bearophileHUGS@lycos.com</a><br></div><div><div>
<mailto:<a href="mailto:bearophileHUGS@lycos.com" target="_blank">bearophileHUGS@lycos.<u></u>com</a>>> wrote:<br>
<br>
    I remember Walter saying two or more times that the semantics of D<br>
    offers some optimization opportunities that probably are not yet<br>
    used to try to reduce the run-time of D programs. Is Walter willing<br>
    to write down a list of such opportunities? (Ideas from other<br>
    persons are welcome). Maybe some LDC/GDC developer will make the<br>
    GCC/LLVM back-ends use them. The implementation of those ideas will<br>
    require some time, so later it's better to put the list in the D wiki.<br>
<br>
    Bye,<br>
    bearophile<br>
<br>
<br>
<br></div></div><div>
This information could possibly be helpful.  Though given that most of<br>
(gdc) codegen is on par with g++, there's probably not much on the list<br>
that isn't already detected by the backend optimisation passes.<br>
<br>
<br>
--<br>
Iain Buclaw<br>
<br>
*(p < e ? p++ : p) = (c & 0x0f) + '0';<br>
</div></blockquote>
<br>
Does GDC use the additional type information for optimization? Eg. if something is immutable, then aliasing issues do not have to be considered for it when reading and writing through multiple pointers repeatedly.<br>
</blockquote></div><br></div></div></div><div class="gmail_extra">It uses some type information, eg:<br><br></div><div class="gmail_extra">const/immutable/wild  -> qualified const.<br></div><div class="gmail_extra">shared -> qualified volatile.<br>



</div><div class="gmail_extra">shared + const/wild -> qualified const/volatile.<br clear="all"></div><div class="gmail_extra"><br><br></div><div class="gmail_extra">Done nothing in regards to C 'restrict' optimisations.  However the D array .ptr type could also be considered 'restrict' also.<br>


</div></div></blockquote><div><br></div></div></div><div>Yes, I was just about to bring up __restrict, there is probably good opportunity for that.</div><div>Why do you suppose .ptr is restrict? One problem with D's slicing is it's very hard to assume __restrict on basically any arrays.</div>


<div>I feel like 'scope' might imply a __restrict input... although the relationship is kinda backwards, so maybe not...</div><div><br></div></div></div></div></blockquote><div><br></div></div></div><div>At least, many array operations, eg:  a[] += b[].  Require the arrays not to be overlapping, so could do some optimisations based around that knowledge.<br>
</div></div></div></div></blockquote><div><br></div><div style>What reason is there that these may not be overlapping?</div><div><span style="color:rgb(80,0,80)"><br></span></div><div><span style="color:rgb(80,0,80)"> </span></div>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div class="im"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div></div><div>
How about pure? Is GDC able to factor pure function calls with the same arguments outside of loops, or eliminate consecutive calls? It's really tedious to do this by hand, and breaks code continuity. Particularly important in a language that supports properties, since they'll be accessed consecutively all the time.</div>


<div><br></div></div></div></div></blockquote><div><br></div></div><div>Only builtins are pure in the sense of 'C'.  Even functions considered PUREstrong by the frontend may update an internal state, so the rules just don't apply.  Except for maybe global functions...   In any case, the only benefit you can reap from 'D pure' functions are that they are more likely to be const-folded / inlined.<br>
</div></div></div></div></blockquote><div><br></div><div style>Oh my god... ..... this is the most upsetting thing I've heard all day! :(</div><div style>No really, I have been SOOOO excited for so long about this optimisation potential in D!</div>
<div style>There's gotta be something that can be done! >_<</div><div style><br></div><div style>Does the front end know if the function actually DOES assign to any state? The compiler could easily work that out, and in the event it doesn't actually perform any such assignment, it could be marked pure for reals...</div>
<div><span style="color:rgb(80,0,80)"><br></span></div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">
<div class="im"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div></div><div>
What about immutable? You said it qualifies const, which in C++ is absolutely meaningless in terms of optimisation potential; just because something is const, the source of the pointer can certainly be non-const somewhere else, which means C++ can't possibly factor const loads outside of loops, and must respect consecutive dereferences of the same pointer.</div>


<div>immutable in D should certainly be able to be factored outside loops, so it is more meaningful than const, and actually has real optimisation potential. Can GCC actually express an immutable value?</div></div></div>
</div></blockquote><div><br></div></div><div>Other than saying that the type is const-qualified, the decl is set read-only, which only means to the backend that 'this decl may not be the lhs of an assignment.'<br>
</div></div></div></div></blockquote><div><br></div><div style>Well tell the backend that it's restrict aswell, that will give the backend more opportunities where aliasing is a potential problem.</div><div><span style="color:rgb(80,0,80)"><br>
</span></div><div><span style="color:rgb(80,0,80)"> </span></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">
<div class="im"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div></div><div>I remember there was a problem a while back that I brought to you about GDC generating stack frames unnecessarily for leaf functions, is that resolved? I haven't checked in a while.</div>

<div>
<br></div></div></div></div></blockquote><div><br></div></div><div>It probably is if you re referring to the thread I'm thinking of.<br></div><div class="im"><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">

<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div></div><div>Does GDC have access to a GDC-specific __restrict attribute to tag stuff manually? I'm struggling to think where it can be automated...</div>

</div></div></div>
</blockquote></div></div><br></div><div class="gmail_extra">Nope, but that can be added in using our new attribute syntax. :~)<br clear="all"></div></div></blockquote><div><br></div><div style>So, the sad truth is, with all of D's numerous keywords and explicit qualifications, there are actually NO potential optimisations available that C could not equally make use of.</div>
<div style>I can't believe that pure thing, that's seriously depressing! I forgot you could assign to state within pure functions. Why is that? It's not actually pure at all!</div><div style><br></div><div style>
I guess there's a little bonus if you tag immutable as restrict, but that's a disappointing sum total...</div></div></div></div>