diff options
author | Simon Ser <contact@emersion.fr> | 2022-06-16 14:43:24 +0200 |
---|---|---|
committer | Simon Ser <contact@emersion.fr> | 2022-06-16 14:43:24 +0200 |
commit | 29291cb47cdaa72d1142a008fef3301dcb86dfac (patch) | |
tree | 77616ce5285dea16bc1ebe1a41e02b1ed3b80ce6 /render | |
parent | f28c0e2046c59aeb9f014ef4c22d4517e38f4721 (diff) |
render/texture: drop wlr_texture_is_opaque
Whether a texture is opaque or not doesn't depend on the renderer
at all, it just depends on the source buffer. Instead of forcing
all renderers to implement wlr_texture_impl.is_opaque, let's move
this in common code and use the wlr_buffer format to know whether
a texture will be opaque.
Diffstat (limited to 'render')
-rw-r--r-- | render/gles2/texture.c | 6 | ||||
-rw-r--r-- | render/pixman/renderer.c | 6 | ||||
-rw-r--r-- | render/vulkan/texture.c | 9 | ||||
-rw-r--r-- | render/wlr_texture.c | 7 |
4 files changed, 0 insertions, 28 deletions
diff --git a/render/gles2/texture.c b/render/gles2/texture.c index 57420744..d794e436 100644 --- a/render/gles2/texture.c +++ b/render/gles2/texture.c @@ -29,11 +29,6 @@ struct wlr_gles2_texture *gles2_get_texture( return (struct wlr_gles2_texture *)wlr_texture; } -static bool gles2_texture_is_opaque(struct wlr_texture *wlr_texture) { - struct wlr_gles2_texture *texture = gles2_get_texture(wlr_texture); - return !texture->has_alpha; -} - static bool check_stride(const struct wlr_pixel_format_info *fmt, uint32_t stride, uint32_t width) { if (stride % (fmt->bpp / 8) != 0) { @@ -161,7 +156,6 @@ static void gles2_texture_unref(struct wlr_texture *wlr_texture) { } static const struct wlr_texture_impl texture_impl = { - .is_opaque = gles2_texture_is_opaque, .write_pixels = gles2_texture_write_pixels, .destroy = gles2_texture_unref, }; diff --git a/render/pixman/renderer.c b/render/pixman/renderer.c index 13db0880..2853b704 100644 --- a/render/pixman/renderer.c +++ b/render/pixman/renderer.c @@ -46,11 +46,6 @@ static struct wlr_pixman_texture *get_texture( return (struct wlr_pixman_texture *)wlr_texture; } -static bool texture_is_opaque(struct wlr_texture *wlr_texture) { - struct wlr_pixman_texture *texture = get_texture(wlr_texture); - return !texture->format_info->has_alpha; -} - static void texture_destroy(struct wlr_texture *wlr_texture) { struct wlr_pixman_texture *texture = get_texture(wlr_texture); wl_list_remove(&texture->link); @@ -61,7 +56,6 @@ static void texture_destroy(struct wlr_texture *wlr_texture) { } static const struct wlr_texture_impl texture_impl = { - .is_opaque = texture_is_opaque, .destroy = texture_destroy, }; diff --git a/render/vulkan/texture.c b/render/vulkan/texture.c index 26af9867..35b9562e 100644 --- a/render/vulkan/texture.c +++ b/render/vulkan/texture.c @@ -33,14 +33,6 @@ static VkImageAspectFlagBits mem_plane_aspect(unsigned i) { } } -static bool vulkan_texture_is_opaque(struct wlr_texture *wlr_texture) { - struct wlr_vk_texture *texture = vulkan_get_texture(wlr_texture); - const struct wlr_pixel_format_info *format_info = drm_get_pixel_format_info( - texture->format->drm_format); - assert(format_info); - return !format_info->has_alpha; -} - // Will transition the texture to shaderReadOnlyOptimal layout for reading // from fragment shader later on static bool write_pixels(struct wlr_texture *wlr_texture, @@ -199,7 +191,6 @@ static void vulkan_texture_unref(struct wlr_texture *wlr_texture) { } static const struct wlr_texture_impl texture_impl = { - .is_opaque = vulkan_texture_is_opaque, .write_pixels = vulkan_texture_write_pixels, .destroy = vulkan_texture_unref, }; diff --git a/render/wlr_texture.c b/render/wlr_texture.c index 36cbf136..fa864d02 100644 --- a/render/wlr_texture.c +++ b/render/wlr_texture.c @@ -71,13 +71,6 @@ struct wlr_texture *wlr_texture_from_buffer(struct wlr_renderer *renderer, return renderer->impl->texture_from_buffer(renderer, buffer); } -bool wlr_texture_is_opaque(struct wlr_texture *texture) { - if (!texture->impl->is_opaque) { - return false; - } - return texture->impl->is_opaque(texture); -} - bool wlr_texture_write_pixels(struct wlr_texture *texture, uint32_t stride, uint32_t width, uint32_t height, uint32_t src_x, uint32_t src_y, uint32_t dst_x, uint32_t dst_y, |