From: Imre Deak <imre.deak@intel.com>
To: intel-gfx@lists.freedesktop.org
Cc: Jani Nikula <jani.nikula@intel.com>
Subject: Re: [PATCH] drm/i915: allow requesting the audio power well for all platforms
Date: Fri, 05 Dec 2014 15:55:13 +0200 [thread overview]
Message-ID: <1417787713.17293.25.camel@intelbox> (raw)
In-Reply-To: <1417786089-21207-1-git-send-email-imre.deak@intel.com>
On Fri, 2014-12-05 at 15:28 +0200, Imre Deak wrote:
> So far we only allowed HSW and BDW to request for the audio power
> domain, but it is also needed at least on VLV/CHV. There is no need
> for this restriction, since the power domain->power well mapping should
> take care of the distinctions between platforms.
>
> Spotted-by: Jani Nikula <jani.nikula@intel.com>
> Signed-off-by: Imre Deak <imre.deak@intel.com>
> ---
> drivers/gpu/drm/i915/intel_runtime_pm.c | 20 ++++++++++----------
> 1 file changed, 10 insertions(+), 10 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/intel_runtime_pm.c b/drivers/gpu/drm/i915/intel_runtime_pm.c
> index 8a2bd18..58204ab 100644
> --- a/drivers/gpu/drm/i915/intel_runtime_pm.c
> +++ b/drivers/gpu/drm/i915/intel_runtime_pm.c
> @@ -50,7 +50,7 @@
> * present for a given platform.
> */
>
> -static struct i915_power_domains *hsw_pwr;
> +static struct i915_power_domains *i915_pwr;
>
> #define for_each_power_well(i, power_well, domain_mask, power_domains) \
> for (i = 0; \
> @@ -1098,10 +1098,8 @@ int intel_power_domains_init(struct drm_i915_private *dev_priv)
> */
> if (IS_HASWELL(dev_priv->dev)) {
> set_power_wells(power_domains, hsw_power_wells);
> - hsw_pwr = power_domains;
> } else if (IS_BROADWELL(dev_priv->dev)) {
> set_power_wells(power_domains, bdw_power_wells);
> - hsw_pwr = power_domains;
> } else if (IS_CHERRYVIEW(dev_priv->dev)) {
> set_power_wells(power_domains, chv_power_wells);
> } else if (IS_VALLEYVIEW(dev_priv->dev)) {
> @@ -1110,6 +1108,8 @@ int intel_power_domains_init(struct drm_i915_private *dev_priv)
> set_power_wells(power_domains, i9xx_always_on_power_well);
> }
>
> + i915_pwr = power_domains;
> +
> return 0;
> }
>
> @@ -1146,7 +1146,7 @@ void intel_power_domains_fini(struct drm_i915_private *dev_priv)
> * we're going to unload/reload. */
> intel_display_set_init_power(dev_priv, true);
>
> - hsw_pwr = NULL;
> + i915_pwr = NULL;
> }
>
> static void intel_power_domains_resume(struct drm_i915_private *dev_priv)
> @@ -1360,10 +1360,10 @@ int i915_request_power_well(void)
> {
> struct drm_i915_private *dev_priv;
>
> - if (!hsw_pwr)
> + if (!i915_pwr)
> return -ENODEV;
>
> - dev_priv = container_of(hsw_pwr, struct drm_i915_private,
> + dev_priv = container_of(i915_pwr, struct drm_i915_private,
> power_domains);
> intel_display_power_get(dev_priv, POWER_DOMAIN_AUDIO);
> return 0;
> @@ -1375,10 +1375,10 @@ int i915_release_power_well(void)
> {
> struct drm_i915_private *dev_priv;
>
> - if (!hsw_pwr)
> + if (!i915_pwr)
> return -ENODEV;
>
> - dev_priv = container_of(hsw_pwr, struct drm_i915_private,
> + dev_priv = container_of(i915_pwr, struct drm_i915_private,
> power_domains);
> intel_display_power_put(dev_priv, POWER_DOMAIN_AUDIO);
> return 0;
> @@ -1395,10 +1395,10 @@ int i915_get_cdclk_freq(void)
> {
> struct drm_i915_private *dev_priv;
>
> - if (!hsw_pwr)
> + if (!i915_pwr)
> return -ENODEV;
Err, we should also WARN and return here for !HAS_DDI. This is used for
restoring the audio BCLK M/N values in the HSW/BDW extended mode
registers, but there is no corresponding registers on other platforms.
>
> - dev_priv = container_of(hsw_pwr, struct drm_i915_private,
> + dev_priv = container_of(i915_pwr, struct drm_i915_private,
> power_domains);
>
> return intel_ddi_get_cdclk_freq(dev_priv);
_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/intel-gfx
next prev parent reply other threads:[~2014-12-05 13:56 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-12-05 13:28 [PATCH] drm/i915: allow requesting the audio power well for all platforms Imre Deak
2014-12-05 13:55 ` Imre Deak [this message]
2015-01-26 19:12 ` Rodrigo Vivi
2015-01-26 19:48 ` Imre Deak
2014-12-05 17:09 ` shuang.he
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=1417787713.17293.25.camel@intelbox \
--to=imre.deak@intel.com \
--cc=intel-gfx@lists.freedesktop.org \
--cc=jani.nikula@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.