-
Notifications
You must be signed in to change notification settings - Fork 346
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
fix QT>=6.4 segfault by always setting surface type #984
base: master
Are you sure you want to change the base?
Conversation
This is confirmed to work on macOS with qt 6.8 |
Doesn't work for me on Fedora. |
@linuxdude42 please post full startup logs and run mythfrontend with env var |
I don't get any additional output when running the qt6 based image with QT_DEBUG_PLUGINS set. I do get output for the qt5 image, so I know I've set the variable correctly. Does the attached excerpt from a strace output help? It shows that the files for the egl plugins are being opened. |
sorry try this
then attach the myth.log |
I hope this helps, but it still doesn't have any qt debug output. |
Yeah that is pretty lacking, just to confirm before applying this PR you were getting "Qt: QOpenGLContext::makeCurrent() called with non-opengl surface " ? the 300D error is the same that @warpme gets currently. The EGL error is actually "EGL_BAD_SURFACE" which would imply certainly a similar error to what Qt itself was saying without. Can you try your graphics cards proprietary driver? Does the display server log have anything potentially useful in it? |
Yes, before the patch I get:
and after the patch I get:
My laptop has Intel's UHD Graphics 630 I am using the Intel i915 driver. I don't see anything useful in the Xorg.0.log file. I'm happy to compile in any debugging code you think would be useful. I would very much like to get this resolved so we can (hopefully) transition the default compile from qt5 to qt6 after the next release. Feel free to contact me directly. |
I see the same 300d error on one of my production frontends. That system is an Intel NUC6 with HD Graphics 500 video using the i915 driver. |
In reviewing what was said in #754 at least @kmdewaal also got this error with intel graphics and @warpme is thought to have as well. @jhoyt4 can you confirm what graphics card is driving the box it worked on? I assume plenty of people are using these on mini pcs thus the intel only graphics but if it does work with amd/nvidia proprietary drivers that would be interesting. At a minimum may make narrowing the problem easier. |
Apple GPU on an M1 and M3max |
Another data point. Works on my old 2014 Mac Mini running macOS 12.7.6 and using Intel Iris graphics. |
Another data point: boty menu and playback is OK under the following conditions:
This is with Fedora 41, Qt 6.8.0, master with this fix included. |
Indeed - this confirms (for me): issue is within egl based x11 integration layer in qt6(xcb_egl). As x11 with xcb_glx and eglfs are working, I'm concluding:
Before Qt6.4 all was working ok - so for me all this points to regression in qt6+ It is a bit sad for me that Qt team seems to be not interested in resolving this issue... |
Applying this fix and then testing it with Qt5 gives the following new error message in the mythfrontend log:
Doing what the error message says on the parent widget with the following code in mythrenderopengl.cpp:560:
This does fix the error message in Qt5. I think the patch from this ticket combined with the code snippet above can be applied to master. It does however NOT fix the abort in Qt6 for Intel/VAAPI based systems. This still needs to be done. |
See #754 for details but this is the recommendation from QT dev @alpqr that 100% WFM. Note, as I mention there officially the old behavior would be best replicated by setting this to the internal value
QSurface::RasterGLSurface
from https://doc.qt.io/qt-6/qsurface.html#SurfaceType-enum as this is what QT 6.3 and lower did. If you want me to update the PR to that I can. I don't have osx to test there.Clearly people are running mythtv with QT > 6.3 so I am not sure why only some users hit this bug. Maybe it is only if they have hardware rendering enabled? Given how long it has stood though there must be something scoping it to just a select few of us.
Checklist
Fixes #754