- 
                Notifications
    You must be signed in to change notification settings 
- Fork 181
vello_hybrid: add native WebGL backend #1011
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
Conversation
feb47e7    to
    dbcd9cd      
    Compare
  
    59e824d    to
    eb2c76a      
    Compare
  
    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.
Initial comments on other parts of code. I ran the demos (native webgl, webgl, and winit). They look great 🥳
71c9a45    to
    a3f6cf3      
    Compare
  
    987f7de    to
    ef903a9      
    Compare
  
    | Note, the  | 
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.
LGTM - Amazing work 🚀
This makes the webgl renderer backend compile safe.
27f98bf    to
    25ea383      
    Compare
  
    - Add warning if both webgl features are active. - Add todos - Add new example to CI.
| All clear to merge from Raph: #vello > vello_hybrid: WebGL2 renderer backend that skips wgpu #947 @ 💬 | 
…1016) # Context Addresses comment #1011 (comment) from @DJMcNab . Replaces `include_str!` with a direct import from `vello_sparse_shaders` to get access to the wgsl source code. ### Changes - Adds a `wgsl` module to the build-time module generated by `vello_sparse_shaders`. This allows `render_strips.wgsl` to be accessed via: `vello_sparse_shaders::wgsl::RENDER_STRIPS` instead of a cross-package `include_str!`. - Adds a `glsl` feature flag to `vello_sparse_shaders` so the default compiled module does not include `glsl` unless the `glsl` feature is used. This makes builds much leaner for wgsl without glsl. ### Test plan Reviewed generated code, and tested both examples manually: - `cargo run_wasm -p wgpu_webgl --release --port 8001` - `cargo run_wasm -p native_webgl --release --port 8000` Finally, CI is very thorough.
Note: This PR currently branches off #1021 as there is a lint error on `main` and I wanted to ensure CI fully passed. > [!TIP] > This is ready to review and passes all tests in CI. ### Context This follows #1011 and is the testing portion. In order to ensure renderer parity and correctness, I've forked the `vello_hybrid` tests to also include a `_hybrid_webgl` variant that use: `#[wasm_bindgen_test::wasm_bindgen_test]` and run via the browser. <details> <summary> As a demo of this PR, I locally introduced a "fake error" that reflects the image. After running `wasm-pack test --chrome --features webgl` from the `vello_sparse_tests` directory, I got the following very long webpage. (unfurl details section by clicking this text, and scroll to bottom of test results) </summary>  </details> ### Features - Add headless and headed browser testing of the webgl backend. - Because the browser can't read from the file system easily, reference images are inlined into the binary via the proc macro and provided to the `check_refs` function. - Existing `_hybrid` tests are unchanged. I've added a `_hybrid_webgl` test. - For ease of debugging the diff'd images are appended to the document after tests have run. This makes it much easier to understand the failure. - Add `check vello_hybrid webgl backend passes vello_sparse_tests suite` CI step that uses headless browser. These tests could be fancier, but they do the job right now. Debugging a failure isn't easy, however the diff can be manually retrieved and compared by a human by spinning up a browser. The goal of having webgl tests automatically match the vello_hybrid tests is to keep the `wgpu` and `webgl` renderer backends in sync. ### Test plan This PR changes no business logic and is the test. Note: Browser WebGL backend tests currently pass all of the same tests as the vello_hybrid wgpu renderer. Can be seen in CI here: https://github.com/linebender/vello/actions/runs/15211363959/job/42786078261?pr=1020 I tested the functionality of this change by introducing intentional breakages and ensuring that headless tests failed, and diff images could be found on the browser when run without headless. ### Risks I'm not sure of any risks as this isn't user facing. ### Manually testing this change Pull branch down locally. Then navigate the `vello_sparse_tests` and run: `wasm-pack test --chrome --features webgl`. Navigate to the browser URL and see 65 tests succeed. ### Followup work #1026 #1025 --------- Co-authored-by: Daniel McNab <[email protected]>
Context
This PR follows the conversation had about #947 . I made this PR separately as it also incorporates the clipping changes #957 .
In short, this PR adds a native WebGL backend when targeting
wasm32and if using the"webgl"feature onvello_hybrid.The primary motivation of using a custom webgl renderer is binary size, allowing 3mb to be removed when targeting WebGL2 natively. This is achieved by omitting
wgpufrom the binary when the architecture iswasm32and the"webgl"feature flag is set onvello_hybrid.Changes
vello_hybrid examples
webglexample has been renamed towgpu_webgl. Now it's more clear that it leverageswgpu's WebGL backend.native_webglexample has been added which uses the new WebGL renderer backend.ci.ymltests both thewgpu_webglexample and thenative_webglexample - smoke testing both webgl techniques.ClipScenehas been added for manually viewing and testing deeply nested clipping. (file)The PR can be manually tested by locally pulling the branch and running the two examples:
cargo run_wasm -p wgpu_webgl --release: Test original examplecargo run_wasm -p native_webgl --release: Test new backendNew
vello_sparse_shaderspackage addedThis new package contains the WGSL shaders as a source of truth.
vello_hybridoptionally depends on this library which triggers a build step generating a compiled module. The module contains GLSL shader source code, as well as mappings from the WGSL identifiers to the naga-mangled identifiers in the GLSL.The generated code:
The generated code can then be imported with:
use vello_sparse_shaders::{clear_slots, render_strips};vello_hybridchangesA new
rendersubdirectory has been added that contains:common.rs: All the shared render logic.wgpu.rs: The original renderer leveragingwgpu.webgl.rs: The new WebGL native backend renderer.The
Schedulerhas been made backend-agnostic by operating on a newRendererBackendtrait. Both thewgpuandwebglrenderer backends implementRendererBackend.Feature flag changes
Feature flags in
vello_hybridare additive. By default thewgpufeature is enabled. If the compile target iswasm32and thewebglfeature is enabled onvello_hybrid, then the native WebGL renderer will be enabled.Warnings
A runtime warning has been added that will trigger once on either renderer being instantiated, if both:
wgpuwith its WebGL backend is active.WebGlRendereris also active.The warning is:
Screen recording
Note
The screen recording below is slightly stale – I've since changed the background to be dark so the white text scene can be read.
Left side is
native_webglexample (using native WebGL2)Right side is the existing
webglexample which useswgpuwith thewebglfeature flag.Test plan
To scope down this PR, there are no automated tests for the renderer except for the single browser test introduced in the example. The shader compilation has some unit tests.
This PR was manually tested via the new native webgl example:
cargo run_wasm -p native_webgl. This example can be tested against the originalcargo run_wasm -p wgpu_webgl.Risks
The only risk I'm uncertain about is the addition of the
wgpufeature flag, that is used as a default feature. Could this be a breaking change for users that specify "no default features". They'd have to add thewgpufeature explicitly. This seems minor.Followup work
This PR is huge, because it implements all the existing vello_hybrid features in the WebGL backend. Similarly it also includes build-time shader compilation. Instead of making this change completely impenetrable, I'm splitting test infrastructure into a separate change. This PR must be manually tested in the interim.
The example has been added to CI so that it must compile and run.