Commit deae0044 authored by Michael Müller's avatar Michael Müller Committed by Alexandre Julliard

wined3d: Add support for start instance in draw_primitive_arrays().

parent 8151875f
...@@ -109,6 +109,7 @@ static const struct wined3d_extension_map gl_extension_map[] = ...@@ -109,6 +109,7 @@ static const struct wined3d_extension_map gl_extension_map[] =
{"GL_APPLE_ycbcr_422", APPLE_YCBCR_422 }, {"GL_APPLE_ycbcr_422", APPLE_YCBCR_422 },
/* ARB */ /* ARB */
{"GL_ARB_base_instance", ARB_BASE_INSTANCE },
{"GL_ARB_blend_func_extended", ARB_BLEND_FUNC_EXTENDED }, {"GL_ARB_blend_func_extended", ARB_BLEND_FUNC_EXTENDED },
{"GL_ARB_clear_buffer_object", ARB_CLEAR_BUFFER_OBJECT }, {"GL_ARB_clear_buffer_object", ARB_CLEAR_BUFFER_OBJECT },
{"GL_ARB_clear_texture", ARB_CLEAR_TEXTURE }, {"GL_ARB_clear_texture", ARB_CLEAR_TEXTURE },
...@@ -2686,6 +2687,9 @@ static void load_gl_funcs(struct wined3d_gl_info *gl_info) ...@@ -2686,6 +2687,9 @@ static void load_gl_funcs(struct wined3d_gl_info *gl_info)
/* GL_APPLE_flush_buffer_range */ /* GL_APPLE_flush_buffer_range */
USE_GL_FUNC(glBufferParameteriAPPLE) USE_GL_FUNC(glBufferParameteriAPPLE)
USE_GL_FUNC(glFlushMappedBufferRangeAPPLE) USE_GL_FUNC(glFlushMappedBufferRangeAPPLE)
/* GL_ARB_base_instance */
USE_GL_FUNC(glDrawArraysInstancedBaseInstance)
USE_GL_FUNC(glDrawElementsInstancedBaseVertexBaseInstance)
/* GL_ARB_blend_func_extended */ /* GL_ARB_blend_func_extended */
USE_GL_FUNC(glBindFragDataLocationIndexed) USE_GL_FUNC(glBindFragDataLocationIndexed)
USE_GL_FUNC(glGetFragDataIndex) USE_GL_FUNC(glGetFragDataIndex)
...@@ -3881,6 +3885,7 @@ static BOOL wined3d_adapter_init_gl_caps(struct wined3d_adapter *adapter, ...@@ -3881,6 +3885,7 @@ static BOOL wined3d_adapter_init_gl_caps(struct wined3d_adapter *adapter,
{ARB_ES2_COMPATIBILITY, MAKEDWORD_VERSION(4, 1)}, {ARB_ES2_COMPATIBILITY, MAKEDWORD_VERSION(4, 1)},
{ARB_VIEWPORT_ARRAY, MAKEDWORD_VERSION(4, 1)}, {ARB_VIEWPORT_ARRAY, MAKEDWORD_VERSION(4, 1)},
{ARB_BASE_INSTANCE, MAKEDWORD_VERSION(4, 2)},
{ARB_CONSERVATIVE_DEPTH, MAKEDWORD_VERSION(4, 2)}, {ARB_CONSERVATIVE_DEPTH, MAKEDWORD_VERSION(4, 2)},
{ARB_INTERNALFORMAT_QUERY, MAKEDWORD_VERSION(4, 2)}, {ARB_INTERNALFORMAT_QUERY, MAKEDWORD_VERSION(4, 2)},
{ARB_MAP_BUFFER_ALIGNMENT, MAKEDWORD_VERSION(4, 2)}, {ARB_MAP_BUFFER_ALIGNMENT, MAKEDWORD_VERSION(4, 2)},
......
...@@ -69,18 +69,32 @@ static void draw_primitive_arrays(struct wined3d_context *context, const struct ...@@ -69,18 +69,32 @@ static void draw_primitive_arrays(struct wined3d_context *context, const struct
return; return;
} }
if (start_instance) if (start_instance && !(gl_info->supported[ARB_BASE_INSTANCE] && gl_info->supported[ARB_INSTANCED_ARRAYS]))
FIXME("Start instance (%u) not supported.\n", start_instance); FIXME("Start instance (%u) not supported.\n", start_instance);
if (gl_info->supported[ARB_INSTANCED_ARRAYS]) if (gl_info->supported[ARB_INSTANCED_ARRAYS])
{ {
if (!idx_size) if (!idx_size)
{ {
if (gl_info->supported[ARB_BASE_INSTANCE])
{
GL_EXTCALL(glDrawArraysInstancedBaseInstance(state->gl_primitive_type, start_idx, count, instance_count, start_instance));
checkGLcall("glDrawArraysInstancedBaseInstance");
return;
}
GL_EXTCALL(glDrawArraysInstanced(state->gl_primitive_type, start_idx, count, instance_count)); GL_EXTCALL(glDrawArraysInstanced(state->gl_primitive_type, start_idx, count, instance_count));
checkGLcall("glDrawArraysInstanced"); checkGLcall("glDrawArraysInstanced");
return; return;
} }
if (gl_info->supported[ARB_BASE_INSTANCE])
{
GL_EXTCALL(glDrawElementsInstancedBaseVertexBaseInstance(state->gl_primitive_type, count, idx_type,
(const char *)idx_data + (idx_size * start_idx), instance_count, base_vertex_idx, start_instance));
checkGLcall("glDrawElementsInstancedBaseVertexBaseInstance");
return;
}
if (gl_info->supported[ARB_DRAW_ELEMENTS_BASE_VERTEX]) if (gl_info->supported[ARB_DRAW_ELEMENTS_BASE_VERTEX])
{ {
GL_EXTCALL(glDrawElementsInstancedBaseVertex(state->gl_primitive_type, count, idx_type, GL_EXTCALL(glDrawElementsInstancedBaseVertex(state->gl_primitive_type, count, idx_type,
......
...@@ -42,6 +42,7 @@ enum wined3d_gl_extension ...@@ -42,6 +42,7 @@ enum wined3d_gl_extension
APPLE_FLUSH_BUFFER_RANGE, APPLE_FLUSH_BUFFER_RANGE,
APPLE_YCBCR_422, APPLE_YCBCR_422,
/* ARB */ /* ARB */
ARB_BASE_INSTANCE,
ARB_BLEND_FUNC_EXTENDED, ARB_BLEND_FUNC_EXTENDED,
ARB_CLEAR_BUFFER_OBJECT, ARB_CLEAR_BUFFER_OBJECT,
ARB_CLEAR_TEXTURE, ARB_CLEAR_TEXTURE,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment