From c88c54fb385a9fe29f79db2ece3e8ebba0edd0a3 Mon Sep 17 00:00:00 2001 From: Simon Ser Date: Tue, 28 Jul 2020 16:56:18 +0200 Subject: [PATCH] render: introduce wlr_renderer_bind_buffer --- include/render/wlr_renderer.h | 8 ++++++++ include/wlr/render/interface.h | 2 ++ include/wlr/render/wlr_renderer.h | 1 + render/wlr_renderer.c | 10 ++++++++++ 4 files changed, 21 insertions(+) create mode 100644 include/render/wlr_renderer.h diff --git a/include/render/wlr_renderer.h b/include/render/wlr_renderer.h new file mode 100644 index 00000000..0ef1ef82 --- /dev/null +++ b/include/render/wlr_renderer.h @@ -0,0 +1,8 @@ +#ifndef RENDER_WLR_RENDERER_H +#define RENDER_WLR_RENDERER_H + +#include + +bool wlr_renderer_bind_buffer(struct wlr_renderer *r, struct wlr_buffer *buffer); + +#endif diff --git a/include/wlr/render/interface.h b/include/wlr/render/interface.h index 998b1cfa..1b57c660 100644 --- a/include/wlr/render/interface.h +++ b/include/wlr/render/interface.h @@ -30,6 +30,8 @@ #include struct wlr_renderer_impl { + bool (*bind_buffer)(struct wlr_renderer *renderer, + struct wlr_buffer *buffer); void (*begin)(struct wlr_renderer *renderer, uint32_t width, uint32_t height); void (*end)(struct wlr_renderer *renderer); diff --git a/include/wlr/render/wlr_renderer.h b/include/wlr/render/wlr_renderer.h index 363a12e4..8908d3ce 100644 --- a/include/wlr/render/wlr_renderer.h +++ b/include/wlr/render/wlr_renderer.h @@ -21,6 +21,7 @@ enum wlr_renderer_read_pixels_flags { struct wlr_renderer_impl; struct wlr_drm_format_set; +struct wlr_buffer; struct wlr_renderer { const struct wlr_renderer_impl *impl; diff --git a/render/wlr_renderer.c b/render/wlr_renderer.c index bdcc836f..311747f1 100644 --- a/render/wlr_renderer.c +++ b/render/wlr_renderer.c @@ -7,6 +7,7 @@ #include #include #include "util/signal.h" +#include "render/wlr_renderer.h" void wlr_renderer_init(struct wlr_renderer *renderer, const struct wlr_renderer_impl *impl) { @@ -37,6 +38,15 @@ void wlr_renderer_destroy(struct wlr_renderer *r) { } } +bool wlr_renderer_bind_buffer(struct wlr_renderer *r, + struct wlr_buffer *buffer) { + assert(!r->rendering); + if (!r->impl->bind_buffer) { + return false; + } + return r->impl->bind_buffer(r, buffer); +} + void wlr_renderer_begin(struct wlr_renderer *r, uint32_t width, uint32_t height) { assert(!r->rendering);