Check for disappearing DRM connectors
DisplayPort MST connectors will disappear when they're disconnected, so we need to check for that.
This commit is contained in:
parent
f4faa731f0
commit
0aa00da1f3
|
@ -748,6 +748,11 @@ void wlr_drm_scan_connectors(struct wlr_drm_backend *backend) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
size_t seen_len = backend->outputs->length;
|
||||||
|
// +1 so it can never be 0
|
||||||
|
bool seen[seen_len + 1];
|
||||||
|
memset(seen, 0, sizeof(seen));
|
||||||
|
|
||||||
for (int i = 0; i < res->count_connectors; ++i) {
|
for (int i = 0; i < res->count_connectors; ++i) {
|
||||||
drmModeConnector *conn = drmModeGetConnector(backend->fd,
|
drmModeConnector *conn = drmModeGetConnector(backend->fd,
|
||||||
res->connectors[i]);
|
res->connectors[i]);
|
||||||
|
@ -805,6 +810,7 @@ void wlr_drm_scan_connectors(struct wlr_drm_backend *backend) {
|
||||||
wlr_log(L_INFO, "Found display '%s'", output->output.name);
|
wlr_log(L_INFO, "Found display '%s'", output->output.name);
|
||||||
} else {
|
} else {
|
||||||
output = backend->outputs->items[index];
|
output = backend->outputs->items[index];
|
||||||
|
seen[index] = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (output->state == WLR_DRM_OUTPUT_DISCONNECTED &&
|
if (output->state == WLR_DRM_OUTPUT_DISCONNECTED &&
|
||||||
|
@ -850,6 +856,22 @@ void wlr_drm_scan_connectors(struct wlr_drm_backend *backend) {
|
||||||
}
|
}
|
||||||
|
|
||||||
drmModeFreeResources(res);
|
drmModeFreeResources(res);
|
||||||
|
|
||||||
|
for (size_t i = seen_len; i-- > 0;) {
|
||||||
|
if (seen[i]) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct wlr_drm_output *output = backend->outputs->items[i];
|
||||||
|
|
||||||
|
wlr_log(L_INFO, "'%s' disappeared", output->output.name);
|
||||||
|
wlr_drm_output_cleanup(output, false);
|
||||||
|
|
||||||
|
drmModeFreeCrtc(output->old_crtc);
|
||||||
|
free(output);
|
||||||
|
|
||||||
|
list_del(backend->outputs, i);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void page_flip_handler(int fd, unsigned seq,
|
static void page_flip_handler(int fd, unsigned seq,
|
||||||
|
|
Loading…
Reference in New Issue