From 493804e4215ee23101305e0bf5598bb6f21fb663 Mon Sep 17 00:00:00 2001 From: Simon Ser Date: Mon, 29 Apr 2019 22:33:46 +0300 Subject: [PATCH] buffer: add wlr_buffer_get_dmabuf --- include/wlr/types/wlr_buffer.h | 7 +++++++ types/wlr_buffer.c | 18 ++++++++++++++++++ 2 files changed, 25 insertions(+) diff --git a/include/wlr/types/wlr_buffer.h b/include/wlr/types/wlr_buffer.h index 0c987b17..11b36596 100644 --- a/include/wlr/types/wlr_buffer.h +++ b/include/wlr/types/wlr_buffer.h @@ -11,6 +11,7 @@ #include #include +#include /** * A client buffer. @@ -67,5 +68,11 @@ void wlr_buffer_unref(struct wlr_buffer *buffer); */ struct wlr_buffer *wlr_buffer_apply_damage(struct wlr_buffer *buffer, struct wl_resource *resource, pixman_region32_t *damage); +/** + * Reads the DMA-BUF attributes of the buffer. If this buffer isn't a DMA-BUF, + * returns false. + */ +bool wlr_buffer_get_dmabuf(struct wlr_buffer *buffer, + struct wlr_dmabuf_attributes *attribs); #endif diff --git a/types/wlr_buffer.c b/types/wlr_buffer.c index cec3475c..9d079b9a 100644 --- a/types/wlr_buffer.c +++ b/types/wlr_buffer.c @@ -203,3 +203,21 @@ struct wlr_buffer *wlr_buffer_apply_damage(struct wlr_buffer *buffer, buffer->released = true; return buffer; } + +bool wlr_buffer_get_dmabuf(struct wlr_buffer *buffer, + struct wlr_dmabuf_attributes *attribs) { + if (buffer->resource == NULL) { + return false; + } + + struct wl_resource *buffer_resource = buffer->resource; + if (!wlr_dmabuf_v1_resource_is_buffer(buffer_resource)) { + return false; + } + + struct wlr_dmabuf_v1_buffer *dmabuf_buffer = + wlr_dmabuf_v1_buffer_from_buffer_resource(buffer_resource); + memcpy(attribs, &dmabuf_buffer->attributes, + sizeof(struct wlr_dmabuf_attributes)); + return true; +}