<html>
    <head>
      <base href="https://bugs.freedesktop.org/" />
    </head>
    <body>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - Implement SSBOs in GLSL front-end and i965"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=89597#c37">Comment # 37</a>
              on <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - Implement SSBOs in GLSL front-end and i965"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=89597">bug 89597</a>
              from <span class="vcard"><a class="email" href="mailto:itoral@igalia.com" title="Iago Toral <itoral@igalia.com>"> <span class="fn">Iago Toral</span></a>
</span></b>
        <pre>(In reply to Iago Toral from <a href="show_bug.cgi?id=89597#c36">comment #36</a>)
<span class="quote">> (In reply to Kenneth Graunke from <a href="show_bug.cgi?id=89597#c35">comment #35</a>)
> > Is this on Gen7?  Does setting GEN7_PS_VECTOR_MASK_ENABLE in 3DSTATE_PS
> > DWord 2 help?  (Gen8+ already does this.)

> Yes, it is gen7. I've just tested this but it does not seem to have any
> effect in this case, the problem persists.</span >

As far as I can see, this issue spawns from the fact that atomic messages can
include a message header with pixel mask information while scattered read/write
messages (like many other read/write messages) can't, which can lead to some
inconsistencies when both are used together, something that I imagine being
common in SSBO usage patterns, unfortunately.

The PRMs clearly state that the pixel mask and the dispatch mask can be
different, which means that in these scenarios atomic operations will operate
on less channels (since the pixel mask is implicitly anded with the execution
mask) than our read/write messages, leading the inconsistent behavior I
explained in <a href="show_bug.cgi?id=89597#c34">comment #34</a>.

One way to work around this issue would be to fix the pixel mask in atomic
operations to always be 0xffff. Since the mask is anded with the dispatch mask
this should make atomic operations effectively use the dispatch mask and
operate on the same channels as our read/write messages. I have tested this
locally with a couple of examples and this seems to work, producing consistent
results.

Would this be an option?

If that is not a good idea, then I guess the alternative would be to do it the
other way around: fix the dispatch mask in the read/write messages to be like
the pixel mask we use in atomic operations, but I don't know if that is
possible.</pre>
        </div>
      </p>
      <hr>
      <span>You are receiving this mail because:</span>
      
      <ul>
          <li>You are the QA Contact for the bug.</li>
      </ul>
    </body>
</html>