mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	drm/i915/dp: fall back to 18 bpp when sink capability is unknown
Per DP spec, the source device should fall back to 18 bpp, VESA range
RGB when the sink capability is unknown. Fix the color depth
clamping. 18 bpp color depth should ensure full color range in automatic
mode.
The clamping has been HDMI specific since its introduction in
commit 996a2239f9
Author: Daniel Vetter <daniel.vetter@ffwll.ch>
Date:   Fri Apr 19 11:24:34 2013 +0200
    drm/i915: Disable high-bpc on pre-1.4 EDID screens
Cc: stable@vger.kernel.org
Reported-and-tested-by: Dihan Wickremasuriya <nayomal@gmail.com>
Bugzilla: https://bugzilla.kernel.org/show_bug.cgi?id=105331
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Link: http://patchwork.freedesktop.org/patch/msgid/1452695720-7076-1-git-send-email-jani.nikula@intel.com
			
			
This commit is contained in:
		
							parent
							
								
									6765bd6dd2
								
							
						
					
					
						commit
						013dd9e038
					
				| @ -12157,11 +12157,21 @@ connected_sink_compute_bpp(struct intel_connector *connector, | ||||
| 		pipe_config->pipe_bpp = connector->base.display_info.bpc*3; | ||||
| 	} | ||||
| 
 | ||||
| 	/* Clamp bpp to 8 on screens without EDID 1.4 */ | ||||
| 	if (connector->base.display_info.bpc == 0 && bpp > 24) { | ||||
| 		DRM_DEBUG_KMS("clamping display bpp (was %d) to default limit of 24\n", | ||||
| 			      bpp); | ||||
| 		pipe_config->pipe_bpp = 24; | ||||
| 	/* Clamp bpp to default limit on screens without EDID 1.4 */ | ||||
| 	if (connector->base.display_info.bpc == 0) { | ||||
| 		int type = connector->base.connector_type; | ||||
| 		int clamp_bpp = 24; | ||||
| 
 | ||||
| 		/* Fall back to 18 bpp when DP sink capability is unknown. */ | ||||
| 		if (type == DRM_MODE_CONNECTOR_DisplayPort || | ||||
| 		    type == DRM_MODE_CONNECTOR_eDP) | ||||
| 			clamp_bpp = 18; | ||||
| 
 | ||||
| 		if (bpp > clamp_bpp) { | ||||
| 			DRM_DEBUG_KMS("clamping display bpp (was %d) to default limit of %d\n", | ||||
| 				      bpp, clamp_bpp); | ||||
| 			pipe_config->pipe_bpp = clamp_bpp; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Jani Nikula
						Jani Nikula