summaryrefslogtreecommitdiffstats
path: root/src/video_core/renderer_opengl/gl_shader_manager.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/video_core/renderer_opengl/gl_shader_manager.h')
-rw-r--r--src/video_core/renderer_opengl/gl_shader_manager.h19
1 files changed, 19 insertions, 0 deletions
diff --git a/src/video_core/renderer_opengl/gl_shader_manager.h b/src/video_core/renderer_opengl/gl_shader_manager.h
index 48669b3cd..df7e1f644 100644
--- a/src/video_core/renderer_opengl/gl_shader_manager.h
+++ b/src/video_core/renderer_opengl/gl_shader_manager.h
@@ -10,6 +10,7 @@
#include <glad/glad.h>
#include "video_core/renderer_opengl/gl_resource_manager.h"
+#include "video_core/renderer_opengl/gl_device.h"
#pragma optimize("", off)
@@ -24,6 +25,12 @@ class ProgramManager {
};
public:
+ explicit ProgramManager(const Device& device) {
+ if (device.UseAssemblyShaders()) {
+ glEnable(GL_COMPUTE_PROGRAM_NV);
+ }
+ }
+
void BindProgram(GLuint program) {
if (current_source_program == program) {
return;
@@ -32,6 +39,17 @@ public:
glUseProgram(program);
}
+ void BindComputeAssemblyProgram(GLuint program) {
+ if (current_compute_assembly_program != program) {
+ current_compute_assembly_program = program;
+ glBindProgramARB(GL_COMPUTE_PROGRAM_NV, program);
+ }
+ if (current_source_program != 0) {
+ current_source_program = 0;
+ glUseProgram(0);
+ }
+ }
+
void BindAssemblyPrograms(std::span<const OGLAssemblyProgram, NUM_STAGES> programs,
u32 stage_mask) {
const u32 changed_mask = current_assembly_mask ^ stage_mask;
@@ -67,6 +85,7 @@ private:
u32 current_assembly_mask = 0;
std::array<GLuint, NUM_STAGES> current_assembly_programs;
+ GLuint current_compute_assembly_program = 0;
};
} // namespace OpenGL