[Intel-gfx] [PATCH] drm/i915/hdmi: Add HDMI 2.0 audio clock recovery N values

Jani Nikula jani.nikula at linux.intel.com
Mon Oct 15 11:31:20 UTC 2018


On Mon, 15 Oct 2018, Jani Nikula <jani.nikula at linux.intel.com> wrote:
> On Fri, 05 Oct 2018, clinton.a.taylor at intel.com wrote:
>> From: Clint Taylor <clinton.a.taylor at intel.com>
>>
>> HDMI 2.0 594Mhz modes were incorrectly selecting 25.200Mhz Automatic N
>> value mode instead of HDMI specification values.
>>
>> Signed-off-by: Clint Taylor <clinton.a.taylor at intel.com>
>> ---
>>  drivers/gpu/drm/i915/intel_audio.c | 16 ++++++++++++++++
>>  1 file changed, 16 insertions(+)
>>
>> diff --git a/drivers/gpu/drm/i915/intel_audio.c b/drivers/gpu/drm/i915/intel_audio.c
>> index 769f3f5..4b8f6f6 100644
>> --- a/drivers/gpu/drm/i915/intel_audio.c
>> +++ b/drivers/gpu/drm/i915/intel_audio.c
>> @@ -144,6 +144,8 @@ struct dp_aud_n_m {
>>  /* HDMI N/CTS table */
>>  #define TMDS_297M 297000
>>  #define TMDS_296M 296703
>> +#define TMDS_594M 594000
>> +#define TMDS_593M 593407
>>  static const struct {
>>  	int sample_rate;
>>  	int clock;
>> @@ -164,6 +166,20 @@ struct dp_aud_n_m {
>>  	{ 176400, TMDS_297M, 18816, 247500 },
>>  	{ 192000, TMDS_296M, 23296, 281250 },
>>  	{ 192000, TMDS_297M, 20480, 247500 },
>> +	{ 44100, TMDS_593M, 8918, 937500 },
>> +	{ 44100, TMDS_594M, 9408, 990000 },
>> +	{ 48000, TMDS_593M, 5824, 562500 },
>> +	{ 48000, TMDS_594M, 6144, 594000 },
>> +	{ 32000, TMDS_593M, 5824, 843750 },
>> +	{ 32000, TMDS_594M, 3072, 445500 },
>> +	{ 88200, TMDS_593M, 17836, 937500 },
>> +	{ 88200, TMDS_594M, 9408, 990000 },
>
> The N here should be 18816. The rest looks good.

PS. This should probably have Cc: stable.

Could I persuade you to write a cleanup patch on top to re-arrange the
array in groups:

	/* multiples of 32 kHz */
	/* multiples of 44.1 kHz */
	/* multiples of 48 kHz */

with each group in increasing audio sample frequency, I'll review it in
same go. Otherwise, I'll write the patch myself. The current ordering is
a PITA to review against the spec...

BR,
Jani.

>
> BR,
> Jani.
>
>> +	{ 96000, TMDS_593M, 11648, 562500 },
>> +	{ 96000, TMDS_594M, 12288, 594000 },
>> +	{ 176400, TMDS_593M, 35672, 937500 },
>> +	{ 176400, TMDS_594M, 37632, 990000 },
>> +	{ 192000, TMDS_593M, 23296, 562500 },
>> +	{ 192000, TMDS_594M, 24576, 594000 },
>>  };
>>  
>>  /* get AUD_CONFIG_PIXEL_CLOCK_HDMI_* value for mode */

-- 
Jani Nikula, Intel Open Source Graphics Center


More information about the Intel-gfx mailing list