Lines Matching full:timeline
30 u64 timeline; member
157 /* Make the cached node available for reuse with any timeline */ in __active_retire()
158 ref->cache->timeline = 0; /* needs cmpxchg(u64) */ in __active_retire()
170 /* Finally free the discarded timeline tree */ in __active_retire()
237 GEM_BUG_ON(idx == 0); /* 0 is the unordered timeline, rsvd for cache */ in __active_lookup()
240 * We track the most recently used timeline to skip a rbtree search in __active_lookup()
244 * current timeline. in __active_lookup()
248 u64 cached = READ_ONCE(it->timeline); in __active_lookup()
255 * An unclaimed cache [.timeline=0] can only be claimed once. in __active_lookup()
259 * idx. If, and only if, the timeline is currently zero is it in __active_lookup()
264 if (!cached && !cmpxchg64(&it->timeline, 0, idx)) in __active_lookup()
275 if (it->timeline < idx) { in __active_lookup()
277 } else if (it->timeline > idx) { in __active_lookup()
308 if (node->timeline == idx) in active_instance()
311 if (node->timeline < idx) in active_instance()
327 node->timeline = idx; in active_instance()
374 GEM_BUG_ON(node->timeline != engine->kernel_context->timeline->fence_context); in ____active_del_barrier()
378 * outside of the kernel_context timeline mutex and so someone in ____active_del_barrier()
421 * This request is on the kernel_context timeline, and so in replace_barrier()
484 /* We expect the caller to manage the exclusive timeline ordering */ in i915_active_set_exclusive()
770 return node->timeline == idx && !i915_active_fence_isset(&node->base); in is_idle_barrier()
804 if (node->timeline < idx) in reuse_idle_barrier()
813 * any idle-barriers on this timeline that we missed, or just use in reuse_idle_barrier()
821 if (node->timeline > idx) in reuse_idle_barrier()
824 if (node->timeline < idx) in reuse_idle_barrier()
832 * kernel_context timeline, which notably we do not hold in reuse_idle_barrier()
877 u64 idx = engine->kernel_context->timeline->fence_context; in i915_active_acquire_preallocate_barrier()
891 node->timeline = idx; in i915_active_acquire_preallocate_barrier()
966 if (it->timeline < node->timeline) in i915_active_acquire_barrier()
994 GEM_BUG_ON(i915_request_timeline(rq) != engine->kernel_context->timeline); in i915_request_add_active_barriers()
1014 * __i915_active_fence_set: Update the last active fence along its timeline
1018 * Records the new @fence as the last active fence along its timeline in
1022 * that the order of fences within the timeline of the i915_active_fence is
1044 * we are first on the timeline. If it is still present, in __i915_active_fence_set()
1053 * Note the strong ordering of the timeline also provides consistent in __i915_active_fence_set()
1077 /* Must maintain timeline ordering wrt previous active requests */ in i915_active_fence_set()
1080 if (fence) /* but the previous fence may not belong to that timeline! */ in i915_active_fence_set()