diff options
author | Jason Macnak <natsu@google.com> | 2024-02-29 22:18:52 +0000 |
---|---|---|
committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2024-02-29 22:18:52 +0000 |
commit | 730c1743b845204d9a9190daf2b5cb1a335b782a (patch) | |
tree | dfa8be2aa25bbabc906beca820ca01660018a53b | |
parent | b23315d0050b7f75476bb8f109801b48250b2b2a (diff) | |
parent | 340b69c025b49af595704d8b26dc505215a739c8 (diff) | |
download | gfxstream-730c1743b845204d9a9190daf2b5cb1a335b782a.tar.gz |
Merge "Update link status in glProgramBinary" into main
-rw-r--r-- | host/gl/glestranslator/GLES_V2/GLESv30Imp.cpp | 34 |
1 files changed, 29 insertions, 5 deletions
diff --git a/host/gl/glestranslator/GLES_V2/GLESv30Imp.cpp b/host/gl/glestranslator/GLES_V2/GLESv30Imp.cpp index 5903eeb7..fea7f60e 100644 --- a/host/gl/glestranslator/GLES_V2/GLESv30Imp.cpp +++ b/host/gl/glestranslator/GLES_V2/GLESv30Imp.cpp @@ -1,8 +1,3 @@ -// Auto-generated with: android/scripts/gen-entries.py --mode=translator_passthrough android/android-emugl/host/libs/libOpenGLESDispatch/gles3_only.entries --output=android/android-emugl/host/libs/Translator/GLES_V2/GLESv30Imp.cpp -// This file is best left unedited. -// Try to make changes through gen_translator in gen-entries.py, -// and/or parcel out custom functionality in separate code. - EXTERN_PART GL_APICALL GLconstubyteptr GL_APIENTRY glGetStringi(GLenum name, GLint index) { GET_CTX_V2_RET(0); GLconstubyteptr glGetStringiRET = ctx->dispatcher().glGetStringi(name, index); @@ -988,7 +983,36 @@ GL_APICALL void GL_APIENTRY glProgramBinary(GLuint program, GLenum binaryFormat, GET_CTX_V2(); if (ctx->shareGroup().get()) { const GLuint globalProgramName = ctx->shareGroup()->getGlobalName(NamedObjectType::SHADER_OR_PROGRAM, program); + SET_ERROR_IF(globalProgramName == 0, GL_INVALID_VALUE); + + auto objData = + ctx->shareGroup()->getObjectData(NamedObjectType::SHADER_OR_PROGRAM, program); + SET_ERROR_IF(!objData, GL_INVALID_OPERATION); + SET_ERROR_IF(objData->getDataType() != PROGRAM_DATA, GL_INVALID_OPERATION); + + ProgramData* programData = (ProgramData*)objData; + ctx->dispatcher().glProgramBinary(globalProgramName, binaryFormat, binary, length); + + GLint linkStatus = GL_FALSE; + ctx->dispatcher().glGetProgramiv(globalProgramName, GL_LINK_STATUS, &linkStatus); + + programData->setHostLinkStatus(linkStatus); + programData->setLinkStatus(linkStatus); + + GLsizei infoLogLength = 0; + ctx->dispatcher().glGetProgramiv(globalProgramName, GL_INFO_LOG_LENGTH, &infoLogLength); + + if (infoLogLength > 0) { + std::vector<GLchar> infoLog(infoLogLength); + ctx->dispatcher().glGetProgramInfoLog(globalProgramName, infoLogLength, &infoLogLength, + infoLog.data()); + + if (infoLogLength) { + infoLog.resize(infoLogLength); + programData->setInfoLog(infoLog.data()); + } + } } } |