Merge branch 'async-master' into 'master'

Draft: render,types/wlr_shm: Offload slow cleanup ops

See merge request wlroots/wlroots!4755
This commit is contained in:
Kurt Kartaltepe 2025-11-30 00:11:40 +00:00
commit 2c9b315e7d
6 changed files with 130 additions and 4 deletions

View file

@ -1,15 +1,31 @@
#include <fcntl.h>
#include <stdlib.h>
#include <unistd.h>
#include <wlr/render/dmabuf.h>
#include <wlr/util/log.h>
#include "render/dmabuf.h"
#include "util/cleanup.h"
static void defer_close_dmabuf(void *data) {
struct wlr_dmabuf_attributes *attribs = data;
void wlr_dmabuf_attributes_finish(struct wlr_dmabuf_attributes *attribs) {
for (int i = 0; i < attribs->n_planes; ++i) {
close(attribs->fd[i]);
}
free(attribs);
}
void wlr_dmabuf_attributes_finish(struct wlr_dmabuf_attributes *attribs) {
struct wlr_dmabuf_attributes *attribs_defer = calloc(1, sizeof(struct wlr_dmabuf_attributes));
attribs_defer->n_planes = attribs->n_planes;
for (int i = 0; i < attribs->n_planes; ++i) {
attribs_defer->fd[i] = attribs->fd[i];
attribs->fd[i] = -1;
}
attribs->n_planes = 0;
wlr_cleanup_defer((struct wlr_task){&defer_close_dmabuf, attribs_defer});
}
bool wlr_dmabuf_attributes_copy(struct wlr_dmabuf_attributes *dst,