summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/video_core/renderer_opengl/gl_rasterizer.cpp18
-rw-r--r--src/video_core/renderer_opengl/gl_rasterizer.h3
2 files changed, 16 insertions, 5 deletions
diff --git a/src/video_core/renderer_opengl/gl_rasterizer.cpp b/src/video_core/renderer_opengl/gl_rasterizer.cpp
index a0527fe57..d4c7191b3 100644
--- a/src/video_core/renderer_opengl/gl_rasterizer.cpp
+++ b/src/video_core/renderer_opengl/gl_rasterizer.cpp
@@ -33,7 +33,8 @@ using Maxwell = Tegra::Engines::Maxwell3D::Regs;
33using PixelFormat = VideoCore::Surface::PixelFormat; 33using PixelFormat = VideoCore::Surface::PixelFormat;
34using SurfaceType = VideoCore::Surface::SurfaceType; 34using SurfaceType = VideoCore::Surface::SurfaceType;
35 35
36MICROPROFILE_DEFINE(OpenGL_VAO, "OpenGL", "Vertex Array Setup", MP_RGB(128, 128, 192)); 36MICROPROFILE_DEFINE(OpenGL_VAO, "OpenGL", "Vertex Format Setup", MP_RGB(128, 128, 192));
37MICROPROFILE_DEFINE(OpenGL_VB, "OpenGL", "Vertex Buffer Setup", MP_RGB(128, 128, 192));
37MICROPROFILE_DEFINE(OpenGL_Shader, "OpenGL", "Shader Setup", MP_RGB(128, 128, 192)); 38MICROPROFILE_DEFINE(OpenGL_Shader, "OpenGL", "Shader Setup", MP_RGB(128, 128, 192));
38MICROPROFILE_DEFINE(OpenGL_UBO, "OpenGL", "Const Buffer Setup", MP_RGB(128, 128, 192)); 39MICROPROFILE_DEFINE(OpenGL_UBO, "OpenGL", "Const Buffer Setup", MP_RGB(128, 128, 192));
39MICROPROFILE_DEFINE(OpenGL_Index, "OpenGL", "Index Buffer Setup", MP_RGB(128, 128, 192)); 40MICROPROFILE_DEFINE(OpenGL_Index, "OpenGL", "Index Buffer Setup", MP_RGB(128, 128, 192));
@@ -122,7 +123,7 @@ RasterizerOpenGL::RasterizerOpenGL(Core::Frontend::EmuWindow& window, ScreenInfo
122 123
123RasterizerOpenGL::~RasterizerOpenGL() {} 124RasterizerOpenGL::~RasterizerOpenGL() {}
124 125
125void RasterizerOpenGL::SetupVertexArrays() { 126void RasterizerOpenGL::SetupVertexFormat() {
126 MICROPROFILE_SCOPE(OpenGL_VAO); 127 MICROPROFILE_SCOPE(OpenGL_VAO);
127 const auto& gpu = Core::System::GetInstance().GPU().Maxwell3D(); 128 const auto& gpu = Core::System::GetInstance().GPU().Maxwell3D();
128 const auto& regs = gpu.regs; 129 const auto& regs = gpu.regs;
@@ -175,8 +176,13 @@ void RasterizerOpenGL::SetupVertexArrays() {
175 } 176 }
176 } 177 }
177 state.draw.vertex_array = VAO.handle; 178 state.draw.vertex_array = VAO.handle;
178 state.draw.vertex_buffer = buffer_cache.GetHandle();
179 state.Apply(); 179 state.Apply();
180}
181
182void RasterizerOpenGL::SetupVertexBuffer() {
183 MICROPROFILE_SCOPE(OpenGL_VB);
184 const auto& gpu = Core::System::GetInstance().GPU().Maxwell3D();
185 const auto& regs = gpu.regs;
180 186
181 // Upload all guest vertex arrays sequentially to our buffer 187 // Upload all guest vertex arrays sequentially to our buffer
182 for (u32 index = 0; index < Maxwell::NumVertexArrays; ++index) { 188 for (u32 index = 0; index < Maxwell::NumVertexArrays; ++index) {
@@ -203,6 +209,9 @@ void RasterizerOpenGL::SetupVertexArrays() {
203 glVertexBindingDivisor(index, 0); 209 glVertexBindingDivisor(index, 0);
204 } 210 }
205 } 211 }
212
213 // Implicit set by glBindVertexBuffer. Stupid glstate handling...
214 state.draw.vertex_buffer = buffer_cache.GetHandle();
206} 215}
207 216
208DrawParameters RasterizerOpenGL::SetupDraw() { 217DrawParameters RasterizerOpenGL::SetupDraw() {
@@ -621,7 +630,8 @@ void RasterizerOpenGL::DrawArrays() {
621 630
622 buffer_cache.Map(buffer_size); 631 buffer_cache.Map(buffer_size);
623 632
624 SetupVertexArrays(); 633 SetupVertexFormat();
634 SetupVertexBuffer();
625 DrawParameters params = SetupDraw(); 635 DrawParameters params = SetupDraw();
626 SetupShaders(params.primitive_mode); 636 SetupShaders(params.primitive_mode);
627 637
diff --git a/src/video_core/renderer_opengl/gl_rasterizer.h b/src/video_core/renderer_opengl/gl_rasterizer.h
index 47097c569..0fab3eb28 100644
--- a/src/video_core/renderer_opengl/gl_rasterizer.h
+++ b/src/video_core/renderer_opengl/gl_rasterizer.h
@@ -207,7 +207,8 @@ private:
207 207
208 std::size_t CalculateIndexBufferSize() const; 208 std::size_t CalculateIndexBufferSize() const;
209 209
210 void SetupVertexArrays(); 210 void SetupVertexFormat();
211 void SetupVertexBuffer();
211 212
212 DrawParameters SetupDraw(); 213 DrawParameters SetupDraw();
213 214