From c0ec75919afdf3761998e0d85a63bd3543a1674b Mon Sep 17 00:00:00 2001 From: Daniel Stone Date: Thu, 9 Feb 2017 13:58:35 +0000 Subject: [PATCH] compositor-drm: Avoid connector_allocator for hotplugs Rather than using connector_allocator to determine whether an output is newly connected or not, use a list walk across all outputs instead. Signed-off-by: Daniel Stone Reviewed-by: Quentin Glidic Reported-by: Peter Senna Tschudin --- libweston/compositor-drm.c | 31 +++++++++++++++++++++++++------ 1 file changed, 25 insertions(+), 6 deletions(-) diff --git a/libweston/compositor-drm.c b/libweston/compositor-drm.c index 5f1ca959..99699d76 100644 --- a/libweston/compositor-drm.c +++ b/libweston/compositor-drm.c @@ -257,6 +257,25 @@ drm_output_find_by_crtc(struct drm_backend *b, uint32_t crtc_id) return NULL; } +static struct drm_output * +drm_output_find_by_connector(struct drm_backend *b, uint32_t connector_id) +{ + struct drm_output *output; + + wl_list_for_each(output, &b->compositor->output_list, base.link) { + if (output->connector_id == connector_id) + return output; + } + + wl_list_for_each(output, &b->compositor->pending_output_list, + base.link) { + if (output->connector_id == connector_id) + return output; + } + + return NULL; +} + static void drm_fb_destroy_callback(struct gbm_bo *bo, void *data) { @@ -2764,14 +2783,14 @@ update_outputs(struct drm_backend *b, struct udev_device *drm_device) connected |= (1 << connector_id); - if (!(b->connector_allocator & (1 << connector_id))) { - create_output_for_connector(b, resources, - connector, drm_device); - weston_log("connector %d connected\n", connector_id); - - } else { + if (drm_output_find_by_connector(b, connector_id)) { drmModeFreeConnector(connector); + continue; } + + create_output_for_connector(b, resources, + connector, drm_device); + weston_log("connector %d connected\n", connector_id); } drmModeFreeResources(resources);