From: Jesse Barnes <jbarnes@virtuousgeek.org>
To: "Rafael J. Wysocki" <rjw@rjwysocki.net>
Cc: intel-gfx@lists.freedesktop.org, kristen@linux.intel.com
Subject: Re: [PATCH 4/4] drm/i915: make sure PC8 is enabled on suspend and disabled on resume
Date: Fri, 30 May 2014 14:05:59 -0700 [thread overview]
Message-ID: <20140530140559.0e2bda1a@jbarnes-desktop> (raw)
In-Reply-To: <13618057.iipR8eHAlm@vostro.rjw.lan>
On Fri, 30 May 2014 23:12:45 +0200
"Rafael J. Wysocki" <rjw@rjwysocki.net> wrote:
> On Friday, May 30, 2014 11:29:15 AM Jesse Barnes wrote:
> > On Fri, 30 May 2014 16:37:53 +0300
> > Imre Deak <imre.deak@intel.com> wrote:
> >
> > > On Thu, 2014-05-29 at 14:11 -0700, Jesse Barnes wrote:
> > > > From: Kristen Carlson Accardi <kristen@linux.intel.com>
> > > >
> > > > This matches the runtime suspend paths and allows the system to enter
> > > > the lowest power mode at freeze time.
> > > >
> > > > Signed-off-by: Kristen Carlson Accardi <kristen@linux.intel.com>
> > > > Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
> > > > ---
> > > > drivers/gpu/drm/i915/i915_drv.c | 6 ++++++
> > > > 1 file changed, 6 insertions(+)
> > > >
> > > > diff --git a/drivers/gpu/drm/i915/i915_drv.c b/drivers/gpu/drm/i915/i915_drv.c
> > > > index b6211d7..24dc856 100644
> > > > --- a/drivers/gpu/drm/i915/i915_drv.c
> > > > +++ b/drivers/gpu/drm/i915/i915_drv.c
> > > > @@ -558,6 +558,9 @@ static int i915_drm_freeze(struct drm_device *dev)
> > > >
> > > > intel_display_set_init_power(dev_priv, false);
> > > >
> > > > + if (IS_HASWELL(dev) || IS_BROADWELL(dev))
> > > > + hsw_enable_pc8(dev_priv);
> > > > +
> > > > return 0;
> > > > }
> > > >
> > > > @@ -618,6 +621,9 @@ static int __i915_drm_thaw(struct drm_device *dev, bool restore_gtt_mappings)
> > > > {
> > > > struct drm_i915_private *dev_priv = dev->dev_private;
> > > >
> > > > + if (IS_HASWELL(dev) || IS_BROADWELL(dev))
> > > > + hsw_disable_pc8(dev_priv);
> > >
> > > I would put this before we access any of the HW regs in thaw_early() and
> > > correspondingly the above call to hsw_enable_pc8() to suspend_late()
> > > before we call pci_disable_device().
> > >
> > > With that change this is:
> > > Reviewed-by: Imre Deak <imre.deak@intel.com>
> >
> > For the thaw side I think that makes sense.
> >
> > But for the freeze side, putting it in suspend_late won't get us the
> > freeze behavior we want. I think Rafael and Kristen are thinking of
> > re-using the freeze infrastructure for some kind of connected standby
> > feature, where most stuff is frozen, but the system isn't in S3 or S4,
> > so we need the enable_pc8 call in the _freeze path as well.
> >
> > Rafael, is that correct?
>
> No, it isn't. The .freeze()/.thaw() callbacks are hibernation-specific.
> There are no plans for using this in PM beyond hibernation.
>
> What we're going to use are .suspend/_late/_noirq() and the corresponding
> resume callbacks and runtime PM.
>
> > I'll add a late_freeze and put it there instead, so it doesn't pollute
> > the S3 suspend path.
>
> The freeze/thaw stuff need not do any PM BTW, it just needs to quiesce the
> device to prevent it from doing DMA etc and then bring it back to life.
Ok thanks. Kristen corrected me on IRC too. The latest patch I sent
should do what we want then, now that I've removed the freeze_late
function and put our PC8 enable in suspend_late like Imre suggested
initially.
--
Jesse Barnes, Intel Open Source Technology Center
next prev parent reply other threads:[~2014-05-30 21:05 UTC|newest]
Thread overview: 42+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-05-29 21:11 [PATCH 1/4] drm/i915: disable power wells on suspend Jesse Barnes
2014-05-29 21:11 ` [PATCH 2/4] drm/i915: leave rc6 enabled at suspend time Jesse Barnes
2014-05-30 12:54 ` Imre Deak
2014-05-30 15:32 ` Jesse Barnes
2014-05-30 15:40 ` Chris Wilson
2014-05-30 18:20 ` Jesse Barnes
2014-06-02 8:43 ` Daniel Vetter
2014-05-30 18:33 ` [PATCH] drm/i915: leave rc6 enabled at suspend time v2 Jesse Barnes
2014-06-04 19:33 ` [PATCH] drm/i915: leave rc6 enabled at suspend time v3 Jesse Barnes
2014-06-04 20:45 ` [PATCH] drm/i915: leave rc6 enabled at suspend time v4 Jesse Barnes
2014-06-05 9:21 ` Daniel Vetter
2014-06-05 15:50 ` Jesse Barnes
2014-06-10 13:42 ` Imre Deak
2014-06-10 13:57 ` Daniel Vetter
2014-06-10 14:41 ` Imre Deak
2014-06-10 15:26 ` Daniel Vetter
2014-06-11 22:21 ` Jesse Barnes
2014-06-11 22:24 ` Jesse Barnes
2014-06-12 15:08 ` Imre Deak
2014-05-30 19:00 ` [PATCH 2/4] drm/i915: leave rc6 enabled at suspend time Kristen Carlson Accardi
2014-05-29 21:11 ` [PATCH 3/4] drm/i915: send proper opregion notifications on suspend/resume Jesse Barnes
2014-05-29 21:48 ` [PATCH 3/5] ACPI: export target system state for use by drivers Jesse Barnes
2014-05-30 2:09 ` Rafael J. Wysocki
2014-05-29 21:48 ` [PATCH 4/5] drm/i915: send proper opregion notifications on suspend/resume Jesse Barnes
2014-05-30 13:47 ` [PATCH 3/4] " Imre Deak
2014-05-30 19:08 ` Kristen Carlson Accardi
2014-05-29 21:11 ` [PATCH 4/4] drm/i915: make sure PC8 is enabled on suspend and disabled on resume Jesse Barnes
2014-05-30 13:37 ` Imre Deak
2014-05-30 18:29 ` Jesse Barnes
2014-05-30 21:12 ` Rafael J. Wysocki
2014-05-30 21:05 ` Jesse Barnes [this message]
2014-05-30 18:32 ` [PATCH] drm/i915: make sure PC8 is enabled on suspend and disabled on resume v2 Jesse Barnes
2014-05-30 18:40 ` [PATCH] drm/i915: make sure PC8 is enabled on suspend and disabled on resume v3 Jesse Barnes
2014-05-30 18:48 ` [PATCH] drm/i915: make sure PC8 is enabled on suspend and disabled on resume v4 Jesse Barnes
2014-06-04 20:02 ` Imre Deak
2014-06-02 8:45 ` [PATCH 4/4] drm/i915: make sure PC8 is enabled on suspend and disabled on resume Daniel Vetter
2014-06-02 11:37 ` Imre Deak
2014-06-02 15:32 ` Daniel Vetter
2014-06-02 15:57 ` Imre Deak
2014-06-02 16:05 ` Daniel Vetter
2014-05-30 12:48 ` [PATCH 1/4] drm/i915: disable power wells on suspend Imre Deak
2014-05-30 18:59 ` Kristen Carlson Accardi
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=20140530140559.0e2bda1a@jbarnes-desktop \
--to=jbarnes@virtuousgeek.org \
--cc=intel-gfx@lists.freedesktop.org \
--cc=kristen@linux.intel.com \
--cc=rjw@rjwysocki.net \
/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