bool igt_wait_for_spinner(struct igt_spinner *spin, struct i915_request *rq) { return !(wait_for_us(i915_seqno_passed(hws_seqno(spin, rq), rq->fence.seqno), 10) && wait_for(i915_seqno_passed(hws_seqno(spin, rq), rq->fence.seqno), 1000)); }
static bool wait_until_running(struct hang *h, struct i915_request *rq) { return !(wait_for_us(i915_seqno_passed(hws_seqno(h, rq), rq->fence.seqno), 10) && wait_for(i915_seqno_passed(hws_seqno(h, rq), rq->fence.seqno), 1000)); }
static int semaphore_passed(struct intel_engine_cs *engine) { struct drm_i915_private *dev_priv = engine->i915; struct intel_engine_cs *signaller; u32 seqno; engine->hangcheck.deadlock++; signaller = semaphore_waits_for(engine, &seqno); if (signaller == NULL) return -1; if (IS_ERR(signaller)) return 0; /* Prevent pathological recursion due to driver bugs */ if (signaller->hangcheck.deadlock >= I915_NUM_ENGINES) return -1; if (i915_seqno_passed(intel_engine_get_seqno(signaller), seqno)) return 1; /* cursory check for an unkickable deadlock */ if (I915_READ_CTL(signaller) & RING_WAIT_SEMAPHORE && semaphore_passed(signaller) < 0) return -1; return 0; }
static int igt_wakeup_thread(void *arg) { struct igt_wakeup *w = arg; struct intel_wait wait; while (wait_for_ready(w)) { GEM_BUG_ON(kthread_should_stop()); intel_wait_init_for_seqno(&wait, w->seqno); intel_engine_add_wait(w->engine, &wait); for (;;) { set_current_state(TASK_UNINTERRUPTIBLE); if (i915_seqno_passed(intel_engine_get_seqno(w->engine), w->seqno)) break; if (test_bit(STOP, &w->flags)) /* emergency escape */ break; schedule(); } intel_engine_remove_wait(w->engine, &wait); __set_current_state(TASK_RUNNING); } return 0; }