Skip to content
This repository was archived by the owner on Nov 8, 2023. It is now read-only.

Commit cfd36ae

Browse files
committed
Merge tag 'drm-intel-fixes-2024-05-30' of https://gitlab.freedesktop.org/drm/i915/kernel into drm-fixes
drm/i915 fixes for v6.10-rc2: - Fix a race in audio component by registering it later - Make DPT object unshrinkable to avoid shrinking when framebuffer has not shrunk - Fix CCS id calculation to fix a perf regression - Fix selftest caching mode - Fix FIELD_PREP compiler warnings - Fix indefinite wait for GT wakeref release - Revert overeager multi-gt pm reference removal Signed-off-by: Dave Airlie <airlied@redhat.com> From: Jani Nikula <jani.nikula@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/87a5k7iwod.fsf@intel.com
2 parents 3e049b6 + 75800e2 commit cfd36ae

File tree

11 files changed

+71
-25
lines changed

11 files changed

+71
-25
lines changed

drivers/gpu/drm/i915/display/intel_audio.c

Lines changed: 21 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -1252,17 +1252,6 @@ static const struct component_ops i915_audio_component_bind_ops = {
12521252
static void i915_audio_component_init(struct drm_i915_private *i915)
12531253
{
12541254
u32 aud_freq, aud_freq_init;
1255-
int ret;
1256-
1257-
ret = component_add_typed(i915->drm.dev,
1258-
&i915_audio_component_bind_ops,
1259-
I915_COMPONENT_AUDIO);
1260-
if (ret < 0) {
1261-
drm_err(&i915->drm,
1262-
"failed to add audio component (%d)\n", ret);
1263-
/* continue with reduced functionality */
1264-
return;
1265-
}
12661255

12671256
if (DISPLAY_VER(i915) >= 9) {
12681257
aud_freq_init = intel_de_read(i915, AUD_FREQ_CNTRL);
@@ -1285,6 +1274,21 @@ static void i915_audio_component_init(struct drm_i915_private *i915)
12851274

12861275
/* init with current cdclk */
12871276
intel_audio_cdclk_change_post(i915);
1277+
}
1278+
1279+
static void i915_audio_component_register(struct drm_i915_private *i915)
1280+
{
1281+
int ret;
1282+
1283+
ret = component_add_typed(i915->drm.dev,
1284+
&i915_audio_component_bind_ops,
1285+
I915_COMPONENT_AUDIO);
1286+
if (ret < 0) {
1287+
drm_err(&i915->drm,
1288+
"failed to add audio component (%d)\n", ret);
1289+
/* continue with reduced functionality */
1290+
return;
1291+
}
12881292

12891293
i915->display.audio.component_registered = true;
12901294
}
@@ -1317,6 +1321,12 @@ void intel_audio_init(struct drm_i915_private *i915)
13171321
i915_audio_component_init(i915);
13181322
}
13191323

1324+
void intel_audio_register(struct drm_i915_private *i915)
1325+
{
1326+
if (!i915->display.audio.lpe.platdev)
1327+
i915_audio_component_register(i915);
1328+
}
1329+
13201330
/**
13211331
* intel_audio_deinit() - deinitialize the audio driver
13221332
* @i915: the i915 drm device private data

drivers/gpu/drm/i915/display/intel_audio.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -28,6 +28,7 @@ void intel_audio_codec_get_config(struct intel_encoder *encoder,
2828
void intel_audio_cdclk_change_pre(struct drm_i915_private *dev_priv);
2929
void intel_audio_cdclk_change_post(struct drm_i915_private *dev_priv);
3030
void intel_audio_init(struct drm_i915_private *dev_priv);
31+
void intel_audio_register(struct drm_i915_private *i915);
3132
void intel_audio_deinit(struct drm_i915_private *dev_priv);
3233
void intel_audio_sdp_split_update(const struct intel_crtc_state *crtc_state);
3334

drivers/gpu/drm/i915/display/intel_display_driver.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -540,6 +540,8 @@ void intel_display_driver_register(struct drm_i915_private *i915)
540540

541541
intel_display_driver_enable_user_access(i915);
542542

543+
intel_audio_register(i915);
544+
543545
intel_display_debugfs_register(i915);
544546

545547
/*

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

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -255,6 +255,7 @@ struct i915_execbuffer {
255255
struct intel_context *context; /* logical state for the request */
256256
struct i915_gem_context *gem_context; /** caller's context */
257257
intel_wakeref_t wakeref;
258+
intel_wakeref_t wakeref_gt0;
258259

259260
/** our requests to build */
260261
struct i915_request *requests[MAX_ENGINE_INSTANCE + 1];
@@ -2685,6 +2686,7 @@ static int
26852686
eb_select_engine(struct i915_execbuffer *eb)
26862687
{
26872688
struct intel_context *ce, *child;
2689+
struct intel_gt *gt;
26882690
unsigned int idx;
26892691
int err;
26902692

@@ -2708,10 +2710,17 @@ eb_select_engine(struct i915_execbuffer *eb)
27082710
}
27092711
}
27102712
eb->num_batches = ce->parallel.number_children + 1;
2713+
gt = ce->engine->gt;
27112714

27122715
for_each_child(ce, child)
27132716
intel_context_get(child);
27142717
eb->wakeref = intel_gt_pm_get(ce->engine->gt);
2718+
/*
2719+
* Keep GT0 active on MTL so that i915_vma_parked() doesn't
2720+
* free VMAs while execbuf ioctl is validating VMAs.
2721+
*/
2722+
if (gt->info.id)
2723+
eb->wakeref_gt0 = intel_gt_pm_get(to_gt(gt->i915));
27152724

27162725
if (!test_bit(CONTEXT_ALLOC_BIT, &ce->flags)) {
27172726
err = intel_context_alloc_state(ce);
@@ -2750,6 +2759,9 @@ eb_select_engine(struct i915_execbuffer *eb)
27502759
return err;
27512760

27522761
err:
2762+
if (gt->info.id)
2763+
intel_gt_pm_put(to_gt(gt->i915), eb->wakeref_gt0);
2764+
27532765
intel_gt_pm_put(ce->engine->gt, eb->wakeref);
27542766
for_each_child(ce, child)
27552767
intel_context_put(child);
@@ -2763,6 +2775,12 @@ eb_put_engine(struct i915_execbuffer *eb)
27632775
struct intel_context *child;
27642776

27652777
i915_vm_put(eb->context->vm);
2778+
/*
2779+
* This works in conjunction with eb_select_engine() to prevent
2780+
* i915_vma_parked() from interfering while execbuf validates vmas.
2781+
*/
2782+
if (eb->gt->info.id)
2783+
intel_gt_pm_put(to_gt(eb->gt->i915), eb->wakeref_gt0);
27662784
intel_gt_pm_put(eb->context->engine->gt, eb->wakeref);
27672785
for_each_child(eb->context, child)
27682786
intel_context_put(child);

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

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -284,7 +284,9 @@ bool i915_gem_object_has_iomem(const struct drm_i915_gem_object *obj);
284284
static inline bool
285285
i915_gem_object_is_shrinkable(const struct drm_i915_gem_object *obj)
286286
{
287-
return i915_gem_object_type_has(obj, I915_GEM_OBJECT_IS_SHRINKABLE);
287+
/* TODO: make DPT shrinkable when it has no bound vmas */
288+
return i915_gem_object_type_has(obj, I915_GEM_OBJECT_IS_SHRINKABLE) &&
289+
!obj->is_dpt;
288290
}
289291

290292
static inline bool

drivers/gpu/drm/i915/gem/selftests/i915_gem_dmabuf.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -196,7 +196,7 @@ static int verify_access(struct drm_i915_private *i915,
196196
if (err)
197197
goto out_file;
198198

199-
mode = intel_gt_coherent_map_type(to_gt(i915), native_obj, true);
199+
mode = intel_gt_coherent_map_type(to_gt(i915), native_obj, false);
200200
vaddr = i915_gem_object_pin_map_unlocked(native_obj, mode);
201201
if (IS_ERR(vaddr)) {
202202
err = PTR_ERR(vaddr);

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

Lines changed: 7 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -263,8 +263,13 @@ static void signal_irq_work(struct irq_work *work)
263263
i915_request_put(rq);
264264
}
265265

266+
/* Lazy irq enabling after HW submission */
266267
if (!READ_ONCE(b->irq_armed) && !list_empty(&b->signalers))
267268
intel_breadcrumbs_arm_irq(b);
269+
270+
/* And confirm that we still want irqs enabled before we yield */
271+
if (READ_ONCE(b->irq_armed) && !atomic_read(&b->active))
272+
intel_breadcrumbs_disarm_irq(b);
268273
}
269274

270275
struct intel_breadcrumbs *
@@ -315,13 +320,7 @@ void __intel_breadcrumbs_park(struct intel_breadcrumbs *b)
315320
return;
316321

317322
/* Kick the work once more to drain the signalers, and disarm the irq */
318-
irq_work_sync(&b->irq_work);
319-
while (READ_ONCE(b->irq_armed) && !atomic_read(&b->active)) {
320-
local_irq_disable();
321-
signal_irq_work(&b->irq_work);
322-
local_irq_enable();
323-
cond_resched();
324-
}
323+
irq_work_queue(&b->irq_work);
325324
}
326325

327326
void intel_breadcrumbs_free(struct kref *kref)
@@ -404,7 +403,7 @@ static void insert_breadcrumb(struct i915_request *rq)
404403
* the request as it may have completed and raised the interrupt as
405404
* we were attaching it into the lists.
406405
*/
407-
if (!b->irq_armed || __i915_request_is_complete(rq))
406+
if (!READ_ONCE(b->irq_armed) || __i915_request_is_complete(rq))
408407
irq_work_queue(&b->irq_work);
409408
}
410409

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

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -885,6 +885,12 @@ static intel_engine_mask_t init_engine_mask(struct intel_gt *gt)
885885
if (IS_DG2(gt->i915)) {
886886
u8 first_ccs = __ffs(CCS_MASK(gt));
887887

888+
/*
889+
* Store the number of active cslices before
890+
* changing the CCS engine configuration
891+
*/
892+
gt->ccs.cslices = CCS_MASK(gt);
893+
888894
/* Mask off all the CCS engine */
889895
info->engine_mask &= ~GENMASK(CCS3, CCS0);
890896
/* Put back in the first CCS engine */

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

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -19,7 +19,7 @@ unsigned int intel_gt_apply_ccs_mode(struct intel_gt *gt)
1919

2020
/* Build the value for the fixed CCS load balancing */
2121
for (cslice = 0; cslice < I915_MAX_CCS; cslice++) {
22-
if (CCS_MASK(gt) & BIT(cslice))
22+
if (gt->ccs.cslices & BIT(cslice))
2323
/*
2424
* If available, assign the cslice
2525
* to the first available engine...

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

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -207,6 +207,14 @@ struct intel_gt {
207207
[MAX_ENGINE_INSTANCE + 1];
208208
enum intel_submission_method submission_method;
209209

210+
struct {
211+
/*
212+
* Mask of the non fused CCS slices
213+
* to be used for the load balancing
214+
*/
215+
intel_engine_mask_t cslices;
216+
} ccs;
217+
210218
/*
211219
* Default address space (either GGTT or ppGTT depending on arch).
212220
*

0 commit comments

Comments
 (0)