[Intel-gfx] [PATCH] drm/i915: Error out when trying to set a y-tiled as a sprite
Ville Syrjälä
ville.syrjala at linux.intel.com
Mon Oct 29 17:24:09 CET 2012
On Sun, Oct 28, 2012 at 10:04:54AM +0000, Chris Wilson wrote:
> On Fri, 26 Oct 2012 10:42:54 -0700, Jesse Barnes <jbarnes at virtuousgeek.org> wrote:
> > On Fri, 26 Oct 2012 18:30:50 +0100
> > Damien Lespiau <damien.lespiau at gmail.com> wrote:
> >
> > > From: Damien Lespiau <damien.lespiau at intel.com>
> > >
> > > Signed-off-by: Damien Lespiau <damien.lespiau at intel.com>
> > > ---
> > > drivers/gpu/drm/i915/intel_sprite.c | 5 +++++
> > > 1 file changed, 5 insertions(+)
> > >
> > > diff --git a/drivers/gpu/drm/i915/intel_sprite.c b/drivers/gpu/drm/i915/intel_sprite.c
> > > index 3434b6e..aa8d09b 100644
> > > --- a/drivers/gpu/drm/i915/intel_sprite.c
> > > +++ b/drivers/gpu/drm/i915/intel_sprite.c
> > > @@ -465,6 +465,11 @@ intel_update_plane(struct drm_plane *plane, struct drm_crtc *crtc,
> > > if (intel_plane->pipe != intel_crtc->pipe)
> > > return -EINVAL;
> > >
> > > + /* Sprite planes can be linear or x-tiled surfaces */
> > > + if (!(obj->tiling_mode == I915_TILING_NONE ||
> > > + obj->tiling_mode == I915_TILING_X))
> > > + return -EINVAL;
> > > +
> > > /*
> > > * Clamp the width & height into the visible area. Note we don't
> > > * try to scale the source if part of the visible region is offscreen.
> >
> > Do we not catch this when we make the fb? If not we may want to do
> > this there...
>
> We do. However, we don't catch userspace changing the tiling on an
> existing fb (unless actually pinned)...
Why not simply count how many fbs reference a given bo, and reject
tiling changes when the count > 0?
--
Ville Syrjälä
Intel OTC
More information about the Intel-gfx
mailing list