[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <alpine.DEB.2.22.394.2307181922160.3532114@eliteleevi.tm.intel.com>
Date: Tue, 18 Jul 2023 20:04:41 +0300 (EEST)
From: Kai Vehmanen <kai.vehmanen@...ux.intel.com>
To: Maarten Lankhorst <maarten.lankhorst@...ux.intel.com>
cc: Alsa-devel <alsa-devel@...a-project.org>,
sound-open-firmware@...a-project.org, linux-kernel@...r.kernel.org,
Jaroslav Kysela <perex@...ex.cz>,
Takashi Iwai <tiwai@...e.com>,
Cezary Rojewski <cezary.rojewski@...el.com>,
Pierre-Louis Bossart <pierre-louis.bossart@...ux.intel.com>,
Liam Girdwood <liam.r.girdwood@...ux.intel.com>,
Peter Ujfalusi <peter.ujfalusi@...ux.intel.com>,
Bard Liao <yung-chuan.liao@...ux.intel.com>,
Ranjani Sridharan <ranjani.sridharan@...ux.intel.com>,
Kai Vehmanen <kai.vehmanen@...ux.intel.com>,
Mark Brown <broonie@...nel.org>,
Daniel Baluta <daniel.baluta@....com>,
Matthew Auld <matthew.auld@...el.com>
Subject: Re: [PATCH 6/7] ASoC: SOF: Intel: Remove deferred probe for SOF
Hi,
thank you Maarten for doing the series! I think a lot of people will be
happy to get rid of the 60sec timeout.
I kicked off a CI run SOF public infra for the whole series at
https://github.com/thesofproject/linux/pull/4478
Some results still in progress but so far so good.
Some concerns inline:
On Tue, 18 Jul 2023, Maarten Lankhorst wrote:
> This was only used to allow modprobing i915, by converting to the
> -EPROBE_DEFER mechanism, it can be completely removed, and is in
> fact counterproductive since -EPROBE_DEFER otherwise won't be
> handled correctly.
We actually have a request_module() for the regular HDA codec drivers as
well (sof_probe_continue() -> snd_sof_probe() -> hda_dsp_probe() ->
hda_init_caps() -> hda_codec_probe_bus(). But right, this is not
necessarily a problem on its own, so it looks we indeed can drop the work
queue. Nice!
> diff --git a/sound/soc/sof/intel/hda-codec.c b/sound/soc/sof/intel/hda-codec.c
> index f1fd5b44aaac9..344b61576c0e3 100644
> --- a/sound/soc/sof/intel/hda-codec.c
> +++ b/sound/soc/sof/intel/hda-codec.c
> @@ -415,7 +415,7 @@ int hda_codec_i915_init(struct snd_sof_dev *sdev)
> return 0;
>
> /* i915 exposes a HDA codec for HDMI audio */
> - ret = snd_hdac_i915_init(bus, true);
> + ret = snd_hdac_i915_init(bus, false);
> if (ret < 0)
> return ret;
My only bigger concern is corner cases where the display PCI device is on
the bus and visible to kernel, but for some reason there is no working
driver in the system or it is disabled.
With this patch, not having a workign display driver means that there is
also no audio in the system as the SOF driver will never get probed.
In current mainline, one will get the 60sec timeout warning and then
audio driver will proceed to probe and you'll have audio support (minus
HDMI/DP).
This is mostly an issue with very new hardware (e.g. hw is still
behind force_probe flag in xe/i915 driver), but we've had some odd
cases with e.g. systems with both Intel IGFX and other vendors' DGPU.
Audio drivers see the Intel VGA controller in system and will
call snd_hdac_i915_init(), but the audio component bind will never
succeed if the the Intel IGFX is not in actual use.
Will need a bit of time to think about possible scenarios. Possibly this
is not an issue outside early development systems. In theory if IGFX is
disabled in BIOS, and not visible to OS, we are good, and if it's visible,
the i915/xe driver should be loaded, so we are good again.
Br, Kai
Powered by blists - more mailing lists