Skip to content

Commit 48ae397

Browse files
committed
drm/i915: Push the ring creation flags to the backend
Push the ring creation flags from the outer GEM context to the inner intel_context to avoid an unsightly back-reference from inside the backend. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Reviewed-by: Andi Shyti <andi.shyti@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20190809182518.20486-3-chris@chris-wilson.co.uk
1 parent 4c60b1a commit 48ae397

File tree

10 files changed

+59
-32
lines changed

10 files changed

+59
-32
lines changed

drivers/gpu/drm/i915/gem/i915_gem_context.c

Lines changed: 26 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -436,8 +436,6 @@ __create_context(struct drm_i915_private *i915)
436436
i915_gem_context_set_bannable(ctx);
437437
i915_gem_context_set_recoverable(ctx);
438438

439-
ctx->ring_size = 4 * PAGE_SIZE;
440-
441439
for (i = 0; i < ARRAY_SIZE(ctx->hang_timestamp); i++)
442440
ctx->hang_timestamp[i] = jiffies - CONTEXT_FAST_HANG_JIFFIES;
443441

@@ -448,22 +446,34 @@ __create_context(struct drm_i915_private *i915)
448446
return ERR_PTR(err);
449447
}
450448

449+
static void
450+
context_apply_all(struct i915_gem_context *ctx,
451+
void (*fn)(struct intel_context *ce, void *data),
452+
void *data)
453+
{
454+
struct i915_gem_engines_iter it;
455+
struct intel_context *ce;
456+
457+
for_each_gem_engine(ce, i915_gem_context_lock_engines(ctx), it)
458+
fn(ce, data);
459+
i915_gem_context_unlock_engines(ctx);
460+
}
461+
462+
static void __apply_ppgtt(struct intel_context *ce, void *vm)
463+
{
464+
i915_vm_put(ce->vm);
465+
ce->vm = i915_vm_get(vm);
466+
}
467+
451468
static struct i915_address_space *
452469
__set_ppgtt(struct i915_gem_context *ctx, struct i915_address_space *vm)
453470
{
454471
struct i915_address_space *old = ctx->vm;
455-
struct i915_gem_engines_iter it;
456-
struct intel_context *ce;
457472

458473
GEM_BUG_ON(old && i915_vm_is_4lvl(vm) != i915_vm_is_4lvl(old));
459474

460475
ctx->vm = i915_vm_get(vm);
461-
462-
for_each_gem_engine(ce, i915_gem_context_lock_engines(ctx), it) {
463-
i915_vm_put(ce->vm);
464-
ce->vm = i915_vm_get(vm);
465-
}
466-
i915_gem_context_unlock_engines(ctx);
476+
context_apply_all(ctx, __apply_ppgtt, vm);
467477

468478
return old;
469479
}
@@ -560,7 +570,6 @@ i915_gem_context_create_kernel(struct drm_i915_private *i915, int prio)
560570

561571
i915_gem_context_clear_bannable(ctx);
562572
ctx->sched.priority = I915_USER_PRIORITY(prio);
563-
ctx->ring_size = PAGE_SIZE;
564573

565574
GEM_BUG_ON(!i915_gem_context_is_kernel(ctx));
566575

@@ -1544,6 +1553,7 @@ set_engines(struct i915_gem_context *ctx,
15441553
for (n = 0; n < num_engines; n++) {
15451554
struct i915_engine_class_instance ci;
15461555
struct intel_engine_cs *engine;
1556+
struct intel_context *ce;
15471557

15481558
if (copy_from_user(&ci, &user->engines[n], sizeof(ci))) {
15491559
__free_engines(set.engines, n);
@@ -1566,11 +1576,13 @@ set_engines(struct i915_gem_context *ctx,
15661576
return -ENOENT;
15671577
}
15681578

1569-
set.engines->engines[n] = intel_context_create(ctx, engine);
1570-
if (!set.engines->engines[n]) {
1579+
ce = intel_context_create(ctx, engine);
1580+
if (IS_ERR(ce)) {
15711581
__free_engines(set.engines, n);
1572-
return -ENOMEM;
1582+
return PTR_ERR(ce);
15731583
}
1584+
1585+
set.engines->engines[n] = ce;
15741586
}
15751587
set.engines->num_engines = num_engines;
15761588

drivers/gpu/drm/i915/gem/i915_gem_context_types.h

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -169,9 +169,6 @@ struct i915_gem_context {
169169

170170
struct i915_sched_attr sched;
171171

172-
/** ring_size: size for allocating the per-engine ring buffer */
173-
u32 ring_size;
174-
175172
/** guilty_count: How many times this context has caused a GPU hang. */
176173
atomic_t guilty_count;
177174
/**

drivers/gpu/drm/i915/gt/intel_context.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -222,6 +222,7 @@ intel_context_init(struct intel_context *ce,
222222
ce->engine = engine;
223223
ce->ops = engine->cops;
224224
ce->sseu = engine->sseu;
225+
ce->ring = __intel_context_ring_size(SZ_16K);
225226

226227
INIT_LIST_HEAD(&ce->signal_link);
227228
INIT_LIST_HEAD(&ce->signals);

drivers/gpu/drm/i915/gt/intel_context.h

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -136,4 +136,9 @@ int intel_context_prepare_remote_request(struct intel_context *ce,
136136

137137
struct i915_request *intel_context_create_request(struct intel_context *ce);
138138

139+
static inline struct intel_ring *__intel_context_ring_size(u64 sz)
140+
{
141+
return u64_to_ptr(struct intel_ring, sz);
142+
}
143+
139144
#endif /* __INTEL_CONTEXT_H__ */

drivers/gpu/drm/i915/gt/intel_engine_cs.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -738,6 +738,8 @@ create_kernel_context(struct intel_engine_cs *engine)
738738
if (IS_ERR(ce))
739739
return ce;
740740

741+
ce->ring = __intel_context_ring_size(SZ_4K);
742+
741743
err = intel_context_pin(ce);
742744
if (err) {
743745
intel_context_put(ce);

drivers/gpu/drm/i915/gt/intel_lrc.c

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -3115,9 +3115,8 @@ static int __execlists_context_alloc(struct intel_context *ce,
31153115
goto error_deref_obj;
31163116
}
31173117

3118-
ring = intel_engine_create_ring(engine,
3119-
timeline,
3120-
ce->gem_context->ring_size);
3118+
ring = intel_engine_create_ring(engine, timeline,
3119+
(unsigned long)ce->ring);
31213120
intel_timeline_put(timeline);
31223121
if (IS_ERR(ring)) {
31233122
ret = PTR_ERR(ring);

drivers/gpu/drm/i915/gt/intel_ringbuffer.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2350,7 +2350,7 @@ int intel_ring_submission_init(struct intel_engine_cs *engine)
23502350
}
23512351
GEM_BUG_ON(timeline->has_initial_breadcrumb);
23522352

2353-
ring = intel_engine_create_ring(engine, timeline, 32 * PAGE_SIZE);
2353+
ring = intel_engine_create_ring(engine, timeline, SZ_16K);
23542354
intel_timeline_put(timeline);
23552355
if (IS_ERR(ring)) {
23562356
err = PTR_ERR(ring);

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

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -140,7 +140,7 @@ static void mock_context_destroy(struct kref *ref)
140140

141141
GEM_BUG_ON(intel_context_is_pinned(ce));
142142

143-
if (ce->ring)
143+
if (test_bit(CONTEXT_ALLOC_BIT, &ce->flags))
144144
mock_ring_free(ce->ring);
145145

146146
intel_context_fini(ce);

drivers/gpu/drm/i915/gvt/scheduler.c

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1227,8 +1227,6 @@ int intel_vgpu_setup_submission(struct intel_vgpu *vgpu)
12271227
}
12281228

12291229
i915_gem_context_set_force_single_submission(ctx);
1230-
if (!USES_GUC_SUBMISSION(i915))
1231-
ctx->ring_size = 512 * PAGE_SIZE; /* Max ring buffer size */
12321230

12331231
i915_context_ppgtt_root_save(s, i915_vm_to_ppgtt(ctx->vm));
12341232

@@ -1244,6 +1242,12 @@ int intel_vgpu_setup_submission(struct intel_vgpu *vgpu)
12441242
goto out_shadow_ctx;
12451243
}
12461244

1245+
if (!USES_GUC_SUBMISSION(i915)) { /* Max ring buffer size */
1246+
const unsigned int ring_size = 512 * SZ_4K;
1247+
1248+
ce->ring = __intel_context_ring_size(ring_size);
1249+
}
1250+
12471251
ret = intel_context_pin(ce);
12481252
intel_context_put(ce);
12491253
if (ret)

drivers/gpu/drm/i915/i915_debugfs.c

Lines changed: 15 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -324,10 +324,14 @@ static void print_context_stats(struct seq_file *m,
324324

325325
for_each_gem_engine(ce,
326326
i915_gem_context_lock_engines(ctx), it) {
327-
if (ce->state)
328-
per_file_stats(0, ce->state->obj, &kstats);
329-
if (ce->ring)
327+
intel_context_lock_pinned(ce);
328+
if (intel_context_is_pinned(ce)) {
329+
if (ce->state)
330+
per_file_stats(0,
331+
ce->state->obj, &kstats);
330332
per_file_stats(0, ce->ring->vma->obj, &kstats);
333+
}
334+
intel_context_unlock_pinned(ce);
331335
}
332336
i915_gem_context_unlock_engines(ctx);
333337

@@ -1627,12 +1631,15 @@ static int i915_context_status(struct seq_file *m, void *unused)
16271631

16281632
for_each_gem_engine(ce,
16291633
i915_gem_context_lock_engines(ctx), it) {
1630-
seq_printf(m, "%s: ", ce->engine->name);
1631-
if (ce->state)
1632-
describe_obj(m, ce->state->obj);
1633-
if (ce->ring)
1634+
intel_context_lock_pinned(ce);
1635+
if (intel_context_is_pinned(ce)) {
1636+
seq_printf(m, "%s: ", ce->engine->name);
1637+
if (ce->state)
1638+
describe_obj(m, ce->state->obj);
16341639
describe_ctx_ring(m, ce->ring);
1635-
seq_putc(m, '\n');
1640+
seq_putc(m, '\n');
1641+
}
1642+
intel_context_unlock_pinned(ce);
16361643
}
16371644
i915_gem_context_unlock_engines(ctx);
16381645

0 commit comments

Comments
 (0)