summaryrefslogtreecommitdiff
path: root/render/fx_renderer
diff options
context:
space:
mode:
Diffstat (limited to 'render/fx_renderer')
-rw-r--r--render/fx_renderer/fx_pass.c23
-rw-r--r--render/fx_renderer/fx_renderer.c6
2 files changed, 14 insertions, 15 deletions
diff --git a/render/fx_renderer/fx_pass.c b/render/fx_renderer/fx_pass.c
index f3a9485..9a27de1 100644
--- a/render/fx_renderer/fx_pass.c
+++ b/render/fx_renderer/fx_pass.c
@@ -84,10 +84,12 @@ static bool render_pass_submit(struct wlr_render_pass *wlr_pass) {
pop_fx_debug(renderer);
wlr_buffer_unlock(pass->buffer->buffer);
+ if (pass->output) {
+ struct fx_effect_framebuffers *fbos = fx_effect_framebuffers_try_get(pass->output);
+ pixman_region32_fini(&fbos->blur_padding_region);
+ }
free(pass);
- pixman_region32_fini(&renderer->blur_padding_region);
-
return true;
}
@@ -961,6 +963,8 @@ struct fx_gles_render_pass *fx_renderer_begin_buffer_pass(
struct wlr_renderer *wlr_renderer, struct wlr_buffer *wlr_buffer,
struct wlr_output *output, const struct wlr_buffer_pass_options *options) {
struct fx_renderer *renderer = fx_get_renderer(wlr_renderer);
+ assert(output);
+
renderer->basic_renderer = false;
if (!wlr_egl_make_current(renderer->egl)) {
return NULL;
@@ -977,17 +981,14 @@ struct fx_gles_render_pass *fx_renderer_begin_buffer_pass(
return NULL;
}
- // Update the buffers if needed
- struct fx_effect_framebuffers *fbos = NULL;
// For per output framebuffers
- if (output) {
- fbos = fx_effect_framebuffers_try_get(output);
- fx_framebuffer_get_or_create_custom(renderer, output, &fbos->blur_saved_pixels_buffer);
- fx_framebuffer_get_or_create_custom(renderer, output, &fbos->effects_buffer);
- fx_framebuffer_get_or_create_custom(renderer, output, &fbos->effects_buffer_swapped);
- }
+ struct fx_effect_framebuffers *fbos = fx_effect_framebuffers_try_get(output);
+ // Update the buffers if needed
+ fx_framebuffer_get_or_create_custom(renderer, output, &fbos->blur_saved_pixels_buffer);
+ fx_framebuffer_get_or_create_custom(renderer, output, &fbos->effects_buffer);
+ fx_framebuffer_get_or_create_custom(renderer, output, &fbos->effects_buffer_swapped);
- pixman_region32_init(&renderer->blur_padding_region);
+ pixman_region32_init(&fbos->blur_padding_region);
struct fx_gles_render_pass *pass = begin_buffer_pass(buffer, timer);
if (!pass) {
diff --git a/render/fx_renderer/fx_renderer.c b/render/fx_renderer/fx_renderer.c
index 0b9e1a4..b089b4e 100644
--- a/render/fx_renderer/fx_renderer.c
+++ b/render/fx_renderer/fx_renderer.c
@@ -119,6 +119,7 @@ static const char *reset_status_str(GLenum status) {
}
}
+// TODO: Deprecate all older rendering functions?
static bool fx_renderer_begin(struct wlr_renderer *wlr_renderer, uint32_t width,
uint32_t height) {
struct fx_renderer *renderer =
@@ -140,8 +141,6 @@ static bool fx_renderer_begin(struct wlr_renderer *wlr_renderer, uint32_t width,
renderer->viewport_width = width;
renderer->viewport_height = height;
- pixman_region32_init(&renderer->blur_padding_region);
-
// refresh projection matrix
matrix_projection(renderer->projection, width, height,
WL_OUTPUT_TRANSFORM_FLIPPED_180);
@@ -157,8 +156,7 @@ static bool fx_renderer_begin(struct wlr_renderer *wlr_renderer, uint32_t width,
}
static void fx_renderer_end(struct wlr_renderer *wlr_renderer) {
- struct fx_renderer *renderer = fx_get_renderer_in_context(wlr_renderer);
- pixman_region32_fini(&renderer->blur_padding_region);
+ // no-op
}
static void fx_renderer_clear(struct wlr_renderer *wlr_renderer,