Commit f568eeee authored by Daniele Ceraolo Spurio's avatar Daniele Ceraolo Spurio Committed by Chris Wilson

drm/i915: use intel_uncore in fw get/put internal paths

Get/put functions used outside of uncore.c are updated in the next
patch for a nicer split.

v2: use dev_priv where we still have it (Paulo)
Signed-off-by: default avatarDaniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
Cc: Paulo Zanoni <paulo.r.zanoni@intel.com>
Reviewed-by: default avatarPaulo Zanoni <paulo.r.zanoni@intel.com>
Signed-off-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Link: https://patchwork.freedesktop.org/patch/msgid/20190319183543.13679-3-daniele.ceraolospurio@intel.com
parent 159367bb
...@@ -1414,13 +1414,14 @@ static int ironlake_drpc_info(struct seq_file *m) ...@@ -1414,13 +1414,14 @@ static int ironlake_drpc_info(struct seq_file *m)
static int i915_forcewake_domains(struct seq_file *m, void *data) static int i915_forcewake_domains(struct seq_file *m, void *data)
{ {
struct drm_i915_private *i915 = node_to_i915(m->private); struct drm_i915_private *i915 = node_to_i915(m->private);
struct intel_uncore *uncore = &i915->uncore;
struct intel_uncore_forcewake_domain *fw_domain; struct intel_uncore_forcewake_domain *fw_domain;
unsigned int tmp; unsigned int tmp;
seq_printf(m, "user.bypass_count = %u\n", seq_printf(m, "user.bypass_count = %u\n",
i915->uncore.user_forcewake.count); uncore->user_forcewake.count);
for_each_fw_domain(fw_domain, i915, tmp) for_each_fw_domain(fw_domain, uncore, tmp)
seq_printf(m, "%s.wake_count = %u\n", seq_printf(m, "%s.wake_count = %u\n",
intel_uncore_forcewake_domain_to_str(fw_domain->id), intel_uncore_forcewake_domain_to_str(fw_domain->id),
READ_ONCE(fw_domain->wake_count)); READ_ONCE(fw_domain->wake_count));
......
...@@ -2952,7 +2952,7 @@ static int intel_runtime_suspend(struct device *kdev) ...@@ -2952,7 +2952,7 @@ static int intel_runtime_suspend(struct device *kdev)
intel_opregion_notify_adapter(dev_priv, PCI_D1); intel_opregion_notify_adapter(dev_priv, PCI_D1);
} }
assert_forcewakes_inactive(dev_priv); assert_forcewakes_inactive(&dev_priv->uncore);
if (!IS_VALLEYVIEW(dev_priv) && !IS_CHERRYVIEW(dev_priv)) if (!IS_VALLEYVIEW(dev_priv) && !IS_CHERRYVIEW(dev_priv))
intel_hpd_poll_init(dev_priv); intel_hpd_poll_init(dev_priv);
......
...@@ -2102,6 +2102,11 @@ static inline struct drm_i915_private *huc_to_i915(struct intel_huc *huc) ...@@ -2102,6 +2102,11 @@ static inline struct drm_i915_private *huc_to_i915(struct intel_huc *huc)
return container_of(huc, struct drm_i915_private, huc); return container_of(huc, struct drm_i915_private, huc);
} }
static inline struct drm_i915_private *uncore_to_i915(struct intel_uncore *uncore)
{
return container_of(uncore, struct drm_i915_private, uncore);
}
/* Simple iterator over all initialised engines */ /* Simple iterator over all initialised engines */
#define for_each_engine(engine__, dev_priv__, id__) \ #define for_each_engine(engine__, dev_priv__, id__) \
for ((id__) = 0; \ for ((id__) = 0; \
......
This diff is collapsed.
...@@ -32,6 +32,7 @@ ...@@ -32,6 +32,7 @@
#include "i915_reg.h" #include "i915_reg.h"
struct drm_i915_private; struct drm_i915_private;
struct intel_uncore;
enum forcewake_domain_id { enum forcewake_domain_id {
FW_DOMAIN_ID_RENDER = 0, FW_DOMAIN_ID_RENDER = 0,
...@@ -62,9 +63,9 @@ enum forcewake_domains { ...@@ -62,9 +63,9 @@ enum forcewake_domains {
}; };
struct intel_uncore_funcs { struct intel_uncore_funcs {
void (*force_wake_get)(struct drm_i915_private *dev_priv, void (*force_wake_get)(struct intel_uncore *uncore,
enum forcewake_domains domains); enum forcewake_domains domains);
void (*force_wake_put)(struct drm_i915_private *dev_priv, void (*force_wake_put)(struct intel_uncore *uncore,
enum forcewake_domains domains); enum forcewake_domains domains);
u8 (*mmio_readb)(struct drm_i915_private *dev_priv, u8 (*mmio_readb)(struct drm_i915_private *dev_priv,
...@@ -127,12 +128,12 @@ struct intel_uncore { ...@@ -127,12 +128,12 @@ struct intel_uncore {
}; };
/* Iterate over initialised fw domains */ /* Iterate over initialised fw domains */
#define for_each_fw_domain_masked(domain__, mask__, dev_priv__, tmp__) \ #define for_each_fw_domain_masked(domain__, mask__, uncore__, tmp__) \
for (tmp__ = (mask__); \ for (tmp__ = (mask__); \
tmp__ ? (domain__ = &(dev_priv__)->uncore.fw_domain[__mask_next_bit(tmp__)]), 1 : 0;) tmp__ ? (domain__ = &(uncore__)->fw_domain[__mask_next_bit(tmp__)]), 1 : 0;)
#define for_each_fw_domain(domain__, dev_priv__, tmp__) \ #define for_each_fw_domain(domain__, uncore__, tmp__) \
for_each_fw_domain_masked(domain__, (dev_priv__)->uncore.fw_domains, dev_priv__, tmp__) for_each_fw_domain_masked(domain__, (uncore__)->fw_domains, uncore__, tmp__)
static inline struct intel_uncore * static inline struct intel_uncore *
forcewake_domain_to_uncore(const struct intel_uncore_forcewake_domain *d) forcewake_domain_to_uncore(const struct intel_uncore_forcewake_domain *d)
...@@ -151,8 +152,8 @@ void intel_uncore_resume_early(struct drm_i915_private *dev_priv); ...@@ -151,8 +152,8 @@ void intel_uncore_resume_early(struct drm_i915_private *dev_priv);
void intel_uncore_runtime_resume(struct drm_i915_private *dev_priv); void intel_uncore_runtime_resume(struct drm_i915_private *dev_priv);
u64 intel_uncore_edram_size(struct drm_i915_private *dev_priv); u64 intel_uncore_edram_size(struct drm_i915_private *dev_priv);
void assert_forcewakes_inactive(struct drm_i915_private *dev_priv); void assert_forcewakes_inactive(struct intel_uncore *uncore);
void assert_forcewakes_active(struct drm_i915_private *dev_priv, void assert_forcewakes_active(struct intel_uncore *uncore,
enum forcewake_domains fw_domains); enum forcewake_domains fw_domains);
const char *intel_uncore_forcewake_domain_to_str(const enum forcewake_domain_id id); const char *intel_uncore_forcewake_domain_to_str(const enum forcewake_domain_id id);
......
...@@ -140,6 +140,7 @@ static int live_forcewake_ops(void *arg) ...@@ -140,6 +140,7 @@ static int live_forcewake_ops(void *arg)
const struct reg *r; const struct reg *r;
struct drm_i915_private *i915 = arg; struct drm_i915_private *i915 = arg;
struct intel_uncore_forcewake_domain *domain; struct intel_uncore_forcewake_domain *domain;
struct intel_uncore *uncore = &i915->uncore;
struct intel_engine_cs *engine; struct intel_engine_cs *engine;
enum intel_engine_id id; enum intel_engine_id id;
intel_wakeref_t wakeref; intel_wakeref_t wakeref;
...@@ -166,7 +167,7 @@ static int live_forcewake_ops(void *arg) ...@@ -166,7 +167,7 @@ static int live_forcewake_ops(void *arg)
wakeref = intel_runtime_pm_get(i915); wakeref = intel_runtime_pm_get(i915);
for_each_fw_domain(domain, i915, tmp) { for_each_fw_domain(domain, uncore, tmp) {
smp_store_mb(domain->active, false); smp_store_mb(domain->active, false);
if (!hrtimer_cancel(&domain->timer)) if (!hrtimer_cancel(&domain->timer))
continue; continue;
...@@ -188,7 +189,7 @@ static int live_forcewake_ops(void *arg) ...@@ -188,7 +189,7 @@ static int live_forcewake_ops(void *arg)
if (!fw_domains) if (!fw_domains)
continue; continue;
for_each_fw_domain_masked(domain, fw_domains, i915, tmp) { for_each_fw_domain_masked(domain, fw_domains, uncore, tmp) {
if (!domain->wake_count) if (!domain->wake_count)
continue; continue;
...@@ -203,7 +204,7 @@ static int live_forcewake_ops(void *arg) ...@@ -203,7 +204,7 @@ static int live_forcewake_ops(void *arg)
intel_uncore_forcewake_put(i915, fw_domains); intel_uncore_forcewake_put(i915, fw_domains);
/* Flush the forcewake release (delayed onto a timer) */ /* Flush the forcewake release (delayed onto a timer) */
for_each_fw_domain_masked(domain, fw_domains, i915, tmp) { for_each_fw_domain_masked(domain, fw_domains, uncore, tmp) {
smp_store_mb(domain->active, false); smp_store_mb(domain->active, false);
if (hrtimer_cancel(&domain->timer)) if (hrtimer_cancel(&domain->timer))
intel_uncore_fw_release_timer(&domain->timer); intel_uncore_fw_release_timer(&domain->timer);
...@@ -280,7 +281,7 @@ static int live_forcewake_domains(void *arg) ...@@ -280,7 +281,7 @@ static int live_forcewake_domains(void *arg)
i915_reg_t reg = { offset }; i915_reg_t reg = { offset };
iosf_mbi_punit_acquire(); iosf_mbi_punit_acquire();
intel_uncore_forcewake_reset(dev_priv); intel_uncore_forcewake_reset(&dev_priv->uncore);
iosf_mbi_punit_release(); iosf_mbi_punit_release();
check_for_unclaimed_mmio(dev_priv); check_for_unclaimed_mmio(dev_priv);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment