From: "Zanoni, Paulo R" <paulo.r.zanoni@intel.com>
To: "chris@chris-wilson.co.uk" <chris@chris-wilson.co.uk>
Cc: "intel-gfx@lists.freedesktop.org"
<intel-gfx@lists.freedesktop.org>,
"stefanr@s5r6.in-berlin.de" <stefanr@s5r6.in-berlin.de>,
"stevenhoneyman@gmail.com" <stevenhoneyman@gmail.com>,
"Pandiyan, Dhinakaran" <dhinakaran.pandiyan@intel.com>
Subject: Re: [PATCH] drm/i915/fbc: disable FBC on FIFO underruns
Date: Mon, 12 Sep 2016 21:25:48 +0000 [thread overview]
Message-ID: <1473715543.2435.67.camel@intel.com> (raw)
In-Reply-To: <20160912202523.GA7041@nuc-i3427.alporthouse.com>
Em Seg, 2016-09-12 às 21:25 +0100, Chris Wilson escreveu:
> On Mon, Sep 12, 2016 at 05:02:56PM -0300, Paulo Zanoni wrote:
> >
> > Ever since I started working on FBC I was already aware that FBC
> > can
> > really amplify the FIFO underrun symptoms. On systems where FIFO
> > underruns were harmless error messages, enabling FBC would cause
> > the
> > underruns to give black screens.
> >
> > We recently tried to enable FBC on Haswell and got reports of a
> > system
> > that would hang after some hours of uptime, and the first bad
> > commit
> > was the one that enabled FBC. We also observed that this system had
> > FIFO underrun error messages on its dmesg. Although we don't have
> > any
> > evidence that fixing the underruns would solve the bug and make FBC
> > work properly on this machine, IMHO it's better if we minimize the
> > amount of possible problems by just giving up FBC whenever we
> > detect
> > an underrun.
> >
> > v2: New version, different implementation and commit message.
> > v3: Clarify the fact that we run from an IRQ handler (Chris).
> > v4: Also add the underrun_detected check at can_choose() to avoid
> > misleading dmesg messages (DK).
> >
> > Cc: Stefan Richter <stefanr@s5r6.in-berlin.de>
> > Cc: Lyude <cpaul@redhat.com>
> > Cc: stevenhoneyman@gmail.com <stevenhoneyman@gmail.com>
> > Cc: Dhinakaran Pandiyan <dhinakaran.pandiyan@intel.com>
> > Signed-off-by: Paulo Zanoni <paulo.r.zanoni@intel.com>
> > ---
> > drivers/gpu/drm/i915/i915_drv.h | 3 ++
> > drivers/gpu/drm/i915/intel_drv.h | 1 +
> > drivers/gpu/drm/i915/intel_fbc.c | 66
> > ++++++++++++++++++++++++++++++
> > drivers/gpu/drm/i915/intel_fifo_underrun.c | 2 +
> > 4 files changed, 72 insertions(+)
> >
> > diff --git a/drivers/gpu/drm/i915/i915_drv.h
> > b/drivers/gpu/drm/i915/i915_drv.h
> > index 1e2dda8..2025f42 100644
> > --- a/drivers/gpu/drm/i915/i915_drv.h
> > +++ b/drivers/gpu/drm/i915/i915_drv.h
> > @@ -971,6 +971,9 @@ struct intel_fbc {
> > bool enabled;
> > bool active;
> >
> > + bool underrun_detected;
> > + struct work_struct underrun_work;
> > +
> > struct intel_fbc_state_cache {
> > struct {
> > unsigned int mode_flags;
> > diff --git a/drivers/gpu/drm/i915/intel_drv.h
> > b/drivers/gpu/drm/i915/intel_drv.h
> > index abe7a4d..0d05712 100644
> > --- a/drivers/gpu/drm/i915/intel_drv.h
> > +++ b/drivers/gpu/drm/i915/intel_drv.h
> > @@ -1508,6 +1508,7 @@ void intel_fbc_invalidate(struct
> > drm_i915_private *dev_priv,
> > void intel_fbc_flush(struct drm_i915_private *dev_priv,
> > unsigned int frontbuffer_bits, enum
> > fb_op_origin origin);
> > void intel_fbc_cleanup_cfb(struct drm_i915_private *dev_priv);
> > +void intel_fbc_handle_fifo_underrun_irq(struct drm_i915_private
> > *dev_priv);
> >
> > /* intel_hdmi.c */
> > void intel_hdmi_init(struct drm_device *dev, i915_reg_t hdmi_reg,
> > enum port port);
> > diff --git a/drivers/gpu/drm/i915/intel_fbc.c
> > b/drivers/gpu/drm/i915/intel_fbc.c
> > index 5dcb81a..4b91af1 100644
> > --- a/drivers/gpu/drm/i915/intel_fbc.c
> > +++ b/drivers/gpu/drm/i915/intel_fbc.c
> > @@ -774,6 +774,13 @@ static bool intel_fbc_can_activate(struct
> > intel_crtc *crtc)
> > struct intel_fbc *fbc = &dev_priv->fbc;
> > struct intel_fbc_state_cache *cache = &fbc->state_cache;
> >
> > + /* We don't need to use a state cache here since this
> > information is
> > + * global for every CRTC. */
>
> * global for all CRTC.
> */
>
> "global for every CRTC" is confusing, as it says to me that is a
> separate global variable for each CRTC. But what you mean is that
> there
> is one variable that reflects all CRTC.
Makes sense.
>
> >
> > + if (fbc->underrun_detected) {
> > + fbc->no_fbc_reason = "underrun detected";
> > + return false;
> > + }
> > +
> > if (!cache->plane.visible) {
> > fbc->no_fbc_reason = "primary plane not visible";
> > return false;
> > @@ -859,6 +866,11 @@ static bool intel_fbc_can_choose(struct
> > intel_crtc *crtc)
> > return false;
> > }
> >
> > + if (fbc->underrun_detected) {
> > + fbc->no_fbc_reason = "underrun detected";
> > + return false;
> > + }
> > +
> > if (fbc_on_pipe_a_only(dev_priv) && crtc->pipe != PIPE_A)
> > {
> > fbc->no_fbc_reason = "no enabled pipes can have
> > FBC";
> > return false;
> > @@ -1221,6 +1233,59 @@ void intel_fbc_global_disable(struct
> > drm_i915_private *dev_priv)
> > cancel_work_sync(&fbc->work.work);
> > }
> >
> > +static void intel_fbc_underrun_work_fn(struct work_struct *work)
> > +{
> > + struct drm_i915_private *dev_priv =
> > + container_of(work, struct drm_i915_private,
> > fbc.underrun_work);
> > + struct intel_fbc *fbc = &dev_priv->fbc;
> > +
> > + mutex_lock(&fbc->lock);
> > +
> > + /* Maybe we were scheduled twice. */
> > + if (fbc->underrun_detected)
> > + goto out;
> > +
> > + DRM_DEBUG_KMS("Disabling FBC due to FIFO underrun.\n");
> > + fbc->underrun_detected = true;
>
> Could juggle to reduce the coverage of the mutex, but irrelevant.
> A comment as to why we permanently disable the fbc would be useful.
> At
> least to disuade people from trying to make helpful remarks...
There's already one right below, at the
intel_fbc_handle_fifo_underrun_irq documentation, and also on the
commit message. If those are not enough, can you please clarify what
should be done?
Thanks,
Paulo
>
>
> >
> > + intel_fbc_deactivate(dev_priv);
> > +out:
> > + mutex_unlock(&fbc->lock);
> > +}
> > +
> > +/**
> > + * intel_fbc_handle_fifo_underrun_irq - disable FBC when we get a
> > FIFO underrun
> > + * @dev_priv: i915 device instance
> > + *
> > + * Without FBC, most underruns are harmless and don't really cause
> > too many
> > + * problems, except for an annoying message on dmesg. With FBC,
> > underruns can
> > + * become black screens or even worse, especially when paired with
> > bad
> > + * watermarks. So in order for us to be on the safe side,
> > completely disable FBC
> > + * in case we ever detect a FIFO underrun on any pipe. An underrun
> > on any pipe
> > + * already suggests that watermarks may be bad, so try to be as
> > safe as
> > + * possible.
> > + *
> > + * This function is called from the IRQ handler.
> > + */
> > +void intel_fbc_handle_fifo_underrun_irq(struct drm_i915_private
> > *dev_priv)
> > +{
> > + struct intel_fbc *fbc = &dev_priv->fbc;
> > +
> > + if (!fbc_supported(dev_priv))
> > + return;
> > +
> > + /* There's no guarantee that underrun_detected won't be
> > set to true
> > + * right after this check and before the work is
> > scheduled, but that's
> > + * not a problem since we'll check it again under the work
> > function
> > + * while FBC is locked. This check here is just to prevent
> > us from
> > + * unnecessarily scheduling the work, and it relies on the
> > fact that we
> > + * never switch underrun_detect back to false after it's
> > true. */
> */
> >
> > + if (fbc->underrun_detected)
> if (READ_ONCE(fbc->underrun_detected))
> >
> > + return;
> > +
> > + schedule_work(&fbc->underrun_work);
> > +}
> > +
> > /**
> > * intel_fbc_init_pipe_state - initialize FBC's CRTC visibility
> > tracking
> > * @dev_priv: i915 device instance
> > @@ -1292,6 +1357,7 @@ void intel_fbc_init(struct drm_i915_private
> > *dev_priv)
> > enum pipe pipe;
> >
> > INIT_WORK(&fbc->work.work, intel_fbc_work_fn);
> > + INIT_WORK(&fbc->underrun_work,
> > intel_fbc_underrun_work_fn);
> > mutex_init(&fbc->lock);
> > fbc->enabled = false;
> > fbc->active = false;
> > diff --git a/drivers/gpu/drm/i915/intel_fifo_underrun.c
> > b/drivers/gpu/drm/i915/intel_fifo_underrun.c
> > index 2aa7440..ebb4fed 100644
> > --- a/drivers/gpu/drm/i915/intel_fifo_underrun.c
> > +++ b/drivers/gpu/drm/i915/intel_fifo_underrun.c
> > @@ -372,6 +372,8 @@ void intel_cpu_fifo_underrun_irq_handler(struct
> > drm_i915_private *dev_priv,
> > if (intel_set_cpu_fifo_underrun_reporting(dev_priv, pipe,
> > false))
> > DRM_ERROR("CPU pipe %c FIFO underrun\n",
> > pipe_name(pipe));
> > +
> > + intel_fbc_handle_fifo_underrun_irq(dev_priv);
> > }
> >
> > /**
> > --
> > 2.7.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:[~2016-09-12 21:25 UTC|newest]
Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-06-11 1:18 [PATCH] drm/i915/fbc: disable FBC on FIFO underruns Paulo Zanoni
2016-06-11 6:56 ` ✗ Ro.CI.BAT: warning for " Patchwork
2016-06-13 11:47 ` [PATCH] " Stefan Richter
2016-06-13 14:33 ` Zanoni, Paulo R
2016-06-15 12:19 ` Stefan Richter
2016-08-12 23:24 ` Pandiyan, Dhinakaran
2016-08-13 9:05 ` Chris Wilson
2016-08-15 20:49 ` Zanoni, Paulo R
2016-08-15 22:36 ` [PATCH] " Paulo Zanoni
2016-09-02 5:58 ` Pandiyan, Dhinakaran
2016-09-02 14:45 ` Zanoni, Paulo R
2016-09-12 20:02 ` Paulo Zanoni
2016-09-12 20:25 ` Chris Wilson
2016-09-12 21:25 ` Zanoni, Paulo R [this message]
2016-09-13 13:38 ` Paulo Zanoni
2016-09-13 13:56 ` Chris Wilson
2016-09-13 17:07 ` Pandiyan, Dhinakaran
2016-08-16 5:57 ` ✗ Ro.CI.BAT: failure for drm/i915/fbc: disable FBC on FIFO underruns (rev2) Patchwork
2016-09-12 20:54 ` ✓ Fi.CI.BAT: success for drm/i915/fbc: disable FBC on FIFO underruns (rev3) Patchwork
2016-09-13 14:19 ` ✗ Fi.CI.BAT: warning for drm/i915/fbc: disable FBC on FIFO underruns (rev4) 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=1473715543.2435.67.camel@intel.com \
--to=paulo.r.zanoni@intel.com \
--cc=chris@chris-wilson.co.uk \
--cc=dhinakaran.pandiyan@intel.com \
--cc=intel-gfx@lists.freedesktop.org \
--cc=stefanr@s5r6.in-berlin.de \
--cc=stevenhoneyman@gmail.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).