[Intel-gfx] [PATCH] drm/i915/chv: Enable HDMI Clock recovery for Pipe C

Jani Nikula jani.nikula at linux.intel.com
Fri Dec 5 00:37:48 PST 2014


On Fri, 05 Dec 2014, Clint Taylor <clinton.a.taylor at intel.com> wrote:
> On 12/04/2014 11:08 AM, Clint Taylor wrote:
>> On 12/04/2014 12:41 AM, Jani Nikula wrote:
>>> On Wed, 03 Dec 2014, Clint Taylor <clinton.a.taylor at intel.com> wrote:
>>>> On 12/03/2014 01:01 PM, Ville Syrjälä wrote:
>>>>> On Wed, Dec 03, 2014 at 10:10:30AM -0800, clinton.a.taylor at intel.com
>>>>> wrote:
>>>>>> From: Clint Taylor <clinton.a.taylor at intel.com>
>>>>>>
>>>>>> Added PIPE C register support for CHV audio programming.
>>>>>
>>>>> nak. The offset between the pipes looks constant so it should work
>>>>> just fine with _PIPE().
>>>>
>>>> Correct. Now I just need to figure out why AUD_CONFIG_C is cleared after
>>>> ChromeOS boot.
>>>
>>> "after boot" is a long time! ;)
>>>
>>> Do your logs show that ilk_audio_codec_disable (see intel_audio.c) gets
>>> called? With drm.debug=14 you should see "Disable audio codec on port
>>> %c, pipe %c\n".
>>>
>>> BR,
>>> Jani.
>>>
>>
>> I've actually instrumented the driver with more logging and at 22.43 in
>> the dmesg log the last call to audio_codec_enable() is called and is
>> setting the Pixel_Clock bits of AUD_CONFIG_C to 0x9 which is correct for
>> 1080p60. Sometime after 22.436 and before the ChromeOS login screen
>> appears the register is being cleared to 0x0 without knowledge/action of
>> the i915 driver. Mode change and power state change seem to restore the
>> programming correctly.
>>
>>   Most likely candidate right now is an ordering issue with snd_hda
>> during boot.
>>
>
> Ok, removing snd_hda drivers from the boot process did not change the 
> result. Any ideas about what could reset the HD_AUDIO registers to their 
> default?

Maybe it needs some power domain/well we fail to get? Similar to what
DDI based platforms do before and after calls to
intel_audio_codec_enable and intel_audio_codec_disable in intel_ddi.c.

Not really my area, maybe Imre and Ville know better?


BR,
Jani.



>
> -clint
>
>
>> [    8.607022] [drm:intel_audio_codec_enable] ELD on
>> [CONNECTOR:37:HDMI-A-3], [ENCODER:36:TMDS-36]
>> [    8.607027] [drm:ilk_audio_codec_enable] Enable audio codec on port
>> D, pipe C, 8 bytes ELD
>> [    8.607044]  *** CAT enable aud_config reg 0x001E2200 = 0x00090000
>> [   14.741047] [drm:ilk_audio_codec_disable] Disable audio codec on port
>> D, pipe C
>> [   14.741055]  *** CAT disable aud_config reg 0x001E2200 = 0x10000000
>> [   15.773618] [drm:intel_audio_codec_enable] ELD on
>> [CONNECTOR:37:HDMI-A-3], [ENCODER:36:TMDS-36]
>> [   15.773624] [drm:ilk_audio_codec_enable] Enable audio codec on port
>> D, pipe C, 8 bytes ELD
>> [   15.779315]  *** CAT enable aud_config reg 0x001E2200 = 0x00090000
>> [   19.936767] [drm:ilk_audio_codec_disable] Disable audio codec on port
>> D, pipe C
>> [   19.936778]  *** CAT disable aud_config reg 0x001E2200 = 0x10000000
>> [   20.292920] [drm:intel_audio_codec_enable] ELD on
>> [CONNECTOR:37:HDMI-A-3], [ENCODER:36:TMDS-36]
>> [   20.292928] [drm:ilk_audio_codec_enable] Enable audio codec on port
>> D, pipe C, 8 bytes ELD
>> [   20.298615]  *** CAT enable aud_config reg 0x001E2200 = 0x00090000
>> [   20.389110] [drm:ilk_audio_codec_disable] Disable audio codec on port
>> D, pipe C
>> [   20.389121]  *** CAT disable aud_config reg 0x001E2200 = 0x10000000
>> [   22.430931] [drm:intel_audio_codec_enable] ELD on
>> [CONNECTOR:37:HDMI-A-3], [ENCODER:36:TMDS-36]
>> [   22.430940] [drm:ilk_audio_codec_enable] Enable audio codec on port
>> D, pipe C, 8 bytes ELD
>> [   22.436627]  *** CAT enable aud_config reg 0x001E2200 = 0x00090000
>>
>>>
>>>
>>>
>>>>
>>>> -Clint
>>>>
>>>>>
>>>>>>
>>>>>> Signed-off-by: Clint Taylor <clinton.a.taylor at intel.com>
>>>>>> ---
>>>>>>    drivers/gpu/drm/i915/i915_reg.h |   18 ++++++++++++------
>>>>>>    1 file changed, 12 insertions(+), 6 deletions(-)
>>>>>>
>>>>>> diff --git a/drivers/gpu/drm/i915/i915_reg.h
>>>>>> b/drivers/gpu/drm/i915/i915_reg.h
>>>>>> index dc03fac..3d5813a 100644
>>>>>> --- a/drivers/gpu/drm/i915/i915_reg.h
>>>>>> +++ b/drivers/gpu/drm/i915/i915_reg.h
>>>>>> @@ -6189,14 +6189,18 @@ enum punit_power_well {
>>>>>>
>>>>>>    #define _VLV_HDMIW_HDMIEDID_A        (VLV_DISPLAY_BASE + 0x62050)
>>>>>>    #define _VLV_HDMIW_HDMIEDID_B        (VLV_DISPLAY_BASE + 0x62150)
>>>>>> -#define VLV_HDMIW_HDMIEDID(pipe) _PIPE(pipe, \
>>>>>> +#define _CHV_HDMIW_HDMIEDID_C        (VLV_DISPLAY_BASE + 0x62250)
>>>>>> +#define VLV_HDMIW_HDMIEDID(pipe) _PIPE3(pipe, \
>>>>>>                        _VLV_HDMIW_HDMIEDID_A, \
>>>>>> -                    _VLV_HDMIW_HDMIEDID_B)
>>>>>> +                    _VLV_HDMIW_HDMIEDID_B, \
>>>>>> +                    _CHV_HDMIW_HDMIEDID_C)
>>>>>>    #define _VLV_AUD_CNTL_ST_A        (VLV_DISPLAY_BASE + 0x620B4)
>>>>>>    #define _VLV_AUD_CNTL_ST_B        (VLV_DISPLAY_BASE + 0x621B4)
>>>>>> -#define VLV_AUD_CNTL_ST(pipe) _PIPE(pipe, \
>>>>>> +#define _CHV_AUD_CNTL_ST_C        (VLV_DISPLAY_BASE + 0x622B4)
>>>>>> +#define VLV_AUD_CNTL_ST(pipe) _PIPE3(pipe, \
>>>>>>                        _VLV_AUD_CNTL_ST_A, \
>>>>>> -                    _VLV_AUD_CNTL_ST_B)
>>>>>> +                    _VLV_AUD_CNTL_ST_B, \
>>>>>> +                    _CHV_AUD_CNTL_ST_C)
>>>>>>    #define VLV_AUD_CNTL_ST2        (VLV_DISPLAY_BASE + 0x620C0)
>>>>>>
>>>>>>    /* These are the 4 32-bit write offset registers for each stream
>>>>>> @@ -6217,9 +6221,11 @@ enum punit_power_well {
>>>>>>                        _CPT_AUD_CONFIG_B)
>>>>>>    #define _VLV_AUD_CONFIG_A        (VLV_DISPLAY_BASE + 0x62000)
>>>>>>    #define _VLV_AUD_CONFIG_B        (VLV_DISPLAY_BASE + 0x62100)
>>>>>> -#define VLV_AUD_CFG(pipe) _PIPE(pipe, \
>>>>>> +#define _CHV_AUD_CONFIG_C        (VLV_DISPLAY_BASE + 0x62200)
>>>>>> +#define VLV_AUD_CFG(pipe) _PIPE3(pipe, \
>>>>>>                        _VLV_AUD_CONFIG_A, \
>>>>>> -                    _VLV_AUD_CONFIG_B)
>>>>>> +                    _VLV_AUD_CONFIG_B, \
>>>>>> +                    _CHV_AUD_CONFIG_C)
>>>>>>
>>>>>>    #define   AUD_CONFIG_N_VALUE_INDEX        (1 << 29)
>>>>>>    #define   AUD_CONFIG_N_PROG_ENABLE        (1 << 28)
>>>>>> --
>>>>>> 1.7.9.5
>>>>>>
>>>>>> _______________________________________________
>>>>>> Intel-gfx mailing list
>>>>>> Intel-gfx at lists.freedesktop.org
>>>>>> http://lists.freedesktop.org/mailman/listinfo/intel-gfx
>>>>>
>>>>
>>>> _______________________________________________
>>>> Intel-gfx mailing list
>>>> Intel-gfx at lists.freedesktop.org
>>>> http://lists.freedesktop.org/mailman/listinfo/intel-gfx
>>>
>>
>> _______________________________________________
>> Intel-gfx mailing list
>> Intel-gfx at lists.freedesktop.org
>> http://lists.freedesktop.org/mailman/listinfo/intel-gfx
>

-- 
Jani Nikula, Intel Open Source Technology Center



More information about the Intel-gfx mailing list