diff --git a/docs/features.txt b/docs/features.txt index 53073657d8f..d41cd2f8d5c 100644 --- a/docs/features.txt +++ b/docs/features.txt @@ -332,6 +332,7 @@ Khronos, ARB, and OES extensions that are not part of any OpenGL or OpenGL ES ve GL_EXT_semaphore DONE (radeonsi, zink, d3d12, iris, crocus) GL_EXT_semaphore_fd DONE (radeonsi, zink, iris, crocus) GL_EXT_semaphore_win32 DONE (zink, d3d12) + GL_EXT_shader_clock DONE (all drivers that support GL_ARB_shader_clock) GL_EXT_shader_group_vote DONE (all drivers that support GL_ARB_shader_group_vote) GL_EXT_shader_realtime_clock DONE (panfrost/v6+) GL_EXT_sRGB_write_control DONE (all drivers that support GLES 3.0+) diff --git a/src/compiler/glsl/builtin_functions.cpp b/src/compiler/glsl/builtin_functions.cpp index 0c5d7b708a2..dace8466955 100644 --- a/src/compiler/glsl/builtin_functions.cpp +++ b/src/compiler/glsl/builtin_functions.cpp @@ -720,13 +720,15 @@ supports_nv_fragment_shader_interlock(const _mesa_glsl_parse_state *state) static bool shader_clock(const _mesa_glsl_parse_state *state) { - return state->ARB_shader_clock_enable; + return state->ARB_shader_clock_enable || + state->EXT_shader_clock_enable; } static bool shader_clock_int64(const _mesa_glsl_parse_state *state) { - return state->ARB_shader_clock_enable && + return (state->ARB_shader_clock_enable || + state->EXT_shader_clock_enable) && (state->ARB_gpu_shader_int64_enable || state->AMD_gpu_shader_int64_enable); } diff --git a/src/compiler/glsl/glsl_parser_extras.cpp b/src/compiler/glsl/glsl_parser_extras.cpp index 29feb58a18d..4062d428b8d 100644 --- a/src/compiler/glsl/glsl_parser_extras.cpp +++ b/src/compiler/glsl/glsl_parser_extras.cpp @@ -821,6 +821,7 @@ static const _mesa_glsl_extension _mesa_glsl_supported_extensions[] = { EXT_AEP(EXT_gpu_shader5), EXT_AEP(EXT_primitive_bounding_box), EXT(EXT_separate_shader_objects), + EXT(EXT_shader_clock), EXT(EXT_shader_framebuffer_fetch), EXT(EXT_shader_framebuffer_fetch_non_coherent), EXT(EXT_shader_group_vote), diff --git a/src/compiler/glsl/glsl_parser_extras.h b/src/compiler/glsl/glsl_parser_extras.h index 77b85de57ac..ad09d7ad14e 100644 --- a/src/compiler/glsl/glsl_parser_extras.h +++ b/src/compiler/glsl/glsl_parser_extras.h @@ -880,6 +880,8 @@ struct _mesa_glsl_parse_state { bool EXT_primitive_bounding_box_warn; bool EXT_separate_shader_objects_enable; bool EXT_separate_shader_objects_warn; + bool EXT_shader_clock_enable; + bool EXT_shader_clock_warn; bool EXT_shader_framebuffer_fetch_enable; bool EXT_shader_framebuffer_fetch_warn; bool EXT_shader_framebuffer_fetch_non_coherent_enable; diff --git a/src/mesa/main/extensions_table.h b/src/mesa/main/extensions_table.h index 82701a98341..6a812aaf97d 100644 --- a/src/mesa/main/extensions_table.h +++ b/src/mesa/main/extensions_table.h @@ -294,6 +294,7 @@ EXT(EXT_semaphore_fd , EXT_semaphore_fd EXT(EXT_semaphore_win32 , EXT_semaphore_win32 , GLL, GLC, x , ES2, 2017) EXT(EXT_separate_shader_objects , dummy_true , x , x , x , ES2, 2013) EXT(EXT_separate_specular_color , dummy_true , GLL, x , x , x , 1997) +EXT(EXT_shader_clock , ARB_shader_clock , GLL, GLC, x , x , 2025) EXT(EXT_shader_framebuffer_fetch , EXT_shader_framebuffer_fetch , GLL, GLC, x , ES2, 2013) EXT(EXT_shader_framebuffer_fetch_non_coherent, EXT_shader_framebuffer_fetch_non_coherent, GLL, GLC, x, ES2, 2018) EXT(EXT_shader_group_vote , ARB_shader_group_vote , x, x, x , 30, 2013) diff --git a/src/mesa/state_tracker/st_extensions.c b/src/mesa/state_tracker/st_extensions.c index ba0b7f09d7d..c11e54cf9c5 100644 --- a/src/mesa/state_tracker/st_extensions.c +++ b/src/mesa/state_tracker/st_extensions.c @@ -1053,7 +1053,6 @@ void st_init_extensions(struct pipe_screen *screen, EXT_CAP(ARB_sample_locations, programmable_sample_locations); EXT_CAP(ARB_seamless_cube_map, seamless_cube_map); EXT_CAP(ARB_shader_ballot, shader_ballot); - EXT_CAP(ARB_shader_clock, shader_clock); EXT_CAP(ARB_shader_draw_parameters, draw_parameters); EXT_CAP(ARB_shader_group_vote, shader_group_vote); EXT_CAP(EXT_shader_image_load_formatted, image_load_formatted);