VirtualBox

source: vbox/trunk/src/VBox/Additions/common/crOpenGL/pack/packspu_getshaders.c@ 34310

Last change on this file since 34310 was 33045, checked in by vboxsync, 14 years ago

crOpenGL: fix GetObjectParameter[if]v accessing invalid shaders/programs

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 5.7 KB
Line 
1/* $Id: packspu_getshaders.c 33045 2010-10-11 16:57:21Z vboxsync $ */
2
3/** @file
4 * VBox OpenGL GLSL related functions
5 */
6
7/*
8 * Copyright (C) 2009 Oracle Corporation
9 *
10 * This file is part of VirtualBox Open Source Edition (OSE), as
11 * available from http://www.virtualbox.org. This file is free software;
12 * you can redistribute it and/or modify it under the terms of the GNU
13 * General Public License (GPL) as published by the Free Software
14 * Foundation, in version 2 as it comes in the "COPYING" file of the
15 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
16 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
17 */
18
19#include "packspu.h"
20#include "cr_packfunctions.h"
21#include "cr_net.h"
22#include "packspu_proto.h"
23#include "cr_mem.h"
24
25/*@todo combine with the one from server_getshaders.c*/
26typedef struct _crGetActive_t
27{
28 GLsizei length;
29 GLint size;
30 GLenum type;
31} crGetActive_t;
32
33void PACKSPU_APIENTRY packspu_GetActiveAttrib(GLuint program, GLuint index, GLsizei bufSize, GLsizei * length, GLint * size, GLenum * type, char * name)
34{
35 GET_THREAD(thread);
36 int writeback = 1;
37 crGetActive_t *pLocal;
38
39 if (!size || !type || !name) return;
40
41 pLocal = (crGetActive_t*) crAlloc(bufSize+sizeof(crGetActive_t));
42 if (!pLocal) return;
43
44 crPackGetActiveAttrib(program, index, bufSize, (GLsizei*)pLocal, NULL, NULL, NULL, &writeback);
45
46 packspuFlush((void *) thread);
47 while (writeback)
48 crNetRecv();
49
50 if (length) *length = pLocal->length;
51 *size = pLocal->size;
52 *type = pLocal->type;
53 crMemcpy(name, (char*)&pLocal[1], pLocal->length+1);
54 crFree(pLocal);
55}
56
57void PACKSPU_APIENTRY packspu_GetActiveUniform(GLuint program, GLuint index, GLsizei bufSize, GLsizei * length, GLint * size, GLenum * type, char * name)
58{
59 GET_THREAD(thread);
60 int writeback = 1;
61 crGetActive_t *pLocal;
62
63 if (!size || !type || !name) return;
64
65 pLocal = (crGetActive_t*) crAlloc(bufSize+sizeof(crGetActive_t));
66 if (!pLocal) return;
67
68 crPackGetActiveUniform(program, index, bufSize, (GLsizei*)pLocal, NULL, NULL, NULL, &writeback);
69
70 packspuFlush((void *) thread);
71 while (writeback)
72 crNetRecv();
73
74 if (length) *length = pLocal->length;
75 *size = pLocal->size;
76 *type = pLocal->type;
77 crMemcpy(name, &pLocal[1], pLocal->length+1);
78 crFree(pLocal);
79}
80
81void PACKSPU_APIENTRY packspu_GetAttachedShaders(GLuint program, GLsizei maxCount, GLsizei * count, GLuint * shaders)
82{
83 GET_THREAD(thread);
84 int writeback = 1;
85 GLsizei *pLocal;
86
87 if (!shaders) return;
88
89 pLocal = (GLsizei*) crAlloc(maxCount*sizeof(GLuint)+sizeof(GLsizei));
90 if (!pLocal) return;
91
92 crPackGetAttachedShaders(program, maxCount, pLocal, NULL, &writeback);
93
94 packspuFlush((void *) thread);
95 while (writeback)
96 crNetRecv();
97
98 if (count) *count=*pLocal;
99 crMemcpy(shaders, &pLocal[1], *pLocal*sizeof(GLuint));
100 crFree(pLocal);
101}
102
103void PACKSPU_APIENTRY packspu_GetAttachedObjectsARB(GLhandleARB containerObj, GLsizei maxCount, GLsizei * count, GLhandleARB * obj)
104{
105 GET_THREAD(thread);
106 int writeback = 1;
107 GLsizei *pLocal;
108
109 if (!obj) return;
110
111 pLocal = (GLsizei*) crAlloc(maxCount*sizeof(GLhandleARB)+sizeof(GLsizei));
112 if (!pLocal) return;
113
114 crPackGetAttachedObjectsARB(containerObj, maxCount, pLocal, NULL, &writeback);
115
116 packspuFlush((void *) thread);
117 while (writeback)
118 crNetRecv();
119
120 if (count) *count=*pLocal;
121 crMemcpy(obj, &pLocal[1], *pLocal*sizeof(GLhandleARB));
122 crFree(pLocal);
123}
124
125void PACKSPU_APIENTRY packspu_GetInfoLogARB(GLhandleARB obj, GLsizei maxLength, GLsizei * length, GLcharARB * infoLog)
126{
127 GET_THREAD(thread);
128 int writeback = 1;
129 GLsizei *pLocal;
130
131 if (!infoLog) return;
132
133 pLocal = (GLsizei*) crAlloc(maxLength+sizeof(GLsizei));
134 if (!pLocal) return;
135
136 crPackGetInfoLogARB(obj, maxLength, pLocal, NULL, &writeback);
137
138 packspuFlush((void *) thread);
139 while (writeback)
140 crNetRecv();
141
142 if (length) *length=*pLocal;
143 crMemcpy(infoLog, &pLocal[1], (*pLocal)+1);
144 crFree(pLocal);
145}
146
147void PACKSPU_APIENTRY packspu_GetProgramInfoLog(GLuint program, GLsizei bufSize, GLsizei * length, char * infoLog)
148{
149 GET_THREAD(thread);
150 int writeback = 1;
151 GLsizei *pLocal;
152
153 if (!infoLog) return;
154
155 pLocal = (GLsizei*) crAlloc(bufSize+sizeof(GLsizei));
156 if (!pLocal) return;
157
158 crPackGetProgramInfoLog(program, bufSize, pLocal, NULL, &writeback);
159
160 packspuFlush((void *) thread);
161 while (writeback)
162 crNetRecv();
163
164 if (length) *length=*pLocal;
165 crMemcpy(infoLog, &pLocal[1], (bufSize >= pLocal[0]) ? pLocal[0] : bufSize);
166 crFree(pLocal);
167}
168
169void PACKSPU_APIENTRY packspu_GetShaderInfoLog(GLuint shader, GLsizei bufSize, GLsizei * length, char * infoLog)
170{
171 GET_THREAD(thread);
172 int writeback = 1;
173 GLsizei *pLocal;
174
175 if (!infoLog) return;
176
177 pLocal = (GLsizei*) crAlloc(bufSize+sizeof(GLsizei));
178 if (!pLocal) return;
179
180 crPackGetShaderInfoLog(shader, bufSize, pLocal, NULL, &writeback);
181
182 packspuFlush((void *) thread);
183 while (writeback)
184 crNetRecv();
185
186 if (length) *length=*pLocal;
187 crMemcpy(infoLog, &pLocal[1], (bufSize >= pLocal[0]) ? pLocal[0] : bufSize);
188 crFree(pLocal);
189}
190
191void PACKSPU_APIENTRY packspu_GetShaderSource(GLuint shader, GLsizei bufSize, GLsizei * length, char * source)
192{
193 GET_THREAD(thread);
194 int writeback = 1;
195 GLsizei *pLocal;
196
197 if (!source) return;
198
199 pLocal = (GLsizei*) crAlloc(bufSize+sizeof(GLsizei));
200 if (!pLocal) return;
201
202 crPackGetShaderSource(shader, bufSize, pLocal, NULL, &writeback);
203
204 packspuFlush((void *) thread);
205 while (writeback)
206 crNetRecv();
207
208 if (length) *length=*pLocal;
209 crMemcpy(source, &pLocal[1], (bufSize >= pLocal[0]) ? pLocal[0] : bufSize);
210 crFree(pLocal);
211}
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