mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	drm/edid: convert add_cea_modes() to use cea db iter
Iterate through all CTA EDID extension blocks and DisplayID CTA data blocks to add CEA modes. Cc: Ville Syrjälä <ville.syrjala@linux.intel.com> Signed-off-by: Jani Nikula <jani.nikula@intel.com> Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/dfa2d79db61d5eea543bef7aca7d80da3e71f99d.1651569697.git.jani.nikula@intel.com
This commit is contained in:
		
							parent
							
								
									a9ec4fd004
								
							
						
					
					
						commit
						537d9ed2f6
					
				| @ -4689,46 +4689,41 @@ static void drm_parse_y420cmdb_bitmap(struct drm_connector *connector, | |||||||
| static int | static int | ||||||
| add_cea_modes(struct drm_connector *connector, const struct edid *edid) | add_cea_modes(struct drm_connector *connector, const struct edid *edid) | ||||||
| { | { | ||||||
| 	const u8 *cea = drm_find_cea_extension(edid); | 	const struct cea_db *db; | ||||||
| 	const u8 *db, *hdmi = NULL, *video = NULL; | 	struct cea_db_iter iter; | ||||||
| 	u8 dbl, hdmi_len, video_len = 0; |  | ||||||
| 	int modes = 0; | 	int modes = 0; | ||||||
| 
 | 
 | ||||||
| 	if (cea && cea_revision(cea) >= 3) { | 	cea_db_iter_edid_begin(edid, &iter); | ||||||
| 		int i, start, end; | 	cea_db_iter_for_each(db, &iter) { | ||||||
|  | 		const u8 *hdmi = NULL, *video = NULL; | ||||||
|  | 		u8 hdmi_len = 0, video_len = 0; | ||||||
| 
 | 
 | ||||||
| 		if (cea_db_offsets(cea, &start, &end)) | 		if (cea_db_tag(db) == CTA_DB_VIDEO) { | ||||||
| 			return 0; | 			video = cea_db_data(db); | ||||||
|  | 			video_len = cea_db_payload_len(db); | ||||||
|  | 			modes += do_cea_modes(connector, video, video_len); | ||||||
|  | 		} else if (cea_db_is_hdmi_vsdb(db)) { | ||||||
|  | 			/* FIXME: Switch to use cea_db_data() */ | ||||||
|  | 			hdmi = (const u8 *)db; | ||||||
|  | 			hdmi_len = cea_db_payload_len(db); | ||||||
|  | 		} else if (cea_db_is_y420vdb(db)) { | ||||||
|  | 			const u8 *vdb420 = cea_db_data(db) + 1; | ||||||
| 
 | 
 | ||||||
| 		for_each_cea_db(cea, i, start, end) { | 			/* Add 4:2:0(only) modes present in EDID */ | ||||||
| 			db = &cea[i]; | 			modes += do_y420vdb_modes(connector, vdb420, | ||||||
| 			dbl = cea_db_payload_len(db); | 						  cea_db_payload_len(db) - 1); | ||||||
| 
 |  | ||||||
| 			if (cea_db_tag(db) == CTA_DB_VIDEO) { |  | ||||||
| 				video = db + 1; |  | ||||||
| 				video_len = dbl; |  | ||||||
| 				modes += do_cea_modes(connector, video, dbl); |  | ||||||
| 			} else if (cea_db_is_hdmi_vsdb(db)) { |  | ||||||
| 				hdmi = db; |  | ||||||
| 				hdmi_len = dbl; |  | ||||||
| 			} else if (cea_db_is_y420vdb(db)) { |  | ||||||
| 				const u8 *vdb420 = &db[2]; |  | ||||||
| 
 |  | ||||||
| 				/* Add 4:2:0(only) modes present in EDID */ |  | ||||||
| 				modes += do_y420vdb_modes(connector, |  | ||||||
| 							  vdb420, |  | ||||||
| 							  dbl - 1); |  | ||||||
| 			} |  | ||||||
| 		} | 		} | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	/*
 | 		/*
 | ||||||
| 	 * We parse the HDMI VSDB after having added the cea modes as we will | 		 * We parse the HDMI VSDB after having added the cea modes as we | ||||||
| 	 * be patching their flags when the sink supports stereo 3D. | 		 * will be patching their flags when the sink supports stereo | ||||||
| 	 */ | 		 * 3D. | ||||||
| 	if (hdmi) | 		 */ | ||||||
| 		modes += do_hdmi_vsdb_modes(connector, hdmi, hdmi_len, video, | 		if (hdmi) | ||||||
| 					    video_len); | 			modes += do_hdmi_vsdb_modes(connector, hdmi, hdmi_len, | ||||||
|  | 						    video, video_len); | ||||||
|  | 	} | ||||||
|  | 	cea_db_iter_end(&iter); | ||||||
| 
 | 
 | ||||||
| 	return modes; | 	return modes; | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Jani Nikula
						Jani Nikula