drm-lease-v1: send finished event on failure in submit request

If the "submit" request handler fails, send a "finished" event
so that the client doesn't stall forever.
This commit is contained in:
Simon Ser 2022-10-07 18:18:48 +02:00 committed by Simon Zeni
parent 5c382f6344
commit 11d073ab09
1 changed files with 3 additions and 0 deletions

View File

@ -322,12 +322,14 @@ static void drm_lease_request_v1_handle_submit(
drm_lease_request_v1_from_resource(resource); drm_lease_request_v1_from_resource(resource);
if (!request) { if (!request) {
wlr_log(WLR_DEBUG, "Request has been destroyed"); wlr_log(WLR_DEBUG, "Request has been destroyed");
wp_drm_lease_v1_send_finished(lease_resource);
return; return;
} }
/* Pre-emptively reject invalid lease requests */ /* Pre-emptively reject invalid lease requests */
if (request->invalid) { if (request->invalid) {
wlr_log(WLR_ERROR, "Invalid request"); wlr_log(WLR_ERROR, "Invalid request");
wp_drm_lease_v1_send_finished(lease_resource);
return; return;
} else if (request->n_connectors == 0) { } else if (request->n_connectors == 0) {
wl_resource_post_error(lease_resource, wl_resource_post_error(lease_resource,
@ -341,6 +343,7 @@ static void drm_lease_request_v1_handle_submit(
if (conn->active_lease) { if (conn->active_lease) {
wlr_log(WLR_ERROR, "Failed to create lease, connector %s has " wlr_log(WLR_ERROR, "Failed to create lease, connector %s has "
"already been leased", conn->output->name); "already been leased", conn->output->name);
wp_drm_lease_v1_send_finished(lease_resource);
return; return;
} }
} }