diff options
Diffstat (limited to 'sound/pci/hda/patch_hdmi.c')
| -rw-r--r-- | sound/pci/hda/patch_hdmi.c | 12 | 
1 files changed, 7 insertions, 5 deletions
| diff --git a/sound/pci/hda/patch_hdmi.c b/sound/pci/hda/patch_hdmi.c index 5af372d01834..1483f85999ec 100644 --- a/sound/pci/hda/patch_hdmi.c +++ b/sound/pci/hda/patch_hdmi.c @@ -1396,7 +1396,6 @@ static bool hdmi_present_sense_via_verbs(struct hdmi_spec_per_pin *per_pin,  	struct hda_codec *codec = per_pin->codec;  	struct hdmi_spec *spec = codec->spec;  	struct hdmi_eld *eld = &spec->temp_eld; -	struct hdmi_eld *pin_eld = &per_pin->sink_eld;  	hda_nid_t pin_nid = per_pin->pin_nid;  	/*  	 * Always execute a GetPinSense verb here, even when called from @@ -1413,15 +1412,15 @@ static bool hdmi_present_sense_via_verbs(struct hdmi_spec_per_pin *per_pin,  	present = snd_hda_pin_sense(codec, pin_nid);  	mutex_lock(&per_pin->lock); -	pin_eld->monitor_present = !!(present & AC_PINSENSE_PRESENCE); -	if (pin_eld->monitor_present) +	eld->monitor_present = !!(present & AC_PINSENSE_PRESENCE); +	if (eld->monitor_present)  		eld->eld_valid  = !!(present & AC_PINSENSE_ELDV);  	else  		eld->eld_valid = false;  	codec_dbg(codec,  		"HDMI status: Codec=%d Pin=%d Presence_Detect=%d ELD_Valid=%d\n", -		codec->addr, pin_nid, pin_eld->monitor_present, eld->eld_valid); +		codec->addr, pin_nid, eld->monitor_present, eld->eld_valid);  	if (eld->eld_valid) {  		if (spec->ops.pin_get_eld(codec, pin_nid, eld->eld_buffer, @@ -1441,7 +1440,7 @@ static bool hdmi_present_sense_via_verbs(struct hdmi_spec_per_pin *per_pin,  	else  		update_eld(codec, per_pin, eld); -	ret = !repoll || !pin_eld->monitor_present || pin_eld->eld_valid; +	ret = !repoll || !eld->monitor_present || eld->eld_valid;  	jack = snd_hda_jack_tbl_get(codec, pin_nid);  	if (jack) @@ -1859,6 +1858,8 @@ static void hdmi_set_chmap(struct hdac_device *hdac, int pcm_idx,  	struct hdmi_spec *spec = codec->spec;  	struct hdmi_spec_per_pin *per_pin = pcm_idx_to_pin(spec, pcm_idx); +	if (!per_pin) +		return;  	mutex_lock(&per_pin->lock);  	per_pin->chmap_set = true;  	memcpy(per_pin->chmap, chmap, ARRAY_SIZE(per_pin->chmap)); @@ -2231,6 +2232,7 @@ static void intel_pin_eld_notify(void *audio_ptr, int port)  	if (atomic_read(&(codec)->core.in_pm))  		return; +	snd_hdac_i915_set_bclk(&codec->bus->core);  	check_presence_and_report(codec, pin_nid);  } | 
