[PATCH 1/2] drm: Don't allow page flip to change pixel format
Jesse Barnes
jbarnes at virtuousgeek.org
Mon Jun 4 13:46:32 PDT 2012
That's probably safest, however on Intel we can change the stride and
tiling format for sync flips at least. But I'm ok with this patch; we
generally need to recalculate bw requirements and watermarks when
adjusting depth and such.
On Thu, 31 May 2012 15:54:03 -0400
Alex Deucher <alexdeucher at gmail.com> wrote:
> On Thu, May 31, 2012 at 3:44 PM, Singh, Satyeshwar
> <satyeshwar.singh at intel.com> wrote:
> > Does this by extension mean that stride changes should also not be allowed while page flipping?
>
> Everything beyond a crtc base address change should require a full modeset.
>
> Alex
>
> > Thanks,
> > Satyeshwar
> >
> > -----Original Message-----
> > From: dri-devel-bounces+satyeshwar.singh=intel.com at lists.freedesktop.org [mailto:dri-devel-bounces+satyeshwar.singh=intel.com at lists.freedesktop.org] On Behalf Of Laurent Pinchart
> > Sent: Thursday, May 31, 2012 9:26 AM
> > To: dri-devel at lists.freedesktop.org
> > Subject: [PATCH 1/2] drm: Don't allow page flip to change pixel format
> >
> > A page flip is not a mode set, changing the frame buffer pixel format doesn't make sense and isn't handled by most drivers anyway. Disallow it.
> >
> > Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
> > ---
> > drivers/gpu/drm/drm_crtc.c | 8 ++++++++
> > 1 files changed, 8 insertions(+), 0 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/drm_crtc.c b/drivers/gpu/drm/drm_crtc.c index 92cea9d..0d15b56 100644
> > --- a/drivers/gpu/drm/drm_crtc.c
> > +++ b/drivers/gpu/drm/drm_crtc.c
> > @@ -3530,6 +3530,14 @@ int drm_mode_page_flip_ioctl(struct drm_device *dev,
> > goto out;
> > }
> >
> > + if (crtc->fb->pixel_format != fb->pixel_format ||
> > + crtc->fb->bits_per_pixel != crtc->fb->bits_per_pixel ||
> > + crtc->fb->depth != fb->depth) {
> > + DRM_DEBUG_KMS("Page flip is not allowed to change frame buffer format.\n");
> > + ret = -EINVAL;
> > + goto out;
> > + }
> > +
> > if (page_flip->flags & DRM_MODE_PAGE_FLIP_EVENT) {
> > ret = -ENOMEM;
> > spin_lock_irqsave(&dev->event_lock, flags);
> > --
> > 1.7.3.4
> >
> > _______________________________________________
> > dri-devel mailing list
> > dri-devel at lists.freedesktop.org
> > http://lists.freedesktop.org/mailman/listinfo/dri-devel
> > _______________________________________________
> > dri-devel mailing list
> > dri-devel at lists.freedesktop.org
> > http://lists.freedesktop.org/mailman/listinfo/dri-devel
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/dri-devel
>
--
Jesse Barnes, Intel Open Source Technology Center
More information about the dri-devel
mailing list