<html>
    <head>
      <base href="https://bugs.freedesktop.org/" />
    </head>
    <body>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW --- - vs-temp-array-mat3-index-col-rd test fails with SB"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=71944#c2">Comment # 2</a>
              on <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW --- - vs-temp-array-mat3-index-col-rd test fails with SB"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=71944">bug 71944</a>
              from <span class="vcard"><a class="email" href="mailto:ptpzz@yandex.ru" title="Vadim Girlin <ptpzz@yandex.ru>"> <span class="fn">Vadim Girlin</span></a>
</span></b>
        <pre>(In reply to <a href="show_bug.cgi?id=71944#c0">comment #0</a>)
<span class="quote">> If I revert that commit the test passes with SB, but I'm pretty sure that
> commit only exposed a bug that weren't hit before.</span >

Yes, I think you are right.

<span class="quote">> 
> I looked at the shader dumps and the only thing I found that looked a little
> strange was this.

> before: 7ae9cc71f097af5ae1f83f77f75de2198849faca
> z: SETE               T0.z,  R[2+AR].y, KC0[2].y
> w: SETE               T1.w,  R[2+AR].z, KC0[2].z
> x: SETE               T1.x,  R[2+AR].x, KC0[2].x

> after: 7ae9cc71f097af5ae1f83f77f75de2198849faca
> w: SETE_DX10          T0.w,  R[2+AR].z, KC0[2].z
> z: SETE_DX10          T0.z,  R[2+AR].y, KC0[2].y
> x: SETE_DX10          T1.x,  R[0+AR].x, KC0[2].x

> Is R[0+AR].x correct in the last line or should it be R[2+AR].x?</span >

It's not necessarily incorrect, IIRC components of the indirectly addressed
array are considered as separate arrays by sb, they are allocated independently
and may have different base GPR indices, e.g. yz components of the original
array may be stored in R2.yz-R10.yz (if R0.yz and/or R1.yz are used for
something else) and x component in R0.x-R8.x.

AFAICS the problem is here:

 0106      12      x: MOV                R1.x,  [0x40800000 4].x
 0108              y: MOV                R2.y,  [0x40000000 2].y
 0110              z: MUL                T0.z,  KC0[3].w, R1.x
 0112              w: MUL                T1.w,  KC0[3].z, R1.x
 0114  40800000 
 0115  40000000 
 0116      13      x: MOV                R0.x,  1.0
 0118              y: MUL                T0.y,  KC0[3].x, R1.x

Instruction 0106 writes 4 to R1.x, but instruction 0118 in the next group
expects old value in R1.x (the value that was in R1.x before 0106). So it looks
like scheduler failed to handle that data dependency correctly for some reason,
instruction 0118 should be scheduled in the same group as 0106 or earlier.

Please attach the output with R600_DEBUG=vs,sbdump</pre>
        </div>
      </p>
      <hr>
      <span>You are receiving this mail because:</span>
      
      <ul>
          <li>You are the assignee for the bug.</li>
      </ul>
    </body>
</html>