[PATCH 3/5] wined3d: Bind a VAO when using core profile contexts.
Matteo Bruni
mbruni at codeweavers.com
Thu Jul 9 17:06:19 CDT 2015
---
I'm not explicitly deleting the VAOs on context destruction but
that should be okay since those are just state containers which aren't
shared between contexts.
---
dlls/wined3d/context.c | 9 +++++++++
dlls/wined3d/directx.c | 12 ++++++++++++
2 files changed, 21 insertions(+)
diff --git a/dlls/wined3d/context.c b/dlls/wined3d/context.c
index c74983e..2fef379 100644
--- a/dlls/wined3d/context.c
+++ b/dlls/wined3d/context.c
@@ -1735,6 +1735,15 @@ struct wined3d_context *context_create(struct wined3d_swapchain *swapchain,
gl_info->gl_ops.gl.p_glPixelStorei(GL_UNPACK_ALIGNMENT, 1);
checkGLcall("glPixelStorei(GL_UNPACK_ALIGNMENT, device->surface_alignment);");
+ if (!gl_info->supported[WINED3D_GL_LEGACY_CONTEXT])
+ {
+ GLuint vao;
+
+ GL_EXTCALL(glGenVertexArrays(1, &vao));
+ GL_EXTCALL(glBindVertexArray(vao));
+ checkGLcall("creating VAO");
+ }
+
if (gl_info->supported[ARB_VERTEX_BLEND])
{
/* Direct3D always uses n-1 weights for n world matrices and uses
diff --git a/dlls/wined3d/directx.c b/dlls/wined3d/directx.c
index 859da9d..61c3059 100644
--- a/dlls/wined3d/directx.c
+++ b/dlls/wined3d/directx.c
@@ -2898,6 +2898,7 @@ static void load_gl_funcs(struct wined3d_gl_info *gl_info)
USE_GL_FUNC(glBeginQuery) /* OpenGL 1.5 */
USE_GL_FUNC(glBindAttribLocation) /* OpenGL 2.0 */
USE_GL_FUNC(glBindBuffer) /* OpenGL 1.5 */
+ USE_GL_FUNC(glBindVertexArray) /* OpenGL 3.0 */
USE_GL_FUNC(glBlendColor) /* OpenGL 1.4 */
USE_GL_FUNC(glBlendEquation) /* OpenGL 1.4 */
USE_GL_FUNC(glBlendEquationSeparate) /* OpenGL 2.0 */
@@ -2916,6 +2917,7 @@ static void load_gl_funcs(struct wined3d_gl_info *gl_info)
USE_GL_FUNC(glDeleteProgram) /* OpenGL 2.0 */
USE_GL_FUNC(glDeleteQueries) /* OpenGL 1.5 */
USE_GL_FUNC(glDeleteShader) /* OpenGL 2.0 */
+ USE_GL_FUNC(glDeleteVertexArrays) /* OpenGL 3.0 */
USE_GL_FUNC(glDetachShader) /* OpenGL 2.0 */
USE_GL_FUNC(glDisableVertexAttribArray) /* OpenGL 2.0 */
USE_GL_FUNC(glDrawArraysInstanced) /* OpenGL 3.1 */
@@ -2925,6 +2927,7 @@ static void load_gl_funcs(struct wined3d_gl_info *gl_info)
USE_GL_FUNC(glEndQuery) /* OpenGL 1.5 */
USE_GL_FUNC(glGenBuffers) /* OpenGL 1.5 */
USE_GL_FUNC(glGenQueries) /* OpenGL 1.5 */
+ USE_GL_FUNC(glGenVertexArrays) /* OpenGL 3.0 */
USE_GL_FUNC(glGetActiveUniform) /* OpenGL 2.0 */
USE_GL_FUNC(glGetAttachedShaders) /* OpenGL 2.0 */
USE_GL_FUNC(glGetAttribLocation) /* OpenGL 2.0 */
@@ -3788,6 +3791,15 @@ static BOOL wined3d_adapter_init_gl_caps(struct wined3d_adapter *adapter)
for (i = 0; i < gl_info->limits.buffers; ++i)
adapter->d3d_info.valid_rt_mask |= (1 << i);
+ if (!gl_info->supported[WINED3D_GL_LEGACY_CONTEXT])
+ {
+ GLuint vao;
+
+ GL_EXTCALL(glGenVertexArrays(1, &vao));
+ GL_EXTCALL(glBindVertexArray(vao));
+ checkGLcall("creating VAO");
+ }
+
fixup_extensions(gl_info, gl_renderer_str, gl_vendor, card_vendor, device);
init_driver_info(driver_info, card_vendor, device);
add_gl_compat_wrappers(gl_info);
--
2.3.6
More information about the wine-patches
mailing list