/* $Id: server_getshaders.cpp 78375 2019-05-03 21:51:02Z vboxsync $ */ /** @file * VBox OpenGL GLSL related get functions */ /* * Copyright (C) 2009-2019 Oracle Corporation * * This file is part of VirtualBox Open Source Edition (OSE), as * available from http://www.virtualbox.org. This file is free software; * you can redistribute it and/or modify it under the terms of the GNU * General Public License (GPL) as published by the Free Software * Foundation, in version 2 as it comes in the "COPYING" file of the * VirtualBox OSE distribution. VirtualBox OSE is distributed in the * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. */ #include "cr_spu.h" #include "chromium.h" #include "cr_error.h" #include "cr_mem.h" #include "cr_net.h" #include "server_dispatch.h" #include "server.h" #include #ifdef CR_OPENGL_VERSION_2_0 typedef struct _crGetActive_t { GLsizei length; GLint size; GLenum type; } crGetActive_t; void SERVER_DISPATCH_APIENTRY crServerDispatchGetActiveAttrib(GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLint *size, GLenum *type, char *name) { RT_NOREF(name, type, size, length); crGetActive_t *pLocal = NULL; if (bufSize > 0 && bufSize < INT32_MAX / 2) pLocal = (crGetActive_t*)crCalloc(bufSize + sizeof(crGetActive_t)); if (!pLocal) { crGetActive_t zero; zero.length = 0; crServerReturnValue(&zero, sizeof(zero)); return; } cr_server.head_spu->dispatch_table.GetActiveAttrib(crStateGetProgramHWID(&cr_server.StateTracker, program), index, bufSize, &pLocal->length, &pLocal->size, &pLocal->type, (char*)&pLocal[1]); crServerReturnValue(pLocal, pLocal->length+1+sizeof(crGetActive_t)); crFree(pLocal); } void SERVER_DISPATCH_APIENTRY crServerDispatchGetActiveUniform(GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLint *size, GLenum *type, char *name) { RT_NOREF(name, type, size, length); crGetActive_t *pLocal = NULL; if (bufSize > 0 && bufSize < INT32_MAX / 2) pLocal = (crGetActive_t*) crCalloc(bufSize + sizeof(crGetActive_t)); if (!pLocal) { crGetActive_t zero; zero.length = 0; crServerReturnValue(&zero, sizeof(zero)); return; } cr_server.head_spu->dispatch_table.GetActiveUniform(crStateGetProgramHWID(&cr_server.StateTracker, program), index, bufSize, &pLocal->length, &pLocal->size, &pLocal->type, (char*)&pLocal[1]); crServerReturnValue(pLocal, pLocal->length+1+sizeof(crGetActive_t)); crFree(pLocal); } void SERVER_DISPATCH_APIENTRY crServerDispatchGetAttachedShaders(GLuint program, GLsizei maxCount, GLsizei *count, GLuint *shaders) { RT_NOREF(count, shaders); GLsizei *pLocal = NULL; if (maxCount > 0 && maxCount < INT32_MAX / sizeof(GLuint) / 2) pLocal = (GLsizei*) crCalloc(maxCount * sizeof(GLuint) + sizeof(GLsizei)); if (!pLocal) { GLsizei zero=0; crServerReturnValue(&zero, sizeof(zero)); return; } /* initial (fallback )value */ *pLocal = 0; cr_server.head_spu->dispatch_table.GetAttachedShaders(crStateGetProgramHWID(&cr_server.StateTracker, program), maxCount, pLocal, (GLuint*)&pLocal[1]); { GLsizei i; GLuint *ids=(GLuint*)&pLocal[1]; for (i=0; i<*pLocal; ++i) ids[i] = crStateGLSLShaderHWIDtoID(&cr_server.StateTracker, ids[i]); } crServerReturnValue(pLocal, (*pLocal)*sizeof(GLuint)+sizeof(GLsizei)); crFree(pLocal); } void SERVER_DISPATCH_APIENTRY crServerDispatchGetAttachedObjectsARB(VBoxGLhandleARB containerObj, GLsizei maxCount, GLsizei * count, VBoxGLhandleARB * obj) { RT_NOREF(count, obj); GLsizei *pLocal = NULL; if (maxCount > 0 && maxCount < INT32_MAX / sizeof(VBoxGLhandleARB) / 2) pLocal = (GLsizei*) crCalloc(maxCount * sizeof(VBoxGLhandleARB) + sizeof(GLsizei)); if (!pLocal) { GLsizei zero=0; crServerReturnValue(&zero, sizeof(zero)); return; } /* initial (fallback )value */ *pLocal = 0; cr_server.head_spu->dispatch_table.GetAttachedObjectsARB(crStateGetProgramHWID(&cr_server.StateTracker, containerObj), maxCount, pLocal, (VBoxGLhandleARB*)&pLocal[1]); { GLsizei i; GLuint *ids=(GLuint*)&pLocal[1]; for (i=0; i<*pLocal; ++i) ids[i] = crStateGLSLShaderHWIDtoID(&cr_server.StateTracker, ids[i]); } crServerReturnValue(pLocal, (*pLocal)*sizeof(VBoxGLhandleARB)+sizeof(GLsizei)); crFree(pLocal); } AssertCompile(sizeof(GLsizei) == 4); void SERVER_DISPATCH_APIENTRY crServerDispatchGetInfoLogARB(VBoxGLhandleARB obj, GLsizei maxLength, GLsizei * length, GLcharARB * infoLog) { RT_NOREF(length, infoLog); GLsizei *pLocal = NULL; GLuint hwid; if (maxLength > 0 && maxLength < INT32_MAX / 2) pLocal = (GLsizei*) crCalloc(maxLength + sizeof(GLsizei)); if (!pLocal) { GLsizei zero=0; crServerReturnValue(&zero, sizeof(zero)); return; } /* initial (fallback )value */ *pLocal = 0; /** @todo recheck*/ hwid = crStateGetProgramHWID(&cr_server.StateTracker, obj); if (!hwid) hwid = crStateGetShaderHWID(&cr_server.StateTracker, obj); cr_server.head_spu->dispatch_table.GetInfoLogARB(hwid, maxLength, pLocal, (char*)&pLocal[1]); CRASSERT((*pLocal) <= maxLength); crServerReturnValue(pLocal, (*pLocal)+sizeof(GLsizei)); crFree(pLocal); } void SERVER_DISPATCH_APIENTRY crServerDispatchGetShaderInfoLog(GLuint shader, GLsizei bufSize, GLsizei *length, char *infoLog) { RT_NOREF(length, infoLog); GLsizei *pLocal = NULL; if (bufSize > 0 && bufSize < INT32_MAX / 2) pLocal = (GLsizei*) crCalloc(bufSize + sizeof(GLsizei)); if (!pLocal) { GLsizei zero=0; crServerReturnValue(&zero, sizeof(zero)); return; } /* initial (fallback )value */ *pLocal = 0; cr_server.head_spu->dispatch_table.GetShaderInfoLog(crStateGetShaderHWID(&cr_server.StateTracker, shader), bufSize, pLocal, (char*)&pLocal[1]); crServerReturnValue(pLocal, pLocal[0]+sizeof(GLsizei)); crFree(pLocal); } void SERVER_DISPATCH_APIENTRY crServerDispatchGetProgramInfoLog(GLuint program, GLsizei bufSize, GLsizei *length, char *infoLog) { RT_NOREF(length, infoLog); GLsizei *pLocal = NULL; if (bufSize > 0 && bufSize < INT32_MAX / 2) pLocal = (GLsizei*) crCalloc(bufSize + sizeof(GLsizei)); if (!pLocal) { GLsizei zero=0; crServerReturnValue(&zero, sizeof(zero)); return; } /* initial (fallback )value */ *pLocal = 0; cr_server.head_spu->dispatch_table.GetProgramInfoLog(crStateGetProgramHWID(&cr_server.StateTracker, program), bufSize, pLocal, (char*)&pLocal[1]); CRASSERT(pLocal[0] <= bufSize); crServerReturnValue(pLocal, pLocal[0]+sizeof(GLsizei)); crFree(pLocal); } void SERVER_DISPATCH_APIENTRY crServerDispatchGetShaderSource(GLuint shader, GLsizei bufSize, GLsizei *length, char *source) { RT_NOREF(length, source); GLsizei *pLocal = NULL; if (bufSize > 0 && bufSize < INT32_MAX / 2) pLocal = (GLsizei*) crCalloc(bufSize + sizeof(GLsizei)); if (!pLocal) { GLsizei zero=0; crServerReturnValue(&zero, sizeof(zero)); return; } /* initial (fallback )value */ *pLocal = 0; cr_server.head_spu->dispatch_table.GetShaderSource(crStateGetShaderHWID(&cr_server.StateTracker, shader), bufSize, pLocal, (char*)&pLocal[1]); CRASSERT(pLocal[0] <= bufSize); crServerReturnValue(pLocal, pLocal[0]+sizeof(GLsizei)); crFree(pLocal); } void SERVER_DISPATCH_APIENTRY crServerDispatchGetUniformsLocations(GLuint program, GLsizei maxcbData, GLsizei * cbData, GLvoid * pData) { GLsizei *pLocal = NULL; (void) cbData; (void) pData; if (maxcbData > 0 && maxcbData < INT32_MAX / 2) pLocal = (GLsizei*) crCalloc(maxcbData + sizeof(GLsizei)); if (!pLocal) { GLsizei zero=0; crServerReturnValue(&zero, sizeof(zero)); return; } /* initial (fallback )value */ *pLocal = 0; crStateGLSLProgramCacheUniforms(&cr_server.StateTracker, program, maxcbData, pLocal, (char*)&pLocal[1]); crServerReturnValue(pLocal, (*pLocal)+sizeof(GLsizei)); crFree(pLocal); } void SERVER_DISPATCH_APIENTRY crServerDispatchGetAttribsLocations(GLuint program, GLsizei maxcbData, GLsizei * cbData, GLvoid * pData) { GLsizei *pLocal = NULL; (void) cbData; (void) pData; if (maxcbData > 0 && maxcbData < INT32_MAX / 2) pLocal = (GLsizei*) crCalloc(maxcbData + sizeof(GLsizei)); if (!pLocal) { GLsizei zero=0; crServerReturnValue(&zero, sizeof(zero)); return; } /* initial (fallback )value */ *pLocal = 0; crStateGLSLProgramCacheAttribs(&cr_server.StateTracker, program, maxcbData, pLocal, (char*)&pLocal[1]); crServerReturnValue(pLocal, (*pLocal)+sizeof(GLsizei)); crFree(pLocal); } static GLint __GetUniformSize(GLuint program, GLint location) { GLint size = 0; GLenum type = 0; /** @todo check if index and location is the same*/ cr_server.head_spu->dispatch_table.GetActiveUniform(crStateGetProgramHWID(&cr_server.StateTracker, program), location, 0, NULL, &size, &type, NULL); return crStateGetUniformSize(&cr_server.StateTracker, type); } void SERVER_DISPATCH_APIENTRY crServerDispatchGetUniformfv(GLuint program, GLint location, GLfloat *params) { RT_NOREF(params); int size = __GetUniformSize(program, location) * sizeof(GLfloat); GLfloat *pLocal; pLocal = (GLfloat*) crCalloc(size); if (!pLocal) { GLsizei zero=0; crServerReturnValue(&zero, sizeof(zero)); return; } cr_server.head_spu->dispatch_table.GetUniformfv(crStateGetProgramHWID(&cr_server.StateTracker, program), location, pLocal); crServerReturnValue(pLocal, size); crFree(pLocal); } void SERVER_DISPATCH_APIENTRY crServerDispatchGetUniformiv(GLuint program, GLint location, GLint *params) { RT_NOREF(params); int size = __GetUniformSize(program, location) * sizeof(GLint); GLint *pLocal; pLocal = (GLint*) crCalloc(size); if (!pLocal) { GLsizei zero=0; crServerReturnValue(&zero, sizeof(zero)); return; } cr_server.head_spu->dispatch_table.GetUniformiv(crStateGetProgramHWID(&cr_server.StateTracker, program), location, pLocal); crServerReturnValue(pLocal, size); crFree(pLocal); } GLuint SERVER_DISPATCH_APIENTRY crServerDispatchCreateShader(GLenum type) { GLuint retval, hwVal; hwVal = cr_server.head_spu->dispatch_table.CreateShader(type); retval = crStateCreateShader(&cr_server.StateTracker, hwVal, type); crServerReturnValue(&retval, sizeof(retval)); return retval; /* ignored */ } GLuint SERVER_DISPATCH_APIENTRY crServerDispatchCreateProgram(void) { GLuint retval, hwVal; hwVal = cr_server.head_spu->dispatch_table.CreateProgram(); retval = crStateCreateProgram(&cr_server.StateTracker, hwVal); crServerReturnValue(&retval, sizeof(retval)); return retval; /* ignored */ } GLboolean SERVER_DISPATCH_APIENTRY crServerDispatchIsShader(GLuint shader) { GLboolean retval; retval = cr_server.head_spu->dispatch_table.IsShader(crStateGetShaderHWID(&cr_server.StateTracker, shader)); crServerReturnValue(&retval, sizeof(retval)); return retval; /* ignored */ } GLboolean SERVER_DISPATCH_APIENTRY crServerDispatchIsProgram(GLuint program) { GLboolean retval; retval = cr_server.head_spu->dispatch_table.IsProgram(crStateGetProgramHWID(&cr_server.StateTracker, program)); crServerReturnValue(&retval, sizeof(retval)); return retval; /* ignored */ } void SERVER_DISPATCH_APIENTRY crServerDispatchGetObjectParameterfvARB( VBoxGLhandleARB obj, GLenum pname, GLfloat * params ) { GLfloat local_params[1] = {0}; GLuint hwid = crStateGetProgramHWID(&cr_server.StateTracker, obj); (void) params; if (!hwid) { hwid = crStateGetShaderHWID(&cr_server.StateTracker, obj); if (!hwid) { crWarning("Unknown object %i, in crServerDispatchGetObjectParameterfvARB", obj); } } cr_server.head_spu->dispatch_table.GetObjectParameterfvARB( hwid, pname, local_params ); crServerReturnValue( &(local_params[0]), 1*sizeof(GLfloat) ); } void SERVER_DISPATCH_APIENTRY crServerDispatchGetObjectParameterivARB( VBoxGLhandleARB obj, GLenum pname, GLint * params ) { GLint local_params[1] = {0}; GLuint hwid = crStateGetProgramHWID(&cr_server.StateTracker, obj); if (!hwid) { hwid = crStateGetShaderHWID(&cr_server.StateTracker, obj); if (!hwid) { crWarning("Unknown object %i, in crServerDispatchGetObjectParameterivARB", obj); } } (void) params; cr_server.head_spu->dispatch_table.GetObjectParameterivARB( hwid, pname, local_params ); crServerReturnValue( &(local_params[0]), 1*sizeof(GLint) ); } #endif /* #ifdef CR_OPENGL_VERSION_2_0 */