From: Rodrigo Vivi <rodrigo.vivi@intel.com>
To: Paulo Zanoni <paulo.r.zanoni@intel.com>
Cc: Jani Nikula <jani.nikula@intel.com>, intel-gfx@lists.freedesktop.org
Subject: Re: [PATCH 01/11] drm/i915: don't apply Display WAs 1125 and 1126 to GLK/CNL+
Date: Mon, 22 Oct 2018 16:55:11 -0700 [thread overview]
Message-ID: <20181022235511.GE5342@intel.com> (raw)
In-Reply-To: <1540251120.2734.39.camel@intel.com>
On Mon, Oct 22, 2018 at 04:32:00PM -0700, Paulo Zanoni wrote:
> Em Qui, 2018-10-18 às 16:14 +0300, Ville Syrjälä escreveu:
> > On Tue, Oct 16, 2018 at 03:01:23PM -0700, Paulo Zanoni wrote:
> > > BSpec does not show these WAs as applicable to GLK, and for CNL it
> > > only shows them applicable for a super early pre-production
> > > stepping
> > > we shouldn't be caring about anymore. Remove these so we can avoid
> > > them on ICL too.
> > >
> > > Cc: Matt Roper <matthew.d.roper@intel.com>
> > > Signed-off-by: Paulo Zanoni <paulo.r.zanoni@intel.com>
> > > ---
> > > drivers/gpu/drm/i915/intel_pm.c | 43 ++++++++++++++++++++++-------
> > > ------------
> > > 1 file changed, 23 insertions(+), 20 deletions(-)
> > >
> > > diff --git a/drivers/gpu/drm/i915/intel_pm.c
> > > b/drivers/gpu/drm/i915/intel_pm.c
> > > index 67a4d0735291..18157c6ee126 100644
> > > --- a/drivers/gpu/drm/i915/intel_pm.c
> > > +++ b/drivers/gpu/drm/i915/intel_pm.c
> > > @@ -4696,28 +4696,31 @@ static int skl_compute_plane_wm(const
> > > struct drm_i915_private *dev_priv,
> > > res_lines = div_round_up_fixed16(selected_result,
> > > wp-
> > > >plane_blocks_per_line);
> > >
> > > - /* Display WA #1125: skl,bxt,kbl,glk */
> > > - if (level == 0 && wp->rc_surface)
> > > - res_blocks += fixed16_to_u32_round_up(wp-
> > > >y_tile_minimum);
> > > + if (IS_GEN9(dev_priv) && !IS_GEMINILAKE(dev_priv)) {
> >
> > IS_GEN9_BC || IS_BXT
> >
> > would be a little easier to parse, me thinks.
>
> I can do that, but what I really want is "DISPLAY_GEN(dev_priv) == 9".
work in progress...
btw...
DISPLAY_GEN(dev_priv) == 9 or simply DISPLAY(dev_priv, 9) ?
I'm play around here with:
#define DISPLAY(dev_priv, g) (!!((dev_priv)->info.display_mask & BIT(g-1)))
#define DISPLAY_RANGE(dev_priv, s, e) \
(!!((dev_priv)->info.display_mask & INTEL_GEN_MASK((s), (e))))
thoughts? comments? ideas?
>
> /me looks at Rodrigo
>
> >
> > > + /* Display WA #1125: skl,bxt,kbl */
> > > + if (level == 0 && wp->rc_surface)
> > > + res_blocks +=
> > > + fixed16_to_u32_round_up(wp-
> > > >y_tile_minimum);
> > > +
> > > + /* Display WA #1126: skl,bxt,kbl */
> > > + if (level >= 1 && level <= 7) {
> > > + if (wp->y_tiled) {
> > > + res_blocks +=
> > > + fixed16_to_u32_round_up(wp-
> > > >y_tile_minimum);
> > > + res_lines += wp->y_min_scanlines;
> > > + } else {
> > > + res_blocks++;
> > > + }
> > >
> > > - /* Display WA #1126: skl,bxt,kbl,glk */
> > > - if (level >= 1 && level <= 7) {
> > > - if (wp->y_tiled) {
> > > - res_blocks += fixed16_to_u32_round_up(
> > > - wp-
> > > >y_tile_minimum);
> > > - res_lines += wp->y_min_scanlines;
> > > - } else {
> > > - res_blocks++;
> > > + /*
> > > + * Make sure result blocks for higher
> > > latency levels are
> > > + * atleast as high as level below the
> > > current level.
> > > + * Assumption in DDB algorithm
> > > optimization for special
> > > + * cases. Also covers Display WA #1125 for
> > > RC.
> > > + */
> > > + if (result_prev->plane_res_b > res_blocks)
> > > + res_blocks = result_prev-
> > > >plane_res_b;
> > > }
> > > -
> > > - /*
> > > - * Make sure result blocks for higher latency
> > > levels are atleast
> > > - * as high as level below the current level.
> > > - * Assumption in DDB algorithm optimization for
> > > special cases.
> > > - * Also covers Display WA #1125 for RC.
> > > - */
> > > - if (result_prev->plane_res_b > res_blocks)
> > > - res_blocks = result_prev->plane_res_b;
> >
> > This last thing is part of the glk+ watermark formula as well.
> > But
> > I'm not 100% convinced that it's needed.
>
> I simply can't find where this is documented. WAs 1125 and 1126, which
> contain text that match this code exactly, are not applicable to GLK.
> Which BSpec page and paragraph/section mentions this?
>
>
> > One might assume that the the
> > non-decrasing latency values guarantee that the resulting watermarks
> > are also non-decreasing. But I've not actually done the math to see
> > if
> > that's true.
> >
> > Hmm. It might not actually be true on account of the 'memory latency
> > microseconds >= line time microseconds' check when selecting which
> > method to use to calculate the watermark. Not quite sure which way
> > that would make things go.
> >
> > We also seem to be missing the res_lines handling here. But given
> > that we only did this for compressed fbs before I don't think this
> > patch is making things much worse by limiting this to pre-glk only.
> > The glk+ handling and res_lines fix could be done as a followup.
> >
> > Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
> >
> >
> > > }
> > >
> > > if (INTEL_GEN(dev_priv) >= 11) {
> > > --
> > > 2.14.4
> > >
> > > _______________________________________________
> > > Intel-gfx mailing list
> > > Intel-gfx@lists.freedesktop.org
> > > https://lists.freedesktop.org/mailman/listinfo/intel-gfx
> >
> >
_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx
next prev parent reply other threads:[~2018-10-22 23:55 UTC|newest]
Thread overview: 44+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-10-16 22:01 [PATCH 00/11] More watermarks improvements Paulo Zanoni
2018-10-16 22:01 ` [PATCH 01/11] drm/i915: don't apply Display WAs 1125 and 1126 to GLK/CNL+ Paulo Zanoni
2018-10-18 13:14 ` Ville Syrjälä
2018-10-22 23:32 ` Paulo Zanoni
2018-10-22 23:55 ` Rodrigo Vivi [this message]
2018-10-23 0:12 ` Paulo Zanoni
2018-10-23 0:18 ` Rodrigo Vivi
2018-10-23 7:30 ` Jani Nikula
2018-10-26 0:43 ` Rodrigo Vivi
2018-11-09 0:50 ` [PATCH] " Paulo Zanoni
2018-10-16 22:01 ` [PATCH 02/11] drm/i915: remove padding from struct skl_wm_level Paulo Zanoni
2018-10-16 23:00 ` Lucas De Marchi
2018-10-16 22:01 ` [PATCH 03/11] drm/i915: fix handling of invisible planes in watermarks code Paulo Zanoni
2018-10-18 13:28 ` Ville Syrjälä
2018-10-16 22:01 ` [PATCH 04/11] drm/i915: remove useless memset() for watermarks parameters Paulo Zanoni
2018-10-18 13:31 ` Ville Syrjälä
2018-10-16 22:01 ` [PATCH 05/11] drm/i915: simplify wm->is_planar assignment Paulo Zanoni
2018-10-18 13:34 ` Ville Syrjälä
2018-10-16 22:01 ` [PATCH 06/11] drm/i915: refactor skl_write_plane_wm() Paulo Zanoni
2018-10-18 13:36 ` Ville Syrjälä
2018-10-16 22:01 ` [PATCH 07/11] drm/i915: move ddb_blocks to be a watermark parameter Paulo Zanoni
2018-10-18 13:41 ` Ville Syrjälä
2018-10-22 22:29 ` Paulo Zanoni
2018-10-23 12:07 ` Ville Syrjälä
2018-10-16 22:01 ` [PATCH 08/11] drm/i915: reorganize the error message for invalid watermarks Paulo Zanoni
2018-10-18 13:55 ` Ville Syrjälä
2018-10-18 16:18 ` Ville Syrjälä
2018-10-22 22:22 ` Paulo Zanoni
2018-10-23 12:02 ` Ville Syrjälä
2018-10-16 22:01 ` [PATCH 09/11] drm/i915: make skl_needs_memory_bw_wa() take dev_priv instead of state Paulo Zanoni
2018-10-18 14:02 ` Ville Syrjälä
2018-10-16 22:01 ` [PATCH 10/11] drm/i915: add pipe_htotal to struct skl_wm_params Paulo Zanoni
2018-10-18 14:14 ` Ville Syrjälä
2018-10-16 22:01 ` [PATCH 11/11] drm/i915: pass dev_priv instead of cstate to skl_compute_transition_wm() Paulo Zanoni
2018-10-18 14:20 ` Ville Syrjälä
2018-10-16 22:21 ` ✗ Fi.CI.CHECKPATCH: warning for More watermarks improvements Patchwork
2018-10-16 22:31 ` Paulo Zanoni
2018-10-16 22:25 ` ✗ Fi.CI.SPARSE: " Patchwork
2018-10-16 22:39 ` ✗ Fi.CI.BAT: failure " Patchwork
2018-10-16 22:52 ` Paulo Zanoni
2018-10-18 14:34 ` Saarinen, Jani
2018-10-23 0:09 ` ✓ Fi.CI.BAT: success " Patchwork
2018-10-23 1:41 ` ✓ Fi.CI.IGT: " Patchwork
2018-11-09 1:28 ` ✗ Fi.CI.BAT: failure for More watermarks improvements (rev2) 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=20181022235511.GE5342@intel.com \
--to=rodrigo.vivi@intel.com \
--cc=intel-gfx@lists.freedesktop.org \
--cc=jani.nikula@intel.com \
--cc=paulo.r.zanoni@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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).