mesa: add KHR_no_error support for glGetTexture*HandleARB()
It would be nice to have a no_error path for _mesa_test_texobj_completeness() because this function doesn't only test if the texture is complete. Anyway, that seems enough for now and a bunch of checks are skipped with this patch. Signed-off-by: Samuel Pitoiset <samuel.pitoiset@gmail.com> Reviewed-by: Timothy Arceri <tarceri@itsqueeze.com>
This commit is contained in:
@@ -8,12 +8,12 @@
|
|||||||
<enum name="UNSIGNED_INT64_ARB" value="0x140F" />
|
<enum name="UNSIGNED_INT64_ARB" value="0x140F" />
|
||||||
<type name="uint64EXT" unsigned="true" size="8"/>
|
<type name="uint64EXT" unsigned="true" size="8"/>
|
||||||
|
|
||||||
<function name="GetTextureHandleARB">
|
<function name="GetTextureHandleARB" no_error="true">
|
||||||
<return type="GLuint64"/>
|
<return type="GLuint64"/>
|
||||||
<param name="texture" type="GLuint" />
|
<param name="texture" type="GLuint" />
|
||||||
</function>
|
</function>
|
||||||
|
|
||||||
<function name="GetTextureSamplerHandleARB">
|
<function name="GetTextureSamplerHandleARB" no_error="true">
|
||||||
<return type="GLuint64"/>
|
<return type="GLuint64"/>
|
||||||
<param name="texture" type="GLuint" />
|
<param name="texture" type="GLuint" />
|
||||||
<param name="sampler" type="GLuint" />
|
<param name="sampler" type="GLuint" />
|
||||||
|
@@ -532,6 +532,20 @@ is_sampler_border_color_valid(struct gl_sampler_object *samp)
|
|||||||
return GL_FALSE;
|
return GL_FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GLuint64 GLAPIENTRY
|
||||||
|
_mesa_GetTextureHandleARB_no_error(GLuint texture)
|
||||||
|
{
|
||||||
|
struct gl_texture_object *texObj;
|
||||||
|
|
||||||
|
GET_CURRENT_CONTEXT(ctx);
|
||||||
|
|
||||||
|
texObj = _mesa_lookup_texture(ctx, texture);
|
||||||
|
if (!_mesa_is_texture_complete(texObj, &texObj->Sampler))
|
||||||
|
_mesa_test_texobj_completeness(ctx, texObj);
|
||||||
|
|
||||||
|
return get_texture_handle(ctx, texObj, &texObj->Sampler);
|
||||||
|
}
|
||||||
|
|
||||||
GLuint64 GLAPIENTRY
|
GLuint64 GLAPIENTRY
|
||||||
_mesa_GetTextureHandleARB(GLuint texture)
|
_mesa_GetTextureHandleARB(GLuint texture)
|
||||||
{
|
{
|
||||||
@@ -583,6 +597,23 @@ _mesa_GetTextureHandleARB(GLuint texture)
|
|||||||
return get_texture_handle(ctx, texObj, &texObj->Sampler);
|
return get_texture_handle(ctx, texObj, &texObj->Sampler);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GLuint64 GLAPIENTRY
|
||||||
|
_mesa_GetTextureSamplerHandleARB_no_error(GLuint texture, GLuint sampler)
|
||||||
|
{
|
||||||
|
struct gl_texture_object *texObj;
|
||||||
|
struct gl_sampler_object *sampObj;
|
||||||
|
|
||||||
|
GET_CURRENT_CONTEXT(ctx);
|
||||||
|
|
||||||
|
texObj = _mesa_lookup_texture(ctx, texture);
|
||||||
|
sampObj = _mesa_lookup_samplerobj(ctx, sampler);
|
||||||
|
|
||||||
|
if (!_mesa_is_texture_complete(texObj, sampObj))
|
||||||
|
_mesa_test_texobj_completeness(ctx, texObj);
|
||||||
|
|
||||||
|
return get_texture_handle(ctx, texObj, sampObj);
|
||||||
|
}
|
||||||
|
|
||||||
GLuint64 GLAPIENTRY
|
GLuint64 GLAPIENTRY
|
||||||
_mesa_GetTextureSamplerHandleARB(GLuint texture, GLuint sampler)
|
_mesa_GetTextureSamplerHandleARB(GLuint texture, GLuint sampler)
|
||||||
{
|
{
|
||||||
|
@@ -67,8 +67,15 @@ _mesa_delete_sampler_handles(struct gl_context *ctx,
|
|||||||
*/
|
*/
|
||||||
/*@{*/
|
/*@{*/
|
||||||
|
|
||||||
|
GLuint64 GLAPIENTRY
|
||||||
|
_mesa_GetTextureHandleARB_no_error(GLuint texture);
|
||||||
|
|
||||||
GLuint64 GLAPIENTRY
|
GLuint64 GLAPIENTRY
|
||||||
_mesa_GetTextureHandleARB(GLuint texture);
|
_mesa_GetTextureHandleARB(GLuint texture);
|
||||||
|
|
||||||
|
GLuint64 GLAPIENTRY
|
||||||
|
_mesa_GetTextureSamplerHandleARB_no_error(GLuint texture, GLuint sampler);
|
||||||
|
|
||||||
GLuint64 GLAPIENTRY
|
GLuint64 GLAPIENTRY
|
||||||
_mesa_GetTextureSamplerHandleARB(GLuint texture, GLuint sampler);
|
_mesa_GetTextureSamplerHandleARB(GLuint texture, GLuint sampler);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user