diff options
Diffstat (limited to 'src/mesa')
-rw-r--r-- | src/mesa/main/texturebindless.c | 44 | ||||
-rw-r--r-- | src/mesa/main/texturebindless.h | 14 |
2 files changed, 58 insertions, 0 deletions
diff --git a/src/mesa/main/texturebindless.c b/src/mesa/main/texturebindless.c index dac6c569a5e..5c606e9f4b4 100644 --- a/src/mesa/main/texturebindless.c +++ b/src/mesa/main/texturebindless.c @@ -649,6 +649,17 @@ _mesa_GetTextureSamplerHandleARB(GLuint texture, GLuint sampler) } void GLAPIENTRY +_mesa_MakeTextureHandleResidentARB_no_error(GLuint64 handle) +{ + struct gl_texture_handle_object *texHandleObj; + + GET_CURRENT_CONTEXT(ctx); + + texHandleObj = lookup_texture_handle(ctx, handle); + make_texture_handle_resident(ctx, texHandleObj, true); +} + +void GLAPIENTRY _mesa_MakeTextureHandleResidentARB(GLuint64 handle) { struct gl_texture_handle_object *texHandleObj; @@ -684,6 +695,17 @@ _mesa_MakeTextureHandleResidentARB(GLuint64 handle) } void GLAPIENTRY +_mesa_MakeTextureHandleNonResidentARB_no_error(GLuint64 handle) +{ + struct gl_texture_handle_object *texHandleObj; + + GET_CURRENT_CONTEXT(ctx); + + texHandleObj = lookup_texture_handle(ctx, handle); + make_texture_handle_resident(ctx, texHandleObj, false); +} + +void GLAPIENTRY _mesa_MakeTextureHandleNonResidentARB(GLuint64 handle) { struct gl_texture_handle_object *texHandleObj; @@ -790,6 +812,17 @@ _mesa_GetImageHandleARB(GLuint texture, GLint level, GLboolean layered, } void GLAPIENTRY +_mesa_MakeImageHandleResidentARB_no_error(GLuint64 handle, GLenum access) +{ + struct gl_image_handle_object *imgHandleObj; + + GET_CURRENT_CONTEXT(ctx); + + imgHandleObj = lookup_image_handle(ctx, handle); + make_image_handle_resident(ctx, imgHandleObj, access, true); +} + +void GLAPIENTRY _mesa_MakeImageHandleResidentARB(GLuint64 handle, GLenum access) { struct gl_image_handle_object *imgHandleObj; @@ -834,6 +867,17 @@ _mesa_MakeImageHandleResidentARB(GLuint64 handle, GLenum access) } void GLAPIENTRY +_mesa_MakeImageHandleNonResidentARB_no_error(GLuint64 handle) +{ + struct gl_image_handle_object *imgHandleObj; + + GET_CURRENT_CONTEXT(ctx); + + imgHandleObj = lookup_image_handle(ctx, handle); + make_image_handle_resident(ctx, imgHandleObj, GL_READ_ONLY, false); +} + +void GLAPIENTRY _mesa_MakeImageHandleNonResidentARB(GLuint64 handle) { struct gl_image_handle_object *imgHandleObj; diff --git a/src/mesa/main/texturebindless.h b/src/mesa/main/texturebindless.h index 0fcea61d432..467105ef414 100644 --- a/src/mesa/main/texturebindless.h +++ b/src/mesa/main/texturebindless.h @@ -73,7 +73,14 @@ GLuint64 GLAPIENTRY _mesa_GetTextureSamplerHandleARB(GLuint texture, GLuint sampler); void GLAPIENTRY +_mesa_MakeTextureHandleResidentARB_no_error(GLuint64 handle); + +void GLAPIENTRY _mesa_MakeTextureHandleResidentARB(GLuint64 handle); + +void GLAPIENTRY +_mesa_MakeTextureHandleNonResidentARB_no_error(GLuint64 handle); + void GLAPIENTRY _mesa_MakeTextureHandleNonResidentARB(GLuint64 handle); @@ -82,7 +89,14 @@ _mesa_GetImageHandleARB(GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum format); void GLAPIENTRY +_mesa_MakeImageHandleResidentARB_no_error(GLuint64 handle, GLenum access); + +void GLAPIENTRY _mesa_MakeImageHandleResidentARB(GLuint64 handle, GLenum access); + +void GLAPIENTRY +_mesa_MakeImageHandleNonResidentARB_no_error(GLuint64 handle); + void GLAPIENTRY _mesa_MakeImageHandleNonResidentARB(GLuint64 handle); |