From: Marek Olšák Date: Sat, 21 Mar 2020 03:58:33 +0000 (-0400) Subject: mesa: split _mesa_primitive_restart_index into a function without gl_context X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=e69e59778c53c7176519c63fb961952e4596dfa0;p=mesa.git mesa: split _mesa_primitive_restart_index into a function without gl_context Reviewed-by: Pierre-Eric Pelloux-Prayer Part-of: --- diff --git a/src/mesa/main/varray.h b/src/mesa/main/varray.h index 6a549d2a5f0..c596c277cf6 100644 --- a/src/mesa/main/varray.h +++ b/src/mesa/main/varray.h @@ -321,10 +321,10 @@ extern void GLAPIENTRY _mesa_VertexArrayVertexAttribDivisorEXT(GLuint vaobj, GLuint index, GLuint divisor); static inline unsigned -_mesa_primitive_restart_index(const struct gl_context *ctx, - unsigned index_size) +_mesa_get_prim_restart_index(bool fixed_index, unsigned restart_index, + unsigned index_size) { - /* The index_size parameter is menat to be in bytes. */ + /* The index_size parameter is meant to be in bytes. */ assert(index_size == 1 || index_size == 2 || index_size == 4); /* From the OpenGL 4.3 core specification, page 302: @@ -332,12 +332,20 @@ _mesa_primitive_restart_index(const struct gl_context *ctx, * enabled, the index value determined by PRIMITIVE_RESTART_FIXED_INDEX * is used." */ - if (ctx->Array.PrimitiveRestartFixedIndex) { + if (fixed_index) { /* 1 -> 0xff, 2 -> 0xffff, 4 -> 0xffffffff */ return 0xffffffffu >> 8 * (4 - index_size); } - return ctx->Array.RestartIndex; + return restart_index; +} + +static inline unsigned +_mesa_primitive_restart_index(const struct gl_context *ctx, + unsigned index_size) +{ + return _mesa_get_prim_restart_index(ctx->Array.PrimitiveRestartFixedIndex, + ctx->Array.RestartIndex, index_size); } extern void GLAPIENTRY