summaryrefslogtreecommitdiffstats
path: root/src/video_core/renderer_opengl/utils.cpp
diff options
context:
space:
mode:
authorReinUsesLisp <reinuseslisp@airmail.cc>2019-04-05 23:31:24 +0200
committerReinUsesLisp <reinuseslisp@airmail.cc>2019-04-06 00:10:46 +0200
commit2d1f054c61f71656a72eedbd8bda7693e950ab94 (patch)
treec3ed952b7ed595126cd50f3ad16e4a48b001f92e /src/video_core/renderer_opengl/utils.cpp
parentMerge pull request #2282 from bunnei/gpu-asynch-v2 (diff)
downloadyuzu-2d1f054c61f71656a72eedbd8bda7693e950ab94.tar
yuzu-2d1f054c61f71656a72eedbd8bda7693e950ab94.tar.gz
yuzu-2d1f054c61f71656a72eedbd8bda7693e950ab94.tar.bz2
yuzu-2d1f054c61f71656a72eedbd8bda7693e950ab94.tar.lz
yuzu-2d1f054c61f71656a72eedbd8bda7693e950ab94.tar.xz
yuzu-2d1f054c61f71656a72eedbd8bda7693e950ab94.tar.zst
yuzu-2d1f054c61f71656a72eedbd8bda7693e950ab94.zip
Diffstat (limited to '')
-rw-r--r--src/video_core/renderer_opengl/utils.cpp25
1 files changed, 25 insertions, 0 deletions
diff --git a/src/video_core/renderer_opengl/utils.cpp b/src/video_core/renderer_opengl/utils.cpp
index d84634cb3..79bda54c1 100644
--- a/src/video_core/renderer_opengl/utils.cpp
+++ b/src/video_core/renderer_opengl/utils.cpp
@@ -5,11 +5,36 @@
#include <string>
#include <fmt/format.h>
#include <glad/glad.h>
+#include "common/assert.h"
#include "common/common_types.h"
#include "video_core/renderer_opengl/utils.h"
namespace OpenGL {
+BindBuffersRangePushBuffer::BindBuffersRangePushBuffer(GLenum target) : target{target} {}
+
+BindBuffersRangePushBuffer::~BindBuffersRangePushBuffer() = default;
+
+void BindBuffersRangePushBuffer::Setup(GLuint first_) {
+ first = first_;
+ buffers.clear();
+ offsets.clear();
+ sizes.clear();
+}
+
+void BindBuffersRangePushBuffer::Push(GLuint buffer, GLintptr offset, GLsizeiptr size) {
+ buffers.push_back(buffer);
+ offsets.push_back(offset);
+ sizes.push_back(size);
+}
+
+void BindBuffersRangePushBuffer::Bind() const {
+ const std::size_t count{buffers.size()};
+ DEBUG_ASSERT(count == offsets.size() && count == sizes.size());
+ glBindBuffersRange(target, first, static_cast<GLsizei>(count), buffers.data(), offsets.data(),
+ sizes.data());
+}
+
void LabelGLObject(GLenum identifier, GLuint handle, VAddr addr, std::string extra_info) {
if (!GLAD_GL_KHR_debug) {
return; // We don't need to throw an error as this is just for debugging