diff options
author | Simon Ser <contact@emersion.fr> | 2023-12-05 18:52:48 +0100 |
---|---|---|
committer | Simon Ser <contact@emersion.fr> | 2023-12-05 18:57:43 +0100 |
commit | 1f64f3925c384e9bf20ad813ee3a9195403606ea (patch) | |
tree | 6a219bb2d9bef662e4a433d5070b7262da68ba73 | |
parent | 6a2ff0dffe37f14510643eda777390bc26d3d256 (diff) |
render/gles2: add wlr_gles2_renderer_get_buffer_fbo()
Replacement for wlr_gles2_renderer_get_current_fbo(). Wayfire uses
it for instance.
-rw-r--r-- | include/wlr/render/gles2.h | 5 | ||||
-rw-r--r-- | render/gles2/renderer.c | 20 |
2 files changed, 23 insertions, 2 deletions
diff --git a/include/wlr/render/gles2.h b/include/wlr/render/gles2.h index e096f4f3..454e7eb0 100644 --- a/include/wlr/render/gles2.h +++ b/include/wlr/render/gles2.h @@ -10,6 +10,7 @@ #define WLR_RENDER_GLES2_H #include <GLES2/gl2.h> + #include <wlr/render/wlr_renderer.h> struct wlr_egl; @@ -31,8 +32,8 @@ struct wlr_renderer *wlr_gles2_renderer_create_with_drm_fd(int drm_fd); struct wlr_renderer *wlr_gles2_renderer_create(struct wlr_egl *egl); struct wlr_egl *wlr_gles2_renderer_get_egl(struct wlr_renderer *renderer); -bool wlr_gles2_renderer_check_ext(struct wlr_renderer *renderer, - const char *ext); +bool wlr_gles2_renderer_check_ext(struct wlr_renderer *renderer, const char *ext); +GLuint wlr_gles2_renderer_get_buffer_fbo(struct wlr_renderer *renderer, struct wlr_buffer *buffer); struct wlr_gles2_texture_attribs { GLenum target; /* either GL_TEXTURE_2D or GL_TEXTURE_EXTERNAL_OES */ diff --git a/render/gles2/renderer.c b/render/gles2/renderer.c index 92e80709..a71423c0 100644 --- a/render/gles2/renderer.c +++ b/render/gles2/renderer.c @@ -271,6 +271,26 @@ static struct wlr_render_pass *gles2_begin_buffer_pass(struct wlr_renderer *wlr_ return &pass->base; } +GLuint wlr_gles2_renderer_get_buffer_fbo(struct wlr_renderer *wlr_renderer, + struct wlr_buffer *wlr_buffer) { + struct wlr_gles2_renderer *renderer = gles2_get_renderer(wlr_renderer); + GLuint fbo = 0; + + struct wlr_egl_context prev_ctx = {0}; + wlr_egl_save_context(&prev_ctx); + if (!wlr_egl_make_current(renderer->egl)) { + return 0; + } + + struct wlr_gles2_buffer *buffer = gles2_buffer_get_or_create(renderer, wlr_buffer); + if (buffer) { + fbo = gles2_buffer_get_fbo(buffer); + } + + wlr_egl_restore_context(&prev_ctx); + return fbo; +} + static struct wlr_render_timer *gles2_render_timer_create(struct wlr_renderer *wlr_renderer) { struct wlr_gles2_renderer *renderer = gles2_get_renderer(wlr_renderer); if (!renderer->exts.EXT_disjoint_timer_query) { |