VirtualBox

source: vbox/trunk/src/VBox/HostServices/SharedOpenGL/crserverlib/server_glsl.c@ 74897

Last change on this file since 74897 was 74890, checked in by vboxsync, 6 years ago

3D: Memory allocations fixed, bugref:9251. Merged changes r125768, r125779, r125780, r125812.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 8.5 KB
Line 
1/* $Id: server_glsl.c 74890 2018-10-17 16:58:38Z vboxsync $ */
2/** @file
3 * VBox OpenGL - GLSL related functions
4 */
5
6/*
7 * Copyright (C) 2009-2017 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18#include "cr_spu.h"
19#include "chromium.h"
20#include "cr_error.h"
21#include "cr_mem.h"
22#include "cr_net.h"
23#include "server_dispatch.h"
24#include "server.h"
25
26#ifdef CR_OPENGL_VERSION_2_0
27
28void SERVER_DISPATCH_APIENTRY crServerDispatchShaderSource(GLuint shader, GLsizei count, const char ** string, const GLint * length)
29{
30 /*@todo?crStateShaderSource(shader...);*/
31#ifdef DEBUG_misha
32 GLenum err = cr_server.head_spu->dispatch_table.GetError();
33#endif
34 cr_server.head_spu->dispatch_table.ShaderSource(crStateGetShaderHWID(shader), count, string, length);
35#ifdef DEBUG_misha
36 err = cr_server.head_spu->dispatch_table.GetError();
37 CRASSERT(err == GL_NO_ERROR);
38#endif
39 CR_SERVER_DUMP_SHADER_SOURCE(shader);
40}
41
42void SERVER_DISPATCH_APIENTRY crServerDispatchCompileShader(GLuint shader)
43{
44#ifdef DEBUG_misha
45 GLint iCompileStatus = GL_FALSE;
46#endif
47 crStateCompileShader(shader);
48 cr_server.head_spu->dispatch_table.CompileShader(crStateGetShaderHWID(shader));
49#ifdef DEBUG_misha
50 cr_server.head_spu->dispatch_table.GetShaderiv(crStateGetShaderHWID(shader), GL_COMPILE_STATUS, &iCompileStatus);
51 Assert(iCompileStatus == GL_TRUE);
52#endif
53 CR_SERVER_DUMP_COMPILE_SHADER(shader);
54}
55
56void SERVER_DISPATCH_APIENTRY crServerDispatchDeleteShader(GLuint shader)
57{
58 GLuint shaderHW = crStateGetShaderHWID(shader);
59 crStateDeleteShader(shader);
60 if (shaderHW)
61 cr_server.head_spu->dispatch_table.DeleteShader(shaderHW);
62 else
63 crWarning("crServerDispatchDeleteShader: hwid not found for shader(%d)", shader);
64}
65
66void SERVER_DISPATCH_APIENTRY crServerDispatchAttachShader(GLuint program, GLuint shader)
67{
68 crStateAttachShader(program, shader);
69 cr_server.head_spu->dispatch_table.AttachShader(crStateGetProgramHWID(program), crStateGetShaderHWID(shader));
70}
71
72void SERVER_DISPATCH_APIENTRY crServerDispatchDetachShader(GLuint program, GLuint shader)
73{
74 crStateDetachShader(program, shader);
75 cr_server.head_spu->dispatch_table.DetachShader(crStateGetProgramHWID(program), crStateGetShaderHWID(shader));
76}
77
78void SERVER_DISPATCH_APIENTRY crServerDispatchLinkProgram(GLuint program)
79{
80 crStateLinkProgram(program);
81 cr_server.head_spu->dispatch_table.LinkProgram(crStateGetProgramHWID(program));
82 CR_SERVER_DUMP_LINK_PROGRAM(program);
83}
84
85void SERVER_DISPATCH_APIENTRY crServerDispatchUseProgram(GLuint program)
86{
87 crStateUseProgram(program);
88 cr_server.head_spu->dispatch_table.UseProgram(crStateGetProgramHWID(program));
89}
90
91void SERVER_DISPATCH_APIENTRY crServerDispatchDeleteProgram(GLuint program)
92{
93 GLuint hwId = crStateGetProgramHWID(program);
94 crStateDeleteProgram(program);
95 if (hwId)
96 cr_server.head_spu->dispatch_table.DeleteProgram(hwId);
97 else
98 crWarning("crServerDispatchDeleteProgram: hwid not found for program(%d)", program);
99}
100
101void SERVER_DISPATCH_APIENTRY crServerDispatchValidateProgram(GLuint program)
102{
103 crStateValidateProgram(program);
104 cr_server.head_spu->dispatch_table.ValidateProgram(crStateGetProgramHWID(program));
105}
106
107void SERVER_DISPATCH_APIENTRY crServerDispatchBindAttribLocation(GLuint program, GLuint index, const char * name)
108{
109 crStateBindAttribLocation(program, index, name);
110 cr_server.head_spu->dispatch_table.BindAttribLocation(crStateGetProgramHWID(program), index, name);
111}
112
113void SERVER_DISPATCH_APIENTRY crServerDispatchDeleteObjectARB(VBoxGLhandleARB obj)
114{
115 GLuint hwid = crStateDeleteObjectARB(obj);
116
117 if (hwid)
118 cr_server.head_spu->dispatch_table.DeleteObjectARB(hwid);
119 else
120 crWarning("zero hwid for object %d", obj);
121}
122
123GLint SERVER_DISPATCH_APIENTRY crServerDispatchGetAttribLocation( GLuint program, const char * name )
124{
125 GLint retval;
126 retval = cr_server.head_spu->dispatch_table.GetAttribLocation(crStateGetProgramHWID(program), name );
127 crServerReturnValue( &retval, sizeof(retval) );
128 return retval; /* WILL PROBABLY BE IGNORED */
129}
130
131VBoxGLhandleARB SERVER_DISPATCH_APIENTRY crServerDispatchGetHandleARB( GLenum pname )
132{
133 VBoxGLhandleARB retval;
134 retval = cr_server.head_spu->dispatch_table.GetHandleARB(pname);
135 if (pname==GL_PROGRAM_OBJECT_ARB)
136 {
137 retval = crStateGLSLProgramHWIDtoID(retval);
138 }
139 crServerReturnValue( &retval, sizeof(retval) );
140 return retval; /* WILL PROBABLY BE IGNORED */
141}
142
143GLint SERVER_DISPATCH_APIENTRY crServerDispatchGetUniformLocation(GLuint program, const char * name)
144{
145 GLint retval;
146 retval = cr_server.head_spu->dispatch_table.GetUniformLocation(crStateGetProgramHWID(program), name);
147 crServerReturnValue( &retval, sizeof(retval) );
148 return retval; /* WILL PROBABLY BE IGNORED */
149}
150
151void SERVER_DISPATCH_APIENTRY crServerDispatchGetProgramiv( GLuint program, GLenum pname, GLint * params )
152{
153 GLint local_params[1];
154 (void) params;
155 cr_server.head_spu->dispatch_table.GetProgramiv(crStateGetProgramHWID(program), pname, local_params);
156 crServerReturnValue( &(local_params[0]), 1*sizeof(GLint) );
157}
158
159void SERVER_DISPATCH_APIENTRY crServerDispatchGetShaderiv( GLuint shader, GLenum pname, GLint * params )
160{
161 GLint local_params[1];
162 (void) params;
163 cr_server.head_spu->dispatch_table.GetShaderiv( crStateGetShaderHWID(shader), pname, local_params );
164 crServerReturnValue( &(local_params[0]), 1*sizeof(GLint) );
165}
166#endif /* #ifdef CR_OPENGL_VERSION_2_0 */
167
168/* XXXX Note: shared/separate Program ID numbers aren't totally implemented! */
169GLuint crServerTranslateProgramID( GLuint id )
170{
171 if (!cr_server.sharedPrograms && id) {
172 int client = cr_server.curClient->number;
173 return id + client * 100000;
174 }
175 return id;
176}
177
178
179void SERVER_DISPATCH_APIENTRY crServerDispatchDeleteProgramsARB(GLsizei n, const GLuint * programs)
180{
181 GLuint *pLocalProgs;
182 GLint i;
183
184 if (n >= INT32_MAX / sizeof(GLuint))
185 {
186 crError("crServerDispatchDeleteProgramsARB: parameter 'n' is out of range");
187 return;
188 }
189
190 pLocalProgs = (GLuint *)crAlloc(n * sizeof(GLuint));
191
192 if (!pLocalProgs) {
193 crError("crServerDispatchDeleteProgramsARB: out of memory");
194 return;
195 }
196 for (i = 0; i < n; i++) {
197 pLocalProgs[i] = crServerTranslateProgramID(programs[i]);
198 }
199 crStateDeleteProgramsARB(n, pLocalProgs);
200 cr_server.head_spu->dispatch_table.DeleteProgramsARB(n, pLocalProgs);
201 crFree(pLocalProgs);
202}
203
204
205/** @todo will fail for progs loaded from snapshot */
206GLboolean SERVER_DISPATCH_APIENTRY crServerDispatchIsProgramARB( GLuint program )
207{
208 GLboolean retval;
209 program = crServerTranslateProgramID(program);
210 retval = cr_server.head_spu->dispatch_table.IsProgramARB( program );
211 crServerReturnValue( &retval, sizeof(retval) );
212 return retval; /* WILL PROBABLY BE IGNORED */
213}
214
215
216GLboolean SERVER_DISPATCH_APIENTRY
217crServerDispatchAreProgramsResidentNV(GLsizei n, const GLuint *programs,
218 GLboolean *residences)
219{
220 GLboolean retval = GL_FALSE;
221 GLboolean *res;
222 GLsizei i;
223 (void) residences;
224
225 if (n >= INT32_MAX / sizeof(GLuint))
226 {
227 crError("crServerDispatchAreProgramsResidentNV: parameter 'n' is out of range");
228 return GL_FALSE;
229 }
230
231 res = (GLboolean *)crCalloc(n * sizeof(GLboolean));
232
233 if (!res) {
234 crError("crServerDispatchAreProgramsResidentNV: out of memory");
235 return GL_FALSE;
236 }
237
238 if (!cr_server.sharedTextureObjects) {
239 GLuint *programs2 = (GLuint *) crCalloc(n * sizeof(GLuint));
240 if (programs2)
241 {
242 for (i = 0; i < n; i++)
243 programs2[i] = crServerTranslateProgramID(programs[i]);
244
245 retval = cr_server.head_spu->dispatch_table.AreProgramsResidentNV(n, programs2, res);
246 crFree(programs2);
247 }
248 else
249 {
250 crError("crServerDispatchAreProgramsResidentNV: out of memory");
251 }
252 }
253 else {
254 retval = cr_server.head_spu->dispatch_table.AreProgramsResidentNV(n, programs, res);
255 }
256
257 crServerReturnValue(res, n * sizeof(GLboolean));
258 crFree(res);
259
260 return retval; /* WILL PROBABLY BE IGNORED */
261}
262
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette