From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
To: Tomi Valkeinen <tomi.valkeinen@ti.com>
Cc: dri-devel@lists.freedesktop.org
Subject: Re: [PATCH v3 02/20] drm: omapdrm: fb: Use format information provided by the DRM core
Date: Mon, 12 Dec 2016 23:41:50 +0200 [thread overview]
Message-ID: <3470543.6RSVIumblC@avalon> (raw)
In-Reply-To: <41803d25-2ba2-e022-984f-c0d3653cec97@ti.com>
Hi Tomi,
On Tuesday 20 Sep 2016 15:47:57 Tomi Valkeinen wrote:
> On 19/09/16 15:27, Laurent Pinchart wrote:
> > The driver stores in a custom structure named format several pieces of
> > information about the format that are available in the DRM core. Remove
> > them and get the information from the DRM core instead.
> >
> > Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
> > ---
> >
> >
> > @@ -128,13 +122,13 @@ static const struct drm_framebuffer_funcs
> > omap_framebuffer_funcs = {
> > };
> >
> > static uint32_t get_linear_addr(struct plane *plane,
> > - const struct format *format, int n, int x, int y)
> > + const struct drm_format_info *format, int n, int x, int y)
> > {
> > uint32_t offset;
> >
> > - offset = plane->offset +
> > - (x * format->planes[n].stride_bpp) +
> > - (y * plane->pitch / format->planes[n].sub_y);
> > + offset = plane->offset
> > + + (x * format->cpp[n] / (n == 1 ? 1 : format->hsub))
> > + + (y * plane->pitch / (n == 1 ? 1 : format->vsub));
>
> n is the plane number? Shouldn't the above be (n == 0 ? 1 : format->hsub)?
Oops. I'll fix this.
> > @@ -413,28 +410,32 @@ struct drm_framebuffer *omap_framebuffer_init(struct
> > drm_device *dev,
> >
> > fb = &omap_fb->base;
> > omap_fb->format = format;
> > + omap_fb->dss_format = dss_format;
> >
> > mutex_init(&omap_fb->lock);
> >
> > - for (i = 0; i < n; i++) {
> > + for (i = 0; i < format->num_planes; i++) {
> > struct plane *plane = &omap_fb->planes[i];
> > - int size, pitch = mode_cmd->pitches[i];
> > + unsigned int pitch = mode_cmd->pitches[i];
> > + unsigned int hsub = i == 0 ? 1 : format->hsub;
> > + unsigned int vsub = i == 0 ? 1 : format->vsub;
>
> This makes me wonder... Will all drivers do something like the above?
> It's a bit laborious way to get the pixel subsampling factor, and I
> presume something like above is quite common so that all the
> calculations can be more generic (and not specific to a UV plane).
Helper functions could be useful. That would require auditing drivers to
locate common code patterns, and I'm afraid I don't have time to do so at the
moment. Patches are of course welcome ;-)
Some of this code can also be removed as the DRM core performs checks in
framebuffer_check() too. I'll add a patch to fix that.
--
Regards,
Laurent Pinchart
_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel
next prev parent reply other threads:[~2016-12-12 21:41 UTC|newest]
Thread overview: 46+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-09-19 12:27 [PATCH v3 00/20] OMAP DRM fixes and improvements Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 01/20] drm: omapdrm: fb: Limit number of planes per framebuffer to two Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 02/20] drm: omapdrm: fb: Use format information provided by the DRM core Laurent Pinchart
2016-09-20 12:47 ` Tomi Valkeinen
2016-12-12 21:41 ` Laurent Pinchart [this message]
2016-09-19 12:27 ` [PATCH v3 03/20] drm: omapdrm: fb: Simplify objects lookup when creating framebuffer Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 04/20] drm: omapdrm: fb: Simplify mode command checks " Laurent Pinchart
2016-09-20 12:55 ` Tomi Valkeinen
2016-09-19 12:27 ` [PATCH v3 05/20] drm: omapdrm: fb: Turn framebuffer creation error messages into debug Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 06/20] drm: omapdrm: Handle FIFO underflow IRQs internally Laurent Pinchart
2016-09-20 13:17 ` Tomi Valkeinen
2016-09-20 13:27 ` Tomi Valkeinen
2016-12-12 21:59 ` Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 07/20] drm: omapdrm: Handle CRTC error IRQs directly Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 08/20] drm: omapdrm: Handle OCP error IRQ directly Laurent Pinchart
2016-09-20 13:34 ` Tomi Valkeinen
2016-12-12 22:09 ` Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 09/20] drm: omapdrm: Replace DSS manager state check with omapdrm CRTC state Laurent Pinchart
2016-09-20 13:44 ` Tomi Valkeinen
2016-12-12 22:16 ` Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 10/20] drm: omapdrm: Only commit planes on active CRTCs Laurent Pinchart
2016-09-20 13:51 ` Tomi Valkeinen
2016-12-12 22:53 ` Laurent Pinchart
2016-12-13 7:58 ` Tomi Valkeinen
2016-12-13 13:12 ` Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 11/20] drm: omapdrm: Check DSS manager state in the enable/disable helpers Laurent Pinchart
2016-09-20 13:57 ` Tomi Valkeinen
2016-12-12 23:07 ` Laurent Pinchart
2016-12-13 8:15 ` Tomi Valkeinen
2016-12-13 23:56 ` Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 12/20] drm: omapdrm: Prevent processing the same event multiple times Laurent Pinchart
2016-09-27 12:24 ` Tomi Valkeinen
2016-12-12 10:29 ` Laurent Pinchart
2016-09-27 15:05 ` Daniel Kurtz
2016-12-12 10:21 ` Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 13/20] drm: omapdrm: Use a spinlock to protect the CRTC pending flag Laurent Pinchart
2016-09-27 12:27 ` Tomi Valkeinen
2016-09-19 12:27 ` [PATCH v3 14/20] drm: omapdrm: Keep vblank interrupt enabled while CRTC is active Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 15/20] drm: omapdrm: Don't expose the omap_irq_(un)register() functions Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 16/20] drm: omapdrm: Remove unused parameter from omap_drm_irq handler Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 17/20] drm: omapdrm: Don't call DISPC power handling in IRQ wait functions Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 18/20] drm: omapdrm: Make pipe2vbl function static Laurent Pinchart
2016-12-12 10:41 ` Tomi Valkeinen
2016-12-12 23:17 ` Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 19/20] drm: omapdrm: Simplify IRQ wait implementation Laurent Pinchart
2016-09-19 12:27 ` [PATCH v3 20/20] drm: omapdrm: Remove global variables Laurent Pinchart
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=3470543.6RSVIumblC@avalon \
--to=laurent.pinchart@ideasonboard.com \
--cc=dri-devel@lists.freedesktop.org \
--cc=tomi.valkeinen@ti.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.