diff options
author | Jerome Glisse <jglisse@redhat.com> | 2011-10-24 18:16:34 -0400 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2011-11-01 12:01:49 -0400 |
commit | 340764465aa4a586ca332e61ae64883e5ad6f183 (patch) | |
tree | 3588fd1e53d8f52202c1718fa60928fa5915b19a /drivers/gpu/drm/radeon | |
parent | 305151e36e3d5e0592580e6db3c5855a68f2bf6b (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.c | 5 |
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 | } |