<div dir="ltr">Hi Connor,<div><br></div><div>Lots of good work in defining a new IR.</div><div><br></div><div>I would like to address the LLVM issues:  LunarG's LunarGLASS conventions on LLVM IR generally solve these problems: It has algorithms to re-deduce structured control flow, and if you just want to use LLVM IR as an intermediate language, it could be annotated with the original structured flow control.  Things that should turn into a modifier can be captured as intrinsics, and statically linking the part of LLVM that you need avoids all the release schedule and WebKit-type related issues.<div>
<br></div><div>If Mesa is looking at adding an IR, I highly recommend something that is LLVM based, for the following reasons:</div><div><ul><li>Shaders are going in the direction of having richer C++-like features.<br></li>
<li>It saves tons of engineering time in not creating transforms that have already been written.</li><li>Synergy with other IRs and toolsets that are also being based on LLVM.</li></ul></div><div>JohnK</div><div><br></div>
</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Tue, Aug 19, 2014 at 9:04 AM, Connor Abbott <span dir="ltr"><<a href="mailto:cwabbott0@gmail.com" target="_blank">cwabbott0@gmail.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="">On Mon, Aug 18, 2014 at 8:52 PM, Michel Dänzer <<a href="mailto:michel@daenzer.net">michel@daenzer.net</a>> wrote:<br>

> On 19.08.2014 01:28, Connor Abbott wrote:<br>
>> On Mon, Aug 18, 2014 at 4:32 AM, Michel Dänzer <<a href="mailto:michel@daenzer.net">michel@daenzer.net</a>> wrote:<br>
>>> On 16.08.2014 09:12, Connor Abbott wrote:<br>
>>>> I know what you might be thinking right now. "Wait, *another* IR? Don't<br>
>>>> we already have like 5 of those, not counting all the driver-specific<br>
>>>> ones? Isn't this stuff complicated enough already?" Well, there are some<br>
>>>> pretty good reasons to start afresh (again...). In the years we've been<br>
>>>> using GLSL IR, we've come to realize that, in fact, it's not what we<br>
>>>> want *at all* to do optimizations on.<br>
>>><br>
>>> Did you evaluate using LLVM IR instead of inventing yet another one?<br>
>>><br>
>>><br>
>>> --<br>
>>> Earthling Michel Dänzer            |                  <a href="http://www.amd.com" target="_blank">http://www.amd.com</a><br>
>>> Libre software enthusiast          |                Mesa and X developer<br>
>><br>
>> Yes. See<br>
>><br>
>> <a href="http://lists.freedesktop.org/archives/mesa-dev/2014-February/053502.html" target="_blank">http://lists.freedesktop.org/archives/mesa-dev/2014-February/053502.html</a><br>
>><br>
>> and<br>
>><br>
>> <a href="http://lists.freedesktop.org/archives/mesa-dev/2014-February/053522.html" target="_blank">http://lists.freedesktop.org/archives/mesa-dev/2014-February/053522.html</a><br>
><br>
> I know Ian can't deal with LLVM for some reason. I was wondering if<br>
> *you* evaluated it, and if so, why you rejected it.<br>
><br>
><br>
> --<br>
> Earthling Michel Dänzer            |                  <a href="http://www.amd.com" target="_blank">http://www.amd.com</a><br>
> Libre software enthusiast          |                Mesa and X developer<br>
<br>
<br>
</div>Well, first of all, the fact that Ian and Ken don't want to use it<br>
means that any plan to use LLVM for the Intel driver is dead in the<br>
water anyways - you can translate NIR into LLVM if you want, but for<br>
i965 we want to share optimizations between our 2 backends (FS and<br>
vec4) that we can't do today in GLSL IR so this is what we want to use<br>
for that, and since nobody else does anything with the core GLSL<br>
compiler except when they have to, when we start moving things out of<br>
GLSL IR this will probably replace GLSL IR as the infrastructure that<br>
all Mesa drivers use. But with that in mind, here are a few reasons<br>
why we wouldn't want to use LLVM:<br>
<br>
* LLVM wasn't built to understand structured CFG's, meaning that you<br>
need to re-structurize it using a pass that's fragile and prone to<br>
break if some other pass "optimizes" the shader in a way that makes it<br>
non-structured (i.e. not expressible in terms of loops and if<br>
statements). This loss of information also means that passes that need<br>
to know things like, for example, the loop nesting depth need to do an<br>
analysis pass whereas with NIR you can just walk up the control flow<br>
tree and count the number of loops we hit.<br>
<br>
* LLVM doesn't do modifiers, meaning that we can't do optimizations<br>
like "clamp(x, 0.0, 1.0) => mov.sat x" and "clamp(x, 0.25, 1.0) =><br>
max.sat(x, .25)" in a generic fashion.<br>
<br>
* LLVM is hard to embed into other projects, especially if it's used<br>
as anything but a command-line tool that only runs once. See, for<br>
example, <a href="http://blog.llvm.org/2014/07/ftl-webkits-llvm-based-jit.html" target="_blank">http://blog.llvm.org/2014/07/ftl-webkits-llvm-based-jit.html</a><br>
under "Linking WebKit with LLVM" - most of those problems would also<br>
apply to us.<br>
<br>
* LLVM is on a different release schedule (6 months vs. 3 months), has<br>
a different review process, etc., which means that to add support for<br>
new functionality that involves shaders, we now have to submit patches<br>
to two separate projects, and then 2 months later when we ship Mesa it<br>
turns out that nobody can actually use the new feature because it<br>
depends upon an unreleased version of LLVM that won't be released for<br>
another 3 months and then packaged by distros even later... we've<br>
already had problems where distros refused to ship newer Mesa releases<br>
because radeon depended on a version of LLVM newer than the one they<br>
were shipping, and if we started using LLVM in core Mesa it would get<br>
even worse. Proprietary drivers solve this problem by just forking<br>
LLVM, building it with the rest of their driver, and linking it in as<br>
a static library, but distro packagers would hate us if we did that.<br>
<br>
I wouldn't completely rule out LLVM, and I do think they do a lot of<br>
things right, but for now it seems like it's not the path that the<br>
Intel team wants to take.<br>
<span class="HOEnZb"><font color="#888888"><br>
Connor<br>
</font></span><div class="HOEnZb"><div class="h5">_______________________________________________<br>
mesa-dev mailing list<br>
<a href="mailto:mesa-dev@lists.freedesktop.org">mesa-dev@lists.freedesktop.org</a><br>
<a href="http://lists.freedesktop.org/mailman/listinfo/mesa-dev" target="_blank">http://lists.freedesktop.org/mailman/listinfo/mesa-dev</a><br>
</div></div></blockquote></div><br></div>