Skip to content

Commit

Permalink
drm/i915/gt: Lock intel_engine_apply_whitelist with uncore->lock
Browse files Browse the repository at this point in the history
Refactor intel_engine_apply_whitelist into locked and unlocked versions
so that a caller who already has the lock can apply whitelist.

Signed-off-by: Umesh Nerlige Ramappa <umesh.nerlige.ramappa@intel.com>
  • Loading branch information
unerlige authored and intel-lab-lkp committed Oct 2, 2020
1 parent 47dd81c commit d8a4c73
Showing 1 changed file with 31 additions and 13 deletions.
44 changes: 31 additions & 13 deletions drivers/gpu/drm/i915/gt/intel_workarounds.c
Expand Up @@ -1295,7 +1295,8 @@ void intel_gt_init_workarounds(struct drm_i915_private *i915)
}

static enum forcewake_domains
wal_get_fw_for_rmw(struct intel_uncore *uncore, const struct i915_wa_list *wal)
wal_get_fw(struct intel_uncore *uncore, const struct i915_wa_list *wal,
unsigned int op)
{
enum forcewake_domains fw = 0;
struct i915_wa *wa;
Expand All @@ -1304,8 +1305,7 @@ wal_get_fw_for_rmw(struct intel_uncore *uncore, const struct i915_wa_list *wal)
for (i = 0, wa = wal->list; i < wal->count; i++, wa++)
fw |= intel_uncore_forcewake_for_reg(uncore,
wa->reg,
FW_REG_READ |
FW_REG_WRITE);
op);

return fw;
}
Expand Down Expand Up @@ -1335,7 +1335,7 @@ wa_list_apply(struct intel_uncore *uncore, const struct i915_wa_list *wal)
if (!wal->count)
return;

fw = wal_get_fw_for_rmw(uncore, wal);
fw = wal_get_fw(uncore, wal, FW_REG_READ | FW_REG_WRITE);

spin_lock_irqsave(&uncore->lock, flags);
intel_uncore_forcewake_get__locked(uncore, fw);
Expand Down Expand Up @@ -1645,27 +1645,45 @@ void intel_engine_init_whitelist(struct intel_engine_cs *engine)
wa_init_finish(w);
}

void intel_engine_apply_whitelist(struct intel_engine_cs *engine)
void intel_engine_apply_whitelist_locked(struct intel_engine_cs *engine)
{
const struct i915_wa_list *wal = &engine->whitelist;
struct intel_uncore *uncore = engine->uncore;
const u32 base = engine->mmio_base;
struct i915_wa *wa;
unsigned int i;
enum forcewake_domains fw;

if (!wal->count)
return;
lockdep_assert_held(&uncore->lock);

fw = wal_get_fw(uncore, wal, FW_REG_WRITE);
intel_uncore_forcewake_get__locked(uncore, fw);

for (i = 0, wa = wal->list; i < wal->count; i++, wa++)
intel_uncore_write(uncore,
RING_FORCE_TO_NONPRIV(base, i),
i915_mmio_reg_offset(wa->reg));
intel_uncore_write_fw(uncore,
RING_FORCE_TO_NONPRIV(base, i),
i915_mmio_reg_offset(wa->reg));

/* And clear the rest just in case of garbage */
for (; i < RING_MAX_NONPRIV_SLOTS; i++)
intel_uncore_write(uncore,
RING_FORCE_TO_NONPRIV(base, i),
i915_mmio_reg_offset(RING_NOPID(base)));
intel_uncore_write_fw(uncore,
RING_FORCE_TO_NONPRIV(base, i),
i915_mmio_reg_offset(RING_NOPID(base)));

intel_uncore_forcewake_put__locked(uncore, fw);
}

void intel_engine_apply_whitelist(struct intel_engine_cs *engine)
{
unsigned long flags;
const struct i915_wa_list *wal = &engine->whitelist;

if (!wal->count)
return;

spin_lock_irqsave(&engine->uncore->lock, flags);
intel_engine_apply_whitelist_locked(engine);
spin_unlock_irqrestore(&engine->uncore->lock, flags);
}

static void
Expand Down

0 comments on commit d8a4c73

Please sign in to comment.