gecko-dev/gfx/wr
Jamie Nicol 428ac6de51 Bug 1814344 - Disable scissored clear optimization on all Android except SWGL. r=gfx-reviewers,jrmuizel
In bug 1809738 we found that our scissored render target clear
optimization actively hurt performance on some Mali GPUs. From testing
on a variety of Android devices, we have found that it mostly makes no
difference either way, but hurts performance on some other GPUs
too. On software webrender, however, it is still a performance win.

This patch therefore disables the optimization on all Android, apart
from when using software webrender.

Differential Revision: https://phabricator.services.mozilla.com/D169062
2023-02-07 15:21:48 +00:00
..
ci-scripts Bug 1805128 - Update servo/webrender CI to pass again. r=jrmuizel 2022-12-14 10:07:50 +00:00
example-compositor Bug 1690244 - Move WebRender initialization code out of renderer.rs. r=kvark 2022-08-12 07:30:14 +00:00
examples Bug 1803738 - use unique SpatialTreeItemKey for reference frame in animation example. r=gfx-reviewers,nical 2022-12-04 22:31:42 +00:00
fog Bug 1765921 - Rename `fog` crate to `firefox-on-glean` r=TravisLong,supply-chain-reviewers 2023-01-20 23:14:03 +00:00
glsl-to-cxx Bug 1797721 - Handle tile repeat in brush_linear_gradient SWGL span shader. r=aosmond 2022-10-29 07:03:36 +00:00
peek-poke Bug 1776096 - Bump WebRender crate versions. r=jrmuizel 2022-06-24 04:11:26 +00:00
swgl Bug 1789449 - Adjust clamp order. r=aosmond 2023-01-18 05:32:38 +00:00
webrender Bug 1814344 - Disable scissored clear optimization on all Android except SWGL. r=gfx-reviewers,jrmuizel 2023-02-07 15:21:48 +00:00
webrender_api Bug 1786634 - Remove ImageMask.repeat field because it is always false r=gw 2022-10-11 23:54:28 +00:00
webrender_build Bug 1811977 - Add a new tiled primitive rendering path to webrender r=gfx-reviewers,nical 2023-01-26 20:55:32 +00:00
wr_glyph_rasterizer Bug 1765921 - Rename `fog` crate to `firefox-on-glean` r=TravisLong,supply-chain-reviewers 2023-01-20 23:14:03 +00:00
wr_malloc_size_of Bug 1776096 - Bump WebRender crate versions. r=jrmuizel 2022-06-24 04:11:26 +00:00
wrench Bug 1814628 - Use half-spaces to select the corner of a rounded rect. r=jrmuizel,gfx-reviewers,ahale 2023-02-04 05:48:46 +00:00
.gitignore
.taskcluster.yml Bug 1805128 - Update servo/webrender CI to pass again. r=jrmuizel 2022-12-14 10:07:50 +00:00
Cargo.lock Bug 1812615 - Update to Glean v52.2.0, glean_parser 7.0.0 and UniFFI 0.23. r=chutten,markh,glandium,supply-chain-reviewers 2023-01-31 11:12:05 +00:00
Cargo.toml Bug 1765921 - Rename `fog` crate to `firefox-on-glean` r=TravisLong,supply-chain-reviewers 2023-01-20 23:14:03 +00:00
LICENSE
README.md
rustfmt.toml
servo-tidy.toml Bug 1799442 - Update Glean to v51.8.2, rkv to 0.18 r=janerik,supply-chain-reviewers 2022-11-18 13:56:27 +00:00

README.md

WebRender

Version

WebRender is a GPU-based 2D rendering engine written in Rust. Firefox, the research web browser Servo, and other GUI frameworks draw with it. It currently uses the OpenGL API internally.

Note that the canonical home for this code is in gfx/wr folder of the mozilla-central repository at https://hg.mozilla.org/mozilla-central. The Github repository at https://github.com/servo/webrender should be considered a downstream mirror, although it contains additional metadata (such as Github wiki pages) that do not exist in mozilla-central. Pull requests against the Github repository are still being accepted, although once reviewed, they will be landed on mozilla-central first and then mirrored back. If you are familiar with the mozilla-central contribution workflow, filing bugs in Bugzilla and submitting patches there would be preferred.

Update as a Dependency

After updating shaders in WebRender, go to servo and:

  • Go to the servo directory and do ./mach update-cargo -p webrender
  • Create a pull request to servo

Use WebRender with Servo

To use a local copy of WebRender with servo, go to your servo build directory and:

  • Edit Cargo.toml
  • Add at the end of the file:
[patch."https://github.com/servo/webrender"]
"webrender" = { path = "<path>/webrender" }
"webrender_api" = { path = "<path>/webrender_api" }

where <path> is the path to your local copy of WebRender.

  • Build as normal

Documentation

The Wiki has a few pages describing the internals and conventions of WebRender.

Testing

Tests run using OSMesa to get consistent rendering across platforms.

Still there may be differences depending on font libraries on your system, for example.

See this gist for how to make the text tests useful in Fedora, for example.