VirtualBox

source: vbox/trunk/src/VBox/HostServices/SharedOpenGL/unpacker/unpack_shaders.c@ 76553

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

scm --update-copyright-year

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id Revision
File size: 11.4 KB
Line 
1/* $Id: unpack_shaders.c 76553 2019-01-01 01:45:53Z vboxsync $ */
2/** @file
3 * VBox OpenGL DRI driver functions
4 */
5
6/*
7 * Copyright (C) 2009-2019 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 "unpacker.h"
19#include "cr_error.h"
20#include "cr_protocol.h"
21#include "cr_mem.h"
22#include "cr_string.h"
23#include "cr_version.h"
24
25void crUnpackExtendBindAttribLocation(void)
26{
27 GLuint program = READ_DATA(8, GLuint);
28 GLuint index = READ_DATA(12, GLuint);
29 const char *name = DATA_POINTER(16, const char);
30
31 cr_unpackDispatch.BindAttribLocation(program, index, name);
32}
33
34void crUnpackExtendShaderSource(void)
35{
36 GLint *length = NULL;
37 GLuint shader = READ_DATA(8, GLuint);
38 GLsizei count = READ_DATA(12, GLsizei);
39 GLint hasNonLocalLen = READ_DATA(16, GLsizei);
40 GLint *pLocalLength = DATA_POINTER(20, GLint);
41 char **ppStrings = NULL;
42 GLsizei i, j, jUpTo;
43 int pos, pos_check;
44
45 if (count >= UINT32_MAX / sizeof(char *) / 4)
46 {
47 crError("crUnpackExtendShaderSource: count %u is out of range", count);
48 return;
49 }
50
51 pos = 20 + count * sizeof(*pLocalLength);
52
53 if (hasNonLocalLen > 0)
54 {
55 length = DATA_POINTER(pos, GLint);
56 pos += count * sizeof(*length);
57 }
58
59 pos_check = pos;
60
61 if (!DATA_POINTER_CHECK(pos_check))
62 {
63 crError("crUnpackExtendShaderSource: pos %d is out of range", pos_check);
64 return;
65 }
66
67 for (i = 0; i < count; ++i)
68 {
69 if (pLocalLength[i] <= 0 || pos_check >= INT32_MAX - pLocalLength[i] || !DATA_POINTER_CHECK(pos_check))
70 {
71 crError("crUnpackExtendShaderSource: pos %d is out of range", pos_check);
72 return;
73 }
74
75 pos_check += pLocalLength[i];
76 }
77
78 ppStrings = crAlloc(count * sizeof(char*));
79 if (!ppStrings) return;
80
81 for (i = 0; i < count; ++i)
82 {
83 ppStrings[i] = DATA_POINTER(pos, char);
84 pos += pLocalLength[i];
85 if (!length)
86 {
87 pLocalLength[i] -= 1;
88 }
89
90 Assert(pLocalLength[i] > 0);
91 jUpTo = i == count -1 ? pLocalLength[i] - 1 : pLocalLength[i];
92 for (j = 0; j < jUpTo; ++j)
93 {
94 char *pString = ppStrings[i];
95
96 if (pString[j] == '\0')
97 {
98 Assert(j == jUpTo - 1);
99 pString[j] = '\n';
100 }
101 }
102 }
103
104// cr_unpackDispatch.ShaderSource(shader, count, ppStrings, length ? length : pLocalLength);
105 cr_unpackDispatch.ShaderSource(shader, 1, (const char**)ppStrings, 0);
106
107 crFree(ppStrings);
108}
109
110void crUnpackExtendUniform1fv(void)
111{
112 GLint location = READ_DATA(8, GLint);
113 GLsizei count = READ_DATA(12, GLsizei);
114 const GLfloat *value = DATA_POINTER(16, const GLfloat);
115 cr_unpackDispatch.Uniform1fv(location, count, value);
116}
117
118void crUnpackExtendUniform1iv(void)
119{
120 GLint location = READ_DATA(8, GLint);
121 GLsizei count = READ_DATA(12, GLsizei);
122 const GLint *value = DATA_POINTER(16, const GLint);
123 cr_unpackDispatch.Uniform1iv(location, count, value);
124}
125
126void crUnpackExtendUniform2fv(void)
127{
128 GLint location = READ_DATA(8, GLint);
129 GLsizei count = READ_DATA(12, GLsizei);
130 const GLfloat *value = DATA_POINTER(16, const GLfloat);
131 cr_unpackDispatch.Uniform2fv(location, count, value);
132}
133
134void crUnpackExtendUniform2iv(void)
135{
136 GLint location = READ_DATA(8, GLint);
137 GLsizei count = READ_DATA(12, GLsizei);
138 const GLint *value = DATA_POINTER(16, const GLint);
139 cr_unpackDispatch.Uniform2iv(location, count, value);
140}
141
142void crUnpackExtendUniform3fv(void)
143{
144 GLint location = READ_DATA(8, GLint);
145 GLsizei count = READ_DATA(12, GLsizei);
146 const GLfloat *value = DATA_POINTER(16, const GLfloat);
147 cr_unpackDispatch.Uniform3fv(location, count, value);
148}
149
150void crUnpackExtendUniform3iv(void)
151{
152 GLint location = READ_DATA(8, GLint);
153 GLsizei count = READ_DATA(12, GLsizei);
154 const GLint *value = DATA_POINTER(16, const GLint);
155 cr_unpackDispatch.Uniform3iv(location, count, value);
156}
157
158void crUnpackExtendUniform4fv(void)
159{
160 GLint location = READ_DATA(8, GLint);
161 GLsizei count = READ_DATA(12, GLsizei);
162 const GLfloat *value = DATA_POINTER(16, const GLfloat);
163 cr_unpackDispatch.Uniform4fv(location, count, value);
164}
165
166void crUnpackExtendUniform4iv(void)
167{
168 GLint location = READ_DATA(8, GLint);
169 GLsizei count = READ_DATA(12, GLsizei);
170 const GLint *value = DATA_POINTER(16, const GLint);
171 cr_unpackDispatch.Uniform4iv(location, count, value);
172}
173
174void crUnpackExtendUniformMatrix2fv(void)
175{
176 GLint location = READ_DATA(8, GLint);
177 GLsizei count = READ_DATA(12, GLsizei);
178 GLboolean transpose = READ_DATA(16, GLboolean);
179 const GLfloat *value = DATA_POINTER(16+sizeof(GLboolean), const GLfloat);
180 cr_unpackDispatch.UniformMatrix2fv(location, count, transpose, value);
181}
182
183void crUnpackExtendUniformMatrix3fv(void)
184{
185 GLint location = READ_DATA(8, GLint);
186 GLsizei count = READ_DATA(12, GLsizei);
187 GLboolean transpose = READ_DATA(16, GLboolean);
188 const GLfloat *value = DATA_POINTER(16+sizeof(GLboolean), const GLfloat);
189 cr_unpackDispatch.UniformMatrix3fv(location, count, transpose, value);
190}
191
192void crUnpackExtendUniformMatrix4fv(void)
193{
194 GLint location = READ_DATA(8, GLint);
195 GLsizei count = READ_DATA(12, GLsizei);
196 GLboolean transpose = READ_DATA(16, GLboolean);
197 const GLfloat *value = DATA_POINTER(16+sizeof(GLboolean), const GLfloat);
198 cr_unpackDispatch.UniformMatrix4fv(location, count, transpose, value);
199}
200
201void crUnpackExtendUniformMatrix2x3fv(void)
202{
203 GLint location = READ_DATA(8, GLint);
204 GLsizei count = READ_DATA(12, GLsizei);
205 GLboolean transpose = READ_DATA(16, GLboolean);
206 const GLfloat *value = DATA_POINTER(16+sizeof(GLboolean), const GLfloat);
207 cr_unpackDispatch.UniformMatrix2x3fv(location, count, transpose, value);
208}
209
210void crUnpackExtendUniformMatrix3x2fv(void)
211{
212 GLint location = READ_DATA(8, GLint);
213 GLsizei count = READ_DATA(12, GLsizei);
214 GLboolean transpose = READ_DATA(16, GLboolean);
215 const GLfloat *value = DATA_POINTER(16+sizeof(GLboolean), const GLfloat);
216 cr_unpackDispatch.UniformMatrix3x2fv(location, count, transpose, value);
217}
218
219void crUnpackExtendUniformMatrix2x4fv(void)
220{
221 GLint location = READ_DATA(8, GLint);
222 GLsizei count = READ_DATA(12, GLsizei);
223 GLboolean transpose = READ_DATA(16, GLboolean);
224 const GLfloat *value = DATA_POINTER(16+sizeof(GLboolean), const GLfloat);
225 cr_unpackDispatch.UniformMatrix2x4fv(location, count, transpose, value);
226}
227
228void crUnpackExtendUniformMatrix4x2fv(void)
229{
230 GLint location = READ_DATA(8, GLint);
231 GLsizei count = READ_DATA(12, GLsizei);
232 GLboolean transpose = READ_DATA(16, GLboolean);
233 const GLfloat *value = DATA_POINTER(16+sizeof(GLboolean), const GLfloat);
234 cr_unpackDispatch.UniformMatrix4x2fv(location, count, transpose, value);
235}
236
237void crUnpackExtendUniformMatrix3x4fv(void)
238{
239 GLint location = READ_DATA(8, GLint);
240 GLsizei count = READ_DATA(12, GLsizei);
241 GLboolean transpose = READ_DATA(16, GLboolean);
242 const GLfloat *value = DATA_POINTER(16+sizeof(GLboolean), const GLfloat);
243 cr_unpackDispatch.UniformMatrix3x4fv(location, count, transpose, value);
244}
245
246void crUnpackExtendUniformMatrix4x3fv(void)
247{
248 GLint location = READ_DATA(8, GLint);
249 GLsizei count = READ_DATA(12, GLsizei);
250 GLboolean transpose = READ_DATA(16, GLboolean);
251 const GLfloat *value = DATA_POINTER(16+sizeof(GLboolean), const GLfloat);
252 cr_unpackDispatch.UniformMatrix4x3fv(location, count, transpose, value);
253}
254
255void crUnpackExtendDrawBuffers(void)
256{
257 GLsizei n = READ_DATA(8, GLsizei);
258 const GLenum *bufs = DATA_POINTER(8+sizeof(GLsizei), const GLenum);
259 cr_unpackDispatch.DrawBuffers(n, bufs);
260}
261
262void crUnpackExtendGetActiveAttrib(void)
263{
264 GLuint program = READ_DATA(8, GLuint);
265 GLuint index = READ_DATA(12, GLuint);
266 GLsizei bufSize = READ_DATA(16, GLsizei);
267 SET_RETURN_PTR(20);
268 SET_WRITEBACK_PTR(28);
269 cr_unpackDispatch.GetActiveAttrib(program, index, bufSize, NULL, NULL, NULL, NULL);
270}
271
272void crUnpackExtendGetActiveUniform(void)
273{
274 GLuint program = READ_DATA(8, GLuint);
275 GLuint index = READ_DATA(12, GLuint);
276 GLsizei bufSize = READ_DATA(16, GLsizei);
277 SET_RETURN_PTR(20);
278 SET_WRITEBACK_PTR(28);
279 cr_unpackDispatch.GetActiveUniform(program, index, bufSize, NULL, NULL, NULL, NULL);
280}
281
282void crUnpackExtendGetAttachedShaders(void)
283{
284 GLuint program = READ_DATA(8, GLuint);
285 GLsizei maxCount = READ_DATA(12, GLsizei);
286 SET_RETURN_PTR(16);
287 SET_WRITEBACK_PTR(24);
288 cr_unpackDispatch.GetAttachedShaders(program, maxCount, NULL, NULL);
289}
290
291void crUnpackExtendGetAttachedObjectsARB(void)
292{
293 VBoxGLhandleARB containerObj = READ_DATA(8, VBoxGLhandleARB);
294 GLsizei maxCount = READ_DATA(12, GLsizei);
295 SET_RETURN_PTR(16);
296 SET_WRITEBACK_PTR(24);
297 cr_unpackDispatch.GetAttachedObjectsARB(containerObj, maxCount, NULL, NULL);
298}
299
300void crUnpackExtendGetInfoLogARB(void)
301{
302 VBoxGLhandleARB obj = READ_DATA(8, VBoxGLhandleARB);
303 GLsizei maxLength = READ_DATA(12, GLsizei);
304 SET_RETURN_PTR(16);
305 SET_WRITEBACK_PTR(24);
306 cr_unpackDispatch.GetInfoLogARB(obj, maxLength, NULL, NULL);
307}
308
309void crUnpackExtendGetProgramInfoLog(void)
310{
311 GLuint program = READ_DATA(8, GLuint);
312 GLsizei bufSize = READ_DATA(12, GLsizei);
313 SET_RETURN_PTR(16);
314 SET_WRITEBACK_PTR(24);
315 cr_unpackDispatch.GetProgramInfoLog(program, bufSize, NULL, NULL);
316}
317
318void crUnpackExtendGetShaderInfoLog(void)
319{
320 GLuint shader = READ_DATA(8, GLuint);
321 GLsizei bufSize = READ_DATA(12, GLsizei);
322 SET_RETURN_PTR(16);
323 SET_WRITEBACK_PTR(24);
324 cr_unpackDispatch.GetShaderInfoLog(shader, bufSize, NULL, NULL);
325}
326
327void crUnpackExtendGetShaderSource(void)
328{
329 GLuint shader = READ_DATA(8, GLuint);
330 GLsizei bufSize = READ_DATA(12, GLsizei);
331 SET_RETURN_PTR(16);
332 SET_WRITEBACK_PTR(24);
333 cr_unpackDispatch.GetShaderSource(shader, bufSize, NULL, NULL);
334}
335
336void crUnpackExtendGetAttribLocation(void)
337{
338 int packet_length = READ_DATA(0, int);
339 GLuint program = READ_DATA(8, GLuint);
340 const char *name = DATA_POINTER(12, const char);
341 SET_RETURN_PTR(packet_length-16);
342 SET_WRITEBACK_PTR(packet_length-8);
343 cr_unpackDispatch.GetAttribLocation(program, name);
344}
345
346void crUnpackExtendGetUniformLocation(void)
347{
348 int packet_length = READ_DATA(0, int);
349 GLuint program = READ_DATA(8, GLuint);
350 const char *name = DATA_POINTER(12, const char);
351 SET_RETURN_PTR(packet_length-16);
352 SET_WRITEBACK_PTR(packet_length-8);
353 cr_unpackDispatch.GetUniformLocation(program, name);
354}
355
356void crUnpackExtendGetUniformsLocations(void)
357{
358 GLuint program = READ_DATA(8, GLuint);
359 GLsizei maxcbData = READ_DATA(12, GLsizei);
360 SET_RETURN_PTR(16);
361 SET_WRITEBACK_PTR(24);
362 cr_unpackDispatch.GetUniformsLocations(program, maxcbData, NULL, NULL);
363}
364
365void crUnpackExtendGetAttribsLocations(void)
366{
367 GLuint program = READ_DATA(8, GLuint);
368 GLsizei maxcbData = READ_DATA(12, GLsizei);
369 SET_RETURN_PTR(16);
370 SET_WRITEBACK_PTR(24);
371 cr_unpackDispatch.GetAttribsLocations(program, maxcbData, NULL, NULL);
372}
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