aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/radeon
diff options
context:
space:
mode:
authorJerome Glisse <jglisse@redhat.com>2011-10-24 18:16:34 -0400
committerDave Airlie <airlied@redhat.com>2011-11-01 12:01:49 -0400
commit340764465aa4a586ca332e61ae64883e5ad6f183 (patch)
tree3588fd1e53d8f52202c1718fa60928fa5915b19a /drivers/gpu/drm/radeon
parent305151e36e3d5e0592580e6db3c5855a68f2bf6b (diff)
drm/radeon: avoid bouncing connector status btw disconnected & unknown
Since force handling rework of d0d0a225e6ad43314c9aa7ea081f76adc5098ad4 we could end up bouncing connector status btw disconnected and unknown. When connector status change a call to output_poll_changed happen which in turn ask again for detect but with force set. So set the load detect flags whenever we report the connector as connected or unknown this avoid bouncing btw disconnected and unknown. Signed-off-by: Jerome Glisse <jglisse@redhat.com> Reviewed-by: Alex Deucher <alexdeucher@gmail.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/radeon')
-rw-r--r--drivers/gpu/drm/radeon/radeon_connectors.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_connectors.c b/drivers/gpu/drm/radeon/radeon_connectors.c
index dec6cbe6a0a6..ff6a2e0d9a25 100644
--- a/drivers/gpu/drm/radeon/radeon_connectors.c
+++ b/drivers/gpu/drm/radeon/radeon_connectors.c
@@ -764,7 +764,7 @@ radeon_vga_detect(struct drm_connector *connector, bool force)
764 if (radeon_connector->dac_load_detect && encoder) { 764 if (radeon_connector->dac_load_detect && encoder) {
765 encoder_funcs = encoder->helper_private; 765 encoder_funcs = encoder->helper_private;
766 ret = encoder_funcs->detect(encoder, connector); 766 ret = encoder_funcs->detect(encoder, connector);
767 if (ret == connector_status_connected) 767 if (ret != connector_status_disconnected)
768 radeon_connector->detected_by_load = true; 768 radeon_connector->detected_by_load = true;
769 } 769 }
770 } 770 }
@@ -1005,8 +1005,9 @@ radeon_dvi_detect(struct drm_connector *connector, bool force)
1005 ret = encoder_funcs->detect(encoder, connector); 1005 ret = encoder_funcs->detect(encoder, connector);
1006 if (ret == connector_status_connected) { 1006 if (ret == connector_status_connected) {
1007 radeon_connector->use_digital = false; 1007 radeon_connector->use_digital = false;
1008 radeon_connector->detected_by_load = true;
1009 } 1008 }
1009 if (ret != connector_status_disconnected)
1010 radeon_connector->detected_by_load = true;
1010 } 1011 }
1011 break; 1012 break;
1012 } 1013 }