[igt-dev] [i-g-t 2/5] lib/igt_edid: Helper to read monitor range from EDID

Modem, Bhanuprakash bhanuprakash.modem at intel.com
Fri Mar 4 03:12:26 UTC 2022


On Fri-04-03-2022 06:37 am, Navare, Manasi wrote:
> On Thu, Feb 24, 2022 at 10:46:45AM +0530, Bhanuprakash Modem wrote:
>> Add a helper function to read Monitor's range capability
>> from EDID.
>>
>> Cc: Manasi Navare <manasi.d.navare at intel.com>
>> Signed-off-by: Bhanuprakash Modem <bhanuprakash.modem at intel.com>
>> ---
>>   lib/igt_edid.c | 24 ++++++++++++++++++++++++
>>   lib/igt_edid.h |  2 ++
>>   2 files changed, 26 insertions(+)
>>
>> diff --git a/lib/igt_edid.c b/lib/igt_edid.c
>> index df346c4c8c..bd677f49b8 100644
>> --- a/lib/igt_edid.c
>> +++ b/lib/igt_edid.c
>> @@ -160,6 +160,30 @@ void detailed_timing_set_monitor_range_mode(struct detailed_timing *dt,
>>   	       sizeof(monitor_range_padding));
>>   }
>>   
>> +struct detailed_data_monitor_range
>> +detailed_timing_get_monitor_range(const struct edid *edid)
>> +{
>> +	uint8_t i;
>> +	struct detailed_data_monitor_range mr = {0, 0};
>> +
>> +	for (i = 0; i < DETAILED_TIMINGS_LEN; i++) {
>> +		struct detailed_non_pixel *other_data;
>> +		struct detailed_timing timings = edid->detailed_timings[i];
>> +
>> +		if (timings.pixel_clock[0] != 0 &&
>> +		    timings.pixel_clock[1] != 0)
>> +			continue;
> 
> What is this check checking?

As per EDID Display Range Limits Descriptor specs:

https://en.wikipedia.org/wiki/Extended_Display_Identification_Data#Descriptor

Bytes	Description
0–1	00 00 = Display Descriptor
2	00 = reserved
3	FD = Display Range Limits Descriptor

First 2 bytes (In fact 3) must be zero. I'll try to document this info 
in comments in next version.

> 
>> +
>> +		other_data = &timings.data.other_data;
>> +		if (other_data->type != EDID_DETAIL_MONITOR_RANGE)
>> +			continue;
>> +
>> +		return other_data->data.range;
> 
> Did you  mean to assign this range to mr here as that is what we return

Once we find the monitor range descriptor, no need to iterate remaining 
timing blocks. Yes, we can assign this range to mr & break the loop.

I'll float a new version with these changes.

> 
> Manasi
> 
>> +	}
>> +
>> +	return mr;
>> +}
>> +
>>   /**
>>    * detailed_timing_set_string: set a detailed timing to be a string
>>    */
>> diff --git a/lib/igt_edid.h b/lib/igt_edid.h
>> index aac2f4a208..e412479d84 100644
>> --- a/lib/igt_edid.h
>> +++ b/lib/igt_edid.h
>> @@ -381,6 +381,8 @@ void detailed_timing_set_mode(struct detailed_timing *dt, drmModeModeInfo *mode,
>>   			      int width_mm, int height_mm);
>>   void detailed_timing_set_monitor_range_mode(struct detailed_timing *dt,
>>   					    drmModeModeInfo *mode);
>> +struct detailed_data_monitor_range detailed_timing_get_monitor_range(
>> +				const struct edid *edid);
>>   void detailed_timing_set_string(struct detailed_timing *dt,
>>   				enum detailed_non_pixel_type type,
>>   				const char *str);
>> -- 
>> 2.35.0
>>



More information about the igt-dev mailing list