-
Notifications
You must be signed in to change notification settings - Fork 442
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
GL/DebugTools: read buffer data on WebGL 2.0 #560
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Doesn't feel that much of a rabbit hole to me :)
I didn't feel like adding all the checks for that
Sounds reasonable, ES2 is nowadays only important as a debugging-friendly alternative to WebGL 1 anyway. And it's not like WebGL 1 would be that heavily used either. Plus, I don't remember any suspicious ES2-specific behavior until now so it's unlikely that the tests would discover some new bug :)
src/Magnum/GL/Buffer.cpp
Outdated
glGetBufferSubData(GLenum(bindSomewhereInternal(_targetHint)), offset, size, data); | ||
#else | ||
CORRADE_ASSERT_UNREACHABLE("GL::Buffer::subData(): Buffer data queries in WebGL 2.0 possible only since Emscripten 2.0.17", ); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
As we discussed on Gitter, i'd make the whole thing fail at compile time, and not at runtime, to prevent an accidental footgun. So wrap this and also Buffer::subData()
in #if __EMSCRIPTEN_major__*...
.
Hmm but that means all test code using DebugTools::bufferSubData()
now has to do #if __EMSCRIPTEN_major__*...
as well, umm... OTOH, it'd have to do that anyway, to prevent a runtime assert, so I guess that's fine. Yeah, so make this function disabled at compile time instead.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I was thinking... couldn't we fall back to using EM_ASM
to call getBufferSubData()
function on older Emscripten versions? There'd be some runtime overhead on those versions, but it's much better than not being able to read buffers at all. And it'd remove the need for ugly version checks around the two functions as well as in all tests.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Realistically, is anybody using such old Emscripten anymore? (Except me on the CI, which I should upgrade anyway.)
If ancient Emscriptens would be regularly used by people because they're in LTS Linux distro repos (which is the case with old GCC and old CMake), then it would make sense to add some fallback path, but I don't think anybody really does that.
I'd say -- let's upgrade the WebGL 2 build on the CI to 2.0.17 to not have to ifdef each and every test (can you do that in the PR?) but keep the API in GL::Buffer
ifdef'd to not cause a linker failure for users on older versions. I don't expect regular users to build tests as well, so this should be fine. Then support for < 2.0.17 is just on a best-effort basis (we aim to support but we don't explicitly test for it). To keep at least some variety in the testing, the WebGL 1 CI build would stay on 1.39 for now and the next upgrade round (in a year or so?) would bump WebGL 2 build to 3.0.x and WebGL 1 to 2.0.x.
Hm, now I remember we still have the compatibility code for pre-1.39 event handling behavior in the Application classes, right? Probably a good time to drop that now :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I upgraded to 2.0.17 for the emscripten-webgl2 job but it's failing with very funny errors. Not sure if we actually hit a compiler error there, but I'll try to build with that exact version locally.
9fa66f0
to
09ce4ee
Compare
The macos-gles3 failure seems to be a broken interaction with |
09ce4ee
to
c43151b
Compare
src/Magnum/GL/Test/CMakeLists.txt
Outdated
@@ -162,10 +170,10 @@ if(BUILD_GL_TESTS) | |||
endif() | |||
|
|||
if(NOT MAGNUM_TARGET_GLES2) | |||
corrade_add_test(GLBufferImageGLTest BufferImageGLTest.cpp LIBRARIES MagnumOpenGLTesterTestLib) | |||
corrade_add_test(GLBufferImageGLTest BufferImageGLTest.cpp LIBRARIES MagnumDebugTools MagnumOpenGLTesterTestLib) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To fix the Mac CI failure, can you try swapping the order?
corrade_add_test(GLBufferImageGLTest BufferImageGLTest.cpp LIBRARIES MagnumDebugTools MagnumOpenGLTesterTestLib) | |
corrade_add_test(GLBufferImageGLTest BufferImageGLTest.cpp LIBRARIES MagnumOpenGLTesterTestLib MagnumDebugTools) |
Same below. The *TestLib
has the GL library built with graceful assertions, while the regular DebugTools
links to a regular MagnumGL
. Meaning, there's two duplicate candidates for the (global) GL symbols and the linker picks the first it finds (from DebugTools
), but then the code in MagnumOpenGLTesterTestLib
relies on the second duplicate, causing an assertion due to a different copy of the global used in different parts of the code.
I hope that's enough to make this work, if not then I'd probably need to introduce MagnumDebugToolsTestLib
that relies on MagnumGLTestLib
instead of MagnumGL
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah, thanks, I understand the issue now. Sadly changing the order doesn't seem to make a difference 😢 I assume CMake sorts the link order anyway
Since glGetBufferSubData() is only exposed on Emscripten 2.0.17 and up, both functions are not available on older versions. This is to avoid any accidental foot guns since it explodes at compile time. The webgl2 CI will be upgraded to 2.0.17 in a later commit.
…ata() This avoids requiring any Desktop GL extensions and allows forwarding to Buffer::subData() also on WebGL 2.0 (in a follow-up commit)
This is already done for bufferData()
Required for Buffer::data()/subData() used by GLES3 tests. Otherwise all the tests would have to check the Emscripten version and skip if it's too old.
c43151b
to
1ae3471
Compare
Okay, seems we're at the cursed issues again. I'll take it from here :D |
Ah yes, 2.0.18 doesn't die anymore, but I started hitting #507 now. Curses! Investigating... |
Ah well, and an attempted fix for the macOS global symbol mismatch, where I made |
Oh dear, what have I done 🙊 sorry about this mess |
All "good" for Emscripten now (see #507 (comment) for details). For the other problem, I managed to "fix" it so now it's not macOS or ASan complaining, but Linux tests failing due to asserts not being graceful anymore. I suppose this is the culprit, gotta fix that properly I guess. |
Hm, reshuffled the library order once more and now it seems to work. Although it's a tower of brittle hacks and wishful thinking, hopefully not breaking again anytime soon. Will merge once I implement the template-removal TODO as well. Tomorrow, enough suffering for a Sunday 💀 |
Finally merged a subset of this as 500e41e...4350f13, sorry for the extremely long delay. CircleCI macOS builds started also acting up in the meanwhile, further delaying everything. I ended up deprecating the templated Thanks for your work! |
This became a bit of a rabbit hole 👀
GL::Buffer::data()
andsubData()
are now supported on WebGL 2.0. This is exposed by Emscripten 2.0.17+ as aglGetBufferSubData()
convenience entrypoint. On older Emscripten versions,data()
/subData()
are callable but lead to an "unreachable" assert.DebugTools::bufferData()
andbufferSubData()
now forward toGL::Buffer::subData()
where available, which now makes it work on desktop GL without requiringARB_map_buffer_range
and on WebGL 2.0. Essentially everywhere except WebGL 1.0 and GLES 2.0 withoutEXT_map_buffer_range
DebugTools::bufferData()
. Technically they could also be verified on non-WebGL GLES 2.0 with the right extension, but I didn't feel like adding all the checks for thatTodos:
glGetBufferSubData()
, I probably messed up the Emscripten version checkDebugTools/BufferData.cpp
isn't being compiled, leading to missing symbols. Investigate.Mac GLES3 CI has mysteriouspostponed to Test buffer contents on GLES3 & WebGL, fix global symbol duplication in GL test libraries #565GL::Context::current(): no current context
asserts in testsPost-merge todos for @mosra:
DebugTools::buffer[Sub]Data()
. Originally Buffer used the same API pattern, but it got deprecated and eventually dropped in ecc0ab6 for being too error-prone. Time to do that here too.