<p dir="ltr">I'm inclined to agree here that Freeglut isn't correct to ignore the extension string. If I recall, either WGL or GLX have undefined behavior for unsupported function lookup.</p>
<p dir="ltr">- Nigel</p>
<div class="gmail_quote">On May 16, 2015 5:42 PM, "José Fonseca" <<a href="mailto:jose.r.fonseca@gmail.com">jose.r.fonseca@gmail.com</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Yep, I also reproed the issue here and reached similar conclusion. <div><br></div><div>I too I'm not sure where the bug is. Per <a href="http://lists.freedesktop.org/archives/waffle/2013-June/000164.html" target="_blank">http://lists.freedesktop.org/archives/waffle/2013-June/000164.html</a> it's not safe to look exclusively at the client string neither. GLX_ARB_create_context seem to require server support for certain cases (though maybe that's not the case for SW renderering.'</div><div><br></div><div>FreeGLUT seems the oddball here. For example, GLFW uses glXQueryExtensionsString.</div><div><br></div><div>In short, even if we manage to hack glretrace to cope with this Xvfb weirdness, there are loads of OpenGL apps/toolkits which will choke on it. So I wonder if there's much point to do it. It seems the ideal would be to fix xvfb itself...</div><div><br></div><div>Jose</div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Sat, May 16, 2015 at 4:07 PM, Nick McVeity <span dir="ltr"><<a href="mailto:nmcveity@gmail.com" target="_blank">nmcveity@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><div><div><div>Good idea. Here is the trace:<br><br> 0 glXQueryVersion(dpy = 0x1feb4f0, maj = &1, min = &4) = True<br> 1 glXQueryExtension(dpy = 0x1feb4f0, errorb = &153, event = &93) = True<br> 2 glXQueryExtensionsString(dpy = 0x1feb4f0, screen = 0) = "GLX_ARB_get_proc_address GLX_ARB_multisample GLX_EXT_import_context GLX_EXT_visual_info GLX_EXT_visual_rating GLX_MESA_copy_sub_buffer GLX_MESA_multithread_makecurrent GLX_MESA_query_renderer GLX_OML_swap_method GLX_SGI_make_current_read GLX_SGIS_multisample GLX_SGIX_fbconfig GLX_SGIX_pbuffer GLX_EXT_texture_from_pixmap "<br> 3 glXChooseFBConfig(dpy = 0x1feb4f0, screen = 0, attribList = {GLX_DRAWABLE_TYPE, GLX_WINDOW_BIT, GLX_RENDER_TYPE, GLX_RGBA_BIT, GLX_RED_SIZE, 1, GLX_GREEN_SIZE, 1, GLX_BLUE_SIZE, 1, GLX_ALPHA_SIZE, 1, GLX_DOUBLEBUFFER, True, GLX_DEPTH_SIZE, 1, GLX_STENCIL_SIZE, 1, 0}, nitems = &8) = {0x2028bc0, 0x2028da0, 0x202e070, 0x202e250, 0x2028cb0, 0x2028e90, 0x202e160, 0x202e340}<br> 4 glXGetVisualFromFBConfig(dpy = 0x1feb4f0, config = 0x2028bc0) = &{visual = 0x1ff6700, visualid = 33, screen = 0, depth = 24, c_class = 4, red_mask = 16711680, green_mask = 65280, blue_mask = 255, colormap_size = 256, bits_per_rgb = 8}<br><br></div>No call actually fails but the context fails to create because it can't find the GLX_ARB_create_context extension (which is missing from the extension string list). If glretrace gets a GLX version >= 1.4 and can't find this extension and you request a core profile, the createContext function returns NULL. This code is all in glws_glx.cpp in the createContext function.<br><br></div><div>Further inspection using "DISPLAY=:99 glxinfo" does indicate that the GLX server does not support GLX_ARB_create_context extension:<br><br>name of display: :99<br>display: :99 screen: 0<br>direct rendering: Yes<br>server glx vendor string: SGI<br>server glx version string: 1.4<br>server glx extensions:<br> GLX_ARB_multisample, GLX_EXT_import_context, GLX_EXT_texture_from_pixmap, <br> GLX_EXT_visual_info, GLX_EXT_visual_rating, GLX_MESA_copy_sub_buffer, <br> GLX_OML_swap_method, GLX_SGIS_multisample, GLX_SGIX_fbconfig, <br> GLX_SGIX_pbuffer, GLX_SGI_make_current_read<br>client glx vendor string: Mesa Project and SGI<br>client glx version string: 1.4<br>client glx extensions:<br> GLX_ARB_create_context, GLX_ARB_create_context_profile, <br> GLX_ARB_create_context_robustness, GLX_ARB_fbconfig_float, <br> GLX_ARB_framebuffer_sRGB, GLX_ARB_get_proc_address, GLX_ARB_multisample, <br> GLX_EXT_buffer_age, GLX_EXT_create_context_es2_profile, <br> GLX_EXT_fbconfig_packed_float, GLX_EXT_framebuffer_sRGB, <br> GLX_EXT_import_context, GLX_EXT_texture_from_pixmap, GLX_EXT_visual_info, <br> GLX_EXT_visual_rating, GLX_INTEL_swap_event, GLX_MESA_copy_sub_buffer, <br> GLX_MESA_multithread_makecurrent, GLX_MESA_query_renderer, <br> GLX_MESA_swap_control, GLX_OML_swap_method, GLX_OML_sync_control, <br> GLX_SGIS_multisample, GLX_SGIX_fbconfig, GLX_SGIX_pbuffer, <br> GLX_SGIX_visual_select_group, GLX_SGI_make_current_read, <br> GLX_SGI_swap_control, GLX_SGI_video_sync<br>GLX version: 1.4<br>GLX extensions:<br> GLX_ARB_get_proc_address, GLX_ARB_multisample, GLX_EXT_import_context, <br> GLX_EXT_texture_from_pixmap, GLX_EXT_visual_info, GLX_EXT_visual_rating, <br> GLX_MESA_copy_sub_buffer, GLX_MESA_multithread_makecurrent, <br> GLX_MESA_query_renderer, GLX_OML_swap_method, GLX_SGIS_multisample, <br> GLX_SGIX_fbconfig, GLX_SGIX_pbuffer, GLX_SGI_make_current_read<br><br></div><div>The client supports the extension but not he server, thus it is not in the GLX extensions list. So how does freeglut work in the first place? Looking at the trace:<span><br><br>0 glXQueryExtension(dpy = 0xa444f0, errorb = NULL, event = NULL) = True<br></span><span>1 glXChooseFBConfig(dpy = 0xa444f0, screen = 0, attribList = {GLX_RED_SIZE, 1, GLX_GREEN_SIZE, 1, GLX_BLUE_SIZE, 1, GLX_DOUBLEBUFFER, True, GLX_DEPTH_SIZE, 1, 0}, nitems = &64) = {0xa7e020, 0xa7e200, 0xa83480, 0xa83660, 0xa7d4e0, 0xa7d6c0, 0xa82940, 0xa82b20, 0xa7da80, 0xa7dc60, 0xa82ee0, 0xa830c0, 0xa7ce10, 0xa7d120, 0xa823a0, 0xa82580, 0xa7c2d0, 0xa7c4b0, 0xa81860, 0xa81a40, 0xa7b790, 0xa7b970, 0xa80d20, 0xa80f00, 0xa7bd30, 0xa7bf10, 0xa812c0, 0xa814a0, 0xa7b1f0, 0xa7b3d0, 0xa80780, 0xa80960, 0xa7e110, 0xa7e2f0, 0xa83570, 0xa83750, 0xa7d5d0, 0xa7d7b0, 0xa82a30, 0xa82c10, 0xa7db70, 0xa7dd50, 0xa82fd0, 0xa831b0, 0xa7cf00, 0xa7d210, 0xa82490, 0xa82670, 0xa7c3c0, 0xa7c5a0, 0xa81950, 0xa81b30, 0xa7b880, 0xa7ba60, 0xa80e10, 0xa80ff0, 0xa7be20, 0xa7c000, 0xa813b0, 0xa81590, 0xa7b2e0, 0xa7b4c0, 0xa80870, 0xa80a50}<br>2 glXGetVisualFromFBConfig(dpy = 0xa444f0, config = 0xa7e020) = &{visual = 0xa4f630, visualid = 297, screen = 0, depth = 24, c_class = 4, red_mask = 16711680, green_mask = 65280, blue_mask = 255, colormap_size = 256, bits_per_rgb = 8}<br></span><span>3 glXGetProcAddressARB(procName = "glXCreateContextAttribsARB") = 0x7f49a8ac15f2<br></span><span>4 glXCreateContextAttribsARB(dpy = 0xa444f0, config = 0xa7e020, share_context = NULL, direct = True, attrib_list = {GLX_CONTEXT_MAJOR_VERSION_ARB, 3, GLX_CONTEXT_MINOR_VERSION_ARB, 3, GLX_CONTEXT_FLAGS_ARB, GLX_CONTEXT_DEBUG_BIT_ARB | GLX_CONTEXT_FORWARD_COMPATIBLE_BIT_ARB, 0}) = 0xa55da0<br></span>5 glXIsDirect(dpy = 0xa444f0, ctx = 0xa55da0) = True<br></div><div><br></div><div>It seems it doesn't bother checking the extension string, preferring to just call glXGetProcAddressARB("glXCreateContextAttribsARB") and using the pointer returned. I don't know how valid this is. When I made a similar change to apitrace, glreplay was able to replay the trace that was failing before. If the context is direct, perhaps it doesn't matter than the glx server doesn't support the GLX_ARB_create_context[_profile] extensions?<span><font color="#888888"><br><br></font></span></div><span><font color="#888888"><div> -- Nick<br></div></font></span></div></div><br></div><div><div><div class="gmail_extra"><br><div class="gmail_quote">On Fri, May 15, 2015 at 5:38 PM, Alexander Monakov <span dir="ltr"><<a href="mailto:amonakov@ispras.ru" target="_blank">amonakov@ispras.ru</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">To investigate this further, trace the replayer, i.e.:<br>
<br>
DISPLAY=:99 apitrace trace -o rtrace apitrace replay trace<br>
<br>
This should show what GLX call is failing in the replayer.<br>
<span><font color="#888888"><br>
Alexander<br>
</font></span></blockquote></div><br></div>
</div></div><br>_______________________________________________<br>
apitrace mailing list<br>
<a href="mailto:apitrace@lists.freedesktop.org" target="_blank">apitrace@lists.freedesktop.org</a><br>
<a href="http://lists.freedesktop.org/mailman/listinfo/apitrace" target="_blank">http://lists.freedesktop.org/mailman/listinfo/apitrace</a><br>
<br></blockquote></div><br></div>
<br>_______________________________________________<br>
apitrace mailing list<br>
<a href="mailto:apitrace@lists.freedesktop.org">apitrace@lists.freedesktop.org</a><br>
<a href="http://lists.freedesktop.org/mailman/listinfo/apitrace" target="_blank">http://lists.freedesktop.org/mailman/listinfo/apitrace</a><br>
<br></blockquote></div>