render/dmabuf: cleanup on wlr_dmabuf_attributes_copy error

master
Simon Ser 4 years ago
parent 975d14b799
commit 7ac2ce25e3

@ -16,13 +16,22 @@ bool wlr_dmabuf_attributes_copy(struct wlr_dmabuf_attributes *dst,
struct wlr_dmabuf_attributes *src) { struct wlr_dmabuf_attributes *src) {
memcpy(dst, src, sizeof(struct wlr_dmabuf_attributes)); memcpy(dst, src, sizeof(struct wlr_dmabuf_attributes));
for (int i = 0; i < src->n_planes; ++i) { int i;
for (i = 0; i < src->n_planes; ++i) {
dst->fd[i] = fcntl(src->fd[i], F_DUPFD_CLOEXEC, 0); dst->fd[i] = fcntl(src->fd[i], F_DUPFD_CLOEXEC, 0);
if (dst->fd[i] < 0) { if (dst->fd[i] < 0) {
wlr_log_errno(WLR_ERROR, "fcntl(F_DUPFD_CLOEXEC) failed"); wlr_log_errno(WLR_ERROR, "fcntl(F_DUPFD_CLOEXEC) failed");
return false; goto error;
} }
} }
return true; return true;
error:
for (int j = 0; j < i; j++) {
close(dst->fd[i]);
dst->fd[j] = -1;
}
dst->n_planes = 0;
return false;
} }

Loading…
Cancel
Save