OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 // | 4 // |
5 // This file is auto-generated from | 5 // This file is auto-generated from |
6 // ui/gl/generate_bindings.py | 6 // ui/gl/generate_bindings.py |
7 // It's formatted by clang-format using chromium coding style: | 7 // It's formatted by clang-format using chromium coding style: |
8 // clang-format -i -style=chromium filename | 8 // clang-format -i -style=chromium filename |
9 // DO NOT EDIT! | 9 // DO NOT EDIT! |
10 | 10 |
11 #include <string> | 11 #include <string> |
12 | 12 |
13 #include "base/trace_event/trace_event.h" | 13 #include "base/trace_event/trace_event.h" |
14 #include "ui/gl/gl_bindings.h" | 14 #include "ui/gl/gl_bindings.h" |
15 #include "ui/gl/gl_context.h" | 15 #include "ui/gl/gl_context.h" |
16 #include "ui/gl/gl_enums.h" | 16 #include "ui/gl/gl_enums.h" |
17 #include "ui/gl/gl_glx_api_implementation.h" | 17 #include "ui/gl/gl_glx_api_implementation.h" |
18 #include "ui/gl/gl_implementation.h" | 18 #include "ui/gl/gl_implementation.h" |
19 #include "ui/gl/gl_version_info.h" | 19 #include "ui/gl/gl_version_info.h" |
20 | 20 |
21 namespace gl { | 21 namespace gl { |
22 | 22 |
23 static bool g_debugBindingsInitialized; | |
24 DriverGLX g_driver_glx; | 23 DriverGLX g_driver_glx; |
25 | 24 |
26 void DriverGLX::InitializeStaticBindings() { | 25 void DriverGLX::InitializeStaticBindings() { |
27 fn.glXBindTexImageEXTFn = 0; | 26 fn.glXBindTexImageEXTFn = 0; |
28 fn.glXChooseFBConfigFn = reinterpret_cast<glXChooseFBConfigProc>( | 27 fn.glXChooseFBConfigFn = reinterpret_cast<glXChooseFBConfigProc>( |
29 GetGLProcAddress("glXChooseFBConfig")); | 28 GetGLProcAddress("glXChooseFBConfig")); |
30 fn.glXChooseVisualFn = reinterpret_cast<glXChooseVisualProc>( | 29 fn.glXChooseVisualFn = reinterpret_cast<glXChooseVisualProc>( |
31 GetGLProcAddress("glXChooseVisual")); | 30 GetGLProcAddress("glXChooseVisual")); |
32 fn.glXCopyContextFn = | 31 fn.glXCopyContextFn = |
33 reinterpret_cast<glXCopyContextProc>(GetGLProcAddress("glXCopyContext")); | 32 reinterpret_cast<glXCopyContextProc>(GetGLProcAddress("glXCopyContext")); |
(...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
129 extensions.find("GLX_MESA_copy_sub_buffer ") != std::string::npos; | 128 extensions.find("GLX_MESA_copy_sub_buffer ") != std::string::npos; |
130 ext.b_GLX_MESA_swap_control = | 129 ext.b_GLX_MESA_swap_control = |
131 extensions.find("GLX_MESA_swap_control ") != std::string::npos; | 130 extensions.find("GLX_MESA_swap_control ") != std::string::npos; |
132 ext.b_GLX_OML_sync_control = | 131 ext.b_GLX_OML_sync_control = |
133 extensions.find("GLX_OML_sync_control ") != std::string::npos; | 132 extensions.find("GLX_OML_sync_control ") != std::string::npos; |
134 ext.b_GLX_SGIX_fbconfig = | 133 ext.b_GLX_SGIX_fbconfig = |
135 extensions.find("GLX_SGIX_fbconfig ") != std::string::npos; | 134 extensions.find("GLX_SGIX_fbconfig ") != std::string::npos; |
136 ext.b_GLX_SGI_video_sync = | 135 ext.b_GLX_SGI_video_sync = |
137 extensions.find("GLX_SGI_video_sync ") != std::string::npos; | 136 extensions.find("GLX_SGI_video_sync ") != std::string::npos; |
138 | 137 |
139 debug_fn.glXBindTexImageEXTFn = 0; | |
140 if (ext.b_GLX_EXT_texture_from_pixmap) { | 138 if (ext.b_GLX_EXT_texture_from_pixmap) { |
141 fn.glXBindTexImageEXTFn = reinterpret_cast<glXBindTexImageEXTProc>( | 139 fn.glXBindTexImageEXTFn = reinterpret_cast<glXBindTexImageEXTProc>( |
142 GetGLProcAddress("glXBindTexImageEXT")); | 140 GetGLProcAddress("glXBindTexImageEXT")); |
143 } | 141 } |
144 | 142 |
145 debug_fn.glXCopySubBufferMESAFn = 0; | |
146 if (ext.b_GLX_MESA_copy_sub_buffer) { | 143 if (ext.b_GLX_MESA_copy_sub_buffer) { |
147 fn.glXCopySubBufferMESAFn = reinterpret_cast<glXCopySubBufferMESAProc>( | 144 fn.glXCopySubBufferMESAFn = reinterpret_cast<glXCopySubBufferMESAProc>( |
148 GetGLProcAddress("glXCopySubBufferMESA")); | 145 GetGLProcAddress("glXCopySubBufferMESA")); |
149 } | 146 } |
150 | 147 |
151 debug_fn.glXCreateContextAttribsARBFn = 0; | |
152 if (ext.b_GLX_ARB_create_context) { | 148 if (ext.b_GLX_ARB_create_context) { |
153 fn.glXCreateContextAttribsARBFn = | 149 fn.glXCreateContextAttribsARBFn = |
154 reinterpret_cast<glXCreateContextAttribsARBProc>( | 150 reinterpret_cast<glXCreateContextAttribsARBProc>( |
155 GetGLProcAddress("glXCreateContextAttribsARB")); | 151 GetGLProcAddress("glXCreateContextAttribsARB")); |
156 } | 152 } |
157 | 153 |
158 debug_fn.glXGetFBConfigFromVisualSGIXFn = 0; | |
159 if (ext.b_GLX_SGIX_fbconfig) { | 154 if (ext.b_GLX_SGIX_fbconfig) { |
160 fn.glXGetFBConfigFromVisualSGIXFn = | 155 fn.glXGetFBConfigFromVisualSGIXFn = |
161 reinterpret_cast<glXGetFBConfigFromVisualSGIXProc>( | 156 reinterpret_cast<glXGetFBConfigFromVisualSGIXProc>( |
162 GetGLProcAddress("glXGetFBConfigFromVisualSGIX")); | 157 GetGLProcAddress("glXGetFBConfigFromVisualSGIX")); |
163 } | 158 } |
164 | 159 |
165 debug_fn.glXGetMscRateOMLFn = 0; | |
166 if (ext.b_GLX_OML_sync_control) { | 160 if (ext.b_GLX_OML_sync_control) { |
167 fn.glXGetMscRateOMLFn = reinterpret_cast<glXGetMscRateOMLProc>( | 161 fn.glXGetMscRateOMLFn = reinterpret_cast<glXGetMscRateOMLProc>( |
168 GetGLProcAddress("glXGetMscRateOML")); | 162 GetGLProcAddress("glXGetMscRateOML")); |
169 } | 163 } |
170 | 164 |
171 debug_fn.glXGetSyncValuesOMLFn = 0; | |
172 if (ext.b_GLX_OML_sync_control) { | 165 if (ext.b_GLX_OML_sync_control) { |
173 fn.glXGetSyncValuesOMLFn = reinterpret_cast<glXGetSyncValuesOMLProc>( | 166 fn.glXGetSyncValuesOMLFn = reinterpret_cast<glXGetSyncValuesOMLProc>( |
174 GetGLProcAddress("glXGetSyncValuesOML")); | 167 GetGLProcAddress("glXGetSyncValuesOML")); |
175 } | 168 } |
176 | 169 |
177 debug_fn.glXReleaseTexImageEXTFn = 0; | |
178 if (ext.b_GLX_EXT_texture_from_pixmap) { | 170 if (ext.b_GLX_EXT_texture_from_pixmap) { |
179 fn.glXReleaseTexImageEXTFn = reinterpret_cast<glXReleaseTexImageEXTProc>( | 171 fn.glXReleaseTexImageEXTFn = reinterpret_cast<glXReleaseTexImageEXTProc>( |
180 GetGLProcAddress("glXReleaseTexImageEXT")); | 172 GetGLProcAddress("glXReleaseTexImageEXT")); |
181 } | 173 } |
182 | 174 |
183 debug_fn.glXSwapIntervalEXTFn = 0; | |
184 if (ext.b_GLX_EXT_swap_control) { | 175 if (ext.b_GLX_EXT_swap_control) { |
185 fn.glXSwapIntervalEXTFn = reinterpret_cast<glXSwapIntervalEXTProc>( | 176 fn.glXSwapIntervalEXTFn = reinterpret_cast<glXSwapIntervalEXTProc>( |
186 GetGLProcAddress("glXSwapIntervalEXT")); | 177 GetGLProcAddress("glXSwapIntervalEXT")); |
187 } | 178 } |
188 | 179 |
189 debug_fn.glXSwapIntervalMESAFn = 0; | |
190 if (ext.b_GLX_MESA_swap_control) { | 180 if (ext.b_GLX_MESA_swap_control) { |
191 fn.glXSwapIntervalMESAFn = reinterpret_cast<glXSwapIntervalMESAProc>( | 181 fn.glXSwapIntervalMESAFn = reinterpret_cast<glXSwapIntervalMESAProc>( |
192 GetGLProcAddress("glXSwapIntervalMESA")); | 182 GetGLProcAddress("glXSwapIntervalMESA")); |
193 } | 183 } |
194 | 184 |
195 debug_fn.glXWaitVideoSyncSGIFn = 0; | |
196 if (ext.b_GLX_SGI_video_sync) { | 185 if (ext.b_GLX_SGI_video_sync) { |
197 fn.glXWaitVideoSyncSGIFn = reinterpret_cast<glXWaitVideoSyncSGIProc>( | 186 fn.glXWaitVideoSyncSGIFn = reinterpret_cast<glXWaitVideoSyncSGIProc>( |
198 GetGLProcAddress("glXWaitVideoSyncSGI")); | 187 GetGLProcAddress("glXWaitVideoSyncSGI")); |
199 } | 188 } |
200 | |
201 if (g_debugBindingsInitialized) | |
202 InitializeDebugBindings(); | |
203 } | |
204 | |
205 extern "C" { | |
206 | |
207 static void GL_BINDING_CALL Debug_glXBindTexImageEXT(Display* dpy, | |
208 GLXDrawable drawable, | |
209 int buffer, | |
210 int* attribList) { | |
211 GL_SERVICE_LOG("glXBindTexImageEXT" | |
212 << "(" << static_cast<const void*>(dpy) << ", " << drawable | |
213 << ", " << buffer << ", " | |
214 << static_cast<const void*>(attribList) << ")"); | |
215 DCHECK(g_driver_glx.debug_fn.glXBindTexImageEXTFn != nullptr); | |
216 g_driver_glx.debug_fn.glXBindTexImageEXTFn(dpy, drawable, buffer, attribList); | |
217 } | |
218 | |
219 static GLXFBConfig* GL_BINDING_CALL | |
220 Debug_glXChooseFBConfig(Display* dpy, | |
221 int screen, | |
222 const int* attribList, | |
223 int* nitems) { | |
224 GL_SERVICE_LOG("glXChooseFBConfig" | |
225 << "(" << static_cast<const void*>(dpy) << ", " << screen | |
226 << ", " << static_cast<const void*>(attribList) << ", " | |
227 << static_cast<const void*>(nitems) << ")"); | |
228 DCHECK(g_driver_glx.debug_fn.glXChooseFBConfigFn != nullptr); | |
229 GLXFBConfig* result = g_driver_glx.debug_fn.glXChooseFBConfigFn( | |
230 dpy, screen, attribList, nitems); | |
231 GL_SERVICE_LOG("GL_RESULT: " << result); | |
232 return result; | |
233 } | |
234 | |
235 static XVisualInfo* GL_BINDING_CALL Debug_glXChooseVisual(Display* dpy, | |
236 int screen, | |
237 int* attribList) { | |
238 GL_SERVICE_LOG("glXChooseVisual" | |
239 << "(" << static_cast<const void*>(dpy) << ", " << screen | |
240 << ", " << static_cast<const void*>(attribList) << ")"); | |
241 DCHECK(g_driver_glx.debug_fn.glXChooseVisualFn != nullptr); | |
242 XVisualInfo* result = | |
243 g_driver_glx.debug_fn.glXChooseVisualFn(dpy, screen, attribList); | |
244 GL_SERVICE_LOG("GL_RESULT: " << result); | |
245 return result; | |
246 } | |
247 | |
248 static void GL_BINDING_CALL Debug_glXCopyContext(Display* dpy, | |
249 GLXContext src, | |
250 GLXContext dst, | |
251 unsigned long mask) { | |
252 GL_SERVICE_LOG("glXCopyContext" | |
253 << "(" << static_cast<const void*>(dpy) << ", " << src << ", " | |
254 << dst << ", " << mask << ")"); | |
255 DCHECK(g_driver_glx.debug_fn.glXCopyContextFn != nullptr); | |
256 g_driver_glx.debug_fn.glXCopyContextFn(dpy, src, dst, mask); | |
257 } | |
258 | |
259 static void GL_BINDING_CALL Debug_glXCopySubBufferMESA(Display* dpy, | |
260 GLXDrawable drawable, | |
261 int x, | |
262 int y, | |
263 int width, | |
264 int height) { | |
265 GL_SERVICE_LOG("glXCopySubBufferMESA" | |
266 << "(" << static_cast<const void*>(dpy) << ", " << drawable | |
267 << ", " << x << ", " << y << ", " << width << ", " << height | |
268 << ")"); | |
269 DCHECK(g_driver_glx.debug_fn.glXCopySubBufferMESAFn != nullptr); | |
270 g_driver_glx.debug_fn.glXCopySubBufferMESAFn(dpy, drawable, x, y, width, | |
271 height); | |
272 } | |
273 | |
274 static GLXContext GL_BINDING_CALL Debug_glXCreateContext(Display* dpy, | |
275 XVisualInfo* vis, | |
276 GLXContext shareList, | |
277 int direct) { | |
278 GL_SERVICE_LOG("glXCreateContext" | |
279 << "(" << static_cast<const void*>(dpy) << ", " | |
280 << static_cast<const void*>(vis) << ", " << shareList << ", " | |
281 << direct << ")"); | |
282 DCHECK(g_driver_glx.debug_fn.glXCreateContextFn != nullptr); | |
283 GLXContext result = | |
284 g_driver_glx.debug_fn.glXCreateContextFn(dpy, vis, shareList, direct); | |
285 GL_SERVICE_LOG("GL_RESULT: " << result); | |
286 return result; | |
287 } | |
288 | |
289 static GLXContext GL_BINDING_CALL | |
290 Debug_glXCreateContextAttribsARB(Display* dpy, | |
291 GLXFBConfig config, | |
292 GLXContext share_context, | |
293 int direct, | |
294 const int* attrib_list) { | |
295 GL_SERVICE_LOG("glXCreateContextAttribsARB" | |
296 << "(" << static_cast<const void*>(dpy) << ", " << config | |
297 << ", " << share_context << ", " << direct << ", " | |
298 << static_cast<const void*>(attrib_list) << ")"); | |
299 DCHECK(g_driver_glx.debug_fn.glXCreateContextAttribsARBFn != nullptr); | |
300 GLXContext result = g_driver_glx.debug_fn.glXCreateContextAttribsARBFn( | |
301 dpy, config, share_context, direct, attrib_list); | |
302 GL_SERVICE_LOG("GL_RESULT: " << result); | |
303 return result; | |
304 } | |
305 | |
306 static GLXPixmap GL_BINDING_CALL Debug_glXCreateGLXPixmap(Display* dpy, | |
307 XVisualInfo* visual, | |
308 Pixmap pixmap) { | |
309 GL_SERVICE_LOG("glXCreateGLXPixmap" | |
310 << "(" << static_cast<const void*>(dpy) << ", " | |
311 << static_cast<const void*>(visual) << ", " << pixmap << ")"); | |
312 DCHECK(g_driver_glx.debug_fn.glXCreateGLXPixmapFn != nullptr); | |
313 GLXPixmap result = | |
314 g_driver_glx.debug_fn.glXCreateGLXPixmapFn(dpy, visual, pixmap); | |
315 GL_SERVICE_LOG("GL_RESULT: " << result); | |
316 return result; | |
317 } | |
318 | |
319 static GLXContext GL_BINDING_CALL | |
320 Debug_glXCreateNewContext(Display* dpy, | |
321 GLXFBConfig config, | |
322 int renderType, | |
323 GLXContext shareList, | |
324 int direct) { | |
325 GL_SERVICE_LOG("glXCreateNewContext" | |
326 << "(" << static_cast<const void*>(dpy) << ", " << config | |
327 << ", " << renderType << ", " << shareList << ", " << direct | |
328 << ")"); | |
329 DCHECK(g_driver_glx.debug_fn.glXCreateNewContextFn != nullptr); | |
330 GLXContext result = g_driver_glx.debug_fn.glXCreateNewContextFn( | |
331 dpy, config, renderType, shareList, direct); | |
332 GL_SERVICE_LOG("GL_RESULT: " << result); | |
333 return result; | |
334 } | |
335 | |
336 static GLXPbuffer GL_BINDING_CALL | |
337 Debug_glXCreatePbuffer(Display* dpy, | |
338 GLXFBConfig config, | |
339 const int* attribList) { | |
340 GL_SERVICE_LOG("glXCreatePbuffer" | |
341 << "(" << static_cast<const void*>(dpy) << ", " << config | |
342 << ", " << static_cast<const void*>(attribList) << ")"); | |
343 DCHECK(g_driver_glx.debug_fn.glXCreatePbufferFn != nullptr); | |
344 GLXPbuffer result = | |
345 g_driver_glx.debug_fn.glXCreatePbufferFn(dpy, config, attribList); | |
346 GL_SERVICE_LOG("GL_RESULT: " << result); | |
347 return result; | |
348 } | |
349 | |
350 static GLXPixmap GL_BINDING_CALL Debug_glXCreatePixmap(Display* dpy, | |
351 GLXFBConfig config, | |
352 Pixmap pixmap, | |
353 const int* attribList) { | |
354 GL_SERVICE_LOG("glXCreatePixmap" | |
355 << "(" << static_cast<const void*>(dpy) << ", " << config | |
356 << ", " << pixmap << ", " | |
357 << static_cast<const void*>(attribList) << ")"); | |
358 DCHECK(g_driver_glx.debug_fn.glXCreatePixmapFn != nullptr); | |
359 GLXPixmap result = | |
360 g_driver_glx.debug_fn.glXCreatePixmapFn(dpy, config, pixmap, attribList); | |
361 GL_SERVICE_LOG("GL_RESULT: " << result); | |
362 return result; | |
363 } | |
364 | |
365 static GLXWindow GL_BINDING_CALL Debug_glXCreateWindow(Display* dpy, | |
366 GLXFBConfig config, | |
367 Window win, | |
368 const int* attribList) { | |
369 GL_SERVICE_LOG("glXCreateWindow" | |
370 << "(" << static_cast<const void*>(dpy) << ", " << config | |
371 << ", " << win << ", " << static_cast<const void*>(attribList) | |
372 << ")"); | |
373 DCHECK(g_driver_glx.debug_fn.glXCreateWindowFn != nullptr); | |
374 GLXWindow result = | |
375 g_driver_glx.debug_fn.glXCreateWindowFn(dpy, config, win, attribList); | |
376 GL_SERVICE_LOG("GL_RESULT: " << result); | |
377 return result; | |
378 } | |
379 | |
380 static void GL_BINDING_CALL Debug_glXDestroyContext(Display* dpy, | |
381 GLXContext ctx) { | |
382 GL_SERVICE_LOG("glXDestroyContext" | |
383 << "(" << static_cast<const void*>(dpy) << ", " << ctx << ")"); | |
384 DCHECK(g_driver_glx.debug_fn.glXDestroyContextFn != nullptr); | |
385 g_driver_glx.debug_fn.glXDestroyContextFn(dpy, ctx); | |
386 } | |
387 | |
388 static void GL_BINDING_CALL Debug_glXDestroyGLXPixmap(Display* dpy, | |
389 GLXPixmap pixmap) { | |
390 GL_SERVICE_LOG("glXDestroyGLXPixmap" | |
391 << "(" << static_cast<const void*>(dpy) << ", " << pixmap | |
392 << ")"); | |
393 DCHECK(g_driver_glx.debug_fn.glXDestroyGLXPixmapFn != nullptr); | |
394 g_driver_glx.debug_fn.glXDestroyGLXPixmapFn(dpy, pixmap); | |
395 } | |
396 | |
397 static void GL_BINDING_CALL Debug_glXDestroyPbuffer(Display* dpy, | |
398 GLXPbuffer pbuf) { | |
399 GL_SERVICE_LOG("glXDestroyPbuffer" | |
400 << "(" << static_cast<const void*>(dpy) << ", " << pbuf | |
401 << ")"); | |
402 DCHECK(g_driver_glx.debug_fn.glXDestroyPbufferFn != nullptr); | |
403 g_driver_glx.debug_fn.glXDestroyPbufferFn(dpy, pbuf); | |
404 } | |
405 | |
406 static void GL_BINDING_CALL Debug_glXDestroyPixmap(Display* dpy, | |
407 GLXPixmap pixmap) { | |
408 GL_SERVICE_LOG("glXDestroyPixmap" | |
409 << "(" << static_cast<const void*>(dpy) << ", " << pixmap | |
410 << ")"); | |
411 DCHECK(g_driver_glx.debug_fn.glXDestroyPixmapFn != nullptr); | |
412 g_driver_glx.debug_fn.glXDestroyPixmapFn(dpy, pixmap); | |
413 } | |
414 | |
415 static void GL_BINDING_CALL Debug_glXDestroyWindow(Display* dpy, | |
416 GLXWindow window) { | |
417 GL_SERVICE_LOG("glXDestroyWindow" | |
418 << "(" << static_cast<const void*>(dpy) << ", " << window | |
419 << ")"); | |
420 DCHECK(g_driver_glx.debug_fn.glXDestroyWindowFn != nullptr); | |
421 g_driver_glx.debug_fn.glXDestroyWindowFn(dpy, window); | |
422 } | |
423 | |
424 static const char* GL_BINDING_CALL Debug_glXGetClientString(Display* dpy, | |
425 int name) { | |
426 GL_SERVICE_LOG("glXGetClientString" | |
427 << "(" << static_cast<const void*>(dpy) << ", " << name | |
428 << ")"); | |
429 DCHECK(g_driver_glx.debug_fn.glXGetClientStringFn != nullptr); | |
430 const char* result = g_driver_glx.debug_fn.glXGetClientStringFn(dpy, name); | |
431 GL_SERVICE_LOG("GL_RESULT: " << result); | |
432 return result; | |
433 } | |
434 | |
435 static int GL_BINDING_CALL Debug_glXGetConfig(Display* dpy, | |
436 XVisualInfo* visual, | |
437 int attrib, | |
438 int* value) { | |
439 GL_SERVICE_LOG("glXGetConfig" | |
440 << "(" << static_cast<const void*>(dpy) << ", " | |
441 << static_cast<const void*>(visual) << ", " << attrib << ", " | |
442 << static_cast<const void*>(value) << ")"); | |
443 DCHECK(g_driver_glx.debug_fn.glXGetConfigFn != nullptr); | |
444 int result = g_driver_glx.debug_fn.glXGetConfigFn(dpy, visual, attrib, value); | |
445 GL_SERVICE_LOG("GL_RESULT: " << result); | |
446 return result; | |
447 } | |
448 | |
449 static GLXContext GL_BINDING_CALL Debug_glXGetCurrentContext(void) { | |
450 GL_SERVICE_LOG("glXGetCurrentContext" | |
451 << "(" | |
452 << ")"); | |
453 DCHECK(g_driver_glx.debug_fn.glXGetCurrentContextFn != nullptr); | |
454 GLXContext result = g_driver_glx.debug_fn.glXGetCurrentContextFn(); | |
455 GL_SERVICE_LOG("GL_RESULT: " << result); | |
456 return result; | |
457 } | |
458 | |
459 static Display* GL_BINDING_CALL Debug_glXGetCurrentDisplay(void) { | |
460 GL_SERVICE_LOG("glXGetCurrentDisplay" | |
461 << "(" | |
462 << ")"); | |
463 DCHECK(g_driver_glx.debug_fn.glXGetCurrentDisplayFn != nullptr); | |
464 Display* result = g_driver_glx.debug_fn.glXGetCurrentDisplayFn(); | |
465 GL_SERVICE_LOG("GL_RESULT: " << result); | |
466 return result; | |
467 } | |
468 | |
469 static GLXDrawable GL_BINDING_CALL Debug_glXGetCurrentDrawable(void) { | |
470 GL_SERVICE_LOG("glXGetCurrentDrawable" | |
471 << "(" | |
472 << ")"); | |
473 DCHECK(g_driver_glx.debug_fn.glXGetCurrentDrawableFn != nullptr); | |
474 GLXDrawable result = g_driver_glx.debug_fn.glXGetCurrentDrawableFn(); | |
475 GL_SERVICE_LOG("GL_RESULT: " << result); | |
476 return result; | |
477 } | |
478 | |
479 static GLXDrawable GL_BINDING_CALL Debug_glXGetCurrentReadDrawable(void) { | |
480 GL_SERVICE_LOG("glXGetCurrentReadDrawable" | |
481 << "(" | |
482 << ")"); | |
483 DCHECK(g_driver_glx.debug_fn.glXGetCurrentReadDrawableFn != nullptr); | |
484 GLXDrawable result = g_driver_glx.debug_fn.glXGetCurrentReadDrawableFn(); | |
485 GL_SERVICE_LOG("GL_RESULT: " << result); | |
486 return result; | |
487 } | |
488 | |
489 static int GL_BINDING_CALL Debug_glXGetFBConfigAttrib(Display* dpy, | |
490 GLXFBConfig config, | |
491 int attribute, | |
492 int* value) { | |
493 GL_SERVICE_LOG("glXGetFBConfigAttrib" | |
494 << "(" << static_cast<const void*>(dpy) << ", " << config | |
495 << ", " << attribute << ", " << static_cast<const void*>(value) | |
496 << ")"); | |
497 DCHECK(g_driver_glx.debug_fn.glXGetFBConfigAttribFn != nullptr); | |
498 int result = g_driver_glx.debug_fn.glXGetFBConfigAttribFn(dpy, config, | |
499 attribute, value); | |
500 GL_SERVICE_LOG("GL_RESULT: " << result); | |
501 return result; | |
502 } | |
503 | |
504 static GLXFBConfig GL_BINDING_CALL | |
505 Debug_glXGetFBConfigFromVisualSGIX(Display* dpy, XVisualInfo* visualInfo) { | |
506 GL_SERVICE_LOG("glXGetFBConfigFromVisualSGIX" | |
507 << "(" << static_cast<const void*>(dpy) << ", " | |
508 << static_cast<const void*>(visualInfo) << ")"); | |
509 DCHECK(g_driver_glx.debug_fn.glXGetFBConfigFromVisualSGIXFn != nullptr); | |
510 GLXFBConfig result = | |
511 g_driver_glx.debug_fn.glXGetFBConfigFromVisualSGIXFn(dpy, visualInfo); | |
512 GL_SERVICE_LOG("GL_RESULT: " << result); | |
513 return result; | |
514 } | |
515 | |
516 static GLXFBConfig* GL_BINDING_CALL Debug_glXGetFBConfigs(Display* dpy, | |
517 int screen, | |
518 int* nelements) { | |
519 GL_SERVICE_LOG("glXGetFBConfigs" | |
520 << "(" << static_cast<const void*>(dpy) << ", " << screen | |
521 << ", " << static_cast<const void*>(nelements) << ")"); | |
522 DCHECK(g_driver_glx.debug_fn.glXGetFBConfigsFn != nullptr); | |
523 GLXFBConfig* result = | |
524 g_driver_glx.debug_fn.glXGetFBConfigsFn(dpy, screen, nelements); | |
525 GL_SERVICE_LOG("GL_RESULT: " << result); | |
526 return result; | |
527 } | |
528 | |
529 static bool GL_BINDING_CALL Debug_glXGetMscRateOML(Display* dpy, | |
530 GLXDrawable drawable, | |
531 int32_t* numerator, | |
532 int32_t* denominator) { | |
533 GL_SERVICE_LOG("glXGetMscRateOML" | |
534 << "(" << static_cast<const void*>(dpy) << ", " << drawable | |
535 << ", " << static_cast<const void*>(numerator) << ", " | |
536 << static_cast<const void*>(denominator) << ")"); | |
537 DCHECK(g_driver_glx.debug_fn.glXGetMscRateOMLFn != nullptr); | |
538 bool result = g_driver_glx.debug_fn.glXGetMscRateOMLFn( | |
539 dpy, drawable, numerator, denominator); | |
540 GL_SERVICE_LOG("GL_RESULT: " << result); | |
541 return result; | |
542 } | |
543 | |
544 static void GL_BINDING_CALL Debug_glXGetSelectedEvent(Display* dpy, | |
545 GLXDrawable drawable, | |
546 unsigned long* mask) { | |
547 GL_SERVICE_LOG("glXGetSelectedEvent" | |
548 << "(" << static_cast<const void*>(dpy) << ", " << drawable | |
549 << ", " << static_cast<const void*>(mask) << ")"); | |
550 DCHECK(g_driver_glx.debug_fn.glXGetSelectedEventFn != nullptr); | |
551 g_driver_glx.debug_fn.glXGetSelectedEventFn(dpy, drawable, mask); | |
552 } | |
553 | |
554 static bool GL_BINDING_CALL Debug_glXGetSyncValuesOML(Display* dpy, | |
555 GLXDrawable drawable, | |
556 int64_t* ust, | |
557 int64_t* msc, | |
558 int64_t* sbc) { | |
559 GL_SERVICE_LOG("glXGetSyncValuesOML" | |
560 << "(" << static_cast<const void*>(dpy) << ", " << drawable | |
561 << ", " << static_cast<const void*>(ust) << ", " | |
562 << static_cast<const void*>(msc) << ", " | |
563 << static_cast<const void*>(sbc) << ")"); | |
564 DCHECK(g_driver_glx.debug_fn.glXGetSyncValuesOMLFn != nullptr); | |
565 bool result = | |
566 g_driver_glx.debug_fn.glXGetSyncValuesOMLFn(dpy, drawable, ust, msc, sbc); | |
567 GL_SERVICE_LOG("GL_RESULT: " << result); | |
568 return result; | |
569 } | |
570 | |
571 static XVisualInfo* GL_BINDING_CALL | |
572 Debug_glXGetVisualFromFBConfig(Display* dpy, GLXFBConfig config) { | |
573 GL_SERVICE_LOG("glXGetVisualFromFBConfig" | |
574 << "(" << static_cast<const void*>(dpy) << ", " << config | |
575 << ")"); | |
576 DCHECK(g_driver_glx.debug_fn.glXGetVisualFromFBConfigFn != nullptr); | |
577 XVisualInfo* result = | |
578 g_driver_glx.debug_fn.glXGetVisualFromFBConfigFn(dpy, config); | |
579 GL_SERVICE_LOG("GL_RESULT: " << result); | |
580 return result; | |
581 } | |
582 | |
583 static int GL_BINDING_CALL Debug_glXIsDirect(Display* dpy, GLXContext ctx) { | |
584 GL_SERVICE_LOG("glXIsDirect" | |
585 << "(" << static_cast<const void*>(dpy) << ", " << ctx << ")"); | |
586 DCHECK(g_driver_glx.debug_fn.glXIsDirectFn != nullptr); | |
587 int result = g_driver_glx.debug_fn.glXIsDirectFn(dpy, ctx); | |
588 GL_SERVICE_LOG("GL_RESULT: " << result); | |
589 return result; | |
590 } | |
591 | |
592 static int GL_BINDING_CALL Debug_glXMakeContextCurrent(Display* dpy, | |
593 GLXDrawable draw, | |
594 GLXDrawable read, | |
595 GLXContext ctx) { | |
596 GL_SERVICE_LOG("glXMakeContextCurrent" | |
597 << "(" << static_cast<const void*>(dpy) << ", " << draw << ", " | |
598 << read << ", " << ctx << ")"); | |
599 DCHECK(g_driver_glx.debug_fn.glXMakeContextCurrentFn != nullptr); | |
600 int result = | |
601 g_driver_glx.debug_fn.glXMakeContextCurrentFn(dpy, draw, read, ctx); | |
602 GL_SERVICE_LOG("GL_RESULT: " << result); | |
603 return result; | |
604 } | |
605 | |
606 static int GL_BINDING_CALL Debug_glXMakeCurrent(Display* dpy, | |
607 GLXDrawable drawable, | |
608 GLXContext ctx) { | |
609 GL_SERVICE_LOG("glXMakeCurrent" | |
610 << "(" << static_cast<const void*>(dpy) << ", " << drawable | |
611 << ", " << ctx << ")"); | |
612 DCHECK(g_driver_glx.debug_fn.glXMakeCurrentFn != nullptr); | |
613 int result = g_driver_glx.debug_fn.glXMakeCurrentFn(dpy, drawable, ctx); | |
614 GL_SERVICE_LOG("GL_RESULT: " << result); | |
615 return result; | |
616 } | |
617 | |
618 static int GL_BINDING_CALL Debug_glXQueryContext(Display* dpy, | |
619 GLXContext ctx, | |
620 int attribute, | |
621 int* value) { | |
622 GL_SERVICE_LOG("glXQueryContext" | |
623 << "(" << static_cast<const void*>(dpy) << ", " << ctx << ", " | |
624 << attribute << ", " << static_cast<const void*>(value) | |
625 << ")"); | |
626 DCHECK(g_driver_glx.debug_fn.glXQueryContextFn != nullptr); | |
627 int result = | |
628 g_driver_glx.debug_fn.glXQueryContextFn(dpy, ctx, attribute, value); | |
629 GL_SERVICE_LOG("GL_RESULT: " << result); | |
630 return result; | |
631 } | |
632 | |
633 static void GL_BINDING_CALL Debug_glXQueryDrawable(Display* dpy, | |
634 GLXDrawable draw, | |
635 int attribute, | |
636 unsigned int* value) { | |
637 GL_SERVICE_LOG("glXQueryDrawable" | |
638 << "(" << static_cast<const void*>(dpy) << ", " << draw << ", " | |
639 << attribute << ", " << static_cast<const void*>(value) | |
640 << ")"); | |
641 DCHECK(g_driver_glx.debug_fn.glXQueryDrawableFn != nullptr); | |
642 g_driver_glx.debug_fn.glXQueryDrawableFn(dpy, draw, attribute, value); | |
643 } | |
644 | |
645 static int GL_BINDING_CALL Debug_glXQueryExtension(Display* dpy, | |
646 int* errorb, | |
647 int* event) { | |
648 GL_SERVICE_LOG("glXQueryExtension" | |
649 << "(" << static_cast<const void*>(dpy) << ", " | |
650 << static_cast<const void*>(errorb) << ", " | |
651 << static_cast<const void*>(event) << ")"); | |
652 DCHECK(g_driver_glx.debug_fn.glXQueryExtensionFn != nullptr); | |
653 int result = g_driver_glx.debug_fn.glXQueryExtensionFn(dpy, errorb, event); | |
654 GL_SERVICE_LOG("GL_RESULT: " << result); | |
655 return result; | |
656 } | |
657 | |
658 static const char* GL_BINDING_CALL Debug_glXQueryExtensionsString(Display* dpy, | |
659 int screen) { | |
660 GL_SERVICE_LOG("glXQueryExtensionsString" | |
661 << "(" << static_cast<const void*>(dpy) << ", " << screen | |
662 << ")"); | |
663 DCHECK(g_driver_glx.debug_fn.glXQueryExtensionsStringFn != nullptr); | |
664 const char* result = | |
665 g_driver_glx.debug_fn.glXQueryExtensionsStringFn(dpy, screen); | |
666 GL_SERVICE_LOG("GL_RESULT: " << result); | |
667 return result; | |
668 } | |
669 | |
670 static const char* GL_BINDING_CALL Debug_glXQueryServerString(Display* dpy, | |
671 int screen, | |
672 int name) { | |
673 GL_SERVICE_LOG("glXQueryServerString" | |
674 << "(" << static_cast<const void*>(dpy) << ", " << screen | |
675 << ", " << name << ")"); | |
676 DCHECK(g_driver_glx.debug_fn.glXQueryServerStringFn != nullptr); | |
677 const char* result = | |
678 g_driver_glx.debug_fn.glXQueryServerStringFn(dpy, screen, name); | |
679 GL_SERVICE_LOG("GL_RESULT: " << result); | |
680 return result; | |
681 } | |
682 | |
683 static int GL_BINDING_CALL Debug_glXQueryVersion(Display* dpy, | |
684 int* maj, | |
685 int* min) { | |
686 GL_SERVICE_LOG("glXQueryVersion" | |
687 << "(" << static_cast<const void*>(dpy) << ", " | |
688 << static_cast<const void*>(maj) << ", " | |
689 << static_cast<const void*>(min) << ")"); | |
690 DCHECK(g_driver_glx.debug_fn.glXQueryVersionFn != nullptr); | |
691 int result = g_driver_glx.debug_fn.glXQueryVersionFn(dpy, maj, min); | |
692 GL_SERVICE_LOG("GL_RESULT: " << result); | |
693 return result; | |
694 } | |
695 | |
696 static void GL_BINDING_CALL Debug_glXReleaseTexImageEXT(Display* dpy, | |
697 GLXDrawable drawable, | |
698 int buffer) { | |
699 GL_SERVICE_LOG("glXReleaseTexImageEXT" | |
700 << "(" << static_cast<const void*>(dpy) << ", " << drawable | |
701 << ", " << buffer << ")"); | |
702 DCHECK(g_driver_glx.debug_fn.glXReleaseTexImageEXTFn != nullptr); | |
703 g_driver_glx.debug_fn.glXReleaseTexImageEXTFn(dpy, drawable, buffer); | |
704 } | |
705 | |
706 static void GL_BINDING_CALL Debug_glXSelectEvent(Display* dpy, | |
707 GLXDrawable drawable, | |
708 unsigned long mask) { | |
709 GL_SERVICE_LOG("glXSelectEvent" | |
710 << "(" << static_cast<const void*>(dpy) << ", " << drawable | |
711 << ", " << mask << ")"); | |
712 DCHECK(g_driver_glx.debug_fn.glXSelectEventFn != nullptr); | |
713 g_driver_glx.debug_fn.glXSelectEventFn(dpy, drawable, mask); | |
714 } | |
715 | |
716 static void GL_BINDING_CALL Debug_glXSwapBuffers(Display* dpy, | |
717 GLXDrawable drawable) { | |
718 GL_SERVICE_LOG("glXSwapBuffers" | |
719 << "(" << static_cast<const void*>(dpy) << ", " << drawable | |
720 << ")"); | |
721 DCHECK(g_driver_glx.debug_fn.glXSwapBuffersFn != nullptr); | |
722 g_driver_glx.debug_fn.glXSwapBuffersFn(dpy, drawable); | |
723 } | |
724 | |
725 static void GL_BINDING_CALL Debug_glXSwapIntervalEXT(Display* dpy, | |
726 GLXDrawable drawable, | |
727 int interval) { | |
728 GL_SERVICE_LOG("glXSwapIntervalEXT" | |
729 << "(" << static_cast<const void*>(dpy) << ", " << drawable | |
730 << ", " << interval << ")"); | |
731 DCHECK(g_driver_glx.debug_fn.glXSwapIntervalEXTFn != nullptr); | |
732 g_driver_glx.debug_fn.glXSwapIntervalEXTFn(dpy, drawable, interval); | |
733 } | |
734 | |
735 static void GL_BINDING_CALL Debug_glXSwapIntervalMESA(unsigned int interval) { | |
736 GL_SERVICE_LOG("glXSwapIntervalMESA" | |
737 << "(" << interval << ")"); | |
738 DCHECK(g_driver_glx.debug_fn.glXSwapIntervalMESAFn != nullptr); | |
739 g_driver_glx.debug_fn.glXSwapIntervalMESAFn(interval); | |
740 } | |
741 | |
742 static void GL_BINDING_CALL Debug_glXUseXFont(Font font, | |
743 int first, | |
744 int count, | |
745 int list) { | |
746 GL_SERVICE_LOG("glXUseXFont" | |
747 << "(" << font << ", " << first << ", " << count << ", " | |
748 << list << ")"); | |
749 DCHECK(g_driver_glx.debug_fn.glXUseXFontFn != nullptr); | |
750 g_driver_glx.debug_fn.glXUseXFontFn(font, first, count, list); | |
751 } | |
752 | |
753 static void GL_BINDING_CALL Debug_glXWaitGL(void) { | |
754 GL_SERVICE_LOG("glXWaitGL" | |
755 << "(" | |
756 << ")"); | |
757 DCHECK(g_driver_glx.debug_fn.glXWaitGLFn != nullptr); | |
758 g_driver_glx.debug_fn.glXWaitGLFn(); | |
759 } | |
760 | |
761 static int GL_BINDING_CALL Debug_glXWaitVideoSyncSGI(int divisor, | |
762 int remainder, | |
763 unsigned int* count) { | |
764 GL_SERVICE_LOG("glXWaitVideoSyncSGI" | |
765 << "(" << divisor << ", " << remainder << ", " | |
766 << static_cast<const void*>(count) << ")"); | |
767 DCHECK(g_driver_glx.debug_fn.glXWaitVideoSyncSGIFn != nullptr); | |
768 int result = | |
769 g_driver_glx.debug_fn.glXWaitVideoSyncSGIFn(divisor, remainder, count); | |
770 GL_SERVICE_LOG("GL_RESULT: " << result); | |
771 return result; | |
772 } | |
773 | |
774 static void GL_BINDING_CALL Debug_glXWaitX(void) { | |
775 GL_SERVICE_LOG("glXWaitX" | |
776 << "(" | |
777 << ")"); | |
778 DCHECK(g_driver_glx.debug_fn.glXWaitXFn != nullptr); | |
779 g_driver_glx.debug_fn.glXWaitXFn(); | |
780 } | |
781 } // extern "C" | |
782 | |
783 void DriverGLX::InitializeDebugBindings() { | |
784 if (!debug_fn.glXBindTexImageEXTFn) { | |
785 debug_fn.glXBindTexImageEXTFn = fn.glXBindTexImageEXTFn; | |
786 fn.glXBindTexImageEXTFn = Debug_glXBindTexImageEXT; | |
787 } | |
788 if (!debug_fn.glXChooseFBConfigFn) { | |
789 debug_fn.glXChooseFBConfigFn = fn.glXChooseFBConfigFn; | |
790 fn.glXChooseFBConfigFn = Debug_glXChooseFBConfig; | |
791 } | |
792 if (!debug_fn.glXChooseVisualFn) { | |
793 debug_fn.glXChooseVisualFn = fn.glXChooseVisualFn; | |
794 fn.glXChooseVisualFn = Debug_glXChooseVisual; | |
795 } | |
796 if (!debug_fn.glXCopyContextFn) { | |
797 debug_fn.glXCopyContextFn = fn.glXCopyContextFn; | |
798 fn.glXCopyContextFn = Debug_glXCopyContext; | |
799 } | |
800 if (!debug_fn.glXCopySubBufferMESAFn) { | |
801 debug_fn.glXCopySubBufferMESAFn = fn.glXCopySubBufferMESAFn; | |
802 fn.glXCopySubBufferMESAFn = Debug_glXCopySubBufferMESA; | |
803 } | |
804 if (!debug_fn.glXCreateContextFn) { | |
805 debug_fn.glXCreateContextFn = fn.glXCreateContextFn; | |
806 fn.glXCreateContextFn = Debug_glXCreateContext; | |
807 } | |
808 if (!debug_fn.glXCreateContextAttribsARBFn) { | |
809 debug_fn.glXCreateContextAttribsARBFn = fn.glXCreateContextAttribsARBFn; | |
810 fn.glXCreateContextAttribsARBFn = Debug_glXCreateContextAttribsARB; | |
811 } | |
812 if (!debug_fn.glXCreateGLXPixmapFn) { | |
813 debug_fn.glXCreateGLXPixmapFn = fn.glXCreateGLXPixmapFn; | |
814 fn.glXCreateGLXPixmapFn = Debug_glXCreateGLXPixmap; | |
815 } | |
816 if (!debug_fn.glXCreateNewContextFn) { | |
817 debug_fn.glXCreateNewContextFn = fn.glXCreateNewContextFn; | |
818 fn.glXCreateNewContextFn = Debug_glXCreateNewContext; | |
819 } | |
820 if (!debug_fn.glXCreatePbufferFn) { | |
821 debug_fn.glXCreatePbufferFn = fn.glXCreatePbufferFn; | |
822 fn.glXCreatePbufferFn = Debug_glXCreatePbuffer; | |
823 } | |
824 if (!debug_fn.glXCreatePixmapFn) { | |
825 debug_fn.glXCreatePixmapFn = fn.glXCreatePixmapFn; | |
826 fn.glXCreatePixmapFn = Debug_glXCreatePixmap; | |
827 } | |
828 if (!debug_fn.glXCreateWindowFn) { | |
829 debug_fn.glXCreateWindowFn = fn.glXCreateWindowFn; | |
830 fn.glXCreateWindowFn = Debug_glXCreateWindow; | |
831 } | |
832 if (!debug_fn.glXDestroyContextFn) { | |
833 debug_fn.glXDestroyContextFn = fn.glXDestroyContextFn; | |
834 fn.glXDestroyContextFn = Debug_glXDestroyContext; | |
835 } | |
836 if (!debug_fn.glXDestroyGLXPixmapFn) { | |
837 debug_fn.glXDestroyGLXPixmapFn = fn.glXDestroyGLXPixmapFn; | |
838 fn.glXDestroyGLXPixmapFn = Debug_glXDestroyGLXPixmap; | |
839 } | |
840 if (!debug_fn.glXDestroyPbufferFn) { | |
841 debug_fn.glXDestroyPbufferFn = fn.glXDestroyPbufferFn; | |
842 fn.glXDestroyPbufferFn = Debug_glXDestroyPbuffer; | |
843 } | |
844 if (!debug_fn.glXDestroyPixmapFn) { | |
845 debug_fn.glXDestroyPixmapFn = fn.glXDestroyPixmapFn; | |
846 fn.glXDestroyPixmapFn = Debug_glXDestroyPixmap; | |
847 } | |
848 if (!debug_fn.glXDestroyWindowFn) { | |
849 debug_fn.glXDestroyWindowFn = fn.glXDestroyWindowFn; | |
850 fn.glXDestroyWindowFn = Debug_glXDestroyWindow; | |
851 } | |
852 if (!debug_fn.glXGetClientStringFn) { | |
853 debug_fn.glXGetClientStringFn = fn.glXGetClientStringFn; | |
854 fn.glXGetClientStringFn = Debug_glXGetClientString; | |
855 } | |
856 if (!debug_fn.glXGetConfigFn) { | |
857 debug_fn.glXGetConfigFn = fn.glXGetConfigFn; | |
858 fn.glXGetConfigFn = Debug_glXGetConfig; | |
859 } | |
860 if (!debug_fn.glXGetCurrentContextFn) { | |
861 debug_fn.glXGetCurrentContextFn = fn.glXGetCurrentContextFn; | |
862 fn.glXGetCurrentContextFn = Debug_glXGetCurrentContext; | |
863 } | |
864 if (!debug_fn.glXGetCurrentDisplayFn) { | |
865 debug_fn.glXGetCurrentDisplayFn = fn.glXGetCurrentDisplayFn; | |
866 fn.glXGetCurrentDisplayFn = Debug_glXGetCurrentDisplay; | |
867 } | |
868 if (!debug_fn.glXGetCurrentDrawableFn) { | |
869 debug_fn.glXGetCurrentDrawableFn = fn.glXGetCurrentDrawableFn; | |
870 fn.glXGetCurrentDrawableFn = Debug_glXGetCurrentDrawable; | |
871 } | |
872 if (!debug_fn.glXGetCurrentReadDrawableFn) { | |
873 debug_fn.glXGetCurrentReadDrawableFn = fn.glXGetCurrentReadDrawableFn; | |
874 fn.glXGetCurrentReadDrawableFn = Debug_glXGetCurrentReadDrawable; | |
875 } | |
876 if (!debug_fn.glXGetFBConfigAttribFn) { | |
877 debug_fn.glXGetFBConfigAttribFn = fn.glXGetFBConfigAttribFn; | |
878 fn.glXGetFBConfigAttribFn = Debug_glXGetFBConfigAttrib; | |
879 } | |
880 if (!debug_fn.glXGetFBConfigFromVisualSGIXFn) { | |
881 debug_fn.glXGetFBConfigFromVisualSGIXFn = fn.glXGetFBConfigFromVisualSGIXFn; | |
882 fn.glXGetFBConfigFromVisualSGIXFn = Debug_glXGetFBConfigFromVisualSGIX; | |
883 } | |
884 if (!debug_fn.glXGetFBConfigsFn) { | |
885 debug_fn.glXGetFBConfigsFn = fn.glXGetFBConfigsFn; | |
886 fn.glXGetFBConfigsFn = Debug_glXGetFBConfigs; | |
887 } | |
888 if (!debug_fn.glXGetMscRateOMLFn) { | |
889 debug_fn.glXGetMscRateOMLFn = fn.glXGetMscRateOMLFn; | |
890 fn.glXGetMscRateOMLFn = Debug_glXGetMscRateOML; | |
891 } | |
892 if (!debug_fn.glXGetSelectedEventFn) { | |
893 debug_fn.glXGetSelectedEventFn = fn.glXGetSelectedEventFn; | |
894 fn.glXGetSelectedEventFn = Debug_glXGetSelectedEvent; | |
895 } | |
896 if (!debug_fn.glXGetSyncValuesOMLFn) { | |
897 debug_fn.glXGetSyncValuesOMLFn = fn.glXGetSyncValuesOMLFn; | |
898 fn.glXGetSyncValuesOMLFn = Debug_glXGetSyncValuesOML; | |
899 } | |
900 if (!debug_fn.glXGetVisualFromFBConfigFn) { | |
901 debug_fn.glXGetVisualFromFBConfigFn = fn.glXGetVisualFromFBConfigFn; | |
902 fn.glXGetVisualFromFBConfigFn = Debug_glXGetVisualFromFBConfig; | |
903 } | |
904 if (!debug_fn.glXIsDirectFn) { | |
905 debug_fn.glXIsDirectFn = fn.glXIsDirectFn; | |
906 fn.glXIsDirectFn = Debug_glXIsDirect; | |
907 } | |
908 if (!debug_fn.glXMakeContextCurrentFn) { | |
909 debug_fn.glXMakeContextCurrentFn = fn.glXMakeContextCurrentFn; | |
910 fn.glXMakeContextCurrentFn = Debug_glXMakeContextCurrent; | |
911 } | |
912 if (!debug_fn.glXMakeCurrentFn) { | |
913 debug_fn.glXMakeCurrentFn = fn.glXMakeCurrentFn; | |
914 fn.glXMakeCurrentFn = Debug_glXMakeCurrent; | |
915 } | |
916 if (!debug_fn.glXQueryContextFn) { | |
917 debug_fn.glXQueryContextFn = fn.glXQueryContextFn; | |
918 fn.glXQueryContextFn = Debug_glXQueryContext; | |
919 } | |
920 if (!debug_fn.glXQueryDrawableFn) { | |
921 debug_fn.glXQueryDrawableFn = fn.glXQueryDrawableFn; | |
922 fn.glXQueryDrawableFn = Debug_glXQueryDrawable; | |
923 } | |
924 if (!debug_fn.glXQueryExtensionFn) { | |
925 debug_fn.glXQueryExtensionFn = fn.glXQueryExtensionFn; | |
926 fn.glXQueryExtensionFn = Debug_glXQueryExtension; | |
927 } | |
928 if (!debug_fn.glXQueryExtensionsStringFn) { | |
929 debug_fn.glXQueryExtensionsStringFn = fn.glXQueryExtensionsStringFn; | |
930 fn.glXQueryExtensionsStringFn = Debug_glXQueryExtensionsString; | |
931 } | |
932 if (!debug_fn.glXQueryServerStringFn) { | |
933 debug_fn.glXQueryServerStringFn = fn.glXQueryServerStringFn; | |
934 fn.glXQueryServerStringFn = Debug_glXQueryServerString; | |
935 } | |
936 if (!debug_fn.glXQueryVersionFn) { | |
937 debug_fn.glXQueryVersionFn = fn.glXQueryVersionFn; | |
938 fn.glXQueryVersionFn = Debug_glXQueryVersion; | |
939 } | |
940 if (!debug_fn.glXReleaseTexImageEXTFn) { | |
941 debug_fn.glXReleaseTexImageEXTFn = fn.glXReleaseTexImageEXTFn; | |
942 fn.glXReleaseTexImageEXTFn = Debug_glXReleaseTexImageEXT; | |
943 } | |
944 if (!debug_fn.glXSelectEventFn) { | |
945 debug_fn.glXSelectEventFn = fn.glXSelectEventFn; | |
946 fn.glXSelectEventFn = Debug_glXSelectEvent; | |
947 } | |
948 if (!debug_fn.glXSwapBuffersFn) { | |
949 debug_fn.glXSwapBuffersFn = fn.glXSwapBuffersFn; | |
950 fn.glXSwapBuffersFn = Debug_glXSwapBuffers; | |
951 } | |
952 if (!debug_fn.glXSwapIntervalEXTFn) { | |
953 debug_fn.glXSwapIntervalEXTFn = fn.glXSwapIntervalEXTFn; | |
954 fn.glXSwapIntervalEXTFn = Debug_glXSwapIntervalEXT; | |
955 } | |
956 if (!debug_fn.glXSwapIntervalMESAFn) { | |
957 debug_fn.glXSwapIntervalMESAFn = fn.glXSwapIntervalMESAFn; | |
958 fn.glXSwapIntervalMESAFn = Debug_glXSwapIntervalMESA; | |
959 } | |
960 if (!debug_fn.glXUseXFontFn) { | |
961 debug_fn.glXUseXFontFn = fn.glXUseXFontFn; | |
962 fn.glXUseXFontFn = Debug_glXUseXFont; | |
963 } | |
964 if (!debug_fn.glXWaitGLFn) { | |
965 debug_fn.glXWaitGLFn = fn.glXWaitGLFn; | |
966 fn.glXWaitGLFn = Debug_glXWaitGL; | |
967 } | |
968 if (!debug_fn.glXWaitVideoSyncSGIFn) { | |
969 debug_fn.glXWaitVideoSyncSGIFn = fn.glXWaitVideoSyncSGIFn; | |
970 fn.glXWaitVideoSyncSGIFn = Debug_glXWaitVideoSyncSGI; | |
971 } | |
972 if (!debug_fn.glXWaitXFn) { | |
973 debug_fn.glXWaitXFn = fn.glXWaitXFn; | |
974 fn.glXWaitXFn = Debug_glXWaitX; | |
975 } | |
976 g_debugBindingsInitialized = true; | |
977 } | 189 } |
978 | 190 |
979 void DriverGLX::ClearBindings() { | 191 void DriverGLX::ClearBindings() { |
980 memset(this, 0, sizeof(*this)); | 192 memset(this, 0, sizeof(*this)); |
981 } | 193 } |
982 | 194 |
983 void GLXApiBase::glXBindTexImageEXTFn(Display* dpy, | 195 void GLXApiBase::glXBindTexImageEXTFn(Display* dpy, |
984 GLXDrawable drawable, | 196 GLXDrawable drawable, |
985 int buffer, | 197 int buffer, |
986 int* attribList) { | 198 int* attribList) { |
(...skipping 579 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1566 unsigned int* count) { | 778 unsigned int* count) { |
1567 TRACE_EVENT_BINARY_EFFICIENT0("gpu", "TraceGLAPI::glXWaitVideoSyncSGI") | 779 TRACE_EVENT_BINARY_EFFICIENT0("gpu", "TraceGLAPI::glXWaitVideoSyncSGI") |
1568 return glx_api_->glXWaitVideoSyncSGIFn(divisor, remainder, count); | 780 return glx_api_->glXWaitVideoSyncSGIFn(divisor, remainder, count); |
1569 } | 781 } |
1570 | 782 |
1571 void TraceGLXApi::glXWaitXFn(void) { | 783 void TraceGLXApi::glXWaitXFn(void) { |
1572 TRACE_EVENT_BINARY_EFFICIENT0("gpu", "TraceGLAPI::glXWaitX") | 784 TRACE_EVENT_BINARY_EFFICIENT0("gpu", "TraceGLAPI::glXWaitX") |
1573 glx_api_->glXWaitXFn(); | 785 glx_api_->glXWaitXFn(); |
1574 } | 786 } |
1575 | 787 |
| 788 void DebugGLXApi::glXBindTexImageEXTFn(Display* dpy, |
| 789 GLXDrawable drawable, |
| 790 int buffer, |
| 791 int* attribList) { |
| 792 GL_SERVICE_LOG("glXBindTexImageEXT" |
| 793 << "(" << static_cast<const void*>(dpy) << ", " << drawable |
| 794 << ", " << buffer << ", " |
| 795 << static_cast<const void*>(attribList) << ")"); |
| 796 glx_api_->glXBindTexImageEXTFn(dpy, drawable, buffer, attribList); |
| 797 } |
| 798 |
| 799 GLXFBConfig* DebugGLXApi::glXChooseFBConfigFn(Display* dpy, |
| 800 int screen, |
| 801 const int* attribList, |
| 802 int* nitems) { |
| 803 GL_SERVICE_LOG("glXChooseFBConfig" |
| 804 << "(" << static_cast<const void*>(dpy) << ", " << screen |
| 805 << ", " << static_cast<const void*>(attribList) << ", " |
| 806 << static_cast<const void*>(nitems) << ")"); |
| 807 GLXFBConfig* result = |
| 808 glx_api_->glXChooseFBConfigFn(dpy, screen, attribList, nitems); |
| 809 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 810 return result; |
| 811 } |
| 812 |
| 813 XVisualInfo* DebugGLXApi::glXChooseVisualFn(Display* dpy, |
| 814 int screen, |
| 815 int* attribList) { |
| 816 GL_SERVICE_LOG("glXChooseVisual" |
| 817 << "(" << static_cast<const void*>(dpy) << ", " << screen |
| 818 << ", " << static_cast<const void*>(attribList) << ")"); |
| 819 XVisualInfo* result = glx_api_->glXChooseVisualFn(dpy, screen, attribList); |
| 820 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 821 return result; |
| 822 } |
| 823 |
| 824 void DebugGLXApi::glXCopyContextFn(Display* dpy, |
| 825 GLXContext src, |
| 826 GLXContext dst, |
| 827 unsigned long mask) { |
| 828 GL_SERVICE_LOG("glXCopyContext" |
| 829 << "(" << static_cast<const void*>(dpy) << ", " << src << ", " |
| 830 << dst << ", " << mask << ")"); |
| 831 glx_api_->glXCopyContextFn(dpy, src, dst, mask); |
| 832 } |
| 833 |
| 834 void DebugGLXApi::glXCopySubBufferMESAFn(Display* dpy, |
| 835 GLXDrawable drawable, |
| 836 int x, |
| 837 int y, |
| 838 int width, |
| 839 int height) { |
| 840 GL_SERVICE_LOG("glXCopySubBufferMESA" |
| 841 << "(" << static_cast<const void*>(dpy) << ", " << drawable |
| 842 << ", " << x << ", " << y << ", " << width << ", " << height |
| 843 << ")"); |
| 844 glx_api_->glXCopySubBufferMESAFn(dpy, drawable, x, y, width, height); |
| 845 } |
| 846 |
| 847 GLXContext DebugGLXApi::glXCreateContextFn(Display* dpy, |
| 848 XVisualInfo* vis, |
| 849 GLXContext shareList, |
| 850 int direct) { |
| 851 GL_SERVICE_LOG("glXCreateContext" |
| 852 << "(" << static_cast<const void*>(dpy) << ", " |
| 853 << static_cast<const void*>(vis) << ", " << shareList << ", " |
| 854 << direct << ")"); |
| 855 GLXContext result = glx_api_->glXCreateContextFn(dpy, vis, shareList, direct); |
| 856 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 857 return result; |
| 858 } |
| 859 |
| 860 GLXContext DebugGLXApi::glXCreateContextAttribsARBFn(Display* dpy, |
| 861 GLXFBConfig config, |
| 862 GLXContext share_context, |
| 863 int direct, |
| 864 const int* attrib_list) { |
| 865 GL_SERVICE_LOG("glXCreateContextAttribsARB" |
| 866 << "(" << static_cast<const void*>(dpy) << ", " << config |
| 867 << ", " << share_context << ", " << direct << ", " |
| 868 << static_cast<const void*>(attrib_list) << ")"); |
| 869 GLXContext result = glx_api_->glXCreateContextAttribsARBFn( |
| 870 dpy, config, share_context, direct, attrib_list); |
| 871 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 872 return result; |
| 873 } |
| 874 |
| 875 GLXPixmap DebugGLXApi::glXCreateGLXPixmapFn(Display* dpy, |
| 876 XVisualInfo* visual, |
| 877 Pixmap pixmap) { |
| 878 GL_SERVICE_LOG("glXCreateGLXPixmap" |
| 879 << "(" << static_cast<const void*>(dpy) << ", " |
| 880 << static_cast<const void*>(visual) << ", " << pixmap << ")"); |
| 881 GLXPixmap result = glx_api_->glXCreateGLXPixmapFn(dpy, visual, pixmap); |
| 882 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 883 return result; |
| 884 } |
| 885 |
| 886 GLXContext DebugGLXApi::glXCreateNewContextFn(Display* dpy, |
| 887 GLXFBConfig config, |
| 888 int renderType, |
| 889 GLXContext shareList, |
| 890 int direct) { |
| 891 GL_SERVICE_LOG("glXCreateNewContext" |
| 892 << "(" << static_cast<const void*>(dpy) << ", " << config |
| 893 << ", " << renderType << ", " << shareList << ", " << direct |
| 894 << ")"); |
| 895 GLXContext result = glx_api_->glXCreateNewContextFn(dpy, config, renderType, |
| 896 shareList, direct); |
| 897 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 898 return result; |
| 899 } |
| 900 |
| 901 GLXPbuffer DebugGLXApi::glXCreatePbufferFn(Display* dpy, |
| 902 GLXFBConfig config, |
| 903 const int* attribList) { |
| 904 GL_SERVICE_LOG("glXCreatePbuffer" |
| 905 << "(" << static_cast<const void*>(dpy) << ", " << config |
| 906 << ", " << static_cast<const void*>(attribList) << ")"); |
| 907 GLXPbuffer result = glx_api_->glXCreatePbufferFn(dpy, config, attribList); |
| 908 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 909 return result; |
| 910 } |
| 911 |
| 912 GLXPixmap DebugGLXApi::glXCreatePixmapFn(Display* dpy, |
| 913 GLXFBConfig config, |
| 914 Pixmap pixmap, |
| 915 const int* attribList) { |
| 916 GL_SERVICE_LOG("glXCreatePixmap" |
| 917 << "(" << static_cast<const void*>(dpy) << ", " << config |
| 918 << ", " << pixmap << ", " |
| 919 << static_cast<const void*>(attribList) << ")"); |
| 920 GLXPixmap result = |
| 921 glx_api_->glXCreatePixmapFn(dpy, config, pixmap, attribList); |
| 922 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 923 return result; |
| 924 } |
| 925 |
| 926 GLXWindow DebugGLXApi::glXCreateWindowFn(Display* dpy, |
| 927 GLXFBConfig config, |
| 928 Window win, |
| 929 const int* attribList) { |
| 930 GL_SERVICE_LOG("glXCreateWindow" |
| 931 << "(" << static_cast<const void*>(dpy) << ", " << config |
| 932 << ", " << win << ", " << static_cast<const void*>(attribList) |
| 933 << ")"); |
| 934 GLXWindow result = glx_api_->glXCreateWindowFn(dpy, config, win, attribList); |
| 935 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 936 return result; |
| 937 } |
| 938 |
| 939 void DebugGLXApi::glXDestroyContextFn(Display* dpy, GLXContext ctx) { |
| 940 GL_SERVICE_LOG("glXDestroyContext" |
| 941 << "(" << static_cast<const void*>(dpy) << ", " << ctx << ")"); |
| 942 glx_api_->glXDestroyContextFn(dpy, ctx); |
| 943 } |
| 944 |
| 945 void DebugGLXApi::glXDestroyGLXPixmapFn(Display* dpy, GLXPixmap pixmap) { |
| 946 GL_SERVICE_LOG("glXDestroyGLXPixmap" |
| 947 << "(" << static_cast<const void*>(dpy) << ", " << pixmap |
| 948 << ")"); |
| 949 glx_api_->glXDestroyGLXPixmapFn(dpy, pixmap); |
| 950 } |
| 951 |
| 952 void DebugGLXApi::glXDestroyPbufferFn(Display* dpy, GLXPbuffer pbuf) { |
| 953 GL_SERVICE_LOG("glXDestroyPbuffer" |
| 954 << "(" << static_cast<const void*>(dpy) << ", " << pbuf |
| 955 << ")"); |
| 956 glx_api_->glXDestroyPbufferFn(dpy, pbuf); |
| 957 } |
| 958 |
| 959 void DebugGLXApi::glXDestroyPixmapFn(Display* dpy, GLXPixmap pixmap) { |
| 960 GL_SERVICE_LOG("glXDestroyPixmap" |
| 961 << "(" << static_cast<const void*>(dpy) << ", " << pixmap |
| 962 << ")"); |
| 963 glx_api_->glXDestroyPixmapFn(dpy, pixmap); |
| 964 } |
| 965 |
| 966 void DebugGLXApi::glXDestroyWindowFn(Display* dpy, GLXWindow window) { |
| 967 GL_SERVICE_LOG("glXDestroyWindow" |
| 968 << "(" << static_cast<const void*>(dpy) << ", " << window |
| 969 << ")"); |
| 970 glx_api_->glXDestroyWindowFn(dpy, window); |
| 971 } |
| 972 |
| 973 const char* DebugGLXApi::glXGetClientStringFn(Display* dpy, int name) { |
| 974 GL_SERVICE_LOG("glXGetClientString" |
| 975 << "(" << static_cast<const void*>(dpy) << ", " << name |
| 976 << ")"); |
| 977 const char* result = glx_api_->glXGetClientStringFn(dpy, name); |
| 978 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 979 return result; |
| 980 } |
| 981 |
| 982 int DebugGLXApi::glXGetConfigFn(Display* dpy, |
| 983 XVisualInfo* visual, |
| 984 int attrib, |
| 985 int* value) { |
| 986 GL_SERVICE_LOG("glXGetConfig" |
| 987 << "(" << static_cast<const void*>(dpy) << ", " |
| 988 << static_cast<const void*>(visual) << ", " << attrib << ", " |
| 989 << static_cast<const void*>(value) << ")"); |
| 990 int result = glx_api_->glXGetConfigFn(dpy, visual, attrib, value); |
| 991 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 992 return result; |
| 993 } |
| 994 |
| 995 GLXContext DebugGLXApi::glXGetCurrentContextFn(void) { |
| 996 GL_SERVICE_LOG("glXGetCurrentContext" |
| 997 << "(" |
| 998 << ")"); |
| 999 GLXContext result = glx_api_->glXGetCurrentContextFn(); |
| 1000 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1001 return result; |
| 1002 } |
| 1003 |
| 1004 Display* DebugGLXApi::glXGetCurrentDisplayFn(void) { |
| 1005 GL_SERVICE_LOG("glXGetCurrentDisplay" |
| 1006 << "(" |
| 1007 << ")"); |
| 1008 Display* result = glx_api_->glXGetCurrentDisplayFn(); |
| 1009 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1010 return result; |
| 1011 } |
| 1012 |
| 1013 GLXDrawable DebugGLXApi::glXGetCurrentDrawableFn(void) { |
| 1014 GL_SERVICE_LOG("glXGetCurrentDrawable" |
| 1015 << "(" |
| 1016 << ")"); |
| 1017 GLXDrawable result = glx_api_->glXGetCurrentDrawableFn(); |
| 1018 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1019 return result; |
| 1020 } |
| 1021 |
| 1022 GLXDrawable DebugGLXApi::glXGetCurrentReadDrawableFn(void) { |
| 1023 GL_SERVICE_LOG("glXGetCurrentReadDrawable" |
| 1024 << "(" |
| 1025 << ")"); |
| 1026 GLXDrawable result = glx_api_->glXGetCurrentReadDrawableFn(); |
| 1027 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1028 return result; |
| 1029 } |
| 1030 |
| 1031 int DebugGLXApi::glXGetFBConfigAttribFn(Display* dpy, |
| 1032 GLXFBConfig config, |
| 1033 int attribute, |
| 1034 int* value) { |
| 1035 GL_SERVICE_LOG("glXGetFBConfigAttrib" |
| 1036 << "(" << static_cast<const void*>(dpy) << ", " << config |
| 1037 << ", " << attribute << ", " << static_cast<const void*>(value) |
| 1038 << ")"); |
| 1039 int result = glx_api_->glXGetFBConfigAttribFn(dpy, config, attribute, value); |
| 1040 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1041 return result; |
| 1042 } |
| 1043 |
| 1044 GLXFBConfig DebugGLXApi::glXGetFBConfigFromVisualSGIXFn( |
| 1045 Display* dpy, |
| 1046 XVisualInfo* visualInfo) { |
| 1047 GL_SERVICE_LOG("glXGetFBConfigFromVisualSGIX" |
| 1048 << "(" << static_cast<const void*>(dpy) << ", " |
| 1049 << static_cast<const void*>(visualInfo) << ")"); |
| 1050 GLXFBConfig result = |
| 1051 glx_api_->glXGetFBConfigFromVisualSGIXFn(dpy, visualInfo); |
| 1052 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1053 return result; |
| 1054 } |
| 1055 |
| 1056 GLXFBConfig* DebugGLXApi::glXGetFBConfigsFn(Display* dpy, |
| 1057 int screen, |
| 1058 int* nelements) { |
| 1059 GL_SERVICE_LOG("glXGetFBConfigs" |
| 1060 << "(" << static_cast<const void*>(dpy) << ", " << screen |
| 1061 << ", " << static_cast<const void*>(nelements) << ")"); |
| 1062 GLXFBConfig* result = glx_api_->glXGetFBConfigsFn(dpy, screen, nelements); |
| 1063 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1064 return result; |
| 1065 } |
| 1066 |
| 1067 bool DebugGLXApi::glXGetMscRateOMLFn(Display* dpy, |
| 1068 GLXDrawable drawable, |
| 1069 int32_t* numerator, |
| 1070 int32_t* denominator) { |
| 1071 GL_SERVICE_LOG("glXGetMscRateOML" |
| 1072 << "(" << static_cast<const void*>(dpy) << ", " << drawable |
| 1073 << ", " << static_cast<const void*>(numerator) << ", " |
| 1074 << static_cast<const void*>(denominator) << ")"); |
| 1075 bool result = |
| 1076 glx_api_->glXGetMscRateOMLFn(dpy, drawable, numerator, denominator); |
| 1077 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1078 return result; |
| 1079 } |
| 1080 |
| 1081 void DebugGLXApi::glXGetSelectedEventFn(Display* dpy, |
| 1082 GLXDrawable drawable, |
| 1083 unsigned long* mask) { |
| 1084 GL_SERVICE_LOG("glXGetSelectedEvent" |
| 1085 << "(" << static_cast<const void*>(dpy) << ", " << drawable |
| 1086 << ", " << static_cast<const void*>(mask) << ")"); |
| 1087 glx_api_->glXGetSelectedEventFn(dpy, drawable, mask); |
| 1088 } |
| 1089 |
| 1090 bool DebugGLXApi::glXGetSyncValuesOMLFn(Display* dpy, |
| 1091 GLXDrawable drawable, |
| 1092 int64_t* ust, |
| 1093 int64_t* msc, |
| 1094 int64_t* sbc) { |
| 1095 GL_SERVICE_LOG("glXGetSyncValuesOML" |
| 1096 << "(" << static_cast<const void*>(dpy) << ", " << drawable |
| 1097 << ", " << static_cast<const void*>(ust) << ", " |
| 1098 << static_cast<const void*>(msc) << ", " |
| 1099 << static_cast<const void*>(sbc) << ")"); |
| 1100 bool result = glx_api_->glXGetSyncValuesOMLFn(dpy, drawable, ust, msc, sbc); |
| 1101 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1102 return result; |
| 1103 } |
| 1104 |
| 1105 XVisualInfo* DebugGLXApi::glXGetVisualFromFBConfigFn(Display* dpy, |
| 1106 GLXFBConfig config) { |
| 1107 GL_SERVICE_LOG("glXGetVisualFromFBConfig" |
| 1108 << "(" << static_cast<const void*>(dpy) << ", " << config |
| 1109 << ")"); |
| 1110 XVisualInfo* result = glx_api_->glXGetVisualFromFBConfigFn(dpy, config); |
| 1111 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1112 return result; |
| 1113 } |
| 1114 |
| 1115 int DebugGLXApi::glXIsDirectFn(Display* dpy, GLXContext ctx) { |
| 1116 GL_SERVICE_LOG("glXIsDirect" |
| 1117 << "(" << static_cast<const void*>(dpy) << ", " << ctx << ")"); |
| 1118 int result = glx_api_->glXIsDirectFn(dpy, ctx); |
| 1119 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1120 return result; |
| 1121 } |
| 1122 |
| 1123 int DebugGLXApi::glXMakeContextCurrentFn(Display* dpy, |
| 1124 GLXDrawable draw, |
| 1125 GLXDrawable read, |
| 1126 GLXContext ctx) { |
| 1127 GL_SERVICE_LOG("glXMakeContextCurrent" |
| 1128 << "(" << static_cast<const void*>(dpy) << ", " << draw << ", " |
| 1129 << read << ", " << ctx << ")"); |
| 1130 int result = glx_api_->glXMakeContextCurrentFn(dpy, draw, read, ctx); |
| 1131 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1132 return result; |
| 1133 } |
| 1134 |
| 1135 int DebugGLXApi::glXMakeCurrentFn(Display* dpy, |
| 1136 GLXDrawable drawable, |
| 1137 GLXContext ctx) { |
| 1138 GL_SERVICE_LOG("glXMakeCurrent" |
| 1139 << "(" << static_cast<const void*>(dpy) << ", " << drawable |
| 1140 << ", " << ctx << ")"); |
| 1141 int result = glx_api_->glXMakeCurrentFn(dpy, drawable, ctx); |
| 1142 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1143 return result; |
| 1144 } |
| 1145 |
| 1146 int DebugGLXApi::glXQueryContextFn(Display* dpy, |
| 1147 GLXContext ctx, |
| 1148 int attribute, |
| 1149 int* value) { |
| 1150 GL_SERVICE_LOG("glXQueryContext" |
| 1151 << "(" << static_cast<const void*>(dpy) << ", " << ctx << ", " |
| 1152 << attribute << ", " << static_cast<const void*>(value) |
| 1153 << ")"); |
| 1154 int result = glx_api_->glXQueryContextFn(dpy, ctx, attribute, value); |
| 1155 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1156 return result; |
| 1157 } |
| 1158 |
| 1159 void DebugGLXApi::glXQueryDrawableFn(Display* dpy, |
| 1160 GLXDrawable draw, |
| 1161 int attribute, |
| 1162 unsigned int* value) { |
| 1163 GL_SERVICE_LOG("glXQueryDrawable" |
| 1164 << "(" << static_cast<const void*>(dpy) << ", " << draw << ", " |
| 1165 << attribute << ", " << static_cast<const void*>(value) |
| 1166 << ")"); |
| 1167 glx_api_->glXQueryDrawableFn(dpy, draw, attribute, value); |
| 1168 } |
| 1169 |
| 1170 int DebugGLXApi::glXQueryExtensionFn(Display* dpy, int* errorb, int* event) { |
| 1171 GL_SERVICE_LOG("glXQueryExtension" |
| 1172 << "(" << static_cast<const void*>(dpy) << ", " |
| 1173 << static_cast<const void*>(errorb) << ", " |
| 1174 << static_cast<const void*>(event) << ")"); |
| 1175 int result = glx_api_->glXQueryExtensionFn(dpy, errorb, event); |
| 1176 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1177 return result; |
| 1178 } |
| 1179 |
| 1180 const char* DebugGLXApi::glXQueryExtensionsStringFn(Display* dpy, int screen) { |
| 1181 GL_SERVICE_LOG("glXQueryExtensionsString" |
| 1182 << "(" << static_cast<const void*>(dpy) << ", " << screen |
| 1183 << ")"); |
| 1184 const char* result = glx_api_->glXQueryExtensionsStringFn(dpy, screen); |
| 1185 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1186 return result; |
| 1187 } |
| 1188 |
| 1189 const char* DebugGLXApi::glXQueryServerStringFn(Display* dpy, |
| 1190 int screen, |
| 1191 int name) { |
| 1192 GL_SERVICE_LOG("glXQueryServerString" |
| 1193 << "(" << static_cast<const void*>(dpy) << ", " << screen |
| 1194 << ", " << name << ")"); |
| 1195 const char* result = glx_api_->glXQueryServerStringFn(dpy, screen, name); |
| 1196 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1197 return result; |
| 1198 } |
| 1199 |
| 1200 int DebugGLXApi::glXQueryVersionFn(Display* dpy, int* maj, int* min) { |
| 1201 GL_SERVICE_LOG("glXQueryVersion" |
| 1202 << "(" << static_cast<const void*>(dpy) << ", " |
| 1203 << static_cast<const void*>(maj) << ", " |
| 1204 << static_cast<const void*>(min) << ")"); |
| 1205 int result = glx_api_->glXQueryVersionFn(dpy, maj, min); |
| 1206 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1207 return result; |
| 1208 } |
| 1209 |
| 1210 void DebugGLXApi::glXReleaseTexImageEXTFn(Display* dpy, |
| 1211 GLXDrawable drawable, |
| 1212 int buffer) { |
| 1213 GL_SERVICE_LOG("glXReleaseTexImageEXT" |
| 1214 << "(" << static_cast<const void*>(dpy) << ", " << drawable |
| 1215 << ", " << buffer << ")"); |
| 1216 glx_api_->glXReleaseTexImageEXTFn(dpy, drawable, buffer); |
| 1217 } |
| 1218 |
| 1219 void DebugGLXApi::glXSelectEventFn(Display* dpy, |
| 1220 GLXDrawable drawable, |
| 1221 unsigned long mask) { |
| 1222 GL_SERVICE_LOG("glXSelectEvent" |
| 1223 << "(" << static_cast<const void*>(dpy) << ", " << drawable |
| 1224 << ", " << mask << ")"); |
| 1225 glx_api_->glXSelectEventFn(dpy, drawable, mask); |
| 1226 } |
| 1227 |
| 1228 void DebugGLXApi::glXSwapBuffersFn(Display* dpy, GLXDrawable drawable) { |
| 1229 GL_SERVICE_LOG("glXSwapBuffers" |
| 1230 << "(" << static_cast<const void*>(dpy) << ", " << drawable |
| 1231 << ")"); |
| 1232 glx_api_->glXSwapBuffersFn(dpy, drawable); |
| 1233 } |
| 1234 |
| 1235 void DebugGLXApi::glXSwapIntervalEXTFn(Display* dpy, |
| 1236 GLXDrawable drawable, |
| 1237 int interval) { |
| 1238 GL_SERVICE_LOG("glXSwapIntervalEXT" |
| 1239 << "(" << static_cast<const void*>(dpy) << ", " << drawable |
| 1240 << ", " << interval << ")"); |
| 1241 glx_api_->glXSwapIntervalEXTFn(dpy, drawable, interval); |
| 1242 } |
| 1243 |
| 1244 void DebugGLXApi::glXSwapIntervalMESAFn(unsigned int interval) { |
| 1245 GL_SERVICE_LOG("glXSwapIntervalMESA" |
| 1246 << "(" << interval << ")"); |
| 1247 glx_api_->glXSwapIntervalMESAFn(interval); |
| 1248 } |
| 1249 |
| 1250 void DebugGLXApi::glXUseXFontFn(Font font, int first, int count, int list) { |
| 1251 GL_SERVICE_LOG("glXUseXFont" |
| 1252 << "(" << font << ", " << first << ", " << count << ", " |
| 1253 << list << ")"); |
| 1254 glx_api_->glXUseXFontFn(font, first, count, list); |
| 1255 } |
| 1256 |
| 1257 void DebugGLXApi::glXWaitGLFn(void) { |
| 1258 GL_SERVICE_LOG("glXWaitGL" |
| 1259 << "(" |
| 1260 << ")"); |
| 1261 glx_api_->glXWaitGLFn(); |
| 1262 } |
| 1263 |
| 1264 int DebugGLXApi::glXWaitVideoSyncSGIFn(int divisor, |
| 1265 int remainder, |
| 1266 unsigned int* count) { |
| 1267 GL_SERVICE_LOG("glXWaitVideoSyncSGI" |
| 1268 << "(" << divisor << ", " << remainder << ", " |
| 1269 << static_cast<const void*>(count) << ")"); |
| 1270 int result = glx_api_->glXWaitVideoSyncSGIFn(divisor, remainder, count); |
| 1271 GL_SERVICE_LOG("GL_RESULT: " << result); |
| 1272 return result; |
| 1273 } |
| 1274 |
| 1275 void DebugGLXApi::glXWaitXFn(void) { |
| 1276 GL_SERVICE_LOG("glXWaitX" |
| 1277 << "(" |
| 1278 << ")"); |
| 1279 glx_api_->glXWaitXFn(); |
| 1280 } |
| 1281 |
1576 } // namespace gl | 1282 } // namespace gl |
OLD | NEW |