aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon Ser <contact@emersion.fr>2021-04-12 18:39:03 +0200
committerSimon Ser <contact@emersion.fr>2021-05-17 16:22:43 +0200
commit68758e8c2138a06bbb6edca94cdfae1be8bc3c57 (patch)
tree4ac6fcc0b48901eebe881f1098408e40fb8f1355
parentf6ba26ff583fc0ea3e615521ddc26110e48a5d40 (diff)
buffer: use wlr_texture_from_buffer for DMA-BUFs
-rw-r--r--types/wlr_buffer.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/types/wlr_buffer.c b/types/wlr_buffer.c
index 8ae5e839..10ed7295 100644
--- a/types/wlr_buffer.c
+++ b/types/wlr_buffer.c
@@ -5,6 +5,7 @@
#include <wlr/types/wlr_linux_dmabuf_v1.h>
#include <wlr/util/log.h>
#include "render/pixel_format.h"
+#include "render/wlr_texture.h"
#include "types/wlr_buffer.h"
#include "util/signal.h"
@@ -220,11 +221,11 @@ struct wlr_client_buffer *wlr_client_buffer_import(
} else if (wlr_dmabuf_v1_resource_is_buffer(resource)) {
struct wlr_dmabuf_v1_buffer *dmabuf =
wlr_dmabuf_v1_buffer_from_buffer_resource(resource);
- texture = wlr_texture_from_dmabuf(renderer, &dmabuf->attributes);
+ texture = wlr_texture_from_buffer(renderer, &dmabuf->base);
- // We have imported the DMA-BUF, but we need to prevent the client from
- // re-using the same DMA-BUF for the next frames, so we don't release
- // the buffer yet.
+ // The renderer is responsible for releasing the buffer when
+ // appropriate
+ resource_released = true;
} else {
wlr_log(WLR_ERROR, "Cannot upload texture: unknown buffer type");