Compare commits
67 Commits
9.2-branch
...
gles3-fmt-
Author | SHA1 | Date | |
---|---|---|---|
|
ae0120f247 | ||
|
787bbe65ff | ||
|
5f96348c60 | ||
|
fe23a2c5e1 | ||
|
54d744bfc4 | ||
|
b1c62e9533 | ||
|
0faa38ccc6 | ||
|
ed9f608070 | ||
|
b68dc0c5ee | ||
|
add9b77cbd | ||
|
64e0be7d0b | ||
|
166c4d211d | ||
|
fef9526cb6 | ||
|
a33dc45d2f | ||
|
95da613011 | ||
|
9824382dbd | ||
|
067e9170ef | ||
|
28236b2f28 | ||
|
a1ef7b34ce | ||
|
8d99b25045 | ||
|
3613e67b4a | ||
|
566ce73fab | ||
|
4fd482b841 | ||
|
555245eeb7 | ||
|
e76ddbf0f8 | ||
|
8b89a5bbf5 | ||
|
56e2a876e4 | ||
|
acac9cdde0 | ||
|
8a88168a90 | ||
|
18aca7ac5a | ||
|
4dd38352e5 | ||
|
a0333d34a7 | ||
|
5d1c69be02 | ||
|
e68b841b3c | ||
|
3b495d815f | ||
|
0538b36bac | ||
|
d3d6e05349 | ||
|
4014ee4567 | ||
|
b83a83dcdf | ||
|
19864a4b1c | ||
|
24d89bc7ea | ||
|
84b2017c30 | ||
|
a9c1fa067c | ||
|
d9228105e1 | ||
|
4b7bea48ee | ||
|
b1a21a9f7c | ||
|
f7a82c00cd | ||
|
d053e8e85b | ||
|
0f16eafa17 | ||
|
43413b3fdd | ||
|
974d48a061 | ||
|
173e4f7a42 | ||
|
026099f93a | ||
|
feba88049f | ||
|
cf6ddcecda | ||
|
244d6eb094 | ||
|
7a4eca8280 | ||
|
3d0890d39d | ||
|
2a18d71dbe | ||
|
13fa793585 | ||
|
fca1ec5bfa | ||
|
5b9df1c245 | ||
|
bdea9b9460 | ||
|
e1ccb71996 | ||
|
db902c4948 | ||
|
a40737f505 | ||
|
dbee8d3ea2 |
@@ -826,8 +826,9 @@ struct __DRIdri2LoaderExtensionRec {
|
||||
|
||||
#define __DRI_API_OPENGL 0 /**< OpenGL compatibility profile */
|
||||
#define __DRI_API_GLES 1 /**< OpenGL ES 1.x */
|
||||
#define __DRI_API_GLES2 2 /**< OpenGL ES 2.0 or 3.0 */
|
||||
#define __DRI_API_GLES2 2 /**< OpenGL ES 2.x */
|
||||
#define __DRI_API_OPENGL_CORE 3 /**< OpenGL 3.2+ core profile */
|
||||
#define __DRI_API_GLES3 4 /**< OpenGL ES 3.x */
|
||||
|
||||
#define __DRI_CTX_ATTRIB_MAJOR_VERSION 0
|
||||
#define __DRI_CTX_ATTRIB_MINOR_VERSION 1
|
||||
|
@@ -465,7 +465,10 @@ dri2_setup_screen(_EGLDisplay *disp)
|
||||
api_mask = dri2_dpy->dri2->getAPIMask(dri2_dpy->dri_screen);
|
||||
} else {
|
||||
assert(dri2_dpy->swrast);
|
||||
api_mask = 1 << __DRI_API_OPENGL | 1 << __DRI_API_GLES | 1 << __DRI_API_GLES2;
|
||||
api_mask = 1 << __DRI_API_OPENGL |
|
||||
1 << __DRI_API_GLES |
|
||||
1 << __DRI_API_GLES2 |
|
||||
1 << __DRI_API_GLES3;
|
||||
}
|
||||
|
||||
disp->ClientAPIs = 0;
|
||||
@@ -475,6 +478,8 @@ dri2_setup_screen(_EGLDisplay *disp)
|
||||
disp->ClientAPIs |= EGL_OPENGL_ES_BIT;
|
||||
if (api_mask & (1 << __DRI_API_GLES2))
|
||||
disp->ClientAPIs |= EGL_OPENGL_ES2_BIT;
|
||||
if (api_mask & (1 << __DRI_API_GLES3))
|
||||
disp->ClientAPIs |= EGL_OPENGL_ES3_BIT_KHR;
|
||||
|
||||
assert(dri2_dpy->dri2 || dri2_dpy->swrast);
|
||||
disp->Extensions.KHR_surfaceless_context = EGL_TRUE;
|
||||
@@ -737,8 +742,10 @@ dri2_create_context(_EGLDriver *drv, _EGLDisplay *disp, _EGLConfig *conf,
|
||||
api = __DRI_API_GLES;
|
||||
break;
|
||||
case 2:
|
||||
api = __DRI_API_GLES3;
|
||||
break;
|
||||
case 3:
|
||||
api = __DRI_API_GLES2;
|
||||
api = __DRI_API_GLES3;
|
||||
break;
|
||||
default:
|
||||
_eglError(EGL_BAD_PARAMETER, "eglCreateContext");
|
||||
|
@@ -331,6 +331,7 @@ _eglValidateConfig(const _EGLConfig *conf, EGLBoolean for_matching)
|
||||
mask = EGL_OPENGL_ES_BIT |
|
||||
EGL_OPENVG_BIT |
|
||||
EGL_OPENGL_ES2_BIT |
|
||||
EGL_OPENGL_ES3_BIT_KHR |
|
||||
EGL_OPENGL_BIT;
|
||||
break;
|
||||
default:
|
||||
|
@@ -54,9 +54,11 @@ _eglGetContextAPIBit(_EGLContext *ctx)
|
||||
bit = EGL_OPENGL_ES_BIT;
|
||||
break;
|
||||
case 2:
|
||||
case 3:
|
||||
bit = EGL_OPENGL_ES2_BIT;
|
||||
break;
|
||||
case 3:
|
||||
bit = EGL_OPENGL_ES3_BIT_KHR;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
@@ -37,6 +37,7 @@
|
||||
(EGL_OPENGL_ES_BIT | \
|
||||
EGL_OPENVG_BIT | \
|
||||
EGL_OPENGL_ES2_BIT | \
|
||||
EGL_OPENGL_ES3_BIT_KHR | \
|
||||
EGL_OPENGL_BIT)
|
||||
|
||||
|
||||
|
@@ -140,6 +140,9 @@ _eglUpdateAPIsString(_EGLDisplay *dpy)
|
||||
if (dpy->ClientAPIs & EGL_OPENGL_ES2_BIT)
|
||||
strcat(apis, "OpenGL_ES2 ");
|
||||
|
||||
if (dpy->ClientAPIs & EGL_OPENGL_ES3_BIT_KHR)
|
||||
strcat(apis, "OpenGL_ES3 ");
|
||||
|
||||
if (dpy->ClientAPIs & EGL_OPENVG_BIT)
|
||||
strcat(apis, "OpenVG ");
|
||||
|
||||
|
@@ -435,11 +435,14 @@ _eglSurfaceAttrib(_EGLDriver *drv, _EGLDisplay *dpy, _EGLSurface *surface,
|
||||
{
|
||||
EGLint confval;
|
||||
EGLint err = EGL_SUCCESS;
|
||||
EGLint all_es_bits = EGL_OPENGL_ES_BIT |
|
||||
EGL_OPENGL_ES2_BIT |
|
||||
EGL_OPENGL_ES3_BIT_KHR;
|
||||
|
||||
switch (attribute) {
|
||||
case EGL_MIPMAP_LEVEL:
|
||||
confval = surface->Config->RenderableType;
|
||||
if (!(confval & (EGL_OPENGL_ES_BIT | EGL_OPENGL_ES2_BIT))) {
|
||||
if (!(confval & all_es_bits)) {
|
||||
err = EGL_BAD_PARAMETER;
|
||||
break;
|
||||
}
|
||||
|
@@ -260,6 +260,8 @@ HEXADECIMAL_INTEGER 0[xX][0-9a-fA-F]+[uU]?
|
||||
}
|
||||
|
||||
"##" {
|
||||
if (parser->is_gles)
|
||||
glcpp_error(yylloc, yyextra, "Token pasting (##) is illegal in GLES");
|
||||
return PASTE;
|
||||
}
|
||||
|
||||
|
@@ -363,6 +363,8 @@ integer_constant:
|
||||
expression:
|
||||
integer_constant
|
||||
| IDENTIFIER {
|
||||
if (parser->is_gles)
|
||||
glcpp_error(& @1, parser, "undefined macro %s in expression (illegal in GLES)", $1);
|
||||
$$ = 0;
|
||||
}
|
||||
| expression OR expression {
|
||||
@@ -1179,15 +1181,18 @@ glcpp_parser_create (const struct gl_extensions *extensions, int api)
|
||||
parser->has_new_source_number = 0;
|
||||
parser->new_source_number = 0;
|
||||
|
||||
parser->is_gles = false;
|
||||
|
||||
/* Add pre-defined macros. */
|
||||
if (extensions != NULL) {
|
||||
if (extensions->OES_EGL_image_external)
|
||||
add_builtin_define(parser, "GL_OES_EGL_image_external", 1);
|
||||
}
|
||||
|
||||
if (api == API_OPENGLES2)
|
||||
if (api == API_OPENGLES2) {
|
||||
parser->is_gles = true;
|
||||
add_builtin_define(parser, "GL_ES", 1);
|
||||
else {
|
||||
} else {
|
||||
add_builtin_define(parser, "GL_ARB_draw_buffers", 1);
|
||||
add_builtin_define(parser, "GL_ARB_texture_rectangle", 1);
|
||||
|
||||
@@ -2026,11 +2031,6 @@ static void
|
||||
_glcpp_parser_handle_version_declaration(glcpp_parser_t *parser, intmax_t version,
|
||||
const char *es_identifier)
|
||||
{
|
||||
/* Note: We assume that if any identifier is present, it means ES.
|
||||
* The GLSL parser will double-check that the identifier is correct.
|
||||
*/
|
||||
bool is_es = es_identifier != NULL;
|
||||
|
||||
macro_t *macro = hash_table_find (parser->defines, "__VERSION__");
|
||||
if (macro) {
|
||||
hash_table_remove (parser->defines, "__VERSION__");
|
||||
@@ -2038,17 +2038,23 @@ _glcpp_parser_handle_version_declaration(glcpp_parser_t *parser, intmax_t versio
|
||||
}
|
||||
add_builtin_define (parser, "__VERSION__", version);
|
||||
|
||||
if (version == 100)
|
||||
is_es = true;
|
||||
if (is_es)
|
||||
/* If we didn't have a GLES context to begin with, (indicated
|
||||
* by parser->api), then the version declaration here might
|
||||
* indicate GLES. */
|
||||
if (! parser->is_gles &&
|
||||
(version == 100 ||
|
||||
(es_identifier && (strcmp(es_identifier, "es") == 0))))
|
||||
{
|
||||
parser->is_gles = true;
|
||||
add_builtin_define (parser, "GL_ES", 1);
|
||||
}
|
||||
|
||||
/* Currently, all ES2/ES3 implementations support highp in the
|
||||
* fragment shader, so we always define this macro in ES2/ES3.
|
||||
* If we ever get a driver that doesn't support highp, we'll
|
||||
* need to add a flag to the gl_context and check that here.
|
||||
*/
|
||||
if (version >= 130 || is_es)
|
||||
if (version >= 130 || parser->is_gles)
|
||||
add_builtin_define (parser, "GL_FRAGMENT_PRECISION_HIGH", 1);
|
||||
|
||||
ralloc_asprintf_rewrite_tail (&parser->output, &parser->output_length,
|
||||
|
@@ -182,6 +182,7 @@ struct glcpp_parser {
|
||||
int new_line_number;
|
||||
bool has_new_source_number;
|
||||
int new_source_number;
|
||||
bool is_gles;
|
||||
};
|
||||
|
||||
struct gl_extensions;
|
||||
|
23
src/mapi/glapi/gen/ARB_ES3_compatibility.xml
Normal file
23
src/mapi/glapi/gen/ARB_ES3_compatibility.xml
Normal file
@@ -0,0 +1,23 @@
|
||||
<?xml version="1.0"?>
|
||||
<!DOCTYPE OpenGLAPI SYSTEM "gl_API.dtd">
|
||||
|
||||
<OpenGLAPI>
|
||||
|
||||
<category name="GL_ARB_ES3_compatibility" number="127">
|
||||
<enum name="COMPRESSED_RGB8_ETC2" value="0x9274"/>
|
||||
<enum name="COMPRESSED_SRGB8_ETC2" value="0x9275"/>
|
||||
<enum name="COMPRESSED_RGB8_PUNCHTHROUGH_ALPHA1_ETC2" value="0x9276"/>
|
||||
<enum name="COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2" value="0x9277"/>
|
||||
<enum name="COMPRESSED_RGBA8_ETC2_EAC" value="0x9278"/>
|
||||
<enum name="COMPRESSED_SRGB8_ALPHA8_ETC2_EAC" value="0x9279"/>
|
||||
<enum name="COMPRESSED_R11_EAC" value="0x9270"/>
|
||||
<enum name="COMPRESSED_SIGNED_R11_EAC" value="0x9271"/>
|
||||
<enum name="COMPRESSED_RG11_EAC" value="0x9272"/>
|
||||
<enum name="COMPRESSED_SIGNED_RG11_EAC" value="0x9273"/>
|
||||
<enum name="PRIMITIVE_RESTART_FIXED_INDEX" value="0x8D69"/>
|
||||
<enum name="ANY_SAMPLES_PASSED_CONSERVATIVE" value="0x8D6A"/>
|
||||
<enum name="MAX_ELEMENT_INDEX" value="0x8D6B"/>
|
||||
<enum name="TEXTURE_IMMUTABLE_LEVELS" value="0x82DF"/>
|
||||
</category>
|
||||
|
||||
</OpenGLAPI>
|
@@ -595,7 +595,7 @@
|
||||
<enum name="MAX_FRAGMENT_INPUT_COMPONENTS" value="0x9125"/>
|
||||
<enum name="CONTEXT_PROFILE_MASK" value="0x9126"/>
|
||||
|
||||
<function name="GetInteger64i_v" offset="assign" es2="3.0" exec="skip">
|
||||
<function name="GetInteger64i_v" offset="assign" es2="3.0">
|
||||
<param name="cap" type="GLenum"/>
|
||||
<param name="index" type="GLuint"/>
|
||||
<param name="data" type="GLint64 *"/>
|
||||
|
@@ -101,6 +101,7 @@ API_XML = \
|
||||
ARB_draw_elements_base_vertex.xml \
|
||||
ARB_draw_instanced.xml \
|
||||
ARB_ES2_compatibility.xml \
|
||||
ARB_ES3_compatibility.xml \
|
||||
ARB_framebuffer_object.xml \
|
||||
ARB_geometry_shader4.xml \
|
||||
ARB_instanced_arrays.xml \
|
||||
@@ -144,6 +145,7 @@ COMMON = $(API_XML) \
|
||||
gl_and_es_API.xml \
|
||||
es_EXT.xml \
|
||||
ARB_ES2_compatibility.xml \
|
||||
ARB_ES3_compatibility.xml \
|
||||
ARB_get_program_binary.xml \
|
||||
OES_fixed_point.xml \
|
||||
OES_single_precision.xml
|
||||
|
@@ -8277,7 +8277,11 @@
|
||||
|
||||
<xi:include href="ARB_robustness.xml" xmlns:xi="http://www.w3.org/2001/XInclude"/>
|
||||
|
||||
<!-- ARB extensions #106...#108 -->
|
||||
<!-- ARB extensions #106 -->
|
||||
|
||||
<xi:include href="ARB_base_instance.xml" xmlns:xi="http://www.w3.org/2001/XInclude"/>
|
||||
|
||||
<!-- ARB extensions #108 -->
|
||||
|
||||
<category name="GL_ARB_transform_feedback_instanced" number="109">
|
||||
<function name="DrawTransformFeedbackInstanced" offset="assign"
|
||||
@@ -8304,10 +8308,14 @@
|
||||
|
||||
<!-- ARB extensions #114...#116 -->
|
||||
|
||||
<xi:include href="ARB_base_instance.xml" xmlns:xi="http://www.w3.org/2001/XInclude"/>
|
||||
|
||||
<xi:include href="ARB_texture_storage.xml" xmlns:xi="http://www.w3.org/2001/XInclude"/>
|
||||
|
||||
<!-- ARB extensions #118...#126 -->
|
||||
|
||||
<xi:include href="ARB_ES3_compatibility.xml" xmlns:xi="http://www.w3.org/2001/XInclude"/>
|
||||
|
||||
<!-- ARB extensions #128...#131 -->
|
||||
|
||||
<xi:include href="ARB_invalidate_subdata.xml" xmlns:xi="http://www.w3.org/2001/XInclude"/>
|
||||
|
||||
<!-- Non-ARB extensions sorted by extension number. -->
|
||||
|
@@ -189,6 +189,7 @@ dri2CreateContextAttribs(__DRIscreen *screen, int api,
|
||||
mesa_api = API_OPENGLES;
|
||||
break;
|
||||
case __DRI_API_GLES2:
|
||||
case __DRI_API_GLES3:
|
||||
mesa_api = API_OPENGLES2;
|
||||
break;
|
||||
case __DRI_API_OPENGL_CORE:
|
||||
|
@@ -123,6 +123,7 @@ driCreateContextAttribs(__DRIscreen *screen, int api,
|
||||
mesa_api = API_OPENGLES;
|
||||
break;
|
||||
case __DRI_API_GLES2:
|
||||
case __DRI_API_GLES3:
|
||||
mesa_api = API_OPENGLES2;
|
||||
break;
|
||||
case __DRI_API_OPENGL_CORE:
|
||||
|
@@ -52,23 +52,33 @@ i830InitDriverFunctions(struct dd_function_table *functions)
|
||||
extern const struct tnl_pipeline_stage *intel_pipeline[];
|
||||
|
||||
bool
|
||||
i830CreateContext(const struct gl_config * mesaVis,
|
||||
i830CreateContext(int api,
|
||||
const struct gl_config * mesaVis,
|
||||
__DRIcontext * driContextPriv,
|
||||
unsigned major_version,
|
||||
unsigned minor_version,
|
||||
unsigned *error,
|
||||
void *sharedContextPrivate)
|
||||
{
|
||||
struct dd_function_table functions;
|
||||
struct i830_context *i830 = rzalloc(NULL, struct i830_context);
|
||||
struct intel_context *intel = &i830->intel;
|
||||
struct gl_context *ctx = &intel->ctx;
|
||||
if (!i830)
|
||||
|
||||
if (!i830) {
|
||||
*error = __DRI_CTX_ERROR_NO_MEMORY;
|
||||
return false;
|
||||
}
|
||||
|
||||
i830InitVtbl(i830);
|
||||
i830InitDriverFunctions(&functions);
|
||||
|
||||
if (!intelInitContext(intel, __DRI_API_OPENGL, mesaVis, driContextPriv,
|
||||
sharedContextPrivate, &functions)) {
|
||||
free(i830);
|
||||
if (!intelInitContext(intel, __DRI_API_OPENGL,
|
||||
major_version, minor_version,
|
||||
mesaVis, driContextPriv,
|
||||
sharedContextPrivate, &functions,
|
||||
error)) {
|
||||
ralloc_free(i830);
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@@ -178,8 +178,12 @@ i830_state_draw_region(struct intel_context *intel,
|
||||
/* i830_context.c
|
||||
*/
|
||||
extern bool
|
||||
i830CreateContext(const struct gl_config * mesaVis,
|
||||
i830CreateContext(int api,
|
||||
const struct gl_config * mesaVis,
|
||||
__DRIcontext * driContextPriv,
|
||||
unsigned major_version,
|
||||
unsigned minor_version,
|
||||
unsigned *error,
|
||||
void *sharedContextPrivate);
|
||||
|
||||
/* i830_tex.c, i830_texstate.c
|
||||
|
@@ -168,33 +168,11 @@ i915CreateContext(int api,
|
||||
|
||||
i915InitDriverFunctions(&functions);
|
||||
|
||||
if (!intelInitContext(intel, api, mesaVis, driContextPriv,
|
||||
sharedContextPrivate, &functions)) {
|
||||
*error = __DRI_CTX_ERROR_NO_MEMORY;
|
||||
return false;
|
||||
}
|
||||
|
||||
/* Now that the extension bits are known, filter against the requested API
|
||||
* and version.
|
||||
*/
|
||||
switch (api) {
|
||||
case API_OPENGL_COMPAT: {
|
||||
const unsigned max_version =
|
||||
(ctx->Extensions.ARB_fragment_shader &&
|
||||
ctx->Extensions.ARB_occlusion_query) ? 20 : 15;
|
||||
const unsigned req_version = major_version * 10 + minor_version;
|
||||
|
||||
if (req_version > max_version) {
|
||||
*error = __DRI_CTX_ERROR_BAD_VERSION;
|
||||
return false;
|
||||
}
|
||||
break;
|
||||
}
|
||||
case API_OPENGLES:
|
||||
case API_OPENGLES2:
|
||||
break;
|
||||
default:
|
||||
*error = __DRI_CTX_ERROR_BAD_API;
|
||||
if (!intelInitContext(intel, api, major_version, minor_version,
|
||||
mesaVis, driContextPriv,
|
||||
sharedContextPrivate, &functions,
|
||||
error)) {
|
||||
ralloc_free(i915);
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@@ -87,47 +87,8 @@ brwCreateContext(int api,
|
||||
__DRIscreen *sPriv = driContextPriv->driScreenPriv;
|
||||
struct intel_screen *screen = sPriv->driverPrivate;
|
||||
struct dd_function_table functions;
|
||||
const unsigned req_version = major_version * 10 + minor_version;
|
||||
unsigned max_supported_version = 0;
|
||||
unsigned i;
|
||||
|
||||
#ifdef TEXTURE_FLOAT_ENABLED
|
||||
bool has_texture_float = true;
|
||||
#else
|
||||
bool has_texture_float = false;
|
||||
#endif
|
||||
|
||||
bool supports_gl30 = has_texture_float &&
|
||||
(screen->gen == 6 ||
|
||||
(screen->gen == 7 &&
|
||||
screen->kernel_has_gen7_sol_reset));
|
||||
|
||||
/* Determine max_supported_version. */
|
||||
switch (api) {
|
||||
case API_OPENGL_COMPAT:
|
||||
max_supported_version = supports_gl30 ? 30 : 21;
|
||||
break;
|
||||
case API_OPENGLES:
|
||||
max_supported_version = 11;
|
||||
break;
|
||||
case API_OPENGLES2:
|
||||
max_supported_version = 20;
|
||||
break;
|
||||
case API_OPENGL_CORE:
|
||||
max_supported_version = supports_gl30 ? 31 : 0;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
if (max_supported_version == 0) {
|
||||
*error = __DRI_CTX_ERROR_BAD_API;
|
||||
return false;
|
||||
} else if (req_version > max_supported_version) {
|
||||
*error = __DRI_CTX_ERROR_BAD_VERSION;
|
||||
return false;
|
||||
}
|
||||
|
||||
struct brw_context *brw = rzalloc(NULL, struct brw_context);
|
||||
if (!brw) {
|
||||
printf("%s: failed to alloc context\n", __FUNCTION__);
|
||||
@@ -147,10 +108,12 @@ brwCreateContext(int api,
|
||||
struct intel_context *intel = &brw->intel;
|
||||
struct gl_context *ctx = &intel->ctx;
|
||||
|
||||
if (!intelInitContext( intel, api, mesaVis, driContextPriv,
|
||||
sharedContextPrivate, &functions )) {
|
||||
if (!intelInitContext( intel, api, major_version, minor_version,
|
||||
mesaVis, driContextPriv,
|
||||
sharedContextPrivate, &functions,
|
||||
error)) {
|
||||
printf("%s: failed to init intel context\n", __FUNCTION__);
|
||||
*error = __DRI_CTX_ERROR_NO_MEMORY;
|
||||
ralloc_free(brw);
|
||||
return false;
|
||||
}
|
||||
|
||||
@@ -365,8 +328,8 @@ brwCreateContext(int api,
|
||||
|
||||
intel->batch.need_workaround_flush = true;
|
||||
|
||||
ctx->VertexProgram._MaintainTnlProgram = true;
|
||||
ctx->FragmentProgram._MaintainTexEnvProgram = true;
|
||||
ctx->VertexProgram._MaintainTnlProgram = ctx->API != API_OPENGL_CORE;
|
||||
ctx->FragmentProgram._MaintainTexEnvProgram = ctx->API != API_OPENGL_CORE;
|
||||
|
||||
brw_draw_init( brw );
|
||||
|
||||
|
@@ -52,13 +52,13 @@ can_cut_index_handle_restart_index(struct gl_context *ctx,
|
||||
|
||||
switch (ib->type) {
|
||||
case GL_UNSIGNED_BYTE:
|
||||
cut_index_will_work = (ctx->Array.RestartIndex & 0xff) == 0xff;
|
||||
cut_index_will_work = (ctx->Array._RestartIndex & 0xff) == 0xff;
|
||||
break;
|
||||
case GL_UNSIGNED_SHORT:
|
||||
cut_index_will_work = (ctx->Array.RestartIndex & 0xffff) == 0xffff;
|
||||
cut_index_will_work = (ctx->Array._RestartIndex & 0xffff) == 0xffff;
|
||||
break;
|
||||
case GL_UNSIGNED_INT:
|
||||
cut_index_will_work = ctx->Array.RestartIndex == 0xffffffff;
|
||||
cut_index_will_work = ctx->Array._RestartIndex == 0xffffffff;
|
||||
break;
|
||||
default:
|
||||
cut_index_will_work = false;
|
||||
@@ -157,7 +157,7 @@ brw_handle_primitive_restart(struct gl_context *ctx,
|
||||
/* If PrimitiveRestart is not enabled, then we aren't concerned about
|
||||
* handling this draw.
|
||||
*/
|
||||
if (!(ctx->Array.PrimitiveRestart)) {
|
||||
if (!(ctx->Array._PrimitiveRestart)) {
|
||||
return GL_FALSE;
|
||||
}
|
||||
|
||||
|
@@ -195,6 +195,7 @@ brw_queryobj_get_results(struct gl_context *ctx,
|
||||
break;
|
||||
|
||||
case GL_ANY_SAMPLES_PASSED:
|
||||
case GL_ANY_SAMPLES_PASSED_CONSERVATIVE:
|
||||
/* Set true if any of the sub-queries passed. */
|
||||
for (i = query->first_index; i <= query->last_index; i++) {
|
||||
if (results[i * 2 + 1] != results[i * 2]) {
|
||||
@@ -261,6 +262,7 @@ brw_begin_query(struct gl_context *ctx, struct gl_query_object *q)
|
||||
break;
|
||||
|
||||
case GL_ANY_SAMPLES_PASSED:
|
||||
case GL_ANY_SAMPLES_PASSED_CONSERVATIVE:
|
||||
case GL_SAMPLES_PASSED_ARB:
|
||||
/* Reset our driver's tracking of query state. */
|
||||
drm_intel_bo_unreference(query->bo);
|
||||
@@ -316,6 +318,7 @@ brw_end_query(struct gl_context *ctx, struct gl_query_object *q)
|
||||
break;
|
||||
|
||||
case GL_ANY_SAMPLES_PASSED:
|
||||
case GL_ANY_SAMPLES_PASSED_CONSERVATIVE:
|
||||
case GL_SAMPLES_PASSED_ARB:
|
||||
if (query->bo) {
|
||||
brw_emit_query_end(brw);
|
||||
|
@@ -579,13 +579,55 @@ intelInitDriverFunctions(struct dd_function_table *functions)
|
||||
intel_init_syncobj_functions(functions);
|
||||
}
|
||||
|
||||
static bool
|
||||
validate_context_version(struct intel_screen *screen,
|
||||
int mesa_api,
|
||||
unsigned major_version,
|
||||
unsigned minor_version,
|
||||
unsigned *dri_ctx_error)
|
||||
{
|
||||
unsigned req_version = 10 * major_version + minor_version;
|
||||
unsigned max_version = 0;
|
||||
|
||||
switch (mesa_api) {
|
||||
case API_OPENGL_COMPAT:
|
||||
max_version = screen->max_gl_compat_version;
|
||||
break;
|
||||
case API_OPENGL_CORE:
|
||||
max_version = screen->max_gl_core_version;
|
||||
break;
|
||||
case API_OPENGLES:
|
||||
max_version = screen->max_gl_es1_version;
|
||||
break;
|
||||
case API_OPENGLES2:
|
||||
max_version = screen->max_gl_es2_version;
|
||||
break;
|
||||
default:
|
||||
max_version = 0;
|
||||
break;
|
||||
}
|
||||
|
||||
if (max_version == 0) {
|
||||
*dri_ctx_error = __DRI_CTX_ERROR_BAD_API;
|
||||
return false;
|
||||
} else if (req_version > max_version) {
|
||||
*dri_ctx_error = __DRI_CTX_ERROR_BAD_VERSION;
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool
|
||||
intelInitContext(struct intel_context *intel,
|
||||
int api,
|
||||
unsigned major_version,
|
||||
unsigned minor_version,
|
||||
const struct gl_config * mesaVis,
|
||||
__DRIcontext * driContextPriv,
|
||||
void *sharedContextPrivate,
|
||||
struct dd_function_table *functions)
|
||||
struct dd_function_table *functions,
|
||||
unsigned *dri_ctx_error)
|
||||
{
|
||||
struct gl_context *ctx = &intel->ctx;
|
||||
struct gl_context *shareCtx = (struct gl_context *) sharedContextPrivate;
|
||||
@@ -595,7 +637,14 @@ intelInitContext(struct intel_context *intel,
|
||||
struct gl_config visual;
|
||||
|
||||
/* we can't do anything without a connection to the device */
|
||||
if (intelScreen->bufmgr == NULL)
|
||||
if (intelScreen->bufmgr == NULL) {
|
||||
*dri_ctx_error = __DRI_CTX_ERROR_NO_MEMORY;
|
||||
return false;
|
||||
}
|
||||
|
||||
if (!validate_context_version(intelScreen,
|
||||
api, major_version, minor_version,
|
||||
dri_ctx_error))
|
||||
return false;
|
||||
|
||||
/* Can't rely on invalidate events, fall back to glViewport hack */
|
||||
@@ -611,6 +660,7 @@ intelInitContext(struct intel_context *intel,
|
||||
|
||||
if (!_mesa_initialize_context(&intel->ctx, api, mesaVis, shareCtx,
|
||||
functions)) {
|
||||
*dri_ctx_error = __DRI_CTX_ERROR_NO_MEMORY;
|
||||
printf("%s: failed to init mesa context\n", __FUNCTION__);
|
||||
return false;
|
||||
}
|
||||
|
@@ -515,10 +515,13 @@ extern int INTEL_DEBUG;
|
||||
|
||||
extern bool intelInitContext(struct intel_context *intel,
|
||||
int api,
|
||||
unsigned major_version,
|
||||
unsigned minor_version,
|
||||
const struct gl_config * mesaVis,
|
||||
__DRIcontext * driContextPriv,
|
||||
void *sharedContextPrivate,
|
||||
struct dd_function_table *functions);
|
||||
struct dd_function_table *functions,
|
||||
unsigned *dri_ctx_error);
|
||||
|
||||
extern void intelFinish(struct gl_context * ctx);
|
||||
extern void intel_flush_rendering_to_batch(struct gl_context *ctx);
|
||||
|
@@ -104,6 +104,7 @@ intelInitExtensions(struct gl_context *ctx)
|
||||
ctx->Extensions.ARB_uniform_buffer_object = true;
|
||||
ctx->Extensions.ARB_texture_buffer_object = true;
|
||||
ctx->Extensions.ARB_texture_cube_map_array = true;
|
||||
ctx->Extensions.ARB_ES3_compatibility = true;
|
||||
}
|
||||
|
||||
if (intel->gen >= 5)
|
||||
|
@@ -753,8 +753,12 @@ intelDestroyBuffer(__DRIdrawable * driDrawPriv)
|
||||
* functions.
|
||||
*/
|
||||
extern bool
|
||||
i830CreateContext(const struct gl_config *mesaVis,
|
||||
i830CreateContext(int api,
|
||||
const struct gl_config *mesaVis,
|
||||
__DRIcontext *driContextPriv,
|
||||
unsigned major_version,
|
||||
unsigned minor_version,
|
||||
unsigned *error,
|
||||
void *sharedContextPrivate);
|
||||
|
||||
extern bool
|
||||
@@ -796,27 +800,10 @@ intelCreateContext(gl_api api,
|
||||
major_version, minor_version, error,
|
||||
sharedContextPrivate);
|
||||
} else {
|
||||
switch (api) {
|
||||
case API_OPENGL_COMPAT:
|
||||
if (major_version > 1 || minor_version > 3) {
|
||||
*error = __DRI_CTX_ERROR_BAD_VERSION;
|
||||
success = false;
|
||||
}
|
||||
break;
|
||||
case API_OPENGLES:
|
||||
break;
|
||||
default:
|
||||
*error = __DRI_CTX_ERROR_BAD_API;
|
||||
success = false;
|
||||
}
|
||||
|
||||
if (success) {
|
||||
intelScreen->no_vbo = true;
|
||||
success = i830CreateContext(mesaVis, driContextPriv,
|
||||
success = i830CreateContext(api, mesaVis, driContextPriv,
|
||||
major_version, minor_version, error,
|
||||
sharedContextPrivate);
|
||||
if (!success)
|
||||
*error = __DRI_CTX_ERROR_NO_MEMORY;
|
||||
}
|
||||
}
|
||||
#else
|
||||
success = brwCreateContext(api, mesaVis,
|
||||
@@ -1050,6 +1037,90 @@ intel_screen_make_configs(__DRIscreen *dri_screen)
|
||||
return configs;
|
||||
}
|
||||
|
||||
static void
|
||||
set_max_gl_versions(struct intel_screen *screen)
|
||||
{
|
||||
#ifdef TEXTURE_FLOAT_ENABLED
|
||||
bool has_texture_float = true;
|
||||
#else
|
||||
bool has_texture_float = false;
|
||||
#endif
|
||||
|
||||
switch (screen->gen) {
|
||||
case 7:
|
||||
if (has_texture_float && screen->kernel_has_gen7_sol_reset) {
|
||||
screen->max_gl_core_version = 31;
|
||||
screen->max_gl_compat_version = 30;
|
||||
screen->max_gl_es1_version = 11;
|
||||
screen->max_gl_es2_version = 30;
|
||||
} else {
|
||||
screen->max_gl_core_version = 0;
|
||||
screen->max_gl_compat_version = 21;
|
||||
screen->max_gl_es1_version = 11;
|
||||
screen->max_gl_es2_version = 20;
|
||||
}
|
||||
break;
|
||||
case 6:
|
||||
if (has_texture_float) {
|
||||
screen->max_gl_core_version = 31;
|
||||
screen->max_gl_compat_version = 30;
|
||||
screen->max_gl_es1_version = 11;
|
||||
screen->max_gl_es2_version = 30;
|
||||
} else {
|
||||
screen->max_gl_core_version = 0;
|
||||
screen->max_gl_compat_version = 21;
|
||||
screen->max_gl_es1_version = 11;
|
||||
screen->max_gl_es2_version = 20;
|
||||
}
|
||||
break;
|
||||
case 5:
|
||||
case 4:
|
||||
screen->max_gl_core_version = 0;
|
||||
screen->max_gl_compat_version = 21;
|
||||
screen->max_gl_es1_version = 11;
|
||||
screen->max_gl_es2_version = 20;
|
||||
break;
|
||||
case 3: {
|
||||
bool has_fragment_shader = driQueryOptionb(&screen->optionCache, "fragment_shader");
|
||||
bool has_occlusion_query = driQueryOptionb(&screen->optionCache, "stub_occlusion_query");
|
||||
|
||||
screen->max_gl_core_version = 0;
|
||||
screen->max_gl_es1_version = 11;
|
||||
|
||||
if (has_fragment_shader && has_occlusion_query) {
|
||||
screen->max_gl_compat_version = 21;
|
||||
} else {
|
||||
screen->max_gl_compat_version = 14;
|
||||
}
|
||||
|
||||
if (has_fragment_shader) {
|
||||
screen->max_gl_es2_version = 20;
|
||||
} else {
|
||||
screen->max_gl_es2_version = 0;
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
case 2:
|
||||
screen->max_gl_core_version = 0;
|
||||
screen->max_gl_compat_version = 13;
|
||||
screen->max_gl_es1_version = 11;
|
||||
screen->max_gl_es2_version = 0;
|
||||
break;
|
||||
default:
|
||||
assert(!"unrecognized intel_screen::gen");
|
||||
break;
|
||||
}
|
||||
|
||||
#ifndef FEATURE_ES1
|
||||
screen->max_gl_es1_version = 0;
|
||||
#endif
|
||||
|
||||
#ifndef FEATURE_ES2
|
||||
screen->max_gl_es2_version = 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
/**
|
||||
* This is the driver specific part of the createNewScreen entry point.
|
||||
* Called when using DRI2.
|
||||
@@ -1060,7 +1131,6 @@ static const
|
||||
__DRIconfig **intelInitScreen2(__DRIscreen *psp)
|
||||
{
|
||||
struct intel_screen *intelScreen;
|
||||
unsigned int api_mask;
|
||||
|
||||
if (psp->dri2.loader->base.version <= 2 ||
|
||||
psp->dri2.loader->getBuffersWithFormat == NULL) {
|
||||
@@ -1119,19 +1189,18 @@ __DRIconfig **intelInitScreen2(__DRIscreen *psp)
|
||||
|
||||
intel_override_separate_stencil(intelScreen);
|
||||
|
||||
api_mask = (1 << __DRI_API_OPENGL);
|
||||
#if FEATURE_ES1
|
||||
api_mask |= (1 << __DRI_API_GLES);
|
||||
#endif
|
||||
#if FEATURE_ES2
|
||||
api_mask |= (1 << __DRI_API_GLES2);
|
||||
#endif
|
||||
|
||||
if (IS_9XX(intelScreen->deviceID) || IS_965(intelScreen->deviceID))
|
||||
psp->api_mask = api_mask;
|
||||
|
||||
intelScreen->hw_has_swizzling = intel_detect_swizzling(intelScreen);
|
||||
|
||||
set_max_gl_versions(intelScreen);
|
||||
|
||||
psp->api_mask = (1 << __DRI_API_OPENGL);
|
||||
if (intelScreen->max_gl_es1_version > 0)
|
||||
psp->api_mask |= (1 << __DRI_API_GLES);
|
||||
if (intelScreen->max_gl_es2_version > 0)
|
||||
psp->api_mask |= (1 << __DRI_API_GLES2);
|
||||
if (intelScreen->max_gl_es2_version >= 30)
|
||||
psp->api_mask |= (1 << __DRI_API_GLES3);
|
||||
|
||||
psp->extensions = intelScreenExtensions;
|
||||
|
||||
return (const __DRIconfig**) intel_screen_make_configs(psp);
|
||||
|
@@ -40,6 +40,11 @@ struct intel_screen
|
||||
int deviceID;
|
||||
int gen;
|
||||
|
||||
int max_gl_core_version;
|
||||
int max_gl_compat_version;
|
||||
int max_gl_es1_version;
|
||||
int max_gl_es2_version;
|
||||
|
||||
int logTextureGranularity;
|
||||
|
||||
__DRIscreen *driScrnPriv;
|
||||
|
@@ -239,9 +239,12 @@ intelTexImage(struct gl_context * ctx,
|
||||
__FUNCTION__, texImage->Width, texImage->Height, texImage->Depth,
|
||||
pixels);
|
||||
|
||||
ctx->Driver.AllocTextureImageBuffer(ctx, texImage);
|
||||
if (format != GL_NONE && type != GL_NONE) {
|
||||
_mesa_store_teximage(ctx, dims, texImage,
|
||||
format, type, pixels, unpack);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
|
@@ -1636,7 +1636,7 @@ void GLAPIENTRY _ae_ArrayElement( GLint elt )
|
||||
/* If PrimitiveRestart is enabled and the index is the RestartIndex
|
||||
* then we call PrimitiveRestartNV and return.
|
||||
*/
|
||||
if (ctx->Array.PrimitiveRestart && (elt == ctx->Array.RestartIndex)) {
|
||||
if (ctx->Array._PrimitiveRestart && (elt == ctx->Array._RestartIndex)) {
|
||||
CALL_PrimitiveRestartNV((struct _glapi_table *)disp, ());
|
||||
return;
|
||||
}
|
||||
|
@@ -1377,7 +1377,10 @@ copy_array_attrib(struct gl_context *ctx,
|
||||
dest->LockFirst = src->LockFirst;
|
||||
dest->LockCount = src->LockCount;
|
||||
dest->PrimitiveRestart = src->PrimitiveRestart;
|
||||
dest->PrimitiveRestartFixedIndex = src->PrimitiveRestartFixedIndex;
|
||||
dest->_PrimitiveRestart = src->_PrimitiveRestart;
|
||||
dest->RestartIndex = src->RestartIndex;
|
||||
dest->_RestartIndex = src->_RestartIndex;
|
||||
/* skip NewState */
|
||||
/* skip RebindArrays */
|
||||
|
||||
|
@@ -136,10 +136,24 @@ get_buffer(struct gl_context *ctx, const char *func, GLenum target)
|
||||
}
|
||||
|
||||
|
||||
static inline GLbitfield
|
||||
default_access_mode(const struct gl_context *ctx)
|
||||
/**
|
||||
* Convert a GLbitfield describing the mapped buffer access flags
|
||||
* into one of GL_READ_WRITE, GL_READ_ONLY, or GL_WRITE_ONLY.
|
||||
*/
|
||||
static GLenum
|
||||
simplified_access_mode(struct gl_context *ctx, GLbitfield access)
|
||||
{
|
||||
/* Table 2.6 on page 31 (page 44 of the PDF) of the OpenGL 1.5 spec says:
|
||||
const GLbitfield rwFlags = GL_MAP_READ_BIT | GL_MAP_WRITE_BIT;
|
||||
if ((access & rwFlags) == rwFlags)
|
||||
return GL_READ_WRITE;
|
||||
if ((access & GL_MAP_READ_BIT) == GL_MAP_READ_BIT)
|
||||
return GL_READ_ONLY;
|
||||
if ((access & GL_MAP_WRITE_BIT) == GL_MAP_WRITE_BIT)
|
||||
return GL_WRITE_ONLY;
|
||||
|
||||
/* Otherwise, AccessFlags is zero (the default state).
|
||||
*
|
||||
* Table 2.6 on page 31 (page 44 of the PDF) of the OpenGL 1.5 spec says:
|
||||
*
|
||||
* Name Type Initial Value Legal Values
|
||||
* ... ... ... ...
|
||||
@@ -155,26 +169,9 @@ default_access_mode(const struct gl_context *ctx)
|
||||
* The difference is because GL_OES_mapbuffer only supports mapping buffers
|
||||
* write-only.
|
||||
*/
|
||||
return _mesa_is_gles(ctx)
|
||||
? GL_MAP_WRITE_BIT : (GL_MAP_READ_BIT | GL_MAP_WRITE_BIT);
|
||||
}
|
||||
assert(access == 0);
|
||||
|
||||
|
||||
/**
|
||||
* Convert a GLbitfield describing the mapped buffer access flags
|
||||
* into one of GL_READ_WRITE, GL_READ_ONLY, or GL_WRITE_ONLY.
|
||||
*/
|
||||
static GLenum
|
||||
simplified_access_mode(GLbitfield access)
|
||||
{
|
||||
const GLbitfield rwFlags = GL_MAP_READ_BIT | GL_MAP_WRITE_BIT;
|
||||
if ((access & rwFlags) == rwFlags)
|
||||
return GL_READ_WRITE;
|
||||
if ((access & GL_MAP_READ_BIT) == GL_MAP_READ_BIT)
|
||||
return GL_READ_ONLY;
|
||||
if ((access & GL_MAP_WRITE_BIT) == GL_MAP_WRITE_BIT)
|
||||
return GL_WRITE_ONLY;
|
||||
return GL_READ_WRITE; /* this should never happen, but no big deal */
|
||||
return _mesa_is_gles(ctx) ? GL_WRITE_ONLY : GL_READ_WRITE;
|
||||
}
|
||||
|
||||
|
||||
@@ -354,7 +351,7 @@ _mesa_initialize_buffer_object( struct gl_context *ctx,
|
||||
obj->RefCount = 1;
|
||||
obj->Name = name;
|
||||
obj->Usage = GL_STATIC_DRAW_ARB;
|
||||
obj->AccessFlags = default_access_mode(ctx);
|
||||
obj->AccessFlags = 0;
|
||||
}
|
||||
|
||||
|
||||
@@ -864,7 +861,7 @@ _mesa_DeleteBuffers(GLsizei n, const GLuint *ids)
|
||||
if (_mesa_bufferobj_mapped(bufObj)) {
|
||||
/* if mapped, unmap it now */
|
||||
ctx->Driver.UnmapBuffer(ctx, bufObj);
|
||||
bufObj->AccessFlags = default_access_mode(ctx);
|
||||
bufObj->AccessFlags = 0;
|
||||
bufObj->Pointer = NULL;
|
||||
}
|
||||
|
||||
@@ -1064,7 +1061,7 @@ _mesa_BufferData(GLenum target, GLsizeiptrARB size,
|
||||
if (_mesa_bufferobj_mapped(bufObj)) {
|
||||
/* Unmap the existing buffer. We'll replace it now. Not an error. */
|
||||
ctx->Driver.UnmapBuffer(ctx, bufObj);
|
||||
bufObj->AccessFlags = default_access_mode(ctx);
|
||||
bufObj->AccessFlags = 0;
|
||||
ASSERT(bufObj->Pointer == NULL);
|
||||
}
|
||||
|
||||
@@ -1282,7 +1279,7 @@ _mesa_UnmapBuffer(GLenum target)
|
||||
#endif
|
||||
|
||||
status = ctx->Driver.UnmapBuffer( ctx, bufObj );
|
||||
bufObj->AccessFlags = default_access_mode(ctx);
|
||||
bufObj->AccessFlags = 0;
|
||||
ASSERT(bufObj->Pointer == NULL);
|
||||
ASSERT(bufObj->Offset == 0);
|
||||
ASSERT(bufObj->Length == 0);
|
||||
@@ -1310,7 +1307,7 @@ _mesa_GetBufferParameteriv(GLenum target, GLenum pname, GLint *params)
|
||||
*params = bufObj->Usage;
|
||||
return;
|
||||
case GL_BUFFER_ACCESS_ARB:
|
||||
*params = simplified_access_mode(bufObj->AccessFlags);
|
||||
*params = simplified_access_mode(ctx, bufObj->AccessFlags);
|
||||
return;
|
||||
case GL_BUFFER_MAPPED_ARB:
|
||||
*params = _mesa_bufferobj_mapped(bufObj);
|
||||
@@ -1364,7 +1361,7 @@ _mesa_GetBufferParameteri64v(GLenum target, GLenum pname, GLint64 *params)
|
||||
*params = bufObj->Usage;
|
||||
return;
|
||||
case GL_BUFFER_ACCESS_ARB:
|
||||
*params = simplified_access_mode(bufObj->AccessFlags);
|
||||
*params = simplified_access_mode(ctx, bufObj->AccessFlags);
|
||||
return;
|
||||
case GL_BUFFER_ACCESS_FLAGS:
|
||||
if (!ctx->Extensions.ARB_map_buffer_range)
|
||||
|
@@ -290,6 +290,10 @@ _mesa_DrawBuffers(GLsizei n, const GLenum *buffers)
|
||||
|
||||
/* Turns out n==0 is a valid input that should not produce an error.
|
||||
* The remaining code below correctly handles the n==0 case.
|
||||
*
|
||||
* From the OpenGL 3.0 specification, page 258:
|
||||
* "An INVALID_VALUE error is generated if n is greater than
|
||||
* MAX_DRAW_BUFFERS."
|
||||
*/
|
||||
if (n < 0 || n > (GLsizei) ctx->Const.MaxDrawBuffers) {
|
||||
_mesa_error(ctx, GL_INVALID_VALUE, "glDrawBuffersARB(n)");
|
||||
@@ -305,20 +309,76 @@ _mesa_DrawBuffers(GLsizei n, const GLenum *buffers)
|
||||
destMask[output] = 0x0;
|
||||
}
|
||||
else {
|
||||
/* From the OpenGL 3.0 specification, page 258:
|
||||
* "If the GL is bound to a framebuffer object and DrawBuffers is
|
||||
* supplied with [...] COLOR_ATTACHMENTm where m is greater than or
|
||||
* equal to the value of MAX_COLOR_ATTACHMENTS, then the error
|
||||
* INVALID_OPERATION results."
|
||||
*/
|
||||
if (_mesa_is_user_fbo(ctx->DrawBuffer) && buffers[output] >=
|
||||
GL_COLOR_ATTACHMENT0 + ctx->Const.MaxDrawBuffers) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION, "glDrawBuffersARB(buffer)");
|
||||
return;
|
||||
}
|
||||
|
||||
destMask[output] = draw_buffer_enum_to_bitmask(buffers[output]);
|
||||
if (destMask[output] == BAD_MASK
|
||||
|| _mesa_bitcount(destMask[output]) > 1) {
|
||||
|
||||
/* From the OpenGL 3.0 specification, page 258:
|
||||
* "Each buffer listed in bufs must be one of the values from tables
|
||||
* 4.5 or 4.6. Otherwise, an INVALID_ENUM error is generated.
|
||||
*/
|
||||
if (destMask[output] == BAD_MASK) {
|
||||
_mesa_error(ctx, GL_INVALID_ENUM, "glDrawBuffersARB(buffer)");
|
||||
return;
|
||||
}
|
||||
|
||||
/* From the OpenGL 3.0 specification, page 259:
|
||||
* "For both the default framebuffer and framebuffer objects, the
|
||||
* constants FRONT, BACK, LEFT, RIGHT, and FRONT_AND_BACK are not
|
||||
* valid in the bufs array passed to DrawBuffers, and will result in
|
||||
* the error INVALID_OPERATION. This restriction is because these
|
||||
* constants may themselves refer to multiple buffers, as shown in
|
||||
* table 4.4."
|
||||
*/
|
||||
if (_mesa_bitcount(destMask[output]) > 1) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION, "glDrawBuffersARB(buffer)");
|
||||
return;
|
||||
}
|
||||
|
||||
/* From the OpenGL 3.0 specification, page 259:
|
||||
* "If the GL is bound to the default framebuffer and DrawBuffers is
|
||||
* supplied with a constant (other than NONE) that does not indicate
|
||||
* any of the color buffers allocated to the GL context by the window
|
||||
* system, the error INVALID_OPERATION will be generated.
|
||||
*
|
||||
* If the GL is bound to a framebuffer object and DrawBuffers is
|
||||
* supplied with a constant from table 4.6 [...] then the error
|
||||
* INVALID_OPERATION results."
|
||||
*/
|
||||
destMask[output] &= supportedMask;
|
||||
if (destMask[output] == 0) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION,
|
||||
"glDrawBuffersARB(unsupported buffer)");
|
||||
return;
|
||||
}
|
||||
|
||||
/* ES 3.0 is even more restrictive. From the ES 3.0 spec, page 180:
|
||||
* "If the GL is bound to a framebuffer object, the ith buffer listed
|
||||
* in bufs must be COLOR_ATTACHMENTi or NONE. [...] INVALID_OPERATION."
|
||||
*/
|
||||
if (_mesa_is_gles3(ctx) && _mesa_is_user_fbo(ctx->DrawBuffer) &&
|
||||
buffers[output] != GL_NONE &&
|
||||
buffers[output] != GL_COLOR_ATTACHMENT0 + output) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION, "glDrawBuffers(buffer)");
|
||||
return;
|
||||
}
|
||||
|
||||
/* From the OpenGL 3.0 specification, page 258:
|
||||
* "Except for NONE, a buffer may not appear more than once in the
|
||||
* array pointed to by bufs. Specifying a buffer more then once will
|
||||
* result in the error INVALID_OPERATION."
|
||||
*/
|
||||
if (destMask[output] & usedBufferMask) {
|
||||
/* can't specify a dest buffer more than once! */
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION,
|
||||
"glDrawBuffersARB(duplicated buffer)");
|
||||
return;
|
||||
|
@@ -656,6 +656,9 @@ _mesa_init_constants(struct gl_context *ctx)
|
||||
|
||||
/* PrimitiveRestart */
|
||||
ctx->Const.PrimitiveRestartInSoftware = GL_FALSE;
|
||||
|
||||
/* ES 3.0 or ARB_ES3_compatibility */
|
||||
ctx->Const.MaxElementIndex = 0xffffffffu;
|
||||
}
|
||||
|
||||
|
||||
|
@@ -48,6 +48,20 @@
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
update_derived_primitive_restart_state(struct gl_context *ctx)
|
||||
{
|
||||
/* Update derived primitive restart state.
|
||||
*/
|
||||
if (ctx->Array.PrimitiveRestart)
|
||||
ctx->Array._RestartIndex = ctx->Array.RestartIndex;
|
||||
else
|
||||
ctx->Array._RestartIndex = ~0;
|
||||
|
||||
ctx->Array._PrimitiveRestart = ctx->Array.PrimitiveRestart
|
||||
|| ctx->Array.PrimitiveRestartFixedIndex;
|
||||
}
|
||||
|
||||
/**
|
||||
* Helper to enable/disable client-side state.
|
||||
*/
|
||||
@@ -119,6 +133,8 @@ client_state(struct gl_context *ctx, GLenum cap, GLboolean state)
|
||||
|
||||
*var = state;
|
||||
|
||||
update_derived_primitive_restart_state(ctx);
|
||||
|
||||
if (state)
|
||||
arrayObj->_Enabled |= flag;
|
||||
else
|
||||
@@ -967,6 +983,17 @@ _mesa_set_enable(struct gl_context *ctx, GLenum cap, GLboolean state)
|
||||
if (ctx->Array.PrimitiveRestart != state) {
|
||||
FLUSH_VERTICES(ctx, _NEW_TRANSFORM);
|
||||
ctx->Array.PrimitiveRestart = state;
|
||||
update_derived_primitive_restart_state(ctx);
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_PRIMITIVE_RESTART_FIXED_INDEX:
|
||||
if (!_mesa_is_gles3(ctx) && !ctx->Extensions.ARB_ES3_compatibility)
|
||||
goto invalid_enum_error;
|
||||
if (ctx->Array.PrimitiveRestartFixedIndex != state) {
|
||||
FLUSH_VERTICES(ctx, _NEW_TRANSFORM);
|
||||
ctx->Array.PrimitiveRestartFixedIndex = state;
|
||||
update_derived_primitive_restart_state(ctx);
|
||||
}
|
||||
break;
|
||||
|
||||
@@ -1542,6 +1569,12 @@ _mesa_IsEnabled( GLenum cap )
|
||||
}
|
||||
return ctx->Array.PrimitiveRestart;
|
||||
|
||||
case GL_PRIMITIVE_RESTART_FIXED_INDEX:
|
||||
if (!_mesa_is_gles3(ctx) && !ctx->Extensions.ARB_ES3_compatibility) {
|
||||
goto invalid_enum_error;
|
||||
}
|
||||
return ctx->Array.PrimitiveRestartFixedIndex;
|
||||
|
||||
/* GL3.0 - GL_framebuffer_sRGB */
|
||||
case GL_FRAMEBUFFER_SRGB_EXT:
|
||||
if (!_mesa_is_desktop_gl(ctx))
|
||||
|
@@ -222,7 +222,7 @@ _mesa_get_attachment(struct gl_context *ctx, struct gl_framebuffer *fb,
|
||||
}
|
||||
return &fb->Attachment[BUFFER_COLOR0 + i];
|
||||
case GL_DEPTH_STENCIL_ATTACHMENT:
|
||||
if (!_mesa_is_desktop_gl(ctx))
|
||||
if (!_mesa_is_desktop_gl(ctx) && !_mesa_is_gles3(ctx))
|
||||
return NULL;
|
||||
/* fall-through */
|
||||
case GL_DEPTH_ATTACHMENT_EXT:
|
||||
@@ -492,7 +492,7 @@ _mesa_is_legal_color_format(const struct gl_context *ctx, GLenum baseFormat)
|
||||
case GL_LUMINANCE_ALPHA:
|
||||
case GL_INTENSITY:
|
||||
case GL_ALPHA:
|
||||
return ctx->Extensions.ARB_framebuffer_object;
|
||||
return _mesa_is_desktop_gl(ctx) && ctx->Extensions.ARB_framebuffer_object;
|
||||
case GL_RED:
|
||||
case GL_RG:
|
||||
return ctx->Extensions.ARB_texture_rg;
|
||||
@@ -502,6 +502,57 @@ _mesa_is_legal_color_format(const struct gl_context *ctx, GLenum baseFormat)
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Is the given base format a legal format for a color renderbuffer?
|
||||
*/
|
||||
static GLboolean
|
||||
is_format_color_renderable(const struct gl_context *ctx, gl_format format, GLenum internalFormat)
|
||||
{
|
||||
const GLenum baseFormat =
|
||||
_mesa_get_format_base_format(format);
|
||||
GLboolean valid;
|
||||
|
||||
valid = _mesa_is_legal_color_format(ctx, baseFormat);
|
||||
if (!valid || _mesa_is_desktop_gl(ctx)) {
|
||||
return valid;
|
||||
}
|
||||
|
||||
/* Reject additional cases for GLES */
|
||||
switch (internalFormat) {
|
||||
case GL_RGBA32F:
|
||||
case GL_RGBA16F:
|
||||
case GL_RGBA8_SNORM:
|
||||
case GL_RGB32F:
|
||||
case GL_RGB32I:
|
||||
case GL_RGB32UI:
|
||||
case GL_RGB16F:
|
||||
case GL_RGB16I:
|
||||
case GL_RGB16UI:
|
||||
case GL_RGB8_SNORM:
|
||||
case GL_RGB8I:
|
||||
case GL_RGB8UI:
|
||||
case GL_SRGB8:
|
||||
case GL_R11F_G11F_B10F:
|
||||
case GL_RGB9_E5:
|
||||
case GL_RG32F:
|
||||
case GL_RG16F:
|
||||
case GL_RG8_SNORM:
|
||||
case GL_R32F:
|
||||
case GL_R16F:
|
||||
case GL_R8_SNORM:
|
||||
return GL_FALSE;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
if (format == MESA_FORMAT_ARGB2101010 && internalFormat != GL_RGB10_A2) {
|
||||
return GL_FALSE;
|
||||
}
|
||||
|
||||
return GL_TRUE;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Is the given base format a legal format for a depth/stencil renderbuffer?
|
||||
*/
|
||||
@@ -567,7 +618,7 @@ test_attachment_completeness(const struct gl_context *ctx, GLenum format,
|
||||
baseFormat = _mesa_get_format_base_format(texImage->TexFormat);
|
||||
|
||||
if (format == GL_COLOR) {
|
||||
if (!_mesa_is_legal_color_format(ctx, baseFormat)) {
|
||||
if (!is_format_color_renderable(ctx, texImage->TexFormat, texImage->InternalFormat)) {
|
||||
att_incomplete("bad format");
|
||||
att->Complete = GL_FALSE;
|
||||
return;
|
||||
@@ -621,7 +672,7 @@ test_attachment_completeness(const struct gl_context *ctx, GLenum format,
|
||||
return;
|
||||
}
|
||||
if (format == GL_COLOR) {
|
||||
if (!_mesa_is_legal_color_format(ctx, baseFormat)) {
|
||||
if (!is_format_color_renderable(ctx, att->Renderbuffer->Format, att->Renderbuffer->InternalFormat)) {
|
||||
att_incomplete("bad renderbuffer color format");
|
||||
att->Complete = GL_FALSE;
|
||||
return;
|
||||
@@ -750,7 +801,7 @@ _mesa_test_framebuffer_completeness(struct gl_context *ctx,
|
||||
f = texImg->_BaseFormat;
|
||||
attFormat = texImg->TexFormat;
|
||||
numImages++;
|
||||
if (!_mesa_is_legal_color_format(ctx, f) &&
|
||||
if (!is_format_color_renderable(ctx, attFormat, texImg->InternalFormat) &&
|
||||
!is_legal_depth_format(ctx, f)) {
|
||||
fb->_Status = GL_FRAMEBUFFER_INCOMPLETE_FORMATS_EXT;
|
||||
fbo_incomplete("texture attachment incomplete", -1);
|
||||
@@ -1110,7 +1161,7 @@ _mesa_base_fbo_format(struct gl_context *ctx, GLenum internalFormat)
|
||||
case GL_RGB16:
|
||||
return _mesa_is_desktop_gl(ctx) ? GL_RGB : 0;
|
||||
case GL_SRGB8_EXT:
|
||||
return _mesa_is_desktop_gl(ctx) || _mesa_is_gles3(ctx) ? GL_RGB : 0;
|
||||
return _mesa_is_desktop_gl(ctx) ? GL_RGB : 0;
|
||||
case GL_RGBA4:
|
||||
case GL_RGB5_A1:
|
||||
case GL_RGBA8:
|
||||
@@ -1170,32 +1221,28 @@ _mesa_base_fbo_format(struct gl_context *ctx, GLenum internalFormat)
|
||||
? GL_RG : 0;
|
||||
/* signed normalized texture formats */
|
||||
case GL_R8_SNORM:
|
||||
return ctx->Version >= 30
|
||||
|| (ctx->API == API_OPENGL_COMPAT && ctx->Extensions.EXT_texture_snorm)
|
||||
return (ctx->API == API_OPENGL_COMPAT && ctx->Extensions.EXT_texture_snorm)
|
||||
? GL_RED : 0;
|
||||
case GL_RED_SNORM:
|
||||
case GL_R16_SNORM:
|
||||
return _mesa_is_desktop_gl(ctx) && ctx->Extensions.EXT_texture_snorm
|
||||
? GL_RED : 0;
|
||||
case GL_RG8_SNORM:
|
||||
return ctx->Version >= 30
|
||||
|| (ctx->API == API_OPENGL_COMPAT && ctx->Extensions.EXT_texture_snorm)
|
||||
return (ctx->API == API_OPENGL_COMPAT && ctx->Extensions.EXT_texture_snorm)
|
||||
? GL_RG : 0;
|
||||
case GL_RG_SNORM:
|
||||
case GL_RG16_SNORM:
|
||||
return _mesa_is_desktop_gl(ctx) && ctx->Extensions.EXT_texture_snorm
|
||||
? GL_RG : 0;
|
||||
case GL_RGB8_SNORM:
|
||||
return ctx->Version >= 30
|
||||
|| (ctx->API == API_OPENGL_COMPAT && ctx->Extensions.EXT_texture_snorm)
|
||||
return (ctx->API == API_OPENGL_COMPAT && ctx->Extensions.EXT_texture_snorm)
|
||||
? GL_RGB : 0;
|
||||
case GL_RGB_SNORM:
|
||||
case GL_RGB16_SNORM:
|
||||
return _mesa_is_desktop_gl(ctx) && ctx->Extensions.EXT_texture_snorm
|
||||
? GL_RGB : 0;
|
||||
case GL_RGBA8_SNORM:
|
||||
return ctx->Version >= 30
|
||||
|| (ctx->API == API_OPENGL_COMPAT && ctx->Extensions.EXT_texture_snorm)
|
||||
return (ctx->API == API_OPENGL_COMPAT && ctx->Extensions.EXT_texture_snorm)
|
||||
? GL_RGBA : 0;
|
||||
case GL_RGBA_SNORM:
|
||||
case GL_RGBA16_SNORM:
|
||||
@@ -1227,25 +1274,21 @@ _mesa_base_fbo_format(struct gl_context *ctx, GLenum internalFormat)
|
||||
ctx->Extensions.ARB_framebuffer_object ? GL_INTENSITY : 0;
|
||||
case GL_R16F:
|
||||
case GL_R32F:
|
||||
return ctx->Version >= 30
|
||||
|| (ctx->API == API_OPENGL_COMPAT &&
|
||||
return (ctx->API == API_OPENGL_COMPAT &&
|
||||
ctx->Extensions.ARB_texture_rg &&
|
||||
ctx->Extensions.ARB_texture_float) ? GL_RED : 0;
|
||||
case GL_RG16F:
|
||||
case GL_RG32F:
|
||||
return ctx->Version >= 30
|
||||
|| (ctx->API == API_OPENGL_COMPAT &&
|
||||
return (ctx->API == API_OPENGL_COMPAT &&
|
||||
ctx->Extensions.ARB_texture_rg &&
|
||||
ctx->Extensions.ARB_texture_float) ? GL_RG : 0;
|
||||
case GL_RGB16F:
|
||||
case GL_RGB32F:
|
||||
return (_mesa_is_desktop_gl(ctx) && ctx->Extensions.ARB_texture_float)
|
||||
|| _mesa_is_gles3(ctx)
|
||||
? GL_RGB : 0;
|
||||
case GL_RGBA16F:
|
||||
case GL_RGBA32F:
|
||||
return (_mesa_is_desktop_gl(ctx) && ctx->Extensions.ARB_texture_float)
|
||||
|| _mesa_is_gles3(ctx)
|
||||
? GL_RGBA : 0;
|
||||
case GL_ALPHA16F_ARB:
|
||||
case GL_ALPHA32F_ARB:
|
||||
@@ -1270,10 +1313,10 @@ _mesa_base_fbo_format(struct gl_context *ctx, GLenum internalFormat)
|
||||
case GL_RGB9_E5:
|
||||
return (_mesa_is_desktop_gl(ctx)
|
||||
&& ctx->Extensions.EXT_texture_shared_exponent)
|
||||
|| _mesa_is_gles3(ctx) ? GL_RGB : 0;
|
||||
? GL_RGB : 0;
|
||||
case GL_R11F_G11F_B10F:
|
||||
return (_mesa_is_desktop_gl(ctx) && ctx->Extensions.EXT_packed_float)
|
||||
|| _mesa_is_gles3(ctx) ? GL_RGB : 0;
|
||||
? GL_RGB : 0;
|
||||
|
||||
case GL_RGBA8UI_EXT:
|
||||
case GL_RGBA16UI_EXT:
|
||||
@@ -1291,8 +1334,7 @@ _mesa_base_fbo_format(struct gl_context *ctx, GLenum internalFormat)
|
||||
case GL_RGB8I_EXT:
|
||||
case GL_RGB16I_EXT:
|
||||
case GL_RGB32I_EXT:
|
||||
return ctx->Version >= 30
|
||||
|| (_mesa_is_desktop_gl(ctx) &&
|
||||
return (_mesa_is_desktop_gl(ctx) &&
|
||||
ctx->Extensions.EXT_texture_integer) ? GL_RGB : 0;
|
||||
|
||||
case GL_R8UI:
|
||||
@@ -1312,8 +1354,7 @@ _mesa_base_fbo_format(struct gl_context *ctx, GLenum internalFormat)
|
||||
case GL_RG16I:
|
||||
case GL_RG32UI:
|
||||
case GL_RG32I:
|
||||
return ctx->Version >= 30
|
||||
|| (_mesa_is_desktop_gl(ctx) &&
|
||||
return (_mesa_is_desktop_gl(ctx) &&
|
||||
ctx->Extensions.ARB_texture_rg &&
|
||||
ctx->Extensions.EXT_texture_integer) ? GL_RG : 0;
|
||||
|
||||
|
@@ -2696,6 +2696,20 @@ unpack_int_rgba_ABGR2101010_UINT(const GLuint *src, GLuint dst[][4], GLuint n)
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
unpack_int_rgba_ARGB2101010(const GLuint *src, GLuint dst[][4], GLuint n)
|
||||
{
|
||||
unsigned int i;
|
||||
|
||||
for (i = 0; i < n; i++) {
|
||||
GLuint tmp = src[i];
|
||||
dst[i][0] = (tmp >> 20) & 0x3ff;
|
||||
dst[i][1] = (tmp >> 10) & 0x3ff;
|
||||
dst[i][2] = (tmp >> 0) & 0x3ff;
|
||||
dst[i][3] = (tmp >> 30) & 0x3;
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
_mesa_unpack_uint_rgba_row(gl_format format, GLuint n,
|
||||
const void *src, GLuint dst[][4])
|
||||
@@ -2871,6 +2885,10 @@ _mesa_unpack_uint_rgba_row(gl_format format, GLuint n,
|
||||
unpack_int_rgba_ABGR2101010_UINT(src, dst, n);
|
||||
break;
|
||||
|
||||
case MESA_FORMAT_ARGB2101010:
|
||||
unpack_int_rgba_ARGB2101010(src, dst, n);
|
||||
break;
|
||||
|
||||
default:
|
||||
_mesa_problem(NULL, "%s: bad format %s", __FUNCTION__,
|
||||
_mesa_get_format_name(format));
|
||||
|
@@ -42,6 +42,7 @@
|
||||
#include "framebuffer.h"
|
||||
#include "renderbuffer.h"
|
||||
#include "texobj.h"
|
||||
#include "glformats.h"
|
||||
|
||||
|
||||
|
||||
@@ -898,6 +899,25 @@ _mesa_get_color_read_type(struct gl_context *ctx)
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Returns the read renderbuffer for the specified format.
|
||||
*/
|
||||
struct gl_renderbuffer *
|
||||
_mesa_get_read_renderbuffer(struct gl_context *ctx, GLenum format)
|
||||
{
|
||||
struct gl_framebuffer *rfb = ctx->ReadBuffer;
|
||||
|
||||
if (_mesa_is_color_format(format)) {
|
||||
return rfb->Attachment[rfb->_ColorReadBufferIndex].Renderbuffer;
|
||||
} else if (_mesa_is_depth_format(format) ||
|
||||
_mesa_is_depthstencil_format(format)) {
|
||||
return rfb->Attachment[BUFFER_DEPTH].Renderbuffer;
|
||||
} else {
|
||||
return rfb->Attachment[BUFFER_STENCIL].Renderbuffer;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Print framebuffer info to stderr, for debugging.
|
||||
*/
|
||||
|
@@ -30,6 +30,7 @@
|
||||
|
||||
struct gl_config;
|
||||
struct gl_context;
|
||||
struct gl_renderbuffer;
|
||||
|
||||
extern struct gl_framebuffer *
|
||||
_mesa_create_framebuffer(const struct gl_config *visual);
|
||||
@@ -96,6 +97,9 @@ _mesa_get_color_read_type(struct gl_context *ctx);
|
||||
extern GLenum
|
||||
_mesa_get_color_read_format(struct gl_context *ctx);
|
||||
|
||||
extern struct gl_renderbuffer *
|
||||
_mesa_get_read_renderbuffer(struct gl_context *ctx, GLenum format);
|
||||
|
||||
extern void
|
||||
_mesa_print_framebuffer(const struct gl_framebuffer *fb);
|
||||
|
||||
|
@@ -131,6 +131,7 @@ enum value_extra {
|
||||
EXTRA_API_GL,
|
||||
EXTRA_API_GL_CORE,
|
||||
EXTRA_API_ES2,
|
||||
EXTRA_API_ES3,
|
||||
EXTRA_NEW_BUFFERS,
|
||||
EXTRA_NEW_FRAG_CLAMP,
|
||||
EXTRA_VALID_DRAW_BUFFER,
|
||||
@@ -290,14 +291,30 @@ static const int extra_texture_buffer_object[] = {
|
||||
EXTRA_END
|
||||
};
|
||||
|
||||
static const int extra_ARB_transform_feedback2_api_es3[] = {
|
||||
EXT(ARB_transform_feedback2),
|
||||
EXTRA_API_ES3,
|
||||
EXTRA_END
|
||||
};
|
||||
|
||||
static const int extra_ARB_uniform_buffer_object_and_geometry_shader[] = {
|
||||
EXT(ARB_uniform_buffer_object),
|
||||
EXT(ARB_geometry_shader4),
|
||||
EXTRA_END
|
||||
};
|
||||
|
||||
static const int extra_ARB_ES2_compatibility_api_es2[] = {
|
||||
EXT(ARB_ES2_compatibility),
|
||||
EXTRA_API_ES2,
|
||||
EXTRA_END
|
||||
};
|
||||
|
||||
static const int extra_ARB_ES3_compatibility_api_es3[] = {
|
||||
EXT(ARB_ES3_compatibility),
|
||||
EXTRA_API_ES3,
|
||||
EXTRA_END
|
||||
};
|
||||
|
||||
EXTRA_EXT(ARB_ES2_compatibility);
|
||||
EXTRA_EXT(ARB_texture_cube_map);
|
||||
EXTRA_EXT(MESA_texture_array);
|
||||
EXTRA_EXT2(EXT_secondary_color, ARB_vertex_program);
|
||||
@@ -322,7 +339,6 @@ EXTRA_EXT(ARB_seamless_cube_map);
|
||||
EXTRA_EXT(ARB_sync);
|
||||
EXTRA_EXT(ARB_vertex_shader);
|
||||
EXTRA_EXT(EXT_transform_feedback);
|
||||
EXTRA_EXT(ARB_transform_feedback2);
|
||||
EXTRA_EXT(ARB_transform_feedback3);
|
||||
EXTRA_EXT(EXT_pixel_buffer_object);
|
||||
EXTRA_EXT(ARB_vertex_program);
|
||||
@@ -348,6 +364,12 @@ static const int extra_version_30[] = { EXTRA_VERSION_30, EXTRA_END };
|
||||
static const int extra_version_31[] = { EXTRA_VERSION_31, EXTRA_END };
|
||||
static const int extra_version_32[] = { EXTRA_VERSION_32, EXTRA_END };
|
||||
|
||||
static const int extra_gl30_es3[] = {
|
||||
EXTRA_VERSION_30,
|
||||
EXTRA_API_ES3,
|
||||
EXTRA_END,
|
||||
};
|
||||
|
||||
static const int
|
||||
extra_ARB_vertex_program_api_es2[] = {
|
||||
EXT(ARB_vertex_program),
|
||||
@@ -874,6 +896,12 @@ check_extra(struct gl_context *ctx, const char *func, const struct value_desc *d
|
||||
enabled++;
|
||||
}
|
||||
break;
|
||||
case EXTRA_API_ES3:
|
||||
if (_mesa_is_gles3(ctx)) {
|
||||
total++;
|
||||
enabled++;
|
||||
}
|
||||
break;
|
||||
case EXTRA_API_GL:
|
||||
if (_mesa_is_desktop_gl(ctx)) {
|
||||
total++;
|
||||
@@ -973,6 +1001,15 @@ find_value(const char *func, GLenum pname, void **p, union value *v)
|
||||
int api;
|
||||
|
||||
api = ctx->API;
|
||||
/* We index into the table_set[] list of per-API hash tables using the API's
|
||||
* value in the gl_api enum. Since GLES 3 doesn't have an API_OPENGL* enum
|
||||
* value since it's compatible with GLES2 its entry in table_set[] is at the
|
||||
* end.
|
||||
*/
|
||||
STATIC_ASSERT(Elements(table_set) == API_OPENGL_LAST + 2);
|
||||
if (_mesa_is_gles3(ctx)) {
|
||||
api = API_OPENGL_LAST + 1;
|
||||
}
|
||||
mask = Elements(table(api)) - 1;
|
||||
hash = (pname * prime_factor);
|
||||
while (1) {
|
||||
@@ -1626,7 +1663,7 @@ _mesa_GetBooleani_v( GLenum pname, GLuint index, GLboolean *params )
|
||||
{
|
||||
union value v;
|
||||
enum value_type type =
|
||||
find_value_indexed("glGetBooleanIndexedv", pname, index, &v);
|
||||
find_value_indexed("glGetBooleani_v", pname, index, &v);
|
||||
|
||||
switch (type) {
|
||||
case TYPE_INT:
|
||||
@@ -1651,7 +1688,7 @@ _mesa_GetIntegeri_v( GLenum pname, GLuint index, GLint *params )
|
||||
{
|
||||
union value v;
|
||||
enum value_type type =
|
||||
find_value_indexed("glGetIntegerIndexedv", pname, index, &v);
|
||||
find_value_indexed("glGetIntegeri_v", pname, index, &v);
|
||||
|
||||
switch (type) {
|
||||
case TYPE_INT:
|
||||
@@ -1672,11 +1709,11 @@ _mesa_GetIntegeri_v( GLenum pname, GLuint index, GLint *params )
|
||||
}
|
||||
|
||||
void GLAPIENTRY
|
||||
_mesa_GetInteger64Indexedv( GLenum pname, GLuint index, GLint64 *params )
|
||||
_mesa_GetInteger64i_v( GLenum pname, GLuint index, GLint64 *params )
|
||||
{
|
||||
union value v;
|
||||
enum value_type type =
|
||||
find_value_indexed("glGetIntegerIndexedv", pname, index, &v);
|
||||
find_value_indexed("glGetInteger64i_v", pname, index, &v);
|
||||
|
||||
switch (type) {
|
||||
case TYPE_INT:
|
||||
|
@@ -60,7 +60,7 @@ extern void GLAPIENTRY
|
||||
_mesa_GetIntegeri_v( GLenum pname, GLuint index, GLint *params );
|
||||
|
||||
extern void GLAPIENTRY
|
||||
_mesa_GetInteger64Indexedv( GLenum pname, GLuint index, GLint64 *params );
|
||||
_mesa_GetInteger64i_v( GLenum pname, GLuint index, GLint64 *params );
|
||||
|
||||
extern void GLAPIENTRY
|
||||
_mesa_GetPointerv( GLenum pname, GLvoid **params );
|
||||
|
@@ -44,7 +44,7 @@ prime_factor = 89
|
||||
prime_step = 281
|
||||
hash_table_size = 1024
|
||||
|
||||
gl_apis=set(["GL", "GL_CORE", "GLES", "GLES2"])
|
||||
gl_apis=set(["GL", "GL_CORE", "GLES", "GLES2", "GLES3"])
|
||||
|
||||
def print_header():
|
||||
print "typedef const unsigned short table_t[%d];\n" % (hash_table_size)
|
||||
@@ -67,6 +67,7 @@ api_enum = [
|
||||
'GLES',
|
||||
'GLES2',
|
||||
'GL_CORE',
|
||||
'GLES3', # Not in gl_api enum in mtypes.h
|
||||
]
|
||||
|
||||
def api_index(api):
|
||||
@@ -166,6 +167,9 @@ def generate_hash_tables(enum_list, enabled_apis, param_descriptors):
|
||||
|
||||
for api in valid_apis:
|
||||
add_to_hash_table(tables[api], hash_val, len(params))
|
||||
# Also add GLES2 items to the GLES3 hash table
|
||||
if api == "GLES2":
|
||||
add_to_hash_table(tables["GLES3"], hash_val, len(params))
|
||||
|
||||
params.append(["GL_" + enum_name, param[1]])
|
||||
|
||||
@@ -183,6 +187,8 @@ def opt_to_apis(feature):
|
||||
apis = set([_map[feature]])
|
||||
if "GL" in apis:
|
||||
apis.add("GL_CORE")
|
||||
if "GLES2" in apis:
|
||||
apis.add("GLES3")
|
||||
|
||||
return apis
|
||||
|
||||
|
@@ -204,12 +204,6 @@ descriptor=[
|
||||
[ "TEXTURE_COORD_ARRAY_TYPE", "LOC_CUSTOM, TYPE_ENUM, offsetof(struct gl_client_array, Type), NO_EXTRA" ],
|
||||
[ "TEXTURE_COORD_ARRAY_STRIDE", "LOC_CUSTOM, TYPE_INT, offsetof(struct gl_client_array, Stride), NO_EXTRA" ],
|
||||
|
||||
# GL_ARB_ES2_compatibility
|
||||
[ "SHADER_COMPILER", "CONST(1), extra_ARB_ES2_compatibility" ],
|
||||
[ "MAX_VARYING_VECTORS", "CONTEXT_INT(Const.MaxVarying), extra_ARB_ES2_compatibility" ],
|
||||
[ "MAX_VERTEX_UNIFORM_VECTORS", "LOC_CUSTOM, TYPE_INT, 0, extra_ARB_ES2_compatibility" ],
|
||||
[ "MAX_FRAGMENT_UNIFORM_VECTORS", "LOC_CUSTOM, TYPE_INT, 0, extra_ARB_ES2_compatibility" ],
|
||||
|
||||
# GL_ARB_multitexture
|
||||
[ "MAX_TEXTURE_UNITS", "CONTEXT_INT(Const.MaxTextureUnits), NO_EXTRA" ],
|
||||
[ "CLIENT_ACTIVE_TEXTURE", "LOC_CUSTOM, TYPE_INT, 0, NO_EXTRA" ],
|
||||
@@ -232,15 +226,8 @@ descriptor=[
|
||||
# GL_OES_point_sprite
|
||||
[ "POINT_SPRITE_NV", "CONTEXT_BOOL(Point.PointSprite), extra_NV_point_sprite_ARB_point_sprite" ],
|
||||
|
||||
# GL_ARB_fragment_shader
|
||||
[ "MAX_FRAGMENT_UNIFORM_COMPONENTS_ARB", "CONTEXT_INT(Const.FragmentProgram.MaxUniformComponents), extra_ARB_fragment_shader" ],
|
||||
|
||||
# GL_ARB_vertex_shader
|
||||
[ "MAX_VERTEX_UNIFORM_COMPONENTS_ARB", "CONTEXT_INT(Const.VertexProgram.MaxUniformComponents), extra_ARB_vertex_shader" ],
|
||||
[ "MAX_VARYING_FLOATS_ARB", "LOC_CUSTOM, TYPE_INT, 0, extra_ARB_vertex_shader" ],
|
||||
|
||||
# GL_EXT_texture_lod_bias
|
||||
[ "MAX_TEXTURE_LOD_BIAS_EXT", "CONTEXT_FLOAT(Const.MaxTextureLodBias), NO_EXTRA" ],
|
||||
]},
|
||||
|
||||
|
||||
@@ -317,6 +304,73 @@ descriptor=[
|
||||
|
||||
# GL_NV_read_buffer
|
||||
[ "READ_BUFFER", "LOC_CUSTOM, TYPE_ENUM, NO_OFFSET, extra_NV_read_buffer_api_gl" ],
|
||||
|
||||
# GL_ARB_ES2_compatibility
|
||||
[ "SHADER_COMPILER", "CONST(1), extra_ARB_ES2_compatibility_api_es2" ],
|
||||
[ "MAX_VARYING_VECTORS", "CONTEXT_INT(Const.MaxVarying), extra_ARB_ES2_compatibility_api_es2" ],
|
||||
[ "MAX_VERTEX_UNIFORM_VECTORS", "LOC_CUSTOM, TYPE_INT, 0, extra_ARB_ES2_compatibility_api_es2" ],
|
||||
[ "MAX_FRAGMENT_UNIFORM_VECTORS", "LOC_CUSTOM, TYPE_INT, 0, extra_ARB_ES2_compatibility_api_es2" ],
|
||||
]},
|
||||
|
||||
# GLES3 is not a typo.
|
||||
{ "apis": ["GL", "GLES", "GLES3", "GL_CORE"], "params": [
|
||||
# GL_EXT_texture_lod_bias
|
||||
[ "MAX_TEXTURE_LOD_BIAS_EXT", "CONTEXT_FLOAT(Const.MaxTextureLodBias), NO_EXTRA" ],
|
||||
]},
|
||||
|
||||
|
||||
# Enums in OpenGL and ES 3.0
|
||||
{ "apis": ["GL", "GL_CORE", "GLES3"], "params": [
|
||||
# GL 3.0 / GLES3
|
||||
[ "NUM_EXTENSIONS", "LOC_CUSTOM, TYPE_INT, 0, extra_gl30_es3" ],
|
||||
[ "MAJOR_VERSION", "LOC_CUSTOM, TYPE_INT, 0, extra_gl30_es3" ],
|
||||
[ "MINOR_VERSION", "LOC_CUSTOM, TYPE_INT, 0, extra_gl30_es3" ],
|
||||
|
||||
# GL_ARB_ES3_compatibility
|
||||
[ "MAX_ELEMENT_INDEX", "CONTEXT_INT64(Const.MaxElementIndex), extra_ARB_ES3_compatibility_api_es3"],
|
||||
|
||||
# GL_ARB_fragment_shader
|
||||
[ "MAX_FRAGMENT_UNIFORM_COMPONENTS_ARB", "CONTEXT_INT(Const.FragmentProgram.MaxUniformComponents), extra_ARB_fragment_shader" ],
|
||||
|
||||
# GL_ARB_framebuffer_object
|
||||
[ "MAX_SAMPLES", "CONTEXT_INT(Const.MaxSamples), extra_ARB_framebuffer_object_EXT_framebuffer_multisample" ],
|
||||
|
||||
# GL_ARB_sync
|
||||
[ "MAX_SERVER_WAIT_TIMEOUT", "CONTEXT_INT64(Const.MaxServerWaitTimeout), extra_ARB_sync" ],
|
||||
|
||||
# GL_ARB_transform_feedback2
|
||||
[ "TRANSFORM_FEEDBACK_BUFFER_PAUSED", "LOC_CUSTOM, TYPE_BOOLEAN, 0, extra_ARB_transform_feedback2_api_es3" ],
|
||||
[ "TRANSFORM_FEEDBACK_BUFFER_ACTIVE", "LOC_CUSTOM, TYPE_BOOLEAN, 0, extra_ARB_transform_feedback2_api_es3" ],
|
||||
[ "TRANSFORM_FEEDBACK_BINDING", "LOC_CUSTOM, TYPE_INT, 0, extra_ARB_transform_feedback2_api_es3" ],
|
||||
|
||||
# GL_ARB_uniform_buffer_object
|
||||
[ "MAX_VERTEX_UNIFORM_BLOCKS", "CONTEXT_INT(Const.VertexProgram.MaxUniformBlocks), extra_ARB_uniform_buffer_object" ],
|
||||
[ "MAX_FRAGMENT_UNIFORM_BLOCKS", "CONTEXT_INT(Const.FragmentProgram.MaxUniformBlocks), extra_ARB_uniform_buffer_object" ],
|
||||
[ "MAX_COMBINED_UNIFORM_BLOCKS", "CONTEXT_INT(Const.MaxCombinedUniformBlocks), extra_ARB_uniform_buffer_object" ],
|
||||
[ "MAX_UNIFORM_BLOCK_SIZE", "CONTEXT_INT(Const.MaxUniformBlockSize), extra_ARB_uniform_buffer_object" ],
|
||||
[ "MAX_UNIFORM_BUFFER_BINDINGS", "CONTEXT_INT(Const.MaxUniformBufferBindings), extra_ARB_uniform_buffer_object" ],
|
||||
[ "MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS", "CONTEXT_INT(Const.VertexProgram.MaxCombinedUniformComponents), extra_ARB_uniform_buffer_object" ],
|
||||
[ "MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS", "CONTEXT_INT(Const.FragmentProgram.MaxCombinedUniformComponents), extra_ARB_uniform_buffer_object" ],
|
||||
[ "UNIFORM_BUFFER_OFFSET_ALIGNMENT", "CONTEXT_INT(Const.UniformBufferOffsetAlignment), extra_ARB_uniform_buffer_object" ],
|
||||
[ "UNIFORM_BUFFER_BINDING", "LOC_CUSTOM, TYPE_INT, 0, extra_ARB_uniform_buffer_object" ],
|
||||
|
||||
# GL_ARB_vertex_shader
|
||||
[ "MAX_VERTEX_UNIFORM_COMPONENTS_ARB", "CONTEXT_INT(Const.VertexProgram.MaxUniformComponents), extra_ARB_vertex_shader" ],
|
||||
|
||||
# GL_EXT_framebuffer_blit
|
||||
# NOTE: GL_DRAW_FRAMEBUFFER_BINDING_EXT == GL_FRAMEBUFFER_BINDING_EXT
|
||||
[ "READ_FRAMEBUFFER_BINDING_EXT", "LOC_CUSTOM, TYPE_INT, 0, extra_EXT_framebuffer_blit" ],
|
||||
|
||||
# GL_EXT_pixel_buffer_object
|
||||
[ "PIXEL_PACK_BUFFER_BINDING_EXT", "LOC_CUSTOM, TYPE_INT, 0, extra_EXT_pixel_buffer_object" ],
|
||||
[ "PIXEL_UNPACK_BUFFER_BINDING_EXT", "LOC_CUSTOM, TYPE_INT, 0, extra_EXT_pixel_buffer_object" ],
|
||||
|
||||
# GL_EXT_transform_feedback
|
||||
[ "TRANSFORM_FEEDBACK_BUFFER_BINDING", "LOC_CUSTOM, TYPE_INT, 0, extra_EXT_transform_feedback" ],
|
||||
[ "RASTERIZER_DISCARD", "CONTEXT_BOOL(RasterDiscard), extra_EXT_transform_feedback" ],
|
||||
[ "MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS", "CONTEXT_INT(Const.MaxTransformFeedbackInterleavedComponents), extra_EXT_transform_feedback" ],
|
||||
[ "MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS", "CONTEXT_INT(Const.MaxTransformFeedbackBuffers), extra_EXT_transform_feedback" ],
|
||||
[ "MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS", "CONTEXT_INT(Const.MaxTransformFeedbackSeparateComponents), extra_EXT_transform_feedback" ],
|
||||
]},
|
||||
|
||||
{ "apis": ["GLES", "GLES2"], "params": [
|
||||
@@ -327,10 +381,6 @@ descriptor=[
|
||||
|
||||
# Enums unique to OpenGL ES 2.0
|
||||
{ "apis": ["GLES2"], "params": [
|
||||
[ "MAX_FRAGMENT_UNIFORM_VECTORS", "LOC_CUSTOM, TYPE_INT, 0, NO_EXTRA" ],
|
||||
[ "MAX_VARYING_VECTORS", "CONTEXT_INT(Const.MaxVarying), NO_EXTRA" ],
|
||||
[ "MAX_VERTEX_UNIFORM_VECTORS", "LOC_CUSTOM, TYPE_INT, 0, NO_EXTRA" ],
|
||||
[ "SHADER_COMPILER", "CONST(1), NO_EXTRA" ],
|
||||
# OES_get_program_binary
|
||||
[ "NUM_SHADER_BINARY_FORMATS", "CONST(0), NO_EXTRA" ],
|
||||
[ "SHADER_BINARY_FORMATS", "CONST(0), NO_EXTRA" ],
|
||||
@@ -536,10 +586,6 @@ descriptor=[
|
||||
[ "SECONDARY_COLOR_ARRAY_BUFFER_BINDING_ARB", "LOC_CUSTOM, TYPE_INT, offsetof(struct gl_array_object, VertexAttrib[VERT_ATTRIB_COLOR1].BufferObj), NO_EXTRA" ],
|
||||
[ "FOG_COORDINATE_ARRAY_BUFFER_BINDING_ARB", "LOC_CUSTOM, TYPE_INT, offsetof(struct gl_array_object, VertexAttrib[VERT_ATTRIB_FOG].BufferObj), NO_EXTRA" ],
|
||||
|
||||
# GL_EXT_pixel_buffer_object
|
||||
[ "PIXEL_PACK_BUFFER_BINDING_EXT", "LOC_CUSTOM, TYPE_INT, 0, extra_EXT_pixel_buffer_object" ],
|
||||
[ "PIXEL_UNPACK_BUFFER_BINDING_EXT", "LOC_CUSTOM, TYPE_INT, 0, extra_EXT_pixel_buffer_object" ],
|
||||
|
||||
# GL_ARB_vertex_program
|
||||
# == GL_VERTEX_PROGRAM_NV
|
||||
[ "VERTEX_PROGRAM_ARB", "CONTEXT_BOOL(VertexProgram.Enabled), extra_ARB_vertex_program" ],
|
||||
@@ -580,38 +626,16 @@ descriptor=[
|
||||
[ "NUM_LOOPBACK_COMPONENTS_ATI", "CONST(3), extra_ATI_fragment_shader" ],
|
||||
[ "NUM_INPUT_INTERPOLATOR_COMPONENTS_ATI", "CONST(3), extra_ATI_fragment_shader" ],
|
||||
|
||||
# GL_EXT_framebuffer_blit
|
||||
# NOTE: GL_DRAW_FRAMEBUFFER_BINDING_EXT == GL_FRAMEBUFFER_BINDING_EXT
|
||||
[ "READ_FRAMEBUFFER_BINDING_EXT", "LOC_CUSTOM, TYPE_INT, 0, extra_EXT_framebuffer_blit" ],
|
||||
|
||||
# GL_EXT_provoking_vertex
|
||||
[ "PROVOKING_VERTEX_EXT", "CONTEXT_ENUM(Light.ProvokingVertex), extra_EXT_provoking_vertex" ],
|
||||
[ "QUADS_FOLLOW_PROVOKING_VERTEX_CONVENTION_EXT", "CONTEXT_BOOL(Const.QuadsFollowProvokingVertexConvention), extra_EXT_provoking_vertex" ],
|
||||
|
||||
# GL_ARB_framebuffer_object
|
||||
[ "MAX_SAMPLES", "CONTEXT_INT(Const.MaxSamples), extra_ARB_framebuffer_object_EXT_framebuffer_multisample" ],
|
||||
|
||||
# GL_ARB_seamless_cube_map
|
||||
[ "TEXTURE_CUBE_MAP_SEAMLESS", "CONTEXT_BOOL(Texture.CubeMapSeamless), extra_ARB_seamless_cube_map" ],
|
||||
|
||||
# GL_ARB_sync
|
||||
[ "MAX_SERVER_WAIT_TIMEOUT", "CONTEXT_INT64(Const.MaxServerWaitTimeout), extra_ARB_sync" ],
|
||||
|
||||
# GL_EXT_texture_integer
|
||||
[ "RGBA_INTEGER_MODE_EXT", "BUFFER_BOOL(_IntegerColor), extra_EXT_texture_integer" ],
|
||||
|
||||
# GL_EXT_transform_feedback
|
||||
[ "TRANSFORM_FEEDBACK_BUFFER_BINDING", "LOC_CUSTOM, TYPE_INT, 0, extra_EXT_transform_feedback" ],
|
||||
[ "RASTERIZER_DISCARD", "CONTEXT_BOOL(RasterDiscard), extra_EXT_transform_feedback" ],
|
||||
[ "MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS", "CONTEXT_INT(Const.MaxTransformFeedbackInterleavedComponents), extra_EXT_transform_feedback" ],
|
||||
[ "MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS", "CONTEXT_INT(Const.MaxTransformFeedbackBuffers), extra_EXT_transform_feedback" ],
|
||||
[ "MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS", "CONTEXT_INT(Const.MaxTransformFeedbackSeparateComponents), extra_EXT_transform_feedback" ],
|
||||
|
||||
# GL_ARB_transform_feedback2
|
||||
[ "TRANSFORM_FEEDBACK_BUFFER_PAUSED", "LOC_CUSTOM, TYPE_BOOLEAN, 0, extra_ARB_transform_feedback2" ],
|
||||
[ "TRANSFORM_FEEDBACK_BUFFER_ACTIVE", "LOC_CUSTOM, TYPE_BOOLEAN, 0, extra_ARB_transform_feedback2" ],
|
||||
[ "TRANSFORM_FEEDBACK_BINDING", "LOC_CUSTOM, TYPE_INT, 0, extra_ARB_transform_feedback2" ],
|
||||
|
||||
# GL_ARB_transform_feedback3
|
||||
[ "MAX_TRANSFORM_FEEDBACK_BUFFERS", "CONTEXT_INT(Const.MaxTransformFeedbackBuffers), extra_ARB_transform_feedback3" ],
|
||||
[ "MAX_VERTEX_STREAMS", "CONTEXT_INT(Const.MaxVertexStreams), extra_ARB_transform_feedback3" ],
|
||||
@@ -642,9 +666,6 @@ descriptor=[
|
||||
[ "SAMPLER_BINDING", "LOC_CUSTOM, TYPE_INT, GL_SAMPLER_BINDING, NO_EXTRA" ],
|
||||
|
||||
# GL 3.0
|
||||
[ "NUM_EXTENSIONS", "LOC_CUSTOM, TYPE_INT, 0, extra_version_30" ],
|
||||
[ "MAJOR_VERSION", "LOC_CUSTOM, TYPE_INT, 0, extra_version_30" ],
|
||||
[ "MINOR_VERSION", "LOC_CUSTOM, TYPE_INT, 0, extra_version_30" ],
|
||||
[ "CONTEXT_FLAGS", "CONTEXT_INT(Const.ContextFlags), extra_version_30" ],
|
||||
|
||||
# GL3.0 / GL_EXT_framebuffer_sRGB
|
||||
@@ -671,17 +692,8 @@ descriptor=[
|
||||
[ "MAX_DUAL_SOURCE_DRAW_BUFFERS", "CONTEXT_INT(Const.MaxDualSourceDrawBuffers), extra_ARB_blend_func_extended" ],
|
||||
|
||||
# GL_ARB_uniform_buffer_object
|
||||
[ "MAX_VERTEX_UNIFORM_BLOCKS", "CONTEXT_INT(Const.VertexProgram.MaxUniformBlocks), extra_ARB_uniform_buffer_object" ],
|
||||
[ "MAX_FRAGMENT_UNIFORM_BLOCKS", "CONTEXT_INT(Const.FragmentProgram.MaxUniformBlocks), extra_ARB_uniform_buffer_object" ],
|
||||
[ "MAX_GEOMETRY_UNIFORM_BLOCKS", "CONTEXT_INT(Const.GeometryProgram.MaxUniformBlocks), extra_ARB_uniform_buffer_object_and_geometry_shader" ],
|
||||
[ "MAX_COMBINED_UNIFORM_BLOCKS", "CONTEXT_INT(Const.MaxCombinedUniformBlocks), extra_ARB_uniform_buffer_object" ],
|
||||
[ "MAX_UNIFORM_BLOCK_SIZE", "CONTEXT_INT(Const.MaxUniformBlockSize), extra_ARB_uniform_buffer_object" ],
|
||||
[ "MAX_UNIFORM_BUFFER_BINDINGS", "CONTEXT_INT(Const.MaxUniformBufferBindings), extra_ARB_uniform_buffer_object" ],
|
||||
[ "MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS", "CONTEXT_INT(Const.VertexProgram.MaxCombinedUniformComponents), extra_ARB_uniform_buffer_object" ],
|
||||
[ "MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS", "CONTEXT_INT(Const.FragmentProgram.MaxCombinedUniformComponents), extra_ARB_uniform_buffer_object" ],
|
||||
[ "MAX_COMBINED_GEOMETRY_UNIFORM_COMPONENTS", "CONTEXT_INT(Const.GeometryProgram.MaxCombinedUniformComponents), extra_ARB_uniform_buffer_object_and_geometry_shader" ],
|
||||
[ "UNIFORM_BUFFER_OFFSET_ALIGNMENT", "CONTEXT_INT(Const.UniformBufferOffsetAlignment), extra_ARB_uniform_buffer_object" ],
|
||||
[ "UNIFORM_BUFFER_BINDING", "LOC_CUSTOM, TYPE_INT, 0, extra_ARB_uniform_buffer_object" ],
|
||||
|
||||
# GL_ARB_timer_query
|
||||
[ "TIMESTAMP", "LOC_CUSTOM, TYPE_INT64, 0, extra_ARB_timer_query" ],
|
||||
|
@@ -74,7 +74,9 @@ shading_language_version(struct gl_context *ctx)
|
||||
break;
|
||||
|
||||
case API_OPENGLES2:
|
||||
return (const GLubyte *) "OpenGL ES GLSL ES 1.0.16";
|
||||
return (ctx->Version < 30)
|
||||
? (const GLubyte *) "OpenGL ES GLSL ES 1.0.16"
|
||||
: (const GLubyte *) "OpenGL ES GLSL ES 3.0";
|
||||
|
||||
case API_OPENGLES:
|
||||
/* fall-through */
|
||||
|
@@ -271,7 +271,8 @@ _mesa_bytes_per_pixel(GLenum format, GLenum type)
|
||||
case GL_UNSIGNED_INT_10_10_10_2:
|
||||
case GL_UNSIGNED_INT_2_10_10_10_REV:
|
||||
if (format == GL_RGBA || format == GL_BGRA || format == GL_ABGR_EXT ||
|
||||
format == GL_RGBA_INTEGER_EXT || format == GL_BGRA_INTEGER_EXT)
|
||||
format == GL_RGBA_INTEGER_EXT || format == GL_BGRA_INTEGER_EXT ||
|
||||
format == GL_RGB)
|
||||
return sizeof(GLuint);
|
||||
else
|
||||
return -1;
|
||||
@@ -353,21 +354,9 @@ _mesa_bytes_per_vertex_attrib(GLint comps, GLenum type)
|
||||
* Test if the given format is an integer (non-normalized) format.
|
||||
*/
|
||||
GLboolean
|
||||
_mesa_is_enum_format_integer(GLenum format)
|
||||
_mesa_is_enum_format_unsigned_int(GLenum format)
|
||||
{
|
||||
switch (format) {
|
||||
/* generic integer formats */
|
||||
case GL_RED_INTEGER_EXT:
|
||||
case GL_GREEN_INTEGER_EXT:
|
||||
case GL_BLUE_INTEGER_EXT:
|
||||
case GL_ALPHA_INTEGER_EXT:
|
||||
case GL_RGB_INTEGER_EXT:
|
||||
case GL_RGBA_INTEGER_EXT:
|
||||
case GL_BGR_INTEGER_EXT:
|
||||
case GL_BGRA_INTEGER_EXT:
|
||||
case GL_LUMINANCE_INTEGER_EXT:
|
||||
case GL_LUMINANCE_ALPHA_INTEGER_EXT:
|
||||
case GL_RG_INTEGER:
|
||||
/* specific integer formats */
|
||||
case GL_RGBA32UI_EXT:
|
||||
case GL_RGB32UI_EXT:
|
||||
@@ -393,6 +382,34 @@ _mesa_is_enum_format_integer(GLenum format)
|
||||
case GL_INTENSITY8UI_EXT:
|
||||
case GL_LUMINANCE8UI_EXT:
|
||||
case GL_LUMINANCE_ALPHA8UI_EXT:
|
||||
case GL_RGB10_A2UI:
|
||||
return GL_TRUE;
|
||||
default:
|
||||
return GL_FALSE;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Test if the given format is an integer (non-normalized) format.
|
||||
*/
|
||||
GLboolean
|
||||
_mesa_is_enum_format_signed_int(GLenum format)
|
||||
{
|
||||
switch (format) {
|
||||
/* generic integer formats */
|
||||
case GL_RED_INTEGER_EXT:
|
||||
case GL_GREEN_INTEGER_EXT:
|
||||
case GL_BLUE_INTEGER_EXT:
|
||||
case GL_ALPHA_INTEGER_EXT:
|
||||
case GL_RGB_INTEGER_EXT:
|
||||
case GL_RGBA_INTEGER_EXT:
|
||||
case GL_BGR_INTEGER_EXT:
|
||||
case GL_BGRA_INTEGER_EXT:
|
||||
case GL_LUMINANCE_INTEGER_EXT:
|
||||
case GL_LUMINANCE_ALPHA_INTEGER_EXT:
|
||||
case GL_RG_INTEGER:
|
||||
/* specific integer formats */
|
||||
case GL_RGBA32I_EXT:
|
||||
case GL_RGB32I_EXT:
|
||||
case GL_RG32I:
|
||||
@@ -417,7 +434,6 @@ _mesa_is_enum_format_integer(GLenum format)
|
||||
case GL_INTENSITY8I_EXT:
|
||||
case GL_LUMINANCE8I_EXT:
|
||||
case GL_LUMINANCE_ALPHA8I_EXT:
|
||||
case GL_RGB10_A2UI:
|
||||
return GL_TRUE;
|
||||
default:
|
||||
return GL_FALSE;
|
||||
@@ -425,6 +441,17 @@ _mesa_is_enum_format_integer(GLenum format)
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Test if the given format is an integer (non-normalized) format.
|
||||
*/
|
||||
GLboolean
|
||||
_mesa_is_enum_format_integer(GLenum format)
|
||||
{
|
||||
return _mesa_is_enum_format_unsigned_int(format) ||
|
||||
_mesa_is_enum_format_signed_int(format);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Test if the given type is an integer (non-normalized) format.
|
||||
*/
|
||||
@@ -1031,6 +1058,32 @@ _mesa_base_format_has_channel(GLenum base_format, GLenum pname)
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Returns the number of channels/components for a base format.
|
||||
*/
|
||||
GLint
|
||||
_mesa_base_format_component_count(GLenum base_format)
|
||||
{
|
||||
switch (base_format) {
|
||||
case GL_RED:
|
||||
case GL_ALPHA:
|
||||
case GL_INTENSITY:
|
||||
case GL_DEPTH_COMPONENT:
|
||||
return 1;
|
||||
case GL_RG:
|
||||
case GL_LUMINANCE_ALPHA:
|
||||
case GL_DEPTH_STENCIL:
|
||||
return 2;
|
||||
case GL_RGB:
|
||||
return 3;
|
||||
case GL_RGBA:
|
||||
return 4;
|
||||
default:
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* If format is a generic compressed format, return the corresponding
|
||||
* non-compressed format. For other formats, return the format as-is.
|
||||
@@ -1236,6 +1289,10 @@ _mesa_error_check_format_and_type(const struct gl_context *ctx,
|
||||
ctx->Extensions.ARB_texture_rgb10_a2ui) {
|
||||
break; /* OK */
|
||||
}
|
||||
if (type == GL_UNSIGNED_INT_2_10_10_10_REV && format == GL_RGB &&
|
||||
ctx->API == API_OPENGLES2) {
|
||||
break; /* OK by GL_EXT_texture_type_2_10_10_10_REV */
|
||||
}
|
||||
return GL_INVALID_OPERATION;
|
||||
|
||||
case GL_UNSIGNED_INT_24_8:
|
||||
@@ -1349,6 +1406,11 @@ _mesa_error_check_format_and_type(const struct gl_context *ctx,
|
||||
case GL_UNSIGNED_SHORT_5_6_5:
|
||||
case GL_UNSIGNED_SHORT_5_6_5_REV:
|
||||
return GL_NO_ERROR;
|
||||
case GL_UNSIGNED_INT_2_10_10_10_REV:
|
||||
/* OK by GL_EXT_texture_type_2_10_10_10_REV */
|
||||
if (ctx->API == API_OPENGLES2) {
|
||||
return GL_NO_ERROR;
|
||||
}
|
||||
case GL_HALF_FLOAT:
|
||||
return ctx->Extensions.ARB_half_float_pixel
|
||||
? GL_NO_ERROR : GL_INVALID_ENUM;
|
||||
@@ -1425,8 +1487,18 @@ _mesa_error_check_format_and_type(const struct gl_context *ctx,
|
||||
else if (ctx->Extensions.ARB_depth_buffer_float &&
|
||||
type == GL_FLOAT_32_UNSIGNED_INT_24_8_REV)
|
||||
return GL_NO_ERROR;
|
||||
else
|
||||
switch (type) {
|
||||
case GL_BYTE:
|
||||
case GL_UNSIGNED_BYTE:
|
||||
case GL_SHORT:
|
||||
case GL_UNSIGNED_SHORT:
|
||||
case GL_INT:
|
||||
case GL_UNSIGNED_INT:
|
||||
case GL_FLOAT:
|
||||
return GL_INVALID_OPERATION;
|
||||
default:
|
||||
return GL_INVALID_ENUM;
|
||||
}
|
||||
|
||||
case GL_DUDV_ATI:
|
||||
case GL_DU8DV8_ATI:
|
||||
@@ -1617,3 +1689,442 @@ _mesa_es_error_check_format_and_type(GLenum format, GLenum type,
|
||||
|
||||
return type_valid ? GL_NO_ERROR : GL_INVALID_OPERATION;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Do error checking of format/type combinations for OpenGL ES 3
|
||||
* glTex[Sub]Image.
|
||||
* \return error code, or GL_NO_ERROR.
|
||||
*/
|
||||
GLenum
|
||||
_mesa_es3_error_check_format_and_type(GLenum format, GLenum type,
|
||||
GLenum internalFormat,
|
||||
unsigned dimensions)
|
||||
{
|
||||
GLboolean type_valid = GL_TRUE;
|
||||
|
||||
switch (format) {
|
||||
case GL_RGBA:
|
||||
switch (type) {
|
||||
case GL_UNSIGNED_BYTE:
|
||||
switch (internalFormat) {
|
||||
case GL_RGBA:
|
||||
case GL_RGBA8:
|
||||
case GL_RGB5_A1:
|
||||
case GL_RGBA4:
|
||||
case GL_SRGB8_ALPHA8_EXT:
|
||||
break;
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_BYTE:
|
||||
if (internalFormat != GL_RGBA8_SNORM)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_SHORT_4_4_4_4:
|
||||
switch (internalFormat) {
|
||||
case GL_RGBA:
|
||||
case GL_RGBA4:
|
||||
break;
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_SHORT_5_5_5_1:
|
||||
switch (internalFormat) {
|
||||
case GL_RGBA:
|
||||
case GL_RGB5_A1:
|
||||
break;
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_INT_2_10_10_10_REV:
|
||||
switch (internalFormat) {
|
||||
case GL_RGBA: /* XXX: Spec does *not* say this, but the test expects it */
|
||||
case GL_RGB10_A2:
|
||||
case GL_RGB5_A1:
|
||||
break;
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_HALF_FLOAT:
|
||||
if (internalFormat != GL_RGBA16F)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_FLOAT:
|
||||
switch (internalFormat) {
|
||||
case GL_RGBA16F:
|
||||
case GL_RGBA32F:
|
||||
break;
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_RGBA_INTEGER:
|
||||
switch (type) {
|
||||
case GL_UNSIGNED_BYTE:
|
||||
if (internalFormat != GL_RGBA8UI)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_BYTE:
|
||||
if (internalFormat != GL_RGBA8I)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_SHORT:
|
||||
if (internalFormat != GL_RGBA16UI)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_SHORT:
|
||||
if (internalFormat != GL_RGBA16I)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_INT:
|
||||
if (internalFormat != GL_RGBA32UI)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_INT:
|
||||
if (internalFormat != GL_RGBA32I)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_INT_2_10_10_10_REV:
|
||||
if (internalFormat != GL_RGB10_A2UI)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_RGB:
|
||||
switch (type) {
|
||||
case GL_UNSIGNED_BYTE:
|
||||
switch (internalFormat) {
|
||||
case GL_RGB:
|
||||
case GL_RGB8:
|
||||
case GL_RGB565:
|
||||
case GL_SRGB8:
|
||||
break;
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_BYTE:
|
||||
if (internalFormat != GL_RGB8_SNORM)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_SHORT_5_6_5:
|
||||
switch (internalFormat) {
|
||||
case GL_RGB:
|
||||
case GL_RGB565:
|
||||
break;
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_INT_10F_11F_11F_REV:
|
||||
if (internalFormat != GL_R11F_G11F_B10F)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_INT_5_9_9_9_REV:
|
||||
if (internalFormat != GL_RGB9_E5)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_HALF_FLOAT:
|
||||
switch (internalFormat) {
|
||||
case GL_RGB16F:
|
||||
case GL_R11F_G11F_B10F:
|
||||
case GL_RGB9_E5:
|
||||
break;
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_FLOAT:
|
||||
switch (internalFormat) {
|
||||
case GL_RGB16F:
|
||||
case GL_RGB32F:
|
||||
case GL_R11F_G11F_B10F:
|
||||
case GL_RGB9_E5:
|
||||
break;
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_INT_2_10_10_10_REV:
|
||||
switch (internalFormat) {
|
||||
case GL_RGB:
|
||||
break;
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_RGB_INTEGER:
|
||||
switch (type) {
|
||||
case GL_UNSIGNED_BYTE:
|
||||
if (internalFormat != GL_RGB8UI)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_BYTE:
|
||||
if (internalFormat != GL_RGB8I)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_SHORT:
|
||||
if (internalFormat != GL_RGB16UI)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_SHORT:
|
||||
if (internalFormat != GL_RGB16I)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_INT:
|
||||
if (internalFormat != GL_RGB32UI)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_INT:
|
||||
if (internalFormat != GL_RGB32I)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_RG:
|
||||
switch (type) {
|
||||
case GL_UNSIGNED_BYTE:
|
||||
if (internalFormat != GL_RG8)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_BYTE:
|
||||
if (internalFormat != GL_RG8_SNORM)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_HALF_FLOAT:
|
||||
if (internalFormat != GL_RG16F)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_FLOAT:
|
||||
switch (internalFormat) {
|
||||
case GL_RG16F:
|
||||
case GL_RG32F:
|
||||
break;
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_RG_INTEGER:
|
||||
switch (type) {
|
||||
case GL_UNSIGNED_BYTE:
|
||||
if (internalFormat != GL_RG8UI)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_BYTE:
|
||||
if (internalFormat != GL_RG8I)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_SHORT:
|
||||
if (internalFormat != GL_RG16UI)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_SHORT:
|
||||
if (internalFormat != GL_RG16I)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_INT:
|
||||
if (internalFormat != GL_RG32UI)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_INT:
|
||||
if (internalFormat != GL_RG32I)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_RED:
|
||||
switch (type) {
|
||||
case GL_UNSIGNED_BYTE:
|
||||
if (internalFormat != GL_R8)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_BYTE:
|
||||
if (internalFormat != GL_R8_SNORM)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_HALF_FLOAT:
|
||||
if (internalFormat != GL_R16F)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_FLOAT:
|
||||
switch (internalFormat) {
|
||||
case GL_R16F:
|
||||
case GL_R32F:
|
||||
break;
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_RED_INTEGER:
|
||||
switch (type) {
|
||||
case GL_UNSIGNED_BYTE:
|
||||
if (internalFormat != GL_R8UI)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_BYTE:
|
||||
if (internalFormat != GL_R8I)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_SHORT:
|
||||
if (internalFormat != GL_R16UI)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_SHORT:
|
||||
if (internalFormat != GL_R16I)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_INT:
|
||||
if (internalFormat != GL_R32UI)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_INT:
|
||||
if (internalFormat != GL_R32I)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_DEPTH_COMPONENT:
|
||||
if (dimensions != 2) {
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
switch (type) {
|
||||
case GL_UNSIGNED_SHORT:
|
||||
if (internalFormat != GL_DEPTH_COMPONENT16)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_UNSIGNED_INT:
|
||||
switch (internalFormat) {
|
||||
case GL_DEPTH_COMPONENT16:
|
||||
case GL_DEPTH_COMPONENT24:
|
||||
break;
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_FLOAT:
|
||||
if (internalFormat != GL_DEPTH_COMPONENT32F)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_DEPTH_STENCIL:
|
||||
if (dimensions != 2) {
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
switch (type) {
|
||||
case GL_UNSIGNED_INT_24_8:
|
||||
if (internalFormat != GL_DEPTH24_STENCIL8)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
case GL_FLOAT_32_UNSIGNED_INT_24_8_REV:
|
||||
if (internalFormat != GL_DEPTH32F_STENCIL8)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
|
||||
default:
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
break;
|
||||
|
||||
case GL_ALPHA:
|
||||
case GL_LUMINANCE:
|
||||
case GL_LUMINANCE_ALPHA:
|
||||
if (type != GL_UNSIGNED_BYTE || format != internalFormat)
|
||||
return GL_INVALID_OPERATION;
|
||||
break;
|
||||
}
|
||||
|
||||
return type_valid ? GL_NO_ERROR : GL_INVALID_OPERATION;
|
||||
}
|
||||
|
@@ -61,6 +61,12 @@ _mesa_is_type_unsigned(GLenum type);
|
||||
extern GLboolean
|
||||
_mesa_is_enum_format_integer(GLenum format);
|
||||
|
||||
extern GLboolean
|
||||
_mesa_is_enum_format_unsigned_int(GLenum format);
|
||||
|
||||
extern GLboolean
|
||||
_mesa_is_enum_format_signed_int(GLenum format);
|
||||
|
||||
extern GLboolean
|
||||
_mesa_is_enum_format_or_type_integer(GLenum format, GLenum type);
|
||||
|
||||
@@ -94,6 +100,9 @@ _mesa_base_format_to_integer_format(GLenum format);
|
||||
extern GLboolean
|
||||
_mesa_base_format_has_channel(GLenum base_format, GLenum pname);
|
||||
|
||||
extern GLint
|
||||
_mesa_base_format_component_count(GLenum base_format);
|
||||
|
||||
extern GLenum
|
||||
_mesa_generic_compressed_format_to_uncompressed_format(GLenum format);
|
||||
|
||||
@@ -111,6 +120,11 @@ extern GLenum
|
||||
_mesa_es_error_check_format_and_type(GLenum format, GLenum type,
|
||||
unsigned dimensions);
|
||||
|
||||
extern GLenum
|
||||
_mesa_es3_error_check_format_and_type(GLenum format, GLenum type,
|
||||
GLenum internalFormat,
|
||||
unsigned dimensions);
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
|
@@ -1634,9 +1634,20 @@ struct gl_array_attrib
|
||||
GLuint LockFirst; /**< GL_EXT_compiled_vertex_array */
|
||||
GLuint LockCount; /**< GL_EXT_compiled_vertex_array */
|
||||
|
||||
/** GL 3.1 (slightly different from GL_NV_primitive_restart) */
|
||||
/**
|
||||
* \name Primitive restart controls
|
||||
*
|
||||
* Primitive restart is enabled if either \c PrimitiveRestart or
|
||||
* \c PrimitiveRestart is set. If \c PrimitiveRestart is set, then
|
||||
* \c RestartIndex is used as the cut vertex. Otherwise ~0 is used.
|
||||
*/
|
||||
/*@{*/
|
||||
GLboolean PrimitiveRestart;
|
||||
GLboolean PrimitiveRestartFixedIndex;
|
||||
GLboolean _PrimitiveRestart;
|
||||
GLuint RestartIndex;
|
||||
GLuint _RestartIndex;
|
||||
/*@}*/
|
||||
|
||||
/* GL_ARB_vertex_buffer_object */
|
||||
struct gl_buffer_object *ArrayBufferObj;
|
||||
@@ -2962,6 +2973,17 @@ struct gl_constants
|
||||
* Drivers that support transform feedback must set this value to GL_FALSE.
|
||||
*/
|
||||
GLboolean DisableVaryingPacking;
|
||||
|
||||
/*
|
||||
* Maximum value supported for an index in DrawElements and friends.
|
||||
*
|
||||
* This must be at least (1ull<<24)-1. The default value is
|
||||
* (1ull<<32)-1.
|
||||
*
|
||||
* \since ES 3.0 or GL_ARB_ES3_compatibility
|
||||
* \sa _mesa_init_constants
|
||||
*/
|
||||
GLuint64 MaxElementIndex;
|
||||
};
|
||||
|
||||
|
||||
@@ -3358,6 +3380,7 @@ typedef enum
|
||||
API_OPENGLES,
|
||||
API_OPENGLES2,
|
||||
API_OPENGL_CORE,
|
||||
API_OPENGL_LAST = API_OPENGL_CORE,
|
||||
} gl_api;
|
||||
|
||||
/**
|
||||
|
@@ -885,7 +885,7 @@ _mesa_pack_rgba_span_from_uints(struct gl_context *ctx, GLuint n, GLuint rgba[][
|
||||
#undef FN_NAME
|
||||
|
||||
#define DST_TYPE GLubyte
|
||||
#define SRC_CONVERT(x) MAX2(x, 0)
|
||||
#define SRC_CONVERT(x) CLAMP(x, 0, 0x7f)
|
||||
#define FN_NAME pack_ubyte_from_int_rgba
|
||||
#include "pack_tmp.h"
|
||||
#undef DST_TYPE
|
||||
@@ -3641,7 +3641,11 @@ extract_float_rgba(GLuint n, GLfloat rgba[][4],
|
||||
rgba[i][rDst] = ((p ) & 0x3ff) * rs;
|
||||
rgba[i][gDst] = ((p >> 10) & 0x3ff) * gs;
|
||||
rgba[i][bDst] = ((p >> 20) & 0x3ff) * bs;
|
||||
rgba[i][aDst] = ((p >> 30) ) * as;
|
||||
if (aSrc < 0) {
|
||||
rgba[i][aDst] = 1.0F;
|
||||
} else {
|
||||
rgba[i][aDst] = (p >> 30) * as;
|
||||
}
|
||||
}
|
||||
}
|
||||
else {
|
||||
@@ -3652,7 +3656,11 @@ extract_float_rgba(GLuint n, GLfloat rgba[][4],
|
||||
rgba[i][rDst] = ((p ) & 0x3ff) * rs;
|
||||
rgba[i][gDst] = ((p >> 10) & 0x3ff) * gs;
|
||||
rgba[i][bDst] = ((p >> 20) & 0x3ff) * bs;
|
||||
rgba[i][aDst] = ((p >> 30) ) * as;
|
||||
if (aSrc < 0) {
|
||||
rgba[i][aDst] = 1.0F;
|
||||
} else {
|
||||
rgba[i][aDst] = (p >> 30) * as;
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
@@ -147,6 +147,12 @@ get_query_binding_point(struct gl_context *ctx, GLenum target)
|
||||
return &ctx->Query.CurrentOcclusionObject;
|
||||
else
|
||||
return NULL;
|
||||
case GL_ANY_SAMPLES_PASSED_CONSERVATIVE:
|
||||
if (ctx->Extensions.ARB_ES3_compatibility
|
||||
|| (ctx->API == API_OPENGLES2 && ctx->Version >= 30))
|
||||
return &ctx->Query.CurrentOcclusionObject;
|
||||
else
|
||||
return NULL;
|
||||
case GL_TIME_ELAPSED_EXT:
|
||||
if (ctx->Extensions.EXT_timer_query)
|
||||
return &ctx->Query.CurrentTimerObject;
|
||||
@@ -577,7 +583,8 @@ _mesa_GetQueryObjectiv(GLuint id, GLenum pname, GLint *params)
|
||||
if (!q->Ready)
|
||||
ctx->Driver.WaitQuery(ctx, q);
|
||||
/* if result is too large for returned type, clamp to max value */
|
||||
if (q->Target == GL_ANY_SAMPLES_PASSED) {
|
||||
if (q->Target == GL_ANY_SAMPLES_PASSED
|
||||
|| q->Target == GL_ANY_SAMPLES_PASSED_CONSERVATIVE) {
|
||||
if (q->Result)
|
||||
*params = GL_TRUE;
|
||||
else
|
||||
@@ -628,7 +635,8 @@ _mesa_GetQueryObjectuiv(GLuint id, GLenum pname, GLuint *params)
|
||||
if (!q->Ready)
|
||||
ctx->Driver.WaitQuery(ctx, q);
|
||||
/* if result is too large for returned type, clamp to max value */
|
||||
if (q->Target == GL_ANY_SAMPLES_PASSED) {
|
||||
if (q->Target == GL_ANY_SAMPLES_PASSED
|
||||
|| q->Target == GL_ANY_SAMPLES_PASSED_CONSERVATIVE) {
|
||||
if (q->Result)
|
||||
*params = GL_TRUE;
|
||||
else
|
||||
|
@@ -325,6 +325,11 @@ slow_read_rgba_pixels( struct gl_context *ctx,
|
||||
GLboolean dst_is_integer = _mesa_is_enum_format_integer(format);
|
||||
GLboolean dst_is_uint = _mesa_is_format_unsigned(rbFormat);
|
||||
|
||||
if (_mesa_is_format_integer_color(rbFormat) && format == GL_RGBA && type == GL_UNSIGNED_BYTE) {
|
||||
format = GL_RGBA_INTEGER;
|
||||
dst_is_integer = GL_TRUE;
|
||||
}
|
||||
|
||||
dstStride = _mesa_image_row_stride(packing, width, format, type);
|
||||
dst = (GLubyte *) _mesa_image_address2d(packing, pixels, width, height,
|
||||
format, type, 0, 0);
|
||||
@@ -674,12 +679,57 @@ _mesa_readpixels(struct gl_context *ctx,
|
||||
}
|
||||
|
||||
|
||||
static GLenum
|
||||
read_pixels_es3_error_check(GLenum format, GLenum type,
|
||||
GLenum internalFormat)
|
||||
{
|
||||
GLboolean is_unsigned_int = GL_FALSE;
|
||||
GLboolean is_signed_int = GL_FALSE;
|
||||
|
||||
if (!_mesa_is_color_format(internalFormat)) {
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
|
||||
is_unsigned_int = _mesa_is_enum_format_unsigned_int(internalFormat);
|
||||
if (!is_unsigned_int) {
|
||||
is_signed_int = _mesa_is_enum_format_signed_int(internalFormat);
|
||||
}
|
||||
|
||||
switch (format) {
|
||||
case GL_RGBA:
|
||||
if (type == GL_UNSIGNED_BYTE)
|
||||
return GL_NO_ERROR;
|
||||
if (internalFormat == GL_RGB10_A2 &&
|
||||
type == GL_UNSIGNED_INT_2_10_10_10_REV)
|
||||
return GL_NO_ERROR;
|
||||
if (internalFormat == GL_RGB10_A2UI && type == GL_UNSIGNED_BYTE)
|
||||
return GL_NO_ERROR;
|
||||
break;
|
||||
case GL_BGRA:
|
||||
/* GL_EXT_read_format_bgra */
|
||||
if (type == GL_UNSIGNED_BYTE ||
|
||||
type == GL_UNSIGNED_SHORT_4_4_4_4_REV ||
|
||||
type == GL_UNSIGNED_SHORT_1_5_5_5_REV)
|
||||
return GL_NO_ERROR;
|
||||
break;
|
||||
case GL_RGBA_INTEGER:
|
||||
if ((is_signed_int && type == GL_INT) ||
|
||||
(is_unsigned_int && type == GL_UNSIGNED_INT))
|
||||
return GL_NO_ERROR;
|
||||
break;
|
||||
}
|
||||
|
||||
return GL_INVALID_OPERATION;
|
||||
}
|
||||
|
||||
|
||||
void GLAPIENTRY
|
||||
_mesa_ReadnPixelsARB( GLint x, GLint y, GLsizei width, GLsizei height,
|
||||
GLenum format, GLenum type, GLsizei bufSize,
|
||||
GLvoid *pixels )
|
||||
{
|
||||
GLenum err;
|
||||
GLenum err = GL_NO_ERROR;
|
||||
struct gl_renderbuffer *rb;
|
||||
|
||||
GET_CURRENT_CONTEXT(ctx);
|
||||
ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx);
|
||||
@@ -699,6 +749,22 @@ _mesa_ReadnPixelsARB( GLint x, GLint y, GLsizei width, GLsizei height,
|
||||
return;
|
||||
}
|
||||
|
||||
if (ctx->NewState)
|
||||
_mesa_update_state(ctx);
|
||||
|
||||
if (ctx->ReadBuffer->_Status != GL_FRAMEBUFFER_COMPLETE_EXT) {
|
||||
_mesa_error(ctx, GL_INVALID_FRAMEBUFFER_OPERATION_EXT,
|
||||
"glReadPixels(incomplete framebuffer)" );
|
||||
return;
|
||||
}
|
||||
|
||||
rb = _mesa_get_read_renderbuffer(ctx, format);
|
||||
if (rb == NULL) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION,
|
||||
"glReadPixels(read buffer)");
|
||||
return;
|
||||
}
|
||||
|
||||
/* OpenGL ES 1.x and OpenGL ES 2.0 impose additional restrictions on the
|
||||
* combinations of format and type that can be used.
|
||||
*
|
||||
@@ -707,16 +773,22 @@ _mesa_ReadnPixelsARB( GLint x, GLint y, GLsizei width, GLsizei height,
|
||||
* preferred combination. This code doesn't know what that preferred
|
||||
* combination is, and Mesa can handle anything valid. Just work instead.
|
||||
*/
|
||||
if (_mesa_is_gles(ctx) && ctx->Version < 30) {
|
||||
if (_mesa_is_gles(ctx)) {
|
||||
if (ctx->Version < 30) {
|
||||
err = _mesa_es_error_check_format_and_type(format, type, 2);
|
||||
if (err == GL_NO_ERROR) {
|
||||
if (type == GL_FLOAT || type == GL_HALF_FLOAT_OES) {
|
||||
err = GL_INVALID_OPERATION;
|
||||
} else if (format == GL_DEPTH_COMPONENT
|
||||
|| format == GL_DEPTH_STENCIL) {
|
||||
err = GL_INVALID_ENUM;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
err = read_pixels_es3_error_check(format, type, rb->InternalFormat);
|
||||
}
|
||||
|
||||
if (err == GL_NO_ERROR && (format == GL_DEPTH_COMPONENT
|
||||
|| format == GL_DEPTH_STENCIL)) {
|
||||
err = GL_INVALID_ENUM;
|
||||
}
|
||||
|
||||
if (err != GL_NO_ERROR) {
|
||||
_mesa_error(ctx, err, "glReadPixels(invalid format %s and/or type %s)",
|
||||
@@ -726,9 +798,6 @@ _mesa_ReadnPixelsARB( GLint x, GLint y, GLsizei width, GLsizei height,
|
||||
}
|
||||
}
|
||||
|
||||
if (ctx->NewState)
|
||||
_mesa_update_state(ctx);
|
||||
|
||||
err = _mesa_error_check_format_and_type(ctx, format, type);
|
||||
if (err != GL_NO_ERROR) {
|
||||
_mesa_error(ctx, err, "glReadPixels(invalid format %s and/or type %s)",
|
||||
@@ -737,12 +806,6 @@ _mesa_ReadnPixelsARB( GLint x, GLint y, GLsizei width, GLsizei height,
|
||||
return;
|
||||
}
|
||||
|
||||
if (ctx->ReadBuffer->_Status != GL_FRAMEBUFFER_COMPLETE_EXT) {
|
||||
_mesa_error(ctx, GL_INVALID_FRAMEBUFFER_OPERATION_EXT,
|
||||
"glReadPixels(incomplete framebuffer)" );
|
||||
return;
|
||||
}
|
||||
|
||||
if (_mesa_is_user_fbo(ctx->ReadBuffer) &&
|
||||
ctx->ReadBuffer->Visual.samples > 0) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION, "glReadPixels(multisample FBO)");
|
||||
@@ -754,10 +817,17 @@ _mesa_ReadnPixelsARB( GLint x, GLint y, GLsizei width, GLsizei height,
|
||||
return;
|
||||
}
|
||||
|
||||
if (ctx->Extensions.EXT_texture_integer && _mesa_is_color_format(format)) {
|
||||
if (_mesa_get_color_read_format(ctx) == format &&
|
||||
_mesa_get_color_read_type(ctx) == type) {
|
||||
/* IMPLEMENTATION_COLOR_READ_FORMAT and
|
||||
* IMPLEMENTATION_COLOR_READ_TYPE are being used. Therefore
|
||||
* we don't need to check integer vs. non-integer below.
|
||||
*/
|
||||
} else {
|
||||
/* Check that the destination format and source buffer are both
|
||||
* integer-valued or both non-integer-valued.
|
||||
*/
|
||||
if (ctx->Extensions.EXT_texture_integer && _mesa_is_color_format(format)) {
|
||||
const struct gl_renderbuffer *rb = ctx->ReadBuffer->_ColorReadBuffer;
|
||||
const GLboolean srcInteger = _mesa_is_format_integer_color(rb->Format);
|
||||
const GLboolean dstInteger = _mesa_is_enum_format_integer(format);
|
||||
@@ -767,6 +837,7 @@ _mesa_ReadnPixelsARB( GLint x, GLint y, GLsizei width, GLsizei height,
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (width == 0 || height == 0)
|
||||
return; /* nothing to do */
|
||||
|
@@ -465,6 +465,7 @@ _mesa_update_state_locked( struct gl_context *ctx )
|
||||
if (MESA_VERBOSE & VERBOSE_STATE)
|
||||
_mesa_print_state("_mesa_update_state", new_state);
|
||||
|
||||
if (ctx->API == API_OPENGL_COMPAT || ctx->API == API_OPENGLES) {
|
||||
/* Determine which state flags effect vertex/fragment program state */
|
||||
if (ctx->FragmentProgram._MaintainTexEnvProgram) {
|
||||
prog_flags |= (_NEW_BUFFERS | _NEW_TEXTURE | _NEW_FOG |
|
||||
@@ -478,6 +479,7 @@ _mesa_update_state_locked( struct gl_context *ctx )
|
||||
_NEW_FOG | _NEW_LIGHT |
|
||||
_MESA_NEW_NEED_EYE_COORDS);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Now update derived state info
|
||||
@@ -486,8 +488,10 @@ _mesa_update_state_locked( struct gl_context *ctx )
|
||||
if (new_state & prog_flags)
|
||||
update_program_enables( ctx );
|
||||
|
||||
if (ctx->API == API_OPENGL_COMPAT || ctx->API == API_OPENGLES) {
|
||||
if (new_state & (_NEW_MODELVIEW|_NEW_PROJECTION))
|
||||
_mesa_update_modelview_project( ctx, new_state );
|
||||
}
|
||||
|
||||
if (new_state & (_NEW_PROGRAM|_NEW_TEXTURE|_NEW_TEXTURE_MATRIX))
|
||||
_mesa_update_texture( ctx, new_state );
|
||||
@@ -501,8 +505,10 @@ _mesa_update_state_locked( struct gl_context *ctx )
|
||||
if (new_state & _NEW_POLYGON)
|
||||
update_polygon( ctx );
|
||||
|
||||
if (ctx->API == API_OPENGL_COMPAT || ctx->API == API_OPENGLES) {
|
||||
if (new_state & _NEW_LIGHT)
|
||||
_mesa_update_lighting( ctx );
|
||||
}
|
||||
|
||||
if (new_state & (_NEW_LIGHT | _NEW_PROGRAM))
|
||||
update_twoside( ctx );
|
||||
@@ -516,8 +522,10 @@ _mesa_update_state_locked( struct gl_context *ctx )
|
||||
if (new_state & _NEW_PIXEL)
|
||||
_mesa_update_pixel( ctx, new_state );
|
||||
|
||||
if (ctx->API == API_OPENGL_COMPAT || ctx->API == API_OPENGLES) {
|
||||
if (new_state & _MESA_NEW_SEPARATE_SPECULAR)
|
||||
update_separate_specular( ctx );
|
||||
}
|
||||
|
||||
if (new_state & (_NEW_BUFFERS | _NEW_VIEWPORT))
|
||||
update_viewport_matrix(ctx);
|
||||
|
@@ -1310,8 +1310,7 @@ const struct function gles3_functions_possible[] = {
|
||||
// We check for the aliased -OES version in GLES 2
|
||||
// { "glGetBufferPointerv", 30, -1 },
|
||||
{ "glGetFragDataLocation", 30, -1 },
|
||||
/// XXX: Missing implementation of glGetInteger64i_v
|
||||
// { "glGetInteger64i_v", 30, -1 },
|
||||
{ "glGetInteger64i_v", 30, -1 },
|
||||
{ "glGetInteger64v", 30, -1 },
|
||||
{ "glGetIntegeri_v", 30, -1 },
|
||||
// XXX: Missing implementation of ARB_internalformat_query
|
||||
|
@@ -807,6 +807,7 @@ const struct enum_info everything[] = {
|
||||
{ 0x8256, "GL_RESET_NOTIFICATION_STRATEGY_ARB" },
|
||||
{ 0x8257, "GL_PROGRAM_BINARY_RETRIEVABLE_HINT" },
|
||||
{ 0x8261, "GL_NO_RESET_NOTIFICATION_ARB" },
|
||||
{ 0x82DF, "GL_TEXTURE_IMMUTABLE_LEVELS" },
|
||||
{ 0x8362, "GL_UNSIGNED_BYTE_2_3_3_REV" },
|
||||
{ 0x8363, "GL_UNSIGNED_SHORT_5_6_5" },
|
||||
{ 0x8364, "GL_UNSIGNED_SHORT_5_6_5_REV" },
|
||||
@@ -1662,6 +1663,9 @@ const struct enum_info everything[] = {
|
||||
{ 0x8D55, "GL_RENDERBUFFER_STENCIL_SIZE" },
|
||||
{ 0x8D56, "GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE" },
|
||||
{ 0x8D57, "GL_MAX_SAMPLES" },
|
||||
{ 0x8D69, "GL_PRIMITIVE_RESTART_FIXED_INDEX" },
|
||||
{ 0x8D6A, "GL_ANY_SAMPLES_PASSED_CONSERVATIVE" },
|
||||
{ 0x8D6B, "GL_MAX_ELEMENT_INDEX" },
|
||||
{ 0x8D70, "GL_RGBA32UI" },
|
||||
{ 0x8D71, "GL_RGB32UI" },
|
||||
{ 0x8D72, "GL_ALPHA32UI_EXT" },
|
||||
@@ -1828,6 +1832,16 @@ const struct enum_info everything[] = {
|
||||
{ 0x9146, "GL_DEBUG_SEVERITY_HIGH_ARB" },
|
||||
{ 0x9147, "GL_DEBUG_SEVERITY_MEDIUM_ARB" },
|
||||
{ 0x9148, "GL_DEBUG_SEVERITY_LOW_ARB" },
|
||||
{ 0x9274, "GL_COMPRESSED_RGB8_ETC2" },
|
||||
{ 0x9275, "GL_COMPRESSED_SRGB8_ETC2" },
|
||||
{ 0x9276, "GL_COMPRESSED_RGB8_PUNCHTHROUGH_ALPHA1_ETC2" },
|
||||
{ 0x9277, "GL_COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2" },
|
||||
{ 0x9278, "GL_COMPRESSED_RGBA8_ETC2_EAC" },
|
||||
{ 0x9279, "GL_COMPRESSED_SRGB8_ALPHA8_ETC2_EAC" },
|
||||
{ 0x9270, "GL_COMPRESSED_R11_EAC" },
|
||||
{ 0x9271, "GL_COMPRESSED_SIGNED_R11_EAC" },
|
||||
{ 0x9272, "GL_COMPRESSED_RG11_EAC" },
|
||||
{ 0x9273, "GL_COMPRESSED_SIGNED_RG11_EAC" },
|
||||
{ 0x19262, "GL_RASTER_POSITION_UNCLIPPED_IBM" },
|
||||
{ 0, NULL }
|
||||
};
|
||||
|
@@ -75,6 +75,8 @@ _mesa_choose_tex_format(struct gl_context *ctx, GLenum target,
|
||||
RETURN_IF_SUPPORTED(MESA_FORMAT_ARGB4444);
|
||||
} else if (type == GL_UNSIGNED_SHORT_1_5_5_5_REV) {
|
||||
RETURN_IF_SUPPORTED(MESA_FORMAT_ARGB1555);
|
||||
} else if (type == GL_UNSIGNED_INT_2_10_10_10_REV) {
|
||||
RETURN_IF_SUPPORTED(MESA_FORMAT_ARGB2101010);
|
||||
}
|
||||
RETURN_IF_SUPPORTED(MESA_FORMAT_RGBA8888);
|
||||
RETURN_IF_SUPPORTED(MESA_FORMAT_ARGB8888);
|
||||
@@ -111,6 +113,10 @@ _mesa_choose_tex_format(struct gl_context *ctx, GLenum target,
|
||||
/* shallow RGB formats */
|
||||
case 3:
|
||||
case GL_RGB:
|
||||
if (type == GL_UNSIGNED_INT_2_10_10_10_REV) {
|
||||
RETURN_IF_SUPPORTED(MESA_FORMAT_ARGB2101010);
|
||||
}
|
||||
/* fallthrough */
|
||||
case GL_RGB8:
|
||||
RETURN_IF_SUPPORTED(MESA_FORMAT_RGB888);
|
||||
RETURN_IF_SUPPORTED(MESA_FORMAT_XRGB8888);
|
||||
|
@@ -1893,7 +1893,12 @@ texture_error_check( struct gl_context *ctx,
|
||||
* requires GL_OES_texture_float) are filtered elsewhere.
|
||||
*/
|
||||
|
||||
if (_mesa_is_gles(ctx) && !_mesa_is_gles3(ctx)) {
|
||||
if (_mesa_is_gles(ctx)) {
|
||||
if (_mesa_is_gles3(ctx)) {
|
||||
err = _mesa_es3_error_check_format_and_type(format, type,
|
||||
internalFormat,
|
||||
dimensions);
|
||||
} else {
|
||||
if (format != internalFormat) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION,
|
||||
"glTexImage%dD(format = %s, internalFormat = %s)",
|
||||
@@ -1904,12 +1909,14 @@ texture_error_check( struct gl_context *ctx,
|
||||
}
|
||||
|
||||
err = _mesa_es_error_check_format_and_type(format, type, dimensions);
|
||||
}
|
||||
if (err != GL_NO_ERROR) {
|
||||
_mesa_error(ctx, err,
|
||||
"glTexImage%dD(format = %s, type = %s)",
|
||||
"glTexImage%dD(format = %s, type = %s, internalFormat = %s)",
|
||||
dimensions,
|
||||
_mesa_lookup_enum_by_nr(format),
|
||||
_mesa_lookup_enum_by_nr(type));
|
||||
_mesa_lookup_enum_by_nr(type),
|
||||
_mesa_lookup_enum_by_nr(internalFormat));
|
||||
return GL_TRUE;
|
||||
}
|
||||
}
|
||||
@@ -1947,8 +1954,9 @@ texture_error_check( struct gl_context *ctx,
|
||||
err = _mesa_error_check_format_and_type(ctx, format, type);
|
||||
if (err != GL_NO_ERROR) {
|
||||
_mesa_error(ctx, err,
|
||||
"glTexImage%dD(incompatible format 0x%x, type 0x%x)",
|
||||
dimensions, format, type);
|
||||
"glTexImage%dD(incompatible format = %s, type = %s)",
|
||||
dimensions, _mesa_lookup_enum_by_nr(format),
|
||||
_mesa_lookup_enum_by_nr(type));
|
||||
return GL_TRUE;
|
||||
}
|
||||
|
||||
@@ -1960,8 +1968,9 @@ texture_error_check( struct gl_context *ctx,
|
||||
(_mesa_is_depthstencil_format(internalFormat) != _mesa_is_depthstencil_format(format)) ||
|
||||
(_mesa_is_dudv_format(internalFormat) != _mesa_is_dudv_format(format))) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION,
|
||||
"glTexImage%dD(incompatible internalFormat 0x%x, format 0x%x)",
|
||||
dimensions, internalFormat, format);
|
||||
"glTexImage%dD(incompatible internalFormat = %s, format = %s)",
|
||||
dimensions, _mesa_lookup_enum_by_nr(internalFormat),
|
||||
_mesa_lookup_enum_by_nr(format));
|
||||
return GL_TRUE;
|
||||
}
|
||||
|
||||
@@ -2263,8 +2272,9 @@ texsubimage_error_check(struct gl_context *ctx, GLuint dimensions,
|
||||
err = _mesa_error_check_format_and_type(ctx, format, type);
|
||||
if (err != GL_NO_ERROR) {
|
||||
_mesa_error(ctx, err,
|
||||
"glTexSubImage%dD(incompatible format 0x%x, type 0x%x)",
|
||||
dimensions, format, type);
|
||||
"glTexSubImage%dD(incompatible format = %s, type = %s)",
|
||||
dimensions, _mesa_lookup_enum_by_nr(format),
|
||||
_mesa_lookup_enum_by_nr(type));
|
||||
return GL_TRUE;
|
||||
}
|
||||
|
||||
@@ -2313,6 +2323,29 @@ texsubimage_error_check(struct gl_context *ctx, GLuint dimensions,
|
||||
}
|
||||
|
||||
|
||||
static bool
|
||||
is_srgb_format(GLenum internalFormat)
|
||||
{
|
||||
switch (internalFormat) {
|
||||
case GL_SRGB_EXT:
|
||||
case GL_SRGB8_EXT:
|
||||
case GL_COMPRESSED_SRGB_EXT:
|
||||
case GL_COMPRESSED_SRGB_S3TC_DXT1_EXT:
|
||||
case GL_SRGB_ALPHA_EXT:
|
||||
case GL_SRGB8_ALPHA8_EXT:
|
||||
case GL_COMPRESSED_SRGB_ALPHA_EXT:
|
||||
case GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT1_EXT:
|
||||
case GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT3_EXT:
|
||||
case GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT5_EXT:
|
||||
case GL_COMPRESSED_SRGB8_ETC2:
|
||||
case GL_COMPRESSED_SRGB8_ALPHA8_ETC2_EAC:
|
||||
case GL_COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2:
|
||||
return true;
|
||||
default:
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Test glCopyTexImage[12]D() parameters for errors.
|
||||
*
|
||||
@@ -2337,6 +2370,9 @@ copytexture_error_check( struct gl_context *ctx, GLuint dimensions,
|
||||
GLint width, GLint height, GLint border )
|
||||
{
|
||||
GLint baseFormat;
|
||||
GLint rb_base_format;
|
||||
struct gl_renderbuffer *rb;
|
||||
GLenum rb_internal_format;
|
||||
|
||||
/* check target */
|
||||
if (!legal_texsubimage_target(ctx, dimensions, target)) {
|
||||
@@ -2381,30 +2417,61 @@ copytexture_error_check( struct gl_context *ctx, GLuint dimensions,
|
||||
return GL_TRUE;
|
||||
}
|
||||
|
||||
/* OpenGL ES 1.x and OpenGL ES 2.0 impose additional restrictions on the
|
||||
* internalFormat.
|
||||
*/
|
||||
if (_mesa_is_gles(ctx) && !_mesa_is_gles3(ctx)) {
|
||||
switch (internalFormat) {
|
||||
case GL_ALPHA:
|
||||
case GL_RGB:
|
||||
case GL_RGBA:
|
||||
case GL_LUMINANCE:
|
||||
case GL_LUMINANCE_ALPHA:
|
||||
break;
|
||||
default:
|
||||
rb = _mesa_get_read_renderbuffer(ctx, internalFormat);
|
||||
if (rb == NULL) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION,
|
||||
"glCopyTexImage%dD(read buffer)", dimensions);
|
||||
return GL_TRUE;
|
||||
}
|
||||
|
||||
rb_internal_format = rb->InternalFormat;
|
||||
baseFormat = _mesa_base_tex_format(ctx, internalFormat);
|
||||
rb_base_format = _mesa_base_tex_format(ctx, rb->InternalFormat);
|
||||
if (baseFormat < 0) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION,
|
||||
"glCopyTexImage%dD(internalFormat)", dimensions);
|
||||
return GL_TRUE;
|
||||
}
|
||||
|
||||
if (_mesa_is_color_format(internalFormat)) {
|
||||
if (rb_base_format < 0) {
|
||||
_mesa_error(ctx, GL_INVALID_VALUE,
|
||||
"glCopyTexImage%dD(internalFormat)", dimensions);
|
||||
return GL_TRUE;
|
||||
}
|
||||
}
|
||||
|
||||
baseFormat = _mesa_base_tex_format(ctx, internalFormat);
|
||||
if (baseFormat < 0) {
|
||||
_mesa_error(ctx, GL_INVALID_VALUE,
|
||||
if (_mesa_is_gles(ctx)) {
|
||||
bool valid = true;
|
||||
if (_mesa_base_format_component_count(baseFormat) >
|
||||
_mesa_base_format_component_count(rb_base_format)) {
|
||||
valid = false;
|
||||
}
|
||||
if (baseFormat == GL_DEPTH_COMPONENT ||
|
||||
baseFormat == GL_DEPTH_STENCIL ||
|
||||
rb_base_format == GL_DEPTH_COMPONENT ||
|
||||
rb_base_format == GL_DEPTH_STENCIL ||
|
||||
((baseFormat == GL_LUMINANCE_ALPHA ||
|
||||
baseFormat == GL_ALPHA) &&
|
||||
rb_base_format != GL_RGBA) ||
|
||||
internalFormat == GL_RGB9_E5) {
|
||||
valid = false;
|
||||
}
|
||||
if (internalFormat == GL_RGB9_E5) {
|
||||
valid = false;
|
||||
}
|
||||
if (!valid) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION,
|
||||
"glCopyTexImage%dD(internalFormat)", dimensions);
|
||||
return GL_TRUE;
|
||||
}
|
||||
}
|
||||
|
||||
if (is_srgb_format(internalFormat) != is_srgb_format(rb_internal_format)) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION,
|
||||
"glCopyTexImage%dD(srgb usage mismatch)", dimensions);
|
||||
return GL_TRUE;
|
||||
}
|
||||
|
||||
if (!_mesa_source_buffer_exists(ctx, baseFormat)) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION,
|
||||
@@ -2420,13 +2487,20 @@ copytexture_error_check( struct gl_context *ctx, GLuint dimensions,
|
||||
* integer format and the read color buffer is an integer format."
|
||||
*/
|
||||
if (_mesa_is_color_format(internalFormat)) {
|
||||
struct gl_renderbuffer *rb = ctx->ReadBuffer->_ColorReadBuffer;
|
||||
|
||||
if (_mesa_is_enum_format_integer(rb->InternalFormat) !=
|
||||
_mesa_is_enum_format_integer(internalFormat)) {
|
||||
bool is_int = _mesa_is_enum_format_integer(internalFormat);
|
||||
bool is_rbint = _mesa_is_enum_format_integer(rb_internal_format);
|
||||
if (is_int || is_rbint) {
|
||||
if (is_int != is_rbint) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION,
|
||||
"glCopyTexImage%dD(integer vs non-integer)", dimensions);
|
||||
return GL_TRUE;
|
||||
} else if (_mesa_is_gles(ctx) &&
|
||||
_mesa_is_enum_format_unsigned_int(internalFormat) !=
|
||||
_mesa_is_enum_format_unsigned_int(rb_internal_format)) {
|
||||
_mesa_error(ctx, GL_INVALID_OPERATION,
|
||||
"glCopyTexImage%dD(signed vs unsigned integer)", dimensions);
|
||||
return GL_TRUE;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@@ -1714,18 +1714,23 @@ _mesa_texstore_argb2101010(TEXSTORE_PARAMS)
|
||||
srcPacking,
|
||||
ctx->_ImageTransferState);
|
||||
const GLfloat *src = tempImage;
|
||||
GLushort aMask = 0;
|
||||
GLint img, row, col;
|
||||
if (!tempImage)
|
||||
return GL_FALSE;
|
||||
if (srcFormat == GL_RGB) {
|
||||
aMask = 0xffff;
|
||||
}
|
||||
for (img = 0; img < srcDepth; img++) {
|
||||
GLubyte *dstRow = dstSlices[img];
|
||||
if (baseInternalFormat == GL_RGBA) {
|
||||
if (baseInternalFormat == GL_RGBA || baseInternalFormat == GL_RGB) {
|
||||
for (row = 0; row < srcHeight; row++) {
|
||||
GLuint *dstUI = (GLuint *) dstRow;
|
||||
for (col = 0; col < srcWidth; col++) {
|
||||
GLushort a,r,g,b;
|
||||
|
||||
UNCLAMPED_FLOAT_TO_USHORT(a, src[ACOMP]);
|
||||
a = a | aMask;
|
||||
UNCLAMPED_FLOAT_TO_USHORT(r, src[RCOMP]);
|
||||
UNCLAMPED_FLOAT_TO_USHORT(g, src[GCOMP]);
|
||||
UNCLAMPED_FLOAT_TO_USHORT(b, src[BCOMP]);
|
||||
@@ -1734,20 +1739,6 @@ _mesa_texstore_argb2101010(TEXSTORE_PARAMS)
|
||||
}
|
||||
dstRow += dstRowStride;
|
||||
}
|
||||
} else if (baseInternalFormat == GL_RGB) {
|
||||
for (row = 0; row < srcHeight; row++) {
|
||||
GLuint *dstUI = (GLuint *) dstRow;
|
||||
for (col = 0; col < srcWidth; col++) {
|
||||
GLushort r,g,b;
|
||||
|
||||
UNCLAMPED_FLOAT_TO_USHORT(r, src[RCOMP]);
|
||||
UNCLAMPED_FLOAT_TO_USHORT(g, src[GCOMP]);
|
||||
UNCLAMPED_FLOAT_TO_USHORT(b, src[BCOMP]);
|
||||
dstUI[col] = PACK_COLOR_2101010_US(0xffff, r, g, b);
|
||||
src += 4;
|
||||
}
|
||||
dstRow += dstRowStride;
|
||||
}
|
||||
} else {
|
||||
ASSERT(0);
|
||||
}
|
||||
|
@@ -864,7 +864,8 @@ _mesa_uniform_matrix(struct gl_context *ctx, struct gl_shader_program *shProg,
|
||||
|
||||
/* GL_INVALID_VALUE is generated if `transpose' is not GL_FALSE.
|
||||
* http://www.khronos.org/opengles/sdk/docs/man/xhtml/glUniform.xml */
|
||||
if (ctx->API == API_OPENGLES || ctx->API == API_OPENGLES2) {
|
||||
if (ctx->API == API_OPENGLES
|
||||
|| (ctx->API == API_OPENGLES2 && ctx->Version < 30)) {
|
||||
if (transpose) {
|
||||
_mesa_error(ctx, GL_INVALID_VALUE,
|
||||
"glUniformMatrix(matrix transpose is not GL_FALSE)");
|
||||
|
@@ -151,21 +151,21 @@ update_array(struct gl_context *ctx,
|
||||
}
|
||||
|
||||
if (_mesa_is_gles(ctx)) {
|
||||
/* Once Mesa gets support for GL_OES_vertex_half_float this mask will
|
||||
* change. Adding support for this extension isn't quite as trivial as
|
||||
* we'd like because ES uses a different enum value for GL_HALF_FLOAT.
|
||||
*/
|
||||
legalTypesMask &= ~(FIXED_GL_BIT | HALF_BIT | DOUBLE_BIT);
|
||||
legalTypesMask &= ~(FIXED_GL_BIT | DOUBLE_BIT);
|
||||
|
||||
/* GL_INT and GL_UNSIGNED_INT data is not allowed in OpenGL ES until
|
||||
* 3.0. The 2_10_10_10 types are added in OpenGL ES 3.0 or
|
||||
* GL_OES_vertex_type_10_10_10_2.
|
||||
* GL_OES_vertex_type_10_10_10_2. GL_HALF_FLOAT data is not allowed
|
||||
* until 3.0 or with the GL_OES_vertex_half float extension, which isn't
|
||||
* quite as trivial as we'd like because it uses a different enum value
|
||||
* for GL_HALF_FLOAT_OES.
|
||||
*/
|
||||
if (ctx->Version < 30) {
|
||||
legalTypesMask &= ~(UNSIGNED_INT_BIT
|
||||
| INT_BIT
|
||||
| UNSIGNED_INT_2_10_10_10_REV_BIT
|
||||
| INT_2_10_10_10_REV_BIT);
|
||||
| INT_2_10_10_10_REV_BIT
|
||||
| HALF_BIT);
|
||||
}
|
||||
|
||||
/* BGRA ordering is not supported in ES contexts.
|
||||
@@ -1113,9 +1113,10 @@ _mesa_PrimitiveRestartIndex(GLuint index)
|
||||
|
||||
ASSERT_OUTSIDE_BEGIN_END(ctx);
|
||||
|
||||
if (ctx->Array.RestartIndex != index) {
|
||||
FLUSH_VERTICES(ctx, _NEW_TRANSFORM);
|
||||
ctx->Array.RestartIndex = index;
|
||||
if (ctx->Array.PrimitiveRestart && ctx->Array._RestartIndex != index) {
|
||||
FLUSH_VERTICES(ctx, _NEW_TRANSFORM);
|
||||
ctx->Array._RestartIndex = index;
|
||||
}
|
||||
}
|
||||
|
||||
|
@@ -323,7 +323,28 @@ compute_version_es2(struct gl_context *ctx)
|
||||
ctx->Extensions.ARB_fragment_shader &&
|
||||
ctx->Extensions.ARB_texture_non_power_of_two &&
|
||||
ctx->Extensions.EXT_blend_equation_separate);
|
||||
if (ver_2_0) {
|
||||
/* FINISHME: This list isn't quite right. */
|
||||
const GLboolean ver_3_0 = (ctx->Extensions.ARB_half_float_vertex &&
|
||||
ctx->Extensions.ARB_map_buffer_range &&
|
||||
ctx->Extensions.ARB_shader_texture_lod &&
|
||||
ctx->Extensions.ARB_texture_float &&
|
||||
ctx->Extensions.ARB_texture_rg &&
|
||||
ctx->Extensions.ARB_texture_compression_rgtc &&
|
||||
ctx->Extensions.EXT_draw_buffers2 &&
|
||||
/* ctx->Extensions.ARB_framebuffer_object && */
|
||||
ctx->Extensions.EXT_framebuffer_sRGB &&
|
||||
ctx->Extensions.EXT_packed_float &&
|
||||
ctx->Extensions.EXT_texture_array &&
|
||||
ctx->Extensions.EXT_texture_shared_exponent &&
|
||||
ctx->Extensions.EXT_transform_feedback &&
|
||||
ctx->Extensions.NV_conditional_render &&
|
||||
ctx->Extensions.ARB_draw_instanced &&
|
||||
ctx->Extensions.ARB_uniform_buffer_object &&
|
||||
ctx->Extensions.EXT_texture_snorm &&
|
||||
ctx->Extensions.NV_primitive_restart);
|
||||
if (ver_3_0) {
|
||||
ctx->Version = 30;
|
||||
} else if (ver_2_0) {
|
||||
ctx->Version = 20;
|
||||
} else {
|
||||
_mesa_problem(ctx, "Incomplete OpenGL ES 2.0 support.");
|
||||
|
@@ -94,6 +94,7 @@ st_BeginQuery(struct gl_context *ctx, struct gl_query_object *q)
|
||||
/* convert GL query type to Gallium query type */
|
||||
switch (q->Target) {
|
||||
case GL_ANY_SAMPLES_PASSED:
|
||||
case GL_ANY_SAMPLES_PASSED_CONSERVATIVE:
|
||||
/* fall-through */
|
||||
case GL_SAMPLES_PASSED_ARB:
|
||||
type = PIPE_QUERY_OCCLUSION_COUNTER;
|
||||
|
@@ -230,8 +230,8 @@ st_draw_vbo(struct gl_context *ctx,
|
||||
/* The VBO module handles restart for the non-indexed GLDrawArrays
|
||||
* so we only set these fields for indexed drawing:
|
||||
*/
|
||||
info.primitive_restart = ctx->Array.PrimitiveRestart;
|
||||
info.restart_index = ctx->Array.RestartIndex;
|
||||
info.primitive_restart = ctx->Array._PrimitiveRestart;
|
||||
info.restart_index = ctx->Array._RestartIndex;
|
||||
}
|
||||
else {
|
||||
/* Transform feedback drawing is always non-indexed. */
|
||||
|
@@ -90,8 +90,8 @@ vbo_get_minmax_index(struct gl_context *ctx,
|
||||
GLuint *min_index, GLuint *max_index,
|
||||
const GLuint count)
|
||||
{
|
||||
const GLboolean restart = ctx->Array.PrimitiveRestart;
|
||||
const GLuint restartIndex = ctx->Array.RestartIndex;
|
||||
const GLboolean restart = ctx->Array._PrimitiveRestart;
|
||||
const GLuint restartIndex = ctx->Array._RestartIndex;
|
||||
const int index_size = vbo_sizeof_ib_type(ib->type);
|
||||
const char *indices;
|
||||
GLuint i;
|
||||
@@ -536,7 +536,7 @@ vbo_handle_primitive_restart(struct gl_context *ctx,
|
||||
|
||||
if ((ib != NULL) &&
|
||||
ctx->Const.PrimitiveRestartInSoftware &&
|
||||
ctx->Array.PrimitiveRestart) {
|
||||
ctx->Array._PrimitiveRestart) {
|
||||
/* Handle primitive restart in software */
|
||||
vbo_sw_primitive_restart(ctx, prim, nr_prims, ib);
|
||||
} else {
|
||||
@@ -572,10 +572,10 @@ vbo_draw_arrays(struct gl_context *ctx, GLenum mode, GLint start,
|
||||
prim[0].base_instance = baseInstance;
|
||||
|
||||
/* Implement the primitive restart index */
|
||||
if (ctx->Array.PrimitiveRestart && ctx->Array.RestartIndex < count) {
|
||||
if (ctx->Array._PrimitiveRestart && ctx->Array._RestartIndex < count) {
|
||||
GLuint primCount = 0;
|
||||
|
||||
if (ctx->Array.RestartIndex == start) {
|
||||
if (ctx->Array._RestartIndex == start) {
|
||||
/* special case: RestartIndex at beginning */
|
||||
if (count > 1) {
|
||||
prim[0].start = start + 1;
|
||||
@@ -583,7 +583,7 @@ vbo_draw_arrays(struct gl_context *ctx, GLenum mode, GLint start,
|
||||
primCount = 1;
|
||||
}
|
||||
}
|
||||
else if (ctx->Array.RestartIndex == start + count - 1) {
|
||||
else if (ctx->Array._RestartIndex == start + count - 1) {
|
||||
/* special case: RestartIndex at end */
|
||||
if (count > 1) {
|
||||
prim[0].start = start;
|
||||
@@ -594,10 +594,10 @@ vbo_draw_arrays(struct gl_context *ctx, GLenum mode, GLint start,
|
||||
else {
|
||||
/* general case: RestartIndex in middle, split into two prims */
|
||||
prim[0].start = start;
|
||||
prim[0].count = ctx->Array.RestartIndex - start;
|
||||
prim[0].count = ctx->Array._RestartIndex - start;
|
||||
|
||||
prim[1] = prim[0];
|
||||
prim[1].start = ctx->Array.RestartIndex + 1;
|
||||
prim[1].start = ctx->Array._RestartIndex + 1;
|
||||
prim[1].count = count - prim[1].start;
|
||||
|
||||
primCount = 2;
|
||||
|
@@ -171,7 +171,7 @@ vbo_sw_primitive_restart(struct gl_context *ctx,
|
||||
GLuint sub_prim_num;
|
||||
GLuint end_index;
|
||||
GLuint sub_end_index;
|
||||
GLuint restart_index = ctx->Array.RestartIndex;
|
||||
GLuint restart_index = ctx->Array._RestartIndex;
|
||||
struct _mesa_prim temp_prim;
|
||||
struct vbo_context *vbo = vbo_context(ctx);
|
||||
vbo_draw_func draw_prims_func = vbo->draw_prims;
|
||||
|
Reference in New Issue
Block a user