<div dir="ltr"><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Jan 25, 2019 at 1:53 PM Stéphane Marchesin <<a href="mailto:stephane.marchesin@gmail.com">stephane.marchesin@gmail.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">On Fri, Jan 25, 2019 at 2:25 AM Gert Wollny <<a href="mailto:gw.fossdev@gmail.com" target="_blank">gw.fossdev@gmail.com</a>> wrote:<br>
><br>
> Am Donnerstag, den 24.01.2019, 22:25 -0800 schrieb Stéphane Marchesin:<br>
> ><br>
> > Yes, it's for running virgl on top of GLES. To emulate fp64 in GL on<br>
> > the guest side, we need fp64 on the host...<br>
><br>
> BTW: we could also get it emulated from the guest side. When Elie (in<br>
> CC)  initially proposed the fp64 emulation series it was for r600 and<br>
> TGSI was emitted. The created shaders are horribly long and it is<br>
> certainly not performant, but if it's just for getting OpenGL 4.0<br>
> exposed it should be good enough.<br>
<br>
Yes, Ilia suggested this on IRC yesterday. My impression is that not<br>
many applications/games need high performance fp64 (it's likely mostly<br>
compute stuff, which is not our target). I could be wrong though. If<br>
anyone knows differently, please tell us :)<br></blockquote><div><br></div><div>In our experience, we have yet to see an app actually use the extension.  If we do have such apps, it'd be better to do it in hardware when available.  However, if it's just so that you can claim support, maybe a GLES extension isn't worth the bother?  I don't have a particularly strong opinion at the moment beyond "fp64 sounds like the most non-ES thing ever".<br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
><br>
> I'm not sure though how much work it would be to add this to the soft<br>
> fp64 as it has now landed for NIR, though.<br>
<br>
Yes, with virgl not using NIR, I am not sure how much work soft fp64<br>
will require.<br></blockquote><div><br></div><div>The core of the soft fp64 stuff is a library of GLSL functions which actually implement it.  We just compile them to NIR and then lower fp64 math to function calls and inline.  You could write a lowering pass in GLSL, TGSI, or a back-end compiler based on those easily enough.</div><div><br></div><div>--Jason<br></div></div></div>