From: "Pandiyan, Dhinakaran" <dhinakaran.pandiyan@intel.com>
To: "Roper, Matthew D" <matthew.d.roper@intel.com>
Cc: "intel-gfx@lists.freedesktop.org" <intel-gfx@lists.freedesktop.org>
Subject: Re: [RFC v3 3/9] drm/i915: Move CCS stride alignment W/A inside intel_fb_stride_alignment
Date: Thu, 3 Oct 2019 21:29:05 +0000 [thread overview]
Message-ID: <d586d0de00a46f2bdeaa2af89f39102c8a101f5b.camel@intel.com> (raw)
In-Reply-To: <20191002222944.GM1869@mdroper-desk1.amr.corp.intel.com>
On Wed, 2019-10-02 at 15:29 -0700, Matt Roper wrote:
> On Mon, Sep 23, 2019 at 03:29:29AM -0700, Dhinakaran Pandiyan wrote:
> > Easier to read if all the alignment changes are in one place and contained
> > within a function.
> >
> > Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
> > Cc: Matt Roper <matthew.d.roper@intel.com>
> > Signed-off-by: Dhinakaran Pandiyan <dhinakaran.pandiyan@intel.com>
> > ---
> > drivers/gpu/drm/i915/display/intel_display.c | 31 ++++++++++----------
> > 1 file changed, 16 insertions(+), 15 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/i915/display/intel_display.c
> > b/drivers/gpu/drm/i915/display/intel_display.c
> > index a94d145dd048..c437f00c2072 100644
> > --- a/drivers/gpu/drm/i915/display/intel_display.c
> > +++ b/drivers/gpu/drm/i915/display/intel_display.c
> > @@ -2551,7 +2551,22 @@ intel_fb_stride_alignment(const struct drm_framebuffer *fb, int
> > color_plane)
> > else
> > return 64;
> > } else {
> > - return intel_tile_width_bytes(fb, color_plane);
> > + u32 tile_width = intel_tile_width_bytes(fb, color_plane);
> > +
> > + /*
> > + * Display WA #0531: skl,bxt,kbl,glk
> > + *
> > + * Render decompression and plane width > 3840
> > + * combined with horizontal panning requires the
> > + * plane stride to be a multiple of 4. We'll just
> > + * require the entire fb to accommodate that to avoid
> > + * potential runtime errors at plane configuration time.
> > + */
> > + if (IS_GEN(dev_priv, 9) && is_ccs_modifier(fb->modifier) &&
> > + color_plane == 0 && fb->width > 3840)
> > + tile_width *= 4;
>
> I realize you're only moving this, but I find this workaround
> description confusing since the wording is somewhat ambiguous as to
> whether it's expecting the plane stride to be a multiple of 4 bytes or 4
> tiles. On casual read, I think most people would assume that we're
> talking about bytes here. Only once you realize that the PLANE_STRIDE
> register itself gets programmed in units of tile width does the wording
> here become clear. Maybe we could clarify the comment while moving it?
I remember wanting to rewrite that comment for the exact reason, but forgot to do so. Thanks for the
review, I'll fix it.
>
> Also it might be slightly more clear to do a "return tile_width * 4"
> here instead of modifying tile_width since that's a bit more intuitive
> description of what we're trying to do.
>
> Either way,
>
> Reviewed-by: Matt Roper <matthew.d.roper@intel.com>
>
>
> Matt
>
>
> > +
> > + return tile_width;
> > }
> > }
> >
> > @@ -15705,20 +15720,6 @@ static int intel_framebuffer_init(struct intel_framebuffer *intel_fb,
> > }
> >
> > stride_alignment = intel_fb_stride_alignment(fb, i);
> > -
> > - /*
> > - * Display WA #0531: skl,bxt,kbl,glk
> > - *
> > - * Render decompression and plane width > 3840
> > - * combined with horizontal panning requires the
> > - * plane stride to be a multiple of 4. We'll just
> > - * require the entire fb to accommodate that to avoid
> > - * potential runtime errors at plane configuration time.
> > - */
> > - if (IS_GEN(dev_priv, 9) && i == 0 && fb->width > 3840 &&
> > - is_ccs_modifier(fb->modifier))
> > - stride_alignment *= 4;
> > -
> > if (fb->pitches[i] & (stride_alignment - 1)) {
> > DRM_DEBUG_KMS("plane %d pitch (%d) must be at least %u byte aligned\n",
> > i, fb->pitches[i], stride_alignment);
> > --
> > 2.17.1
> >
>
>
_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx
next prev parent reply other threads:[~2019-10-03 21:29 UTC|newest]
Thread overview: 30+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-09-23 10:29 [RFC v3 0/9] Gen12 E2E compression Dhinakaran Pandiyan
2019-09-23 10:29 ` [RFC v3 1/9] drm/framebuffer: Format modifier for Intel Gen-12 render compression Dhinakaran Pandiyan
2019-09-23 10:29 ` [RFC v3 2/9] drm/i915: Use intel_tile_height() instead of re-implementing Dhinakaran Pandiyan
2019-10-02 22:29 ` Matt Roper
2019-09-23 10:29 ` [RFC v3 3/9] drm/i915: Move CCS stride alignment W/A inside intel_fb_stride_alignment Dhinakaran Pandiyan
2019-10-02 22:29 ` Matt Roper
2019-10-03 21:29 ` Pandiyan, Dhinakaran [this message]
2019-09-23 10:29 ` [RFC v3 4/9] drm/i915/tgl: Gen-12 render decompression Dhinakaran Pandiyan
2019-10-02 22:32 ` Matt Roper
2019-10-03 12:00 ` Ville Syrjälä
2019-09-23 10:29 ` [RFC v3 5/9] drm/i915: Extract framebufer CCS offset checks into a function Dhinakaran Pandiyan
2019-10-04 15:10 ` Ville Syrjälä
2019-10-04 20:33 ` Matt Roper
2019-09-23 10:29 ` [RFC v3 6/9] drm/framebuffer: Format modifier for Intel Gen-12 media compression Dhinakaran Pandiyan
2019-09-26 6:42 ` Pandiyan, Dhinakaran
2019-09-23 10:29 ` [RFC v3 7/9] drm/i915: Skip rotated offset adjustment for unsupported modifiers Dhinakaran Pandiyan
2019-10-03 21:18 ` Dhinakaran Pandiyan
2019-09-23 10:29 ` [RFC v3 8/9] drm/fb: Extend format_info member arrays to handle four planes Dhinakaran Pandiyan
2019-09-23 10:29 ` [RFC v3 9/9] Gen-12 display can decompress surfaces compressed by the media engine Dhinakaran Pandiyan
2019-09-26 10:55 ` [PATCH v4 " Dhinakaran Pandiyan
2019-10-04 15:36 ` Ville Syrjälä
2019-10-04 23:54 ` Dhinakaran Pandiyan
2019-10-04 20:27 ` Matt Roper
2019-10-04 23:20 ` Dhinakaran Pandiyan
2019-09-23 13:53 ` ✗ Fi.CI.CHECKPATCH: warning for Gen12 E2E compression Patchwork
2019-09-23 14:16 ` ✗ Fi.CI.BAT: failure " Patchwork
2019-09-26 11:01 ` ✗ Fi.CI.CHECKPATCH: warning for Gen12 E2E compression (rev2) Patchwork
2019-09-26 11:25 ` ✗ Fi.CI.BAT: failure " Patchwork
2019-10-10 10:14 ` ✗ Fi.CI.CHECKPATCH: warning for Gen12 E2E compression (rev3) Patchwork
2019-10-10 10:39 ` ✗ Fi.CI.BAT: failure " Patchwork
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=d586d0de00a46f2bdeaa2af89f39102c8a101f5b.camel@intel.com \
--to=dhinakaran.pandiyan@intel.com \
--cc=intel-gfx@lists.freedesktop.org \
--cc=matthew.d.roper@intel.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.