<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Thu, May 11, 2017 at 9:08 PM, Chad Versace <span dir="ltr"><<a href="mailto:chadversary@chromium.org" target="_blank">chadversary@chromium.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="HOEnZb"><div class="h5">On Thu 11 May 2017, Jason Ekstrand wrote:<br>
> On Thu, May 11, 2017 at 7:03 AM, Pohjolainen, Topi <<br>
> <a href="mailto:topi.pohjolainen@gmail.com">topi.pohjolainen@gmail.com</a>> wrote:<br>
><br>
> > On Wed, May 10, 2017 at 02:30:31PM -0700, Jason Ekstrand wrote:<br>
> > > ---<br>
> > >  src/intel/isl/isl_gen6.c | 30 ++++++++++++------------------<br>
> > >  1 file changed, 12 insertions(+), 18 deletions(-)<br>
> > ><br>
> > > diff --git a/src/intel/isl/isl_gen6.c b/src/intel/isl/isl_gen6.c<br>
> > > index b746903..0de9620 100644<br>
> > > --- a/src/intel/isl/isl_gen6.c<br>
> > > +++ b/src/intel/isl/isl_gen6.c<br>
> > > @@ -88,6 +88,8 @@ isl_gen6_choose_image_<wbr>alignment_el(const struct<br>
> > isl_device *dev,<br>
> > >      *    | format                 | halign | valign |<br>
> > >      *    +------------------------+----<wbr>----+--------+<br>
> > >      *    | YUV 4:2:2 formats      |      4 |      * |<br>
> > > +    *    | BC1-5                  |      4 |      4 |<br>
> > > +    *    | FXT1                   |      8 |      4 |<br>
> > >      *    | uncompressed formats   |      4 |      * |<br>
> > >      *    +------------------------+----<wbr>----+--------+<br>
> > >      *<br>
> > > @@ -110,29 +112,13 @@ isl_gen6_choose_image_<wbr>alignment_el(const struct<br>
> > isl_device *dev,<br>
> > >      */<br>
> > ><br>
> > >     if (isl_format_is_compressed(<wbr>info->format)) {<br>
> > > +      /* Compressed formats have an alignment equal to their block size<br>
> > */<br>
> > >        *image_align_el = isl_extent3d(1, 1, 1);<br>
> > >        return;<br>
> > >     }<br>
> > ><br>
> > > -   if (isl_format_is_yuv(info-><wbr>format)) {<br>
> > > -      *image_align_el = isl_extent3d(4, 2, 1);<br>
> > > -      return;<br>
> > > -   }<br>
> > > -<br>
> > > -   if (info->samples > 1) {<br>
> > > -      *image_align_el = isl_extent3d(4, 4, 1);<br>
> > > -      return;<br>
> > > -   }<br>
> > > -<br>
> > > -   if (isl_surf_usage_is_depth_or_<wbr>stencil(info->usage) &&<br>
> > > -       !ISL_DEV_USE_SEPARATE_STENCIL(<wbr>dev)) {<br>
> ><br>
> > Maybe mention in the commit that we drop this as it is always false on<br>
> > gen6+?<br>
> > In isl.c: "dev->use_separate_stencil = ISL_DEV_GEN(dev) >= 6;"<br>
> ><br>
><br>
> No, I dropped it not because we always use separate stencil but because<br>
> it's redundant with the regular depth case.  The PRM says to use a 4x4<br>
> alignment for all depth buffers but 4x2 for separate stencil.  Combined<br>
> depth-stencil falls under the "depth" case so I didn't think we needed to<br>
> call it out explicitly.<br>
<br>
</div></div>I admit that the condition I wrote<br>
<br>
        if (isl_surf_usage_is_depth_or_<wbr>stencil(info->usage) &&<br>
            !ISL_DEV_USE_SEPARATE_STENCIL(<wbr>dev))<br>
<br>
was poorly chosen. I should've written it without relying on<br>
ISL_DEV_USE_SEPARATE_STENCIL.<br>
<br>
Topi has a point because a surface with<br>
format=ISL_FORMAT_X24_<wbr>TYPELESS_G8_UINT will necessarily have<br>
usage=ISL_SURF_USAGE_STENCIL_<wbr>BIT (no depth bit). The hardware requires<br>
the surface to have valign=4, and my badly written (but correct)<br>
condition ensured valign=4 in this case. After this patch, the function<br>
wrongly chooses valign=2.<br></blockquote><div><br></div><div>No it won't.  It's hard to see in patch form, but after this patch is applied we check for depth first and then stencil.  If it has ANY depth component, then it will get 4x4 aligned.  Only separate stencil gets 4x2.<br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
I suggest either<br>
<br>
    a. Asserting that separate stencil is true in the neighborhood of<br>
<br>
        if (isl_surf_usage_is_depth(info-<wbr>>usage)) {<br>
<span class="">            /* depth buffer (possibly interleaved with stencil) */<br>
            *image_align_el = isl_extent3d(4, 4, 1);<br>
            return;<br>
        }<br>
<br>
</span>      and dropping the reference to possible interleaved stencil.<br>
<br>
    b. Or, better, rewrite the original logic to be clearer.<br>
<br>
        if ((info->usage & ISL_SURF_USAGE_STENCIL_BIT)<br>
            && info->format == ISL_FORMAT_R8_UINT) {<br>
            /* separate stencil surface */<br>
<span class="">            *image_align_el = isl_extent3d(4, 2, 1);<br>
</span>            return;<br>
        }<br>
<br>
        if (info->usage & (ISL_SURF_USAGE_DEPTH_BIT | ISL_SURF_USAGE_STENCIL_BIT))<br>
            /* separate depth surface or interleaved depthstencil */<br>
<div><div class="h5">            *image_align_el = isl_extent3d(4, 4, 1);<br>
            return;<br>
        }<br>
<br>
> > Other than that:<br>
> ><br>
> > Reviewed-by: Topi Pohjolainen <<a href="mailto:topi.pohjolainen@intel.com">topi.pohjolainen@intel.com</a>><br>
> ><br>
> > > -      /* interleaved depthstencil buffer */<br>
> > > -      *image_align_el = isl_extent3d(4, 4, 1);<br>
> > > -      return;<br>
> > > -   }<br>
> > > -<br>
> > >     if (isl_surf_usage_is_depth(info-<wbr>>usage)) {<br>
> > > -      /* separate depth buffer */<br>
> > > +      /* depth buffer (possibly interleaved with stencil) */<br>
> > >        *image_align_el = isl_extent3d(4, 4, 1);<br>
> > >        return;<br>
> > >     }<br>
> > > @@ -143,5 +129,13 @@ isl_gen6_choose_image_<wbr>alignment_el(const struct<br>
> > isl_device *dev,<br>
> > >        return;<br>
> > >     }<br>
> > ><br>
> > > +   if (info->samples > 1) {<br>
> > > +      *image_align_el = isl_extent3d(4, 4, 1);<br>
> > > +      return;<br>
> > > +   }<br>
> > > +<br>
> > > +   /* For everything else, we can chose any vertical alignment we<br>
> > want.  We<br>
> > > +    * choose an alignment of 2 because it uses the least memory.<br>
> > > +    */<br>
> > >     *image_align_el = isl_extent3d(4, 2, 1);<br>
<br>
</div></div>The code is correct, but the comment is wrong. We cannot choose any<br>
valign we wish for the remaining cases. It is true that 2 is *valid* for<br>
all remaining cases, but it is also *required* for some of those cases,<br>
as explained in the big comment block above. Namely, all render target<br>
surfaces and also separate stencil require valign=2.<br>
</blockquote></div><br></div><div class="gmail_extra">Hrm... Ok, I'll try and come up with a better comment.<br></div></div>