<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Fri, Jul 21, 2017 at 11:29 AM, Pohjolainen, Topi <span dir="ltr"><<a href="mailto:topi.pohjolainen@gmail.com" target="_blank">topi.pohjolainen@gmail.com</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 Fri, Jul 21, 2017 at 11:09:47AM -0700, Jason Ekstrand wrote:<br>
> s/Aling/Align/<br>
><br>
> On Fri, Jul 21, 2017 at 8:00 AM, Topi Pohjolainen <<br>
> <a href="mailto:topi.pohjolainen@gmail.com">topi.pohjolainen@gmail.com</a>> wrote:<br>
><br>
> > in order to support blit engine.<br>
> ><br>
> > Signed-off-by: Topi Pohjolainen <<a href="mailto:topi.pohjolainen@intel.com">topi.pohjolainen@intel.com</a>><br>
> > ---<br>
> >  src/intel/isl/isl.c | 16 +++++++++++++++-<br>
> >  1 file changed, 15 insertions(+), 1 deletion(-)<br>
> ><br>
> > diff --git a/src/intel/isl/isl.c b/src/intel/isl/isl.c<br>
> > index 4393088409..90a8be2c58 100644<br>
> > --- a/src/intel/isl/isl.c<br>
> > +++ b/src/intel/isl/isl.c<br>
> > @@ -1268,9 +1268,23 @@ isl_calc_row_pitch(const struct isl_device *dev,<br>
> >                     const struct isl_extent2d *phys_total_el,<br>
> >                     uint32_t *out_row_pitch)<br>
> >  {<br>
> > -   const uint32_t alignment =<br>
> > +   uint32_t alignment =<br>
> >        isl_calc_row_pitch_alignment(<wbr>surf_info, tile_info);<br>
> ><br>
> > +   /* If pitch isn't given and it can be chosen freely, align it by cache<br>
> > line<br>
> > +    * allowing one to use blit engine on the surface.<br>
> > +    */<br>
> > +   if (surf_info->row_pitch == 0 && tile_info->tiling ==<br>
> > ISL_TILING_LINEAR) {<br>
> > +      /* From the Broadwell PRM docs for XY_SRC_COPY_BLT::<br>
> > SourceBaseAddress:<br>
> > +       *<br>
> > +       *    "Base address of the destination surface: X=0, Y=0. Lower<br>
> > 32bits<br>
> > +       *    of the 48bit addressing. When Src Tiling is enabled (Bit_15<br>
> > +       *    enabled), this address must be 4KB-aligned. When Tiling is not<br>
> > +       *    enabled, this address should be CL (64byte) aligned."<br>
> > +       */<br>
> > +      alignment = MAX2(alignment, 64);<br>
> > +   }<br>
> ><br>
><br>
> I think we want this to be part of isl_calc_row_pitch_alignment<br>
<br>
</div></div>In that case we need to add out_row_pitch as argument so that it can omit<br>
the alignment restriction for already given pitch. In i965 we get buffers that<br>
don't align by 64.<br></blockquote><div><br></div><div>Then those buffers are broken... maybe?  I think we do have breakage in here somewhere but it's not where I thought.  Looking at the docs harder, it appears that only the base address has the 64-byte alignment requirement but the row pitch does not.  In this case, we should be able to just drop this alignment stuff altogether and maybe do something with the alignment field.  However, my gut tells me that this will probably break something somewhere.  We have code in intel_blit.c for handling this for some operations but probably not all.  I think the correct solution is to fix intel_blit.c to just not need the restriction.  Until then, this is probably ok. :(<br><br></div><div>I'd like to see something added to the comment along those lines.  Also, please add cleaning this up to your TODO list if it isn't already there.<br></div><div><br></div><div>Reviewed-by: Jason Ekstrand <<a href="mailto:jason@jlekstrand.net">jason@jlekstrand.net</a>><br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
I had it originally in isl_calc_row_pitch_alignment() but decided it<br>
would be cleaner in isl_calc_row_pitch() due to the special case.<br>
<div class="HOEnZb"><div class="h5"><br>
><br>
> Also, eventually, I'd like us to add an ISL_SURF_USAGE_BLIT_BIT and key<br>
> this as well as the row pitch too large fallback in patch 3 to it.  When we<br>
> go to implement GL_EXT_external_objects, any of these sorts of things which<br>
> apply on gen7+ will have to be in ISL because we need to guarantee that<br>
> Vulkan and GL have the same fallbacks at least for external things.  For<br>
> external, Vulkan will have to set the ISL_SURF_USAGE_BLIT_BIT for this<br>
> reason.<br>
><br>
> --Jason<br>
><br>
><br>
> > +<br>
> >     const uint32_t min_row_pitch =<br>
> >        isl_calc_min_row_pitch(dev, surf_info, tile_info, phys_total_el,<br>
> >                               alignment);<br>
> > --<br>
> > 2.11.0<br>
> ><br>
> > ______________________________<wbr>_________________<br>
> > mesa-dev mailing list<br>
> > <a href="mailto:mesa-dev@lists.freedesktop.org">mesa-dev@lists.freedesktop.org</a><br>
> > <a href="https://lists.freedesktop.org/mailman/listinfo/mesa-dev" rel="noreferrer" target="_blank">https://lists.freedesktop.org/<wbr>mailman/listinfo/mesa-dev</a><br>
> ><br>
</div></div></blockquote></div><br></div></div>