<div dir="ltr"><div>The way shader variants work in st/mesa is that NIR is generated, finalized, and stored in the cache. This helps the most common case when there is only one variant. If shader variants make changes to NIR, like adding samplers, uniforms, and inputs, it needs to be finalized again, which means many passes have to be run again.</div><div><br></div><div>Marek<br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Mon, Nov 25, 2019 at 1:29 PM Kenneth Graunke <<a href="mailto:kenneth@whitecape.org">kenneth@whitecape.org</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">Yeah...I thought the drawpixels lowering set up samplers directly with<br>
explicit bindings.  There should be no need to call it twice.<br>
<br>
We can't handle setting textures_used in nir_shader_gather_info because<br>
that is called both before and after lowering, and some of the<br>
information needed is no longer available on subsequent iterations.<br>
I moved it to gl_nir_lower_samplers_as_deref so it would happen once<br>
when all of the information was still present; lowering passes would<br>
patch it up as needed.<br>
<br>
Maybe the second call got introduced when making the finalize_nir()<br>
hook, and it isn't actually needed?  (I haven't done the archaeology<br>
yet...)<br>
<br>
On Monday, November 25, 2019 2:24:55 AM PST Connor Abbott wrote:<br>
> Why are you calling gl_nir_lower_samplers_as_deref twice? The entire<br>
> point of it is to deal with the crazy legacy GL model where samplers<br>
> are "just normal uniforms" that can be embedded in structs and calling<br>
> glUniform() can update the sampler binding. It doesn't touch samplers<br>
> with an explicit binding at all. It does set nir->info.textures_used,<br>
> but that's a small part of what it does. So while you certainly could<br>
> make it re-entrant, it really wouldn't make any sense to call it twice<br>
> as it isn't necessary for any mesa-internal samplers besides the<br>
> (trivial) updating textures_used. So I'd say that the best course of<br>
> action is to just update nir->info.textures_used by yourself in the<br>
> drawpix lowering pass and not call gl_nir_lower_samplers_as_deref.<br>
> Maybe longer-term the solution is to fill that out in nir_gather_info?<br>
> <br>
> Connor<br>
> <br>
> On Mon, Nov 25, 2019 at 6:56 AM Dave Airlie <<a href="mailto:airlied@gmail.com" target="_blank">airlied@gmail.com</a>> wrote:<br>
> ><br>
> > I was asked to use some newer radeonsi code in my tgsi info gathering<br>
> > wrapper for NIR. One of the things it does is use<br>
> > nir->info.textures_used.<br>
> ><br>
> > Now with the piglit test draw-pixel-with-texture there is a reentrancy<br>
> > issue with the passes.<br>
> ><br>
> > We create a shader and gl_nir_lower_samplers_as_deref get called on<br>
> > it, this sets nir->info.textures_used to 1, and it also lowers all<br>
> > texture derefs in the shader.<br>
> ><br>
> > The shader gets used in a variant later for drawpixels, the drawpixels<br>
> > lowering then adds it's own "drawpix" sampler an accesses it with<br>
> > derefs. Then gl_nir_lower_samplers_as_deref gets called again for the<br>
> > whole shader in finalisation, but this time the first set of derefs<br>
> > have already been lowered so it only lowers the new drawpix ones, and<br>
> > sets nir->info.textures_used to 2 (it's a bitfield), it should be 3.<br>
> ><br>
> > Are the other drivers seeing this? any ideas on what needs to be<br>
> > fixed, the nir sampler lowering could I suppose record<br>
> > nir->info.textures_used for non-deref textures as well.<br>
> ><br>
> > Dave.<br>
> <br>
<br>
</blockquote></div>