2019-09-23 14:54:49 +03:00
|
|
|
/*
|
|
|
|
* Copyright © 2019 Collabora, Ltd.
|
2019-04-18 19:15:48 +03:00
|
|
|
* Copyright © 2019 Harish Krupo
|
|
|
|
* Copyright © 2019 Intel Corporation
|
2021-09-09 21:22:43 +03:00
|
|
|
* Copyright 2021 Advanced Micro Devices, Inc.
|
2019-09-23 14:54:49 +03:00
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining
|
|
|
|
* a copy of this software and associated documentation files (the
|
|
|
|
* "Software"), to deal in the Software without restriction, including
|
|
|
|
* without limitation the rights to use, copy, modify, merge, publish,
|
|
|
|
* distribute, sublicense, and/or sell copies of the Software, and to
|
|
|
|
* permit persons to whom the Software is furnished to do so, subject to
|
|
|
|
* the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice (including the
|
|
|
|
* next paragraph) shall be included in all copies or substantial
|
|
|
|
* portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
|
|
|
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
|
|
|
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
* SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef GL_RENDERER_INTERNAL_H
|
|
|
|
#define GL_RENDERER_INTERNAL_H
|
|
|
|
|
2019-04-18 19:15:48 +03:00
|
|
|
#include <stdbool.h>
|
2021-02-10 13:33:03 +03:00
|
|
|
#include <time.h>
|
2019-04-18 19:15:48 +03:00
|
|
|
|
|
|
|
#include <wayland-util.h>
|
2019-09-23 14:54:49 +03:00
|
|
|
#include <GLES2/gl2.h>
|
|
|
|
#include <GLES2/gl2ext.h>
|
2019-11-13 14:34:30 +03:00
|
|
|
#include "shared/weston-egl-ext.h" /* for PFN* stuff */
|
2019-04-18 19:15:48 +03:00
|
|
|
#include "shared/helpers.h"
|
|
|
|
|
2023-02-15 16:38:32 +03:00
|
|
|
/* Keep the following in sync with vertex.glsl. */
|
|
|
|
enum gl_shader_texcoord_input {
|
|
|
|
SHADER_TEXCOORD_INPUT_ATTRIB = 0,
|
|
|
|
SHADER_TEXCOORD_INPUT_SURFACE,
|
|
|
|
};
|
|
|
|
|
2019-04-18 19:15:48 +03:00
|
|
|
enum gl_shader_texture_variant {
|
|
|
|
SHADER_VARIANT_NONE = 0,
|
|
|
|
/* Keep the following in sync with fragment.glsl. */
|
|
|
|
SHADER_VARIANT_RGBX,
|
|
|
|
SHADER_VARIANT_RGBA,
|
|
|
|
SHADER_VARIANT_Y_U_V,
|
|
|
|
SHADER_VARIANT_Y_UV,
|
|
|
|
SHADER_VARIANT_Y_XUXV,
|
|
|
|
SHADER_VARIANT_XYUV,
|
|
|
|
SHADER_VARIANT_SOLID,
|
|
|
|
SHADER_VARIANT_EXTERNAL,
|
|
|
|
};
|
|
|
|
|
2021-03-22 17:17:28 +03:00
|
|
|
/* Keep the following in sync with fragment.glsl. */
|
|
|
|
enum gl_shader_color_curve {
|
|
|
|
SHADER_COLOR_CURVE_IDENTITY = 0,
|
|
|
|
SHADER_COLOR_CURVE_LUT_3x1D,
|
2024-03-18 17:14:04 +03:00
|
|
|
SHADER_COLOR_CURVE_LINPOW,
|
|
|
|
SHADER_COLOR_CURVE_POWLIN,
|
2021-03-22 17:17:28 +03:00
|
|
|
};
|
|
|
|
|
2021-09-09 21:22:43 +03:00
|
|
|
/* Keep the following in sync with fragment.glsl. */
|
|
|
|
enum gl_shader_color_mapping {
|
|
|
|
SHADER_COLOR_MAPPING_IDENTITY = 0,
|
|
|
|
SHADER_COLOR_MAPPING_3DLUT,
|
2022-06-25 22:48:49 +03:00
|
|
|
SHADER_COLOR_MAPPING_MATRIX,
|
2021-09-09 21:22:43 +03:00
|
|
|
};
|
|
|
|
|
2019-04-18 19:15:48 +03:00
|
|
|
/** GL shader requirements key
|
|
|
|
*
|
|
|
|
* This structure is used as a binary blob key for building and searching
|
|
|
|
* shaders. Therefore it must not contain any bytes or bits the C compiler
|
|
|
|
* would be free to leave undefined e.g. after struct initialization,
|
|
|
|
* struct assignment, or member operations.
|
|
|
|
*
|
|
|
|
* Use 'pahole' from package 'dwarves' to inspect this structure.
|
|
|
|
*/
|
|
|
|
struct gl_shader_requirements
|
|
|
|
{
|
2023-02-15 16:38:32 +03:00
|
|
|
unsigned texcoord_input:1; /* enum gl_shader_texcoord_input */
|
|
|
|
|
2019-04-18 19:15:48 +03:00
|
|
|
unsigned variant:4; /* enum gl_shader_texture_variant */
|
2021-03-12 15:06:34 +03:00
|
|
|
bool input_is_premult:1;
|
2019-04-18 19:15:48 +03:00
|
|
|
bool green_tint:1;
|
|
|
|
|
2024-03-18 17:14:04 +03:00
|
|
|
unsigned color_pre_curve:2; /* enum gl_shader_color_curve */
|
2022-06-25 22:48:49 +03:00
|
|
|
unsigned color_mapping:2; /* enum gl_shader_color_mapping */
|
2024-03-18 17:14:04 +03:00
|
|
|
unsigned color_post_curve:2; /* enum gl_shader_color_curve */
|
2019-04-18 19:15:48 +03:00
|
|
|
/*
|
|
|
|
* The total size of all bitfields plus pad_bits_ must fill up exactly
|
|
|
|
* how many bytes the compiler allocates for them together.
|
|
|
|
*/
|
2024-03-18 17:14:04 +03:00
|
|
|
unsigned pad_bits_:19;
|
2019-04-18 19:15:48 +03:00
|
|
|
};
|
|
|
|
static_assert(sizeof(struct gl_shader_requirements) ==
|
|
|
|
4 /* total bitfield size in bytes */,
|
|
|
|
"struct gl_shader_requirements must not contain implicit padding");
|
2019-09-23 14:54:49 +03:00
|
|
|
|
2021-03-18 18:42:06 +03:00
|
|
|
struct gl_shader;
|
2021-03-09 17:40:25 +03:00
|
|
|
struct weston_color_transform;
|
2021-03-18 18:42:06 +03:00
|
|
|
|
|
|
|
#define GL_SHADER_INPUT_TEX_MAX 3
|
|
|
|
struct gl_shader_config {
|
|
|
|
struct gl_shader_requirements req;
|
|
|
|
|
|
|
|
struct weston_matrix projection;
|
2023-02-15 16:38:32 +03:00
|
|
|
struct weston_matrix surface_to_buffer;
|
2021-03-18 18:42:06 +03:00
|
|
|
float view_alpha;
|
|
|
|
GLfloat unicolor[4];
|
|
|
|
GLint input_tex_filter; /* GL_NEAREST or GL_LINEAR */
|
|
|
|
GLuint input_tex[GL_SHADER_INPUT_TEX_MAX];
|
2024-03-05 00:55:14 +03:00
|
|
|
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
GLuint tex;
|
|
|
|
GLfloat scale_offset[2];
|
|
|
|
} lut_3x1d;
|
2024-03-18 17:14:04 +03:00
|
|
|
struct {
|
|
|
|
GLfloat params[3][10];
|
|
|
|
GLboolean clamped_input;
|
|
|
|
} parametric;
|
2024-03-05 00:55:14 +03:00
|
|
|
} color_pre_curve;
|
|
|
|
|
2021-09-09 21:22:43 +03:00
|
|
|
union {
|
|
|
|
struct {
|
2024-03-05 00:55:14 +03:00
|
|
|
GLuint tex;
|
2021-09-09 21:22:43 +03:00
|
|
|
GLfloat scale_offset[2];
|
|
|
|
} lut3d;
|
2022-06-25 22:48:49 +03:00
|
|
|
GLfloat matrix[9];
|
2021-09-09 21:22:43 +03:00
|
|
|
} color_mapping;
|
2024-03-05 00:55:14 +03:00
|
|
|
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
GLuint tex;
|
|
|
|
GLfloat scale_offset[2];
|
|
|
|
} lut_3x1d;
|
2024-03-18 17:14:04 +03:00
|
|
|
struct {
|
|
|
|
GLfloat params[3][10];
|
|
|
|
GLboolean clamped_input;
|
|
|
|
} parametric;
|
2024-03-05 00:55:14 +03:00
|
|
|
} color_post_curve;
|
2019-09-23 14:54:49 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
struct gl_renderer {
|
|
|
|
struct weston_renderer base;
|
2021-02-09 18:31:11 +03:00
|
|
|
struct weston_compositor *compositor;
|
2022-05-17 15:15:47 +03:00
|
|
|
struct weston_log_scope *renderer_scope;
|
2021-02-09 18:31:11 +03:00
|
|
|
|
2019-09-23 14:54:49 +03:00
|
|
|
bool fragment_shader_debug;
|
|
|
|
bool fan_debug;
|
|
|
|
struct weston_binding *fragment_binding;
|
|
|
|
struct weston_binding *fan_binding;
|
|
|
|
|
2019-09-30 14:57:25 +03:00
|
|
|
EGLenum platform;
|
2019-09-23 14:54:49 +03:00
|
|
|
EGLDisplay egl_display;
|
|
|
|
EGLContext egl_context;
|
|
|
|
EGLConfig egl_config;
|
|
|
|
|
|
|
|
uint32_t gl_version;
|
|
|
|
|
|
|
|
struct wl_array vertices;
|
|
|
|
struct wl_array vtxcnt;
|
|
|
|
|
2021-01-19 00:10:58 +03:00
|
|
|
EGLDeviceEXT egl_device;
|
|
|
|
const char *drm_device;
|
|
|
|
|
2021-03-04 23:47:13 +03:00
|
|
|
struct weston_drm_format_array supported_formats;
|
|
|
|
|
2019-09-23 14:54:49 +03:00
|
|
|
PFNGLEGLIMAGETARGETTEXTURE2DOESPROC image_target_texture_2d;
|
2022-02-20 20:07:36 +03:00
|
|
|
PFNGLTEXIMAGE3DOESPROC tex_image_3d;
|
2019-09-23 14:54:49 +03:00
|
|
|
PFNEGLCREATEIMAGEKHRPROC create_image;
|
|
|
|
PFNEGLDESTROYIMAGEKHRPROC destroy_image;
|
|
|
|
PFNEGLSWAPBUFFERSWITHDAMAGEEXTPROC swap_buffers_with_damage;
|
2019-12-20 04:39:38 +03:00
|
|
|
|
|
|
|
PFNEGLGETPLATFORMDISPLAYEXTPROC get_platform_display;
|
2019-09-23 14:54:49 +03:00
|
|
|
PFNEGLCREATEPLATFORMWINDOWSURFACEEXTPROC create_platform_window;
|
2019-12-20 04:39:38 +03:00
|
|
|
bool has_platform_base;
|
2019-09-23 14:54:49 +03:00
|
|
|
|
|
|
|
PFNEGLBINDWAYLANDDISPLAYWL bind_display;
|
|
|
|
PFNEGLUNBINDWAYLANDDISPLAYWL unbind_display;
|
|
|
|
PFNEGLQUERYWAYLANDBUFFERWL query_buffer;
|
|
|
|
bool has_bind_display;
|
|
|
|
|
|
|
|
bool has_context_priority;
|
|
|
|
|
|
|
|
bool has_egl_image_external;
|
|
|
|
|
|
|
|
bool has_egl_buffer_age;
|
|
|
|
bool has_egl_partial_update;
|
|
|
|
PFNEGLSETDAMAGEREGIONKHRPROC set_damage_region;
|
|
|
|
|
|
|
|
bool has_configless_context;
|
|
|
|
|
|
|
|
bool has_surfaceless_context;
|
|
|
|
|
|
|
|
bool has_dmabuf_import;
|
|
|
|
struct wl_list dmabuf_images;
|
2019-11-27 16:11:05 +03:00
|
|
|
struct wl_list dmabuf_formats;
|
2019-09-23 14:54:49 +03:00
|
|
|
|
2021-10-21 03:52:11 +03:00
|
|
|
bool has_texture_type_2_10_10_10_rev;
|
2019-09-23 14:54:49 +03:00
|
|
|
bool has_gl_texture_rg;
|
2022-01-04 22:32:44 +03:00
|
|
|
bool has_texture_norm16;
|
2021-03-30 14:27:00 +03:00
|
|
|
bool has_texture_storage;
|
2022-08-02 16:20:06 +03:00
|
|
|
bool has_pack_reverse;
|
2021-03-30 14:27:00 +03:00
|
|
|
bool has_rgb8_rgba8;
|
2023-11-29 14:54:52 +03:00
|
|
|
|
2023-10-05 10:23:47 +03:00
|
|
|
bool has_pbo;
|
2023-11-29 14:54:52 +03:00
|
|
|
GLenum pbo_usage;
|
|
|
|
PFNGLMAPBUFFERRANGEEXTPROC map_buffer_range;
|
|
|
|
PFNGLUNMAPBUFFEROESPROC unmap_buffer;
|
2023-10-05 10:23:47 +03:00
|
|
|
|
|
|
|
struct wl_list pending_capture_list;
|
2019-09-23 14:54:49 +03:00
|
|
|
|
|
|
|
struct gl_shader *current_shader;
|
2021-01-28 15:12:48 +03:00
|
|
|
struct gl_shader *fallback_shader;
|
2019-09-23 14:54:49 +03:00
|
|
|
|
|
|
|
struct wl_signal destroy_signal;
|
|
|
|
|
|
|
|
bool has_dmabuf_import_modifiers;
|
|
|
|
PFNEGLQUERYDMABUFFORMATSEXTPROC query_dmabuf_formats;
|
|
|
|
PFNEGLQUERYDMABUFMODIFIERSEXTPROC query_dmabuf_modifiers;
|
|
|
|
|
2021-01-19 00:10:58 +03:00
|
|
|
bool has_device_query;
|
|
|
|
PFNEGLQUERYDISPLAYATTRIBEXTPROC query_display_attrib;
|
|
|
|
PFNEGLQUERYDEVICESTRINGEXTPROC query_device_string;
|
|
|
|
|
2019-09-23 14:54:49 +03:00
|
|
|
bool has_native_fence_sync;
|
|
|
|
PFNEGLCREATESYNCKHRPROC create_sync;
|
|
|
|
PFNEGLDESTROYSYNCKHRPROC destroy_sync;
|
|
|
|
PFNEGLDUPNATIVEFENCEFDANDROIDPROC dup_native_fence_fd;
|
|
|
|
|
|
|
|
bool has_wait_sync;
|
|
|
|
PFNEGLWAITSYNCKHRPROC wait_sync;
|
2019-04-18 19:15:48 +03:00
|
|
|
|
2023-01-12 10:04:40 +03:00
|
|
|
bool has_disjoint_timer_query;
|
|
|
|
PFNGLGENQUERIESEXTPROC gen_queries;
|
|
|
|
PFNGLDELETEQUERIESEXTPROC delete_queries;
|
|
|
|
PFNGLBEGINQUERYEXTPROC begin_query;
|
|
|
|
PFNGLENDQUERYEXTPROC end_query;
|
|
|
|
#if !defined(NDEBUG)
|
|
|
|
PFNGLGETQUERYOBJECTIVEXTPROC get_query_object_iv;
|
|
|
|
#endif
|
|
|
|
PFNGLGETQUERYOBJECTUI64VEXTPROC get_query_object_ui64v;
|
|
|
|
|
2021-03-16 14:11:09 +03:00
|
|
|
bool gl_supports_color_transforms;
|
2019-04-18 19:15:48 +03:00
|
|
|
|
2021-02-10 13:33:03 +03:00
|
|
|
/** Shader program cache in most recently used order
|
2019-04-18 19:15:48 +03:00
|
|
|
*
|
2021-02-10 13:33:03 +03:00
|
|
|
* Uses struct gl_shader::link.
|
2019-04-18 19:15:48 +03:00
|
|
|
*/
|
|
|
|
struct wl_list shader_list;
|
2019-04-18 19:15:48 +03:00
|
|
|
struct weston_log_scope *shader_scope;
|
2019-09-23 14:54:49 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
static inline struct gl_renderer *
|
|
|
|
get_renderer(struct weston_compositor *ec)
|
|
|
|
{
|
|
|
|
return (struct gl_renderer *)ec->renderer;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
gl_renderer_print_egl_error_state(void);
|
|
|
|
|
2019-12-20 04:55:39 +03:00
|
|
|
void
|
2022-05-17 14:55:27 +03:00
|
|
|
gl_renderer_log_extensions(struct gl_renderer *gr,
|
|
|
|
const char *name, const char *extensions);
|
2019-12-20 04:55:39 +03:00
|
|
|
|
2019-09-23 14:54:49 +03:00
|
|
|
void
|
|
|
|
log_egl_config_info(EGLDisplay egldpy, EGLConfig eglconfig);
|
|
|
|
|
2019-09-13 15:35:10 +03:00
|
|
|
EGLConfig
|
|
|
|
gl_renderer_get_egl_config(struct gl_renderer *gr,
|
2019-09-13 17:24:49 +03:00
|
|
|
EGLint egl_surface_type,
|
2023-01-26 19:33:05 +03:00
|
|
|
const struct pixel_format_info *const *formats,
|
|
|
|
unsigned formats_count);
|
2019-09-13 15:35:10 +03:00
|
|
|
|
2019-12-20 05:07:43 +03:00
|
|
|
int
|
|
|
|
gl_renderer_setup_egl_display(struct gl_renderer *gr, void *native_display);
|
|
|
|
|
2019-12-20 04:55:39 +03:00
|
|
|
int
|
2019-12-20 04:28:44 +03:00
|
|
|
gl_renderer_setup_egl_client_extensions(struct gl_renderer *gr);
|
|
|
|
|
2019-09-23 14:54:49 +03:00
|
|
|
int
|
|
|
|
gl_renderer_setup_egl_extensions(struct weston_compositor *ec);
|
|
|
|
|
2021-03-18 18:42:06 +03:00
|
|
|
GLenum
|
|
|
|
gl_shader_texture_variant_get_target(enum gl_shader_texture_variant v);
|
|
|
|
|
2021-03-12 15:06:34 +03:00
|
|
|
bool
|
|
|
|
gl_shader_texture_variant_can_be_premult(enum gl_shader_texture_variant v);
|
|
|
|
|
2020-11-24 15:27:28 +03:00
|
|
|
void
|
2021-02-10 14:15:29 +03:00
|
|
|
gl_shader_destroy(struct gl_renderer *gr, struct gl_shader *shader);
|
2019-04-18 19:15:48 +03:00
|
|
|
|
2021-03-22 13:55:51 +03:00
|
|
|
void
|
|
|
|
gl_renderer_shader_list_destroy(struct gl_renderer *gr);
|
|
|
|
|
2019-04-18 19:15:48 +03:00
|
|
|
struct gl_shader *
|
2021-03-18 14:02:25 +03:00
|
|
|
gl_renderer_create_fallback_shader(struct gl_renderer *gr);
|
2020-11-24 15:27:28 +03:00
|
|
|
|
2021-03-18 14:02:25 +03:00
|
|
|
void
|
|
|
|
gl_renderer_garbage_collect_programs(struct gl_renderer *gr);
|
|
|
|
|
|
|
|
bool
|
2021-03-18 18:42:06 +03:00
|
|
|
gl_renderer_use_program(struct gl_renderer *gr,
|
|
|
|
const struct gl_shader_config *sconf);
|
2020-11-24 15:27:28 +03:00
|
|
|
|
2019-04-18 19:15:48 +03:00
|
|
|
struct weston_log_scope *
|
2021-02-09 18:31:11 +03:00
|
|
|
gl_shader_scope_create(struct gl_renderer *gr);
|
2019-04-18 19:15:48 +03:00
|
|
|
|
2021-03-09 17:40:25 +03:00
|
|
|
bool
|
2022-02-20 20:07:36 +03:00
|
|
|
gl_shader_config_set_color_transform(struct gl_renderer *gr,
|
|
|
|
struct gl_shader_config *sconf,
|
2021-03-09 17:40:25 +03:00
|
|
|
struct weston_color_transform *xform);
|
|
|
|
|
2019-09-23 14:54:49 +03:00
|
|
|
#endif /* GL_RENDERER_INTERNAL_H */
|