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

Commit 75800e2

Browse files
ideakjnikula
authored andcommitted
drm/i915: Fix audio component initialization
After registering the audio component in i915_audio_component_init() the audio driver may call i915_audio_component_get_power() via the component ops. This could program AUD_FREQ_CNTRL with an uninitialized value if the latter function is called before display.audio.freq_cntrl gets initialized. The get_power() function also does a modeset which in the above case happens too early before the initialization step and triggers the "Reject display access from task" error message added by the Fixes: commit below. Fix the above issue by registering the audio component only after the initialization step. Fixes: 87c1694 ("drm/i915: save AUD_FREQ_CNTRL state at audio domain suspend") Closes: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/10291 Cc: stable@vger.kernel.org # v5.5+ Signed-off-by: Imre Deak <imre.deak@intel.com> Reviewed-by: Jani Nikula <jani.nikula@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20240521143022.3784539-1-imre.deak@intel.com (cherry picked from commit fdd0b80) Signed-off-by: Jani Nikula <jani.nikula@intel.com>
1 parent 43e2b37 commit 75800e2

File tree

3 files changed

+24
-11
lines changed

3 files changed

+24
-11
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
/*

0 commit comments

Comments
 (0)