-
-
Notifications
You must be signed in to change notification settings - Fork 107
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
webots: blinking vgl, some times #172
Comments
Reproduced. Investigating. This issue is specific to the EGL back end, which is not surprising. |
In the process of investigating this issue, I discovered several other issues with the EGL back end and fixed those, but I have yet to find the cause of this issue. Since I have very limited resources to work on the EGL back end, it may take a while for this issue to get fixed. Please be patient. |
Thanks to piglit, I have discovered and fixed numerous conformance issues in the EGL back end, but this issue still eludes me. Either it is somehow related to rarely-used OpenGL and GLX features that are still missing in the EGL back end (see #134 and #136) or it is yet another conformance issue that hasn't been uncovered yet. Unfortunately I must declare defeat for now. |
@LeehanLee That is a good clue. I reproduced the issue, and it is almost certainly a bug in VGL, but I have thus far been unable to find the bug. Now that I know that it is specific to one mode of operation, I can hopefully look at the application source code and figure out what that mode of operation does at the OpenGL level. |
I have spent more hours trying to diagnose this, including comparing the apitrace output with and without cameras enabled. Unfortunately I am still at a loss. |
I found the description of the Webots function "wb_camera_enable" here: you can see from the above screenshot, I changed the second parameter "sampling_period" to "50 * time_step"(which was "2 * time_step" before I changed it), and then I found that the blinking frequency in the rendering area was slowed down: slowly_blinking.mp4I'm not sure if this could help you to diagnose this issue. |
That is a good clue. I’ll see if I can find where in the code it copies the image. |
I am now able to build Webots from source and get an OpenGL API trace from it, both with and without cameras enabled. Unfortunately, it hasn't revealed any obvious issues, so I am still clueless. It still isn't clear exactly how enabling cameras changes the OpenGL call sequence. I have tried to add print statements to the code to understand the mechanism by which that happens, but so far it hasn't been revealing. Unfortunately I have to shelve this yet again, as I don't have any more time right now to pursue it. |
Ouch, that was difficult. It ultimately took more than 60 uncompensated hours to diagnose the problem, and I still cannot figure out how to reproduce it in isolation (using fakerut.) However, the following patch seems to fix it:
In a nutshell, the complexity of the Webots camera rendering code exposed a really esoteric aspect of FBO behavior, which is that the draw and read buffer state is attached to the FBO state, but when using the default framebuffer, the draw and read buffer state should be attached to the context instead. I already emulated that behavior in the EGL back end I am going to do some regression testing tomorrow, and I should be able to push this patch by the end of the day. |
Application: webots R2021a (https://www.cyberbotics.com/)
VirtualGL: 2.6.90
TurboVNC: 2.2.6
Container OS: Ubuntu 18.04.5 LTS
Host OS: Centos 7
GPU: Tesla M2090, driver version: 390.116
When webots runs simulations, some run all good, but some have the main display (vgl window) blinking. Screen recorded example: https://video.fbxl.net/videos/watch/3389fa83-c31e-4cc4-a861-805e94b16a59
By trial and error, it looks like that wired behavior is linked to some "robots" (PROTO Nodes/robots), but not all of them; in the same simulation, adding some robots will cause blinking, remove them and add other robots and the simulation will run OK.
Here's a trace output of a (almost) empty simulation: http://dl.free.fr/lH4IZIt0F
The same plus a Boston Dynamics dog (screen recorded one): http://dl.free.fr/wl8bbqSMD
Command to lauch webots:
vglrun +v -d /dev/dri/card1 webots
Docker compose file:
The text was updated successfully, but these errors were encountered: