[Mesa-dev] [Mesa-stable] [PATCH] meta: Fix BlitFramebuffer temp texture setup

Juan A. Suarez Romero jasuarez at igalia.com
Tue Sep 26 16:49:36 UTC 2017


On Tue, 2017-07-11 at 15:42 +0300, Ville Syrjälä wrote:
> On Mon, Jul 10, 2017 at 11:42:18PM +0300, Andres Gomez wrote:
> > Ville, has this patch fallen through the cracks ?
> 
> Nope. I've still been looking into the issue whenever I've had a
> few minutes to spare. I think I have it more or les figured out
> at this stage, but I'll need to respin this patch, and clean up
> some further patches to fix this stuff properly for i915.
> 

Any news on this patch?

	J.A.

> > 
> > On Fri, 2017-06-23 at 14:58 +0300, ville.syrjala at linux.intel.com wrote:
> > > From: Ville Syrjälä <ville.syrjala at linux.intel.com>
> > > 
> > > Pass the correct src coordinates to CopyTexSubImage()
> > > when creating the temporary texture, and also take care to adjust
> > > flipX/Y if the original src coordinates were flipped compared to
> > > the new temporary texture src coordinates.
> > > 
> > > This fixes all the flip_src_x/y tests in
> > > piglit.spec.arb_framebuffer_object.fbo-blit-stretch on i915, but
> > > we're still left with the some failures in the stretch tests.
> > > 
> > > It looks to me like commit b702233f53d6 ("meta: Refactor the
> > > BlitFramebuffer color CopyTexImage fallback.") most likely
> > > broke this codepath.
> > > 
> > > Cc: mesa-stable at lists.freedesktop.org
> > > Cc: Eric Anholt <eric at anholt.net>
> > > Cc: Kenneth Graunke <kenneth at whitecape.org>
> > > Cc: Ian Romanick <ian.d.romanick at intel.com>
> > > Cc: Anuj Phogat <anuj.phogat at gmail.com>
> > > Fixes: b702233f53d6 ("meta: Refactor the BlitFramebuffer color CopyTexImage fallback.")
> > > References: https://bugs.freedesktop.org/show_bug.cgi?id=101414
> > > Signed-off-by: Ville Syrjälä <ville.syrjala at linux.intel.com>
> > > ---
> > >  src/mesa/drivers/common/meta_blit.c | 8 ++++++--
> > >  1 file changed, 6 insertions(+), 2 deletions(-)
> > > 
> > > diff --git a/src/mesa/drivers/common/meta_blit.c b/src/mesa/drivers/common/meta_blit.c
> > > index 7adad469aceb..7262ecdfaf13 100644
> > > --- a/src/mesa/drivers/common/meta_blit.c
> > > +++ b/src/mesa/drivers/common/meta_blit.c
> > > @@ -680,12 +680,16 @@ blitframebuffer_texture(struct gl_context *ctx,
> > >        }
> > >  
> > >        _mesa_meta_setup_copypix_texture(ctx, meta_temp_texture,
> > > -                                       srcX0, srcY0,
> > > +                                       MIN2(srcX0, srcX1),
> > > +                                       MIN2(srcY0, srcY1),
> > >                                         srcW, srcH,
> > >                                         tex_base_format,
> > >                                         filter);
> > >  
> > > -
> > > +      if (srcX0 > srcX1)
> > > +         flipX = -flipX;
> > > +      if (srcY0 > srcY1)
> > > +         flipY = -flipY;
> > >        srcX0 = 0;
> > >        srcY0 = 0;
> > >        srcX1 = srcW;
> > 
> > -- 
> > Br,
> > 
> > Andres
> 
> 


More information about the mesa-dev mailing list