[Mesa-dev] Merge of glsl2 branch to master
Keith Whitwell
keithw at vmware.com
Wed Aug 11 08:09:47 PDT 2010
On Tue, 2010-08-10 at 12:43 -0700, Ian Romanick wrote:
> -----BEGIN PGP SIGNED MESSAGE-----
> Hash: SHA1
>
> Keith Whitwell wrote:
> > On Mon, 2010-08-09 at 23:48 -0700, Eric Anholt wrote:
> >> The previous compiler called _mesa_remove_output_reads unconditionally,
> >> while the new compiler doesn't. This should be left up to the backend
> >> in my opinion, so perhaps a little flag like Shader.EmitNoIfs and
> >> friends for r300g to set for now to call this for the Mesa IR generation
> >> would be a good solution.
> >
> > It seems like this represents a change in the semantics of the mesa
> > driver interface -- previously mesa had the (perhaps implicit) rule that
> > OUT registers were write-only. The glsl2 branch appears not to be
> > respecting that.
> >
> > I don't really mind this as a follow-on change, but it seems like it
> > would be cleaner to keep the glsl2 merge as purely a change on one side
> > of the interface, not one which requires a change to drivers or the
> > interface itself.
>
> I has always thought that ARB_vp/fp allowed this, but it seems that I
> was wrong. I see two options two resolve this:
>
> 1. Always generate duplicate writes to shadow copies of shader outputs.
> Generate all reads from the shadow copies. Rely on the optimizer to
> remove the dead writes.
>
> 2. Add a lowering pass that inserts the shadow copies only for the
> shader outputs that are actually read.
> I'm leaning towards option #2 for a couple reasons. I suspect that the
> optimizer may not eliminate some of the extra writes. Option #2 also
> allows backends that don't need the shadow copies (i.e., i965) to skip
> the extra pass.
>
> On the flip side, I think option #1 may be easier to implement.
I think either is fine - it really just boils down to satisfying the
constraint by whichever method is easiest.
> In either case, I've submitted a bug to track this issue. Someone
> should hack up a validator for Mesa IR and TGSI (like the ir_validate
> pass). I'm sure there other implicit, undocumented invariant
> assumptions sprinkled through the code. Catching deviations from those
> sooner rather than later is the winning plan.
This has been on my list for a while, Corbin's galahad layer is an ideal
place for it to live.
Keith
More information about the mesa-dev
mailing list