mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-04-04 18:11:39 -04:00
drm/i915/pmu: Wait longer for busyness data to be available from GuC
live_engine_busy_stats waits for busyness to start ticking before
sampling busyness for the test sample duration. The wait accesses an
MMIO register and the uncore call to read it takes up to 3 ms in the
worst case. This can result in the wait timing out since the MMIO read
itself consumes up the timeout of 500us. Increase the timeout to a
larger value of 10ms to account for the MMIO read time.
Closes: https://gitlab.freedesktop.org/drm/intel/-/issues/4536
Fixes: 77cdd054dd ("drm/i915/pmu: Connect engine busyness stats from GuC to pmu")
Signed-off-by: Umesh Nerlige Ramappa <umesh.nerlige.ramappa@intel.com>
Reviewed-by: Matthew Brost <matthew.brost@intel.com>
Signed-off-by: John Harrison <John.C.Harrison@Intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20211208183313.13126-1-umesh.nerlige.ramappa@intel.com
This commit is contained in:
committed by
John Harrison
parent
f122a46a63
commit
0b64e2e43d
@@ -229,7 +229,7 @@ static int __spin_until_busier(struct intel_engine_cs *engine, ktime_t busyness)
|
||||
start = ktime_get();
|
||||
while (intel_engine_get_busy_time(engine, &unused) == busyness) {
|
||||
dt = ktime_get() - start;
|
||||
if (dt > 500000) {
|
||||
if (dt > 10000000) {
|
||||
pr_err("active wait timed out %lld\n", dt);
|
||||
ENGINE_TRACE(engine, "active wait time out %lld\n", dt);
|
||||
return -ETIME;
|
||||
|
||||
Reference in New Issue
Block a user