Skip to content

Commit 643b450

Browse files
committed
drm/i915: Only track live rings for retiring
We don't need to track every ring for its lifetime as they are managed by the contexts/engines. What we do want to track are the live rings so that we can sporadically clean up requests if userspace falls behind. We can simply restrict the gt->rings list to being only gt->live_rings. v2: s/live/active/ for consistency with gt.active_requests Suggested-by: Tvrtko Ursulin <[email protected]> Signed-off-by: Chris Wilson <[email protected]> Cc: Tvrtko Ursulin <[email protected]> Reviewed-by: Tvrtko Ursulin <[email protected]> Link: https://patchwork.freedesktop.org/patch/msgid/[email protected]
1 parent b887d61 commit 643b450

File tree

7 files changed

+18
-16
lines changed

7 files changed

+18
-16
lines changed

drivers/gpu/drm/i915/i915_drv.h

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2061,7 +2061,8 @@ struct drm_i915_private {
20612061

20622062
struct i915_gem_timeline global_timeline;
20632063
struct list_head timelines;
2064-
struct list_head rings;
2064+
2065+
struct list_head active_rings;
20652066
u32 active_requests;
20662067
u32 request_serial;
20672068

drivers/gpu/drm/i915/i915_gem.c

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -141,6 +141,7 @@ static u32 __i915_gem_park(struct drm_i915_private *i915)
141141
{
142142
lockdep_assert_held(&i915->drm.struct_mutex);
143143
GEM_BUG_ON(i915->gt.active_requests);
144+
GEM_BUG_ON(!list_empty(&i915->gt.active_rings));
144145

145146
if (!i915->gt.awake)
146147
return I915_EPOCH_INVALID;
@@ -5599,9 +5600,10 @@ int i915_gem_init_early(struct drm_i915_private *dev_priv)
55995600
if (!dev_priv->priorities)
56005601
goto err_dependencies;
56015602

5602-
mutex_lock(&dev_priv->drm.struct_mutex);
5603-
INIT_LIST_HEAD(&dev_priv->gt.rings);
56045603
INIT_LIST_HEAD(&dev_priv->gt.timelines);
5604+
INIT_LIST_HEAD(&dev_priv->gt.active_rings);
5605+
5606+
mutex_lock(&dev_priv->drm.struct_mutex);
56055607
err = i915_gem_timeline_init__global(dev_priv);
56065608
mutex_unlock(&dev_priv->drm.struct_mutex);
56075609
if (err)

drivers/gpu/drm/i915/i915_request.c

Lines changed: 8 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -322,6 +322,7 @@ static void advance_ring(struct i915_request *request)
322322
* noops - they are safe to be replayed on a reset.
323323
*/
324324
tail = READ_ONCE(request->tail);
325+
list_del(&ring->active_link);
325326
} else {
326327
tail = request->postfix;
327328
}
@@ -1096,6 +1097,8 @@ void __i915_request_add(struct i915_request *request, bool flush_caches)
10961097
i915_gem_active_set(&timeline->last_request, request);
10971098

10981099
list_add_tail(&request->ring_link, &ring->request_list);
1100+
if (list_is_first(&request->ring_link, &ring->request_list))
1101+
list_add(&ring->active_link, &request->i915->gt.active_rings);
10991102
request->emitted_jiffies = jiffies;
11001103

11011104
/*
@@ -1418,14 +1421,17 @@ static void ring_retire_requests(struct intel_ring *ring)
14181421

14191422
void i915_retire_requests(struct drm_i915_private *i915)
14201423
{
1421-
struct intel_ring *ring, *next;
1424+
struct intel_ring *ring, *tmp;
14221425

14231426
lockdep_assert_held(&i915->drm.struct_mutex);
14241427

14251428
if (!i915->gt.active_requests)
14261429
return;
14271430

1428-
list_for_each_entry_safe(ring, next, &i915->gt.rings, link)
1431+
/* An outstanding request must be on a still active ring somewhere */
1432+
GEM_BUG_ON(list_empty(&i915->gt.active_rings));
1433+
1434+
list_for_each_entry_safe(ring, tmp, &i915->gt.active_rings, active_link)
14291435
ring_retire_requests(ring);
14301436
}
14311437

drivers/gpu/drm/i915/intel_ringbuffer.c

Lines changed: 0 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1150,8 +1150,6 @@ intel_engine_create_ring(struct intel_engine_cs *engine, int size)
11501150
}
11511151
ring->vma = vma;
11521152

1153-
list_add(&ring->link, &engine->i915->gt.rings);
1154-
11551153
return ring;
11561154
}
11571155

@@ -1163,8 +1161,6 @@ intel_ring_free(struct intel_ring *ring)
11631161
i915_vma_close(ring->vma);
11641162
__i915_gem_object_release_unless_active(obj);
11651163

1166-
list_del(&ring->link);
1167-
11681164
kfree(ring);
11691165
}
11701166

drivers/gpu/drm/i915/intel_ringbuffer.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -130,7 +130,7 @@ struct intel_ring {
130130
void *vaddr;
131131

132132
struct list_head request_list;
133-
struct list_head link;
133+
struct list_head active_link;
134134

135135
u32 head;
136136
u32 tail;

drivers/gpu/drm/i915/selftests/mock_engine.c

Lines changed: 0 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -147,15 +147,11 @@ static struct intel_ring *mock_ring(struct intel_engine_cs *engine)
147147
INIT_LIST_HEAD(&ring->request_list);
148148
intel_ring_update_space(ring);
149149

150-
list_add(&ring->link, &engine->i915->gt.rings);
151-
152150
return ring;
153151
}
154152

155153
static void mock_ring_free(struct intel_ring *ring)
156154
{
157-
list_del(&ring->link);
158-
159155
kfree(ring);
160156
}
161157

drivers/gpu/drm/i915/selftests/mock_gem_device.c

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -224,9 +224,10 @@ struct drm_i915_private *mock_gem_device(void)
224224
if (!i915->priorities)
225225
goto err_dependencies;
226226

227-
mutex_lock(&i915->drm.struct_mutex);
228-
INIT_LIST_HEAD(&i915->gt.rings);
229227
INIT_LIST_HEAD(&i915->gt.timelines);
228+
INIT_LIST_HEAD(&i915->gt.active_rings);
229+
230+
mutex_lock(&i915->drm.struct_mutex);
230231
err = i915_gem_timeline_init__global(i915);
231232
if (err) {
232233
mutex_unlock(&i915->drm.struct_mutex);

0 commit comments

Comments
 (0)