[alsa-devel] [PATCH] ALSA: hda - verify pin:converter connection on unsol event for HSW and VLV
Takashi Iwai
tiwai at suse.de
Thu Jun 12 12:00:38 CEST 2014
At Thu, 12 Jun 2014 14:42:25 +0800,
mengdong.lin at intel.com wrote:
>
> From: Mengdong Lin <mengdong.lin at intel.com>
>
> This patch will verify the pin's coverter selection for an active stream
> when an unsol event reports this pin becomes available again after a display
> mode change or hot-plug event.
>
> For Haswell+ and Valleyview: display mode change or hot-plug can change the
> transcoder:port connection and make all the involved audio pins share the 1st
> converter. So the stream using 1st convertor will flow to multiple pins
> but active streams using other converters will fail. This workaround
> is to assure the pin selects the right conveter and an assigned converter is
> not shared by other unused pins.
>
> Signed-off-by: Mengdong Lin <mengdong.lin at intel.com>
Thanks, applied now with Cc to stable.
Takashi
>
> diff --git a/sound/pci/hda/patch_hdmi.c b/sound/pci/hda/patch_hdmi.c
> index be0a9ee..3e4417b 100644
> --- a/sound/pci/hda/patch_hdmi.c
> +++ b/sound/pci/hda/patch_hdmi.c
> @@ -1594,10 +1594,18 @@ static bool hdmi_present_sense(struct hdmi_spec_per_pin *per_pin, int repoll)
> * Re-setup pin and infoframe. This is needed e.g. when
> * - sink is first plugged-in (infoframe is not set up if !monitor_present)
> * - transcoder can change during stream playback on Haswell
> + * and this can make HW reset converter selection on a pin.
> */
> - if (eld->eld_valid && !old_eld_valid && per_pin->setup)
> + if (eld->eld_valid && !old_eld_valid && per_pin->setup) {
> + if (is_haswell_plus(codec) || is_valleyview(codec)) {
> + intel_verify_pin_cvt_connect(codec, per_pin);
> + intel_not_share_assigned_cvt(codec, pin_nid,
> + per_pin->mux_idx);
> + }
> +
> hdmi_setup_audio_infoframe(codec, per_pin,
> per_pin->non_pcm);
> + }
> }
>
> if (eld_changed)
> --
> 1.8.1.2
>
More information about the Alsa-devel
mailing list