diff options
| author | Ville Syrjälä <ville.syrjala@linux.intel.com> | 2022-03-12 13:50:31 +0200 | 
|---|---|---|
| committer | Ville Syrjälä <ville.syrjala@linux.intel.com> | 2022-06-22 15:38:49 +0300 | 
| commit | 364533f8f449bd097fe403922ebd31b22314bcaf (patch) | |
| tree | d2d8ef1cba33293897987ac35486f72798b0c464 /tools | |
| parent | 03cc8f59efd991f3f76ed87fe1a28fa55905a7a7 (diff) | |
tools/intel_vbt_decode: Decode the end of the LFP data
Decode the tail end of the LFP data, if available.
Reviewed-by: Jani Nikula <jani.nikula@intel.com>
Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Diffstat (limited to 'tools')
| -rw-r--r-- | tools/intel_vbt_decode.c | 73 | 
1 files changed, 72 insertions, 1 deletions
| diff --git a/tools/intel_vbt_decode.c b/tools/intel_vbt_decode.c index e49831e2..574aa255 100644 --- a/tools/intel_vbt_decode.c +++ b/tools/intel_vbt_decode.c @@ -153,6 +153,30 @@ static const void *block_data(const struct bdb_block *block)  	return block->data + 3;  } +static struct bdb_block *find_section(const struct context *context, int section_id); + +static size_t lfp_data_min_size(const struct context *context) +{ +	const struct bdb_lvds_lfp_data_ptrs *ptrs; +	struct bdb_block *ptrs_block; +	size_t size; + +	ptrs_block = find_section(context, BDB_LVDS_LFP_DATA_PTRS); +	if (!ptrs_block) +		return 0; + +	ptrs = block_data(ptrs_block); + +	size = sizeof(struct bdb_lvds_lfp_data); +	if (ptrs->panel_name.table_size) +		size = max(size, ptrs->panel_name.offset + +			   sizeof(struct bdb_lvds_lfp_data_tail)); + +	free(ptrs_block); + +	return size; +} +  static size_t block_min_size(const struct context *context, int section_id)  {  	switch (section_id) { @@ -178,7 +202,7 @@ static size_t block_min_size(const struct context *context, int section_id)  	case BDB_LVDS_LFP_DATA_PTRS:  		return sizeof(struct bdb_lvds_lfp_data_ptrs);  	case BDB_LVDS_LFP_DATA: -		return sizeof(struct bdb_lvds_lfp_data); +		return lfp_data_min_size(context);  	case BDB_LVDS_BACKLIGHT:  		return sizeof(struct bdb_lfp_backlight_data);  	case BDB_LFP_POWER: @@ -916,6 +940,8 @@ static void dump_lvds_data(struct context *context,  			block_data(block) + ptrs->ptr[i].dvo_timing.offset;  		const struct lvds_pnp_id *pnp_id =  			block_data(block) + ptrs->ptr[i].panel_pnp_id.offset; +		const struct bdb_lvds_lfp_data_tail *tail = +			block_data(block) + ptrs->panel_name.offset;  		char mfg[4];  		if (i != context->panel_type && !context->dump_all_panel_types) @@ -960,6 +986,51 @@ static void dump_lvds_data(struct context *context,  		printf("\t\t  Serial: %u\n", pnp_id->serial);  		printf("\t\t  Mfg week: %d\n", pnp_id->mfg_week);  		printf("\t\t  Mfg year: %d\n", 1990 + pnp_id->mfg_year); + +		if (!ptrs->panel_name.table_size) +			continue; + +		printf("\t\tPanel name: %.*s\n", +		       (int)sizeof(tail->panel_name[0].name), tail->panel_name[i].name); + +		if (context->bdb->version < 187) +			continue; + +		printf("\t\tScaling enable: %s\n", +		       YESNO((tail->scaling_enable >> i) & 1)); + +		if (context->bdb->version < 188) +			continue; + +		printf("\t\tSeamless DRRS min refresh rate: %d\n", +		       tail->seamless_drrs_min_refresh_rate[i]); + +		if (context->bdb->version < 208) +			continue; + +		printf("\t\tPixel overlap count: %d\n", +		       tail->pixel_overlap_count[i]); + +		if (context->bdb->version < 227) +			continue; + +		printf("\t\tBlack border:\n"); +		printf("\t\t  Top: %d\n", tail->black_border[i].top); +		printf("\t\t  Bottom: %d\n", tail->black_border[i].top); +		printf("\t\t  Left: %d\n", tail->black_border[i].left); +		printf("\t\t  Right: %d\n", tail->black_border[i].right); + +		if (context->bdb->version < 231) +			continue; + +		printf("\t\tDual LFP port sync enable: %s\n", +		       YESNO((tail->dual_lfp_port_sync_enable >> i) & 1)); + +		if (context->bdb->version < 245) +			continue; + +		printf("\t\tGPU dithering for banding artifacts: %s\n", +		       YESNO((tail->gpu_dithering_for_banding_artifacts >> i) & 1));  	}  	free(ptrs_block); | 
