drm/radeon/kms: add connectors even if i2c fails
Sometimes the i2c test in i2c_bit_add_bus fails if this happens we fail to register the i2c adapter and eventually fail to add the connector. If i2c fails, add the connector to the user can at least force it on. Note that some distros set i2c-algo-bit.bit_test to 1 by default which sometimes fails preventing the ddc i2c adapter from being added. The i2c adapter works even if the bit test fails, probably due to pre/post_xfer not getting called in the test_bit function. I have another patch to follow up on that. See: https://bugs.freedesktop.org/show_bug.cgi?id=36221 Signed-off-by: Alex Deucher <alexdeucher@gmail.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
This commit is contained in:
		
					parent
					
						
							
								8e461123f2
							
						
					
				
			
			
				commit
				
					
						a70882aa31
					
				
			
		
					 2 changed files with 18 additions and 17 deletions
				
			
		|  | @ -1096,6 +1096,9 @@ void radeon_router_select_ddc_port(struct radeon_connector *radeon_connector) | |||
| 	if (!radeon_connector->router.ddc_valid) | ||||
| 		return; | ||||
| 
 | ||||
| 	if (!radeon_connector->router_bus) | ||||
| 		return; | ||||
| 
 | ||||
| 	radeon_i2c_get_byte(radeon_connector->router_bus, | ||||
| 			    radeon_connector->router.i2c_addr, | ||||
| 			    0x3, &val); | ||||
|  | @ -1121,6 +1124,9 @@ void radeon_router_select_cd_port(struct radeon_connector *radeon_connector) | |||
| 	if (!radeon_connector->router.cd_valid) | ||||
| 		return; | ||||
| 
 | ||||
| 	if (!radeon_connector->router_bus) | ||||
| 		return; | ||||
| 
 | ||||
| 	radeon_i2c_get_byte(radeon_connector->router_bus, | ||||
| 			    radeon_connector->router.i2c_addr, | ||||
| 			    0x3, &val); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Alex Deucher
				Alex Deucher