提交 9bad2adb 编写于 作者: C Chris Wilson

drm/i915/gt: Move rps.enabled/active to flags

Pull the boolean intel_rps.enabled and intel_rps.active into a single
flags field, in preparation for more.
Signed-off-by: NChris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: NAndi Shyti <andi.shyti@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20200429205446.3259-2-chris@chris-wilson.co.uk
上级 426d0073
...@@ -556,7 +556,8 @@ static int rps_boost_show(struct seq_file *m, void *data) ...@@ -556,7 +556,8 @@ static int rps_boost_show(struct seq_file *m, void *data)
struct drm_i915_private *i915 = gt->i915; struct drm_i915_private *i915 = gt->i915;
struct intel_rps *rps = &gt->rps; struct intel_rps *rps = &gt->rps;
seq_printf(m, "RPS enabled? %d\n", rps->enabled); seq_printf(m, "RPS enabled? %s\n", yesno(intel_rps_is_enabled(rps)));
seq_printf(m, "RPS active? %s\n", yesno(intel_rps_is_active(rps)));
seq_printf(m, "GPU busy? %s\n", yesno(gt->awake)); seq_printf(m, "GPU busy? %s\n", yesno(gt->awake));
seq_printf(m, "Boosts outstanding? %d\n", seq_printf(m, "Boosts outstanding? %d\n",
atomic_read(&rps->num_waiters)); atomic_read(&rps->num_waiters));
...@@ -576,7 +577,7 @@ static int rps_boost_show(struct seq_file *m, void *data) ...@@ -576,7 +577,7 @@ static int rps_boost_show(struct seq_file *m, void *data)
seq_printf(m, "Wait boosts: %d\n", atomic_read(&rps->boosts)); seq_printf(m, "Wait boosts: %d\n", atomic_read(&rps->boosts));
if (INTEL_GEN(i915) >= 6 && rps->enabled && gt->awake) { if (INTEL_GEN(i915) >= 6 && intel_rps_is_active(rps)) {
struct intel_uncore *uncore = gt->uncore; struct intel_uncore *uncore = gt->uncore;
u32 rpup, rpupei; u32 rpup, rpupei;
u32 rpdown, rpdownei; u32 rpdown, rpdownei;
......
...@@ -648,7 +648,7 @@ void intel_rps_mark_interactive(struct intel_rps *rps, bool interactive) ...@@ -648,7 +648,7 @@ void intel_rps_mark_interactive(struct intel_rps *rps, bool interactive)
mutex_lock(&rps->power.mutex); mutex_lock(&rps->power.mutex);
if (interactive) { if (interactive) {
if (!rps->power.interactive++ && READ_ONCE(rps->active)) if (!rps->power.interactive++ && intel_rps_is_active(rps))
rps_set_power(rps, HIGH_POWER); rps_set_power(rps, HIGH_POWER);
} else { } else {
GEM_BUG_ON(!rps->power.interactive); GEM_BUG_ON(!rps->power.interactive);
...@@ -721,7 +721,7 @@ static int rps_set(struct intel_rps *rps, u8 val, bool update) ...@@ -721,7 +721,7 @@ static int rps_set(struct intel_rps *rps, u8 val, bool update)
void intel_rps_unpark(struct intel_rps *rps) void intel_rps_unpark(struct intel_rps *rps)
{ {
if (!rps->enabled) if (!intel_rps_is_enabled(rps))
return; return;
GT_TRACE(rps_to_gt(rps), "unpark:%x\n", rps->cur_freq); GT_TRACE(rps_to_gt(rps), "unpark:%x\n", rps->cur_freq);
...@@ -732,8 +732,7 @@ void intel_rps_unpark(struct intel_rps *rps) ...@@ -732,8 +732,7 @@ void intel_rps_unpark(struct intel_rps *rps)
*/ */
mutex_lock(&rps->lock); mutex_lock(&rps->lock);
WRITE_ONCE(rps->active, true); intel_rps_set_active(rps);
intel_rps_set(rps, intel_rps_set(rps,
clamp(rps->cur_freq, clamp(rps->cur_freq,
rps->min_freq_softlimit, rps->min_freq_softlimit,
...@@ -754,13 +753,12 @@ void intel_rps_park(struct intel_rps *rps) ...@@ -754,13 +753,12 @@ void intel_rps_park(struct intel_rps *rps)
{ {
struct drm_i915_private *i915 = rps_to_i915(rps); struct drm_i915_private *i915 = rps_to_i915(rps);
if (!rps->enabled) if (!intel_rps_clear_active(rps))
return; return;
if (INTEL_GEN(i915) >= 6) if (INTEL_GEN(i915) >= 6)
rps_disable_interrupts(rps); rps_disable_interrupts(rps);
WRITE_ONCE(rps->active, false);
if (rps->last_freq <= rps->idle_freq) if (rps->last_freq <= rps->idle_freq)
return; return;
...@@ -802,7 +800,7 @@ void intel_rps_boost(struct i915_request *rq) ...@@ -802,7 +800,7 @@ void intel_rps_boost(struct i915_request *rq)
struct intel_rps *rps = &READ_ONCE(rq->engine)->gt->rps; struct intel_rps *rps = &READ_ONCE(rq->engine)->gt->rps;
unsigned long flags; unsigned long flags;
if (i915_request_signaled(rq) || !READ_ONCE(rps->active)) if (i915_request_signaled(rq) || !intel_rps_is_active(rps))
return; return;
/* Serializes with i915_request_retire() */ /* Serializes with i915_request_retire() */
...@@ -831,7 +829,7 @@ int intel_rps_set(struct intel_rps *rps, u8 val) ...@@ -831,7 +829,7 @@ int intel_rps_set(struct intel_rps *rps, u8 val)
GEM_BUG_ON(val > rps->max_freq); GEM_BUG_ON(val > rps->max_freq);
GEM_BUG_ON(val < rps->min_freq); GEM_BUG_ON(val < rps->min_freq);
if (rps->active) { if (intel_rps_is_active(rps)) {
err = rps_set(rps, val, true); err = rps_set(rps, val, true);
if (err) if (err)
return err; return err;
...@@ -1219,6 +1217,7 @@ void intel_rps_enable(struct intel_rps *rps) ...@@ -1219,6 +1217,7 @@ void intel_rps_enable(struct intel_rps *rps)
{ {
struct drm_i915_private *i915 = rps_to_i915(rps); struct drm_i915_private *i915 = rps_to_i915(rps);
struct intel_uncore *uncore = rps_to_uncore(rps); struct intel_uncore *uncore = rps_to_uncore(rps);
bool enabled = false;
if (!HAS_RPS(i915)) if (!HAS_RPS(i915))
return; return;
...@@ -1226,20 +1225,24 @@ void intel_rps_enable(struct intel_rps *rps) ...@@ -1226,20 +1225,24 @@ void intel_rps_enable(struct intel_rps *rps)
intel_gt_check_clock_frequency(rps_to_gt(rps)); intel_gt_check_clock_frequency(rps_to_gt(rps));
intel_uncore_forcewake_get(uncore, FORCEWAKE_ALL); intel_uncore_forcewake_get(uncore, FORCEWAKE_ALL);
if (IS_CHERRYVIEW(i915)) if (rps->max_freq <= rps->min_freq)
rps->enabled = chv_rps_enable(rps); /* leave disabled, no room for dynamic reclocking */;
else if (IS_CHERRYVIEW(i915))
enabled = chv_rps_enable(rps);
else if (IS_VALLEYVIEW(i915)) else if (IS_VALLEYVIEW(i915))
rps->enabled = vlv_rps_enable(rps); enabled = vlv_rps_enable(rps);
else if (INTEL_GEN(i915) >= 9) else if (INTEL_GEN(i915) >= 9)
rps->enabled = gen9_rps_enable(rps); enabled = gen9_rps_enable(rps);
else if (INTEL_GEN(i915) >= 8) else if (INTEL_GEN(i915) >= 8)
rps->enabled = gen8_rps_enable(rps); enabled = gen8_rps_enable(rps);
else if (INTEL_GEN(i915) >= 6) else if (INTEL_GEN(i915) >= 6)
rps->enabled = gen6_rps_enable(rps); enabled = gen6_rps_enable(rps);
else if (IS_IRONLAKE_M(i915)) else if (IS_IRONLAKE_M(i915))
rps->enabled = gen5_rps_enable(rps); enabled = gen5_rps_enable(rps);
else
MISSING_CASE(INTEL_GEN(i915));
intel_uncore_forcewake_put(uncore, FORCEWAKE_ALL); intel_uncore_forcewake_put(uncore, FORCEWAKE_ALL);
if (!rps->enabled) if (!enabled)
return; return;
GT_TRACE(rps_to_gt(rps), GT_TRACE(rps_to_gt(rps),
...@@ -1253,6 +1256,8 @@ void intel_rps_enable(struct intel_rps *rps) ...@@ -1253,6 +1256,8 @@ void intel_rps_enable(struct intel_rps *rps)
GEM_BUG_ON(rps->efficient_freq < rps->min_freq); GEM_BUG_ON(rps->efficient_freq < rps->min_freq);
GEM_BUG_ON(rps->efficient_freq > rps->max_freq); GEM_BUG_ON(rps->efficient_freq > rps->max_freq);
intel_rps_set_enabled(rps);
} }
static void gen6_rps_disable(struct intel_rps *rps) static void gen6_rps_disable(struct intel_rps *rps)
...@@ -1264,7 +1269,7 @@ void intel_rps_disable(struct intel_rps *rps) ...@@ -1264,7 +1269,7 @@ void intel_rps_disable(struct intel_rps *rps)
{ {
struct drm_i915_private *i915 = rps_to_i915(rps); struct drm_i915_private *i915 = rps_to_i915(rps);
rps->enabled = false; intel_rps_clear_enabled(rps);
if (INTEL_GEN(i915) >= 6) if (INTEL_GEN(i915) >= 6)
gen6_rps_disable(rps); gen6_rps_disable(rps);
...@@ -1511,6 +1516,10 @@ static void rps_work(struct work_struct *work) ...@@ -1511,6 +1516,10 @@ static void rps_work(struct work_struct *work)
goto out; goto out;
mutex_lock(&rps->lock); mutex_lock(&rps->lock);
if (!intel_rps_is_active(rps)) {
mutex_unlock(&rps->lock);
return;
}
pm_iir |= vlv_wa_c0_ei(rps, pm_iir); pm_iir |= vlv_wa_c0_ei(rps, pm_iir);
......
...@@ -36,4 +36,34 @@ void gen5_rps_irq_handler(struct intel_rps *rps); ...@@ -36,4 +36,34 @@ void gen5_rps_irq_handler(struct intel_rps *rps);
void gen6_rps_irq_handler(struct intel_rps *rps, u32 pm_iir); void gen6_rps_irq_handler(struct intel_rps *rps, u32 pm_iir);
void gen11_rps_irq_handler(struct intel_rps *rps, u32 pm_iir); void gen11_rps_irq_handler(struct intel_rps *rps, u32 pm_iir);
static inline bool intel_rps_is_enabled(const struct intel_rps *rps)
{
return test_bit(INTEL_RPS_ENABLED, &rps->flags);
}
static inline void intel_rps_set_enabled(struct intel_rps *rps)
{
set_bit(INTEL_RPS_ENABLED, &rps->flags);
}
static inline void intel_rps_clear_enabled(struct intel_rps *rps)
{
clear_bit(INTEL_RPS_ENABLED, &rps->flags);
}
static inline bool intel_rps_is_active(const struct intel_rps *rps)
{
return test_bit(INTEL_RPS_ACTIVE, &rps->flags);
}
static inline void intel_rps_set_active(struct intel_rps *rps)
{
set_bit(INTEL_RPS_ACTIVE, &rps->flags);
}
static inline bool intel_rps_clear_active(struct intel_rps *rps)
{
return test_and_clear_bit(INTEL_RPS_ACTIVE, &rps->flags);
}
#endif /* INTEL_RPS_H */ #endif /* INTEL_RPS_H */
...@@ -31,6 +31,11 @@ struct intel_rps_ei { ...@@ -31,6 +31,11 @@ struct intel_rps_ei {
u32 media_c0; u32 media_c0;
}; };
enum {
INTEL_RPS_ENABLED = 0,
INTEL_RPS_ACTIVE,
};
struct intel_rps { struct intel_rps {
struct mutex lock; /* protects enabling and the worker */ struct mutex lock; /* protects enabling and the worker */
...@@ -39,8 +44,7 @@ struct intel_rps { ...@@ -39,8 +44,7 @@ struct intel_rps {
* dev_priv->irq_lock * dev_priv->irq_lock
*/ */
struct work_struct work; struct work_struct work;
bool enabled; unsigned long flags;
bool active;
u32 pm_iir; u32 pm_iir;
/* PM interrupt bits that should never be masked */ /* PM interrupt bits that should never be masked */
......
...@@ -183,7 +183,7 @@ static u8 wait_for_freq(struct intel_rps *rps, u8 freq, int timeout_ms) ...@@ -183,7 +183,7 @@ static u8 wait_for_freq(struct intel_rps *rps, u8 freq, int timeout_ms)
static u8 rps_set_check(struct intel_rps *rps, u8 freq) static u8 rps_set_check(struct intel_rps *rps, u8 freq)
{ {
mutex_lock(&rps->lock); mutex_lock(&rps->lock);
GEM_BUG_ON(!rps->active); GEM_BUG_ON(!intel_rps_is_active(rps));
intel_rps_set(rps, freq); intel_rps_set(rps, freq);
GEM_BUG_ON(rps->last_freq != freq); GEM_BUG_ON(rps->last_freq != freq);
mutex_unlock(&rps->lock); mutex_unlock(&rps->lock);
...@@ -218,7 +218,7 @@ int live_rps_clock_interval(void *arg) ...@@ -218,7 +218,7 @@ int live_rps_clock_interval(void *arg)
struct igt_spinner spin; struct igt_spinner spin;
int err = 0; int err = 0;
if (!rps->enabled) if (!intel_rps_is_enabled(rps))
return 0; return 0;
if (igt_spinner_init(&spin, gt)) if (igt_spinner_init(&spin, gt))
...@@ -364,7 +364,7 @@ int live_rps_control(void *arg) ...@@ -364,7 +364,7 @@ int live_rps_control(void *arg)
* will be lowered than requested. * will be lowered than requested.
*/ */
if (!rps->enabled || rps->max_freq <= rps->min_freq) if (!intel_rps_is_enabled(rps))
return 0; return 0;
if (IS_CHERRYVIEW(gt->i915)) /* XXX fragile PCU */ if (IS_CHERRYVIEW(gt->i915)) /* XXX fragile PCU */
...@@ -595,7 +595,7 @@ int live_rps_frequency_cs(void *arg) ...@@ -595,7 +595,7 @@ int live_rps_frequency_cs(void *arg)
* frequency, the actual frequency, and the observed clock rate. * frequency, the actual frequency, and the observed clock rate.
*/ */
if (!rps->enabled || rps->max_freq <= rps->min_freq) if (!intel_rps_is_enabled(rps))
return 0; return 0;
if (INTEL_GEN(gt->i915) < 8) /* for CS simplicity */ if (INTEL_GEN(gt->i915) < 8) /* for CS simplicity */
...@@ -737,7 +737,7 @@ int live_rps_frequency_srm(void *arg) ...@@ -737,7 +737,7 @@ int live_rps_frequency_srm(void *arg)
* frequency, the actual frequency, and the observed clock rate. * frequency, the actual frequency, and the observed clock rate.
*/ */
if (!rps->enabled || rps->max_freq <= rps->min_freq) if (!intel_rps_is_enabled(rps))
return 0; return 0;
if (INTEL_GEN(gt->i915) < 8) /* for CS simplicity */ if (INTEL_GEN(gt->i915) < 8) /* for CS simplicity */
...@@ -904,7 +904,7 @@ static int __rps_up_interrupt(struct intel_rps *rps, ...@@ -904,7 +904,7 @@ static int __rps_up_interrupt(struct intel_rps *rps,
return -EIO; return -EIO;
} }
if (!rps->active) { if (!intel_rps_is_active(rps)) {
pr_err("%s: RPS not enabled on starting spinner\n", pr_err("%s: RPS not enabled on starting spinner\n",
engine->name); engine->name);
igt_spinner_end(spin); igt_spinner_end(spin);
...@@ -1017,7 +1017,7 @@ int live_rps_interrupt(void *arg) ...@@ -1017,7 +1017,7 @@ int live_rps_interrupt(void *arg)
* First, let's check whether or not we are receiving interrupts. * First, let's check whether or not we are receiving interrupts.
*/ */
if (!rps->enabled || rps->max_freq <= rps->min_freq) if (!intel_rps_is_enabled(rps))
return 0; return 0;
intel_gt_pm_get(gt); intel_gt_pm_get(gt);
...@@ -1041,7 +1041,7 @@ int live_rps_interrupt(void *arg) ...@@ -1041,7 +1041,7 @@ int live_rps_interrupt(void *arg)
unsigned long saved_heartbeat; unsigned long saved_heartbeat;
intel_gt_pm_wait_for_idle(engine->gt); intel_gt_pm_wait_for_idle(engine->gt);
GEM_BUG_ON(rps->active); GEM_BUG_ON(intel_rps_is_active(rps));
saved_heartbeat = engine_heartbeat_disable(engine); saved_heartbeat = engine_heartbeat_disable(engine);
...@@ -1126,7 +1126,7 @@ int live_rps_power(void *arg) ...@@ -1126,7 +1126,7 @@ int live_rps_power(void *arg)
* that theory. * that theory.
*/ */
if (!rps->enabled || rps->max_freq <= rps->min_freq) if (!intel_rps_is_enabled(rps))
return 0; return 0;
if (!librapl_energy_uJ()) if (!librapl_energy_uJ())
...@@ -1231,7 +1231,7 @@ int live_rps_dynamic(void *arg) ...@@ -1231,7 +1231,7 @@ int live_rps_dynamic(void *arg)
* moving parts into dynamic reclocking based on load. * moving parts into dynamic reclocking based on load.
*/ */
if (!rps->enabled || rps->max_freq <= rps->min_freq) if (!intel_rps_is_enabled(rps))
return 0; return 0;
if (igt_spinner_init(&spin, gt)) if (igt_spinner_init(&spin, gt))
...@@ -1248,7 +1248,7 @@ int live_rps_dynamic(void *arg) ...@@ -1248,7 +1248,7 @@ int live_rps_dynamic(void *arg)
continue; continue;
intel_gt_pm_wait_for_idle(gt); intel_gt_pm_wait_for_idle(gt);
GEM_BUG_ON(rps->active); GEM_BUG_ON(intel_rps_is_active(rps));
rps->cur_freq = rps->min_freq; rps->cur_freq = rps->min_freq;
intel_engine_pm_get(engine); intel_engine_pm_get(engine);
......
...@@ -1199,7 +1199,8 @@ static int i915_rps_boost_info(struct seq_file *m, void *data) ...@@ -1199,7 +1199,8 @@ static int i915_rps_boost_info(struct seq_file *m, void *data)
struct drm_i915_private *dev_priv = node_to_i915(m->private); struct drm_i915_private *dev_priv = node_to_i915(m->private);
struct intel_rps *rps = &dev_priv->gt.rps; struct intel_rps *rps = &dev_priv->gt.rps;
seq_printf(m, "RPS enabled? %d\n", rps->enabled); seq_printf(m, "RPS enabled? %s\n", yesno(intel_rps_is_enabled(rps)));
seq_printf(m, "RPS active? %s\n", yesno(intel_rps_is_active(rps)));
seq_printf(m, "GPU busy? %s\n", yesno(dev_priv->gt.awake)); seq_printf(m, "GPU busy? %s\n", yesno(dev_priv->gt.awake));
seq_printf(m, "Boosts outstanding? %d\n", seq_printf(m, "Boosts outstanding? %d\n",
atomic_read(&rps->num_waiters)); atomic_read(&rps->num_waiters));
...@@ -1219,7 +1220,7 @@ static int i915_rps_boost_info(struct seq_file *m, void *data) ...@@ -1219,7 +1220,7 @@ static int i915_rps_boost_info(struct seq_file *m, void *data)
seq_printf(m, "Wait boosts: %d\n", atomic_read(&rps->boosts)); seq_printf(m, "Wait boosts: %d\n", atomic_read(&rps->boosts));
if (INTEL_GEN(dev_priv) >= 6 && rps->enabled && dev_priv->gt.awake) { if (INTEL_GEN(dev_priv) >= 6 && intel_rps_is_active(rps)) {
u32 rpup, rpupei; u32 rpup, rpupei;
u32 rpdown, rpdownei; u32 rpdown, rpdownei;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册