gecko-dev/gfx/wr
Glenn Watson 36a99a2cba Bug 1579235 - Part 11 - Refactor how external surfaces are composited. r=Bert,sotaro
This patch refactors how external surfaces are stored in the
CompositeState structure. This is primarily to simplify integration
with native compositor mode, but also simplifies the Draw compositor
path.

Previously, the ResolvedExternalSurface struct contained information
that was used to rasterize the external surface (YUV planes etc) and
also the information to composite it (device rect, clip rect, z_id).

Now, ResolvedExternalSurface contains just the information required
to rasterize the external surface, while the compositing information
is handled by adding the external surface as a regular tile. This
makes it possible to unify how external surfaces are drawn, via the
common draw_tile_list method.

Differential Revision: https://phabricator.services.mozilla.com/D65269

--HG--
extra : moz-landing-system : lando
2020-03-05 20:45:15 +00:00
..
ci-scripts Bug 1612437 - Remove ipc-channel from WebRender. r=gw 2020-02-05 11:09:43 +00:00
debugger Bug 1566031 - Update vulnerable lodash version in WebRender Debugger. r=emilio 2019-10-02 19:52:48 +00:00
direct-composition Bug 1615694. Declare our render targets up front to ANGLE. r=kvark 2020-02-18 18:33:48 +00:00
example-compositor Bug 1615694. Declare our render targets up front to ANGLE. r=kvark 2020-02-18 18:33:48 +00:00
examples Bug 1510030 - Implement WebRender backend to run background color animations on the compositor. r=gw,boris 2020-02-27 08:43:06 +00:00
peek-poke Bug 1612988 - Fix warning in a peek_poke test. r=jrmuizel 2020-02-10 14:10:26 +00:00
tileview Bug 1618319: Segregate intern::UpdateList insertions and removals. r=gw 2020-02-27 02:26:09 +00:00
webrender Bug 1579235 - Part 11 - Refactor how external surfaces are composited. r=Bert,sotaro 2020-03-05 20:45:15 +00:00
webrender_api Bug 1616255 - Handle start and end offsets in conic-gradient WR shader. r=gw 2020-03-05 00:03:05 +00:00
webrender_build Bug 1594128 - Dynamically choose the brush kind in the shader. r=gw 2019-11-27 13:22:48 +00:00
wr_malloc_size_of
wrench Bug 1619393 - Increase fuzz by one to allow reftest to pass on AppVeyor. r=Bert 2020-03-05 18:23:38 +00:00
.gitignore
.taskcluster.yml Bug 1619293 - Re-enable rust flags in github CI. r=jrmuizel 2020-03-02 23:56:27 +00:00
appveyor.yml Bug 1619265 - Bump rust versions for github CI. r=jrmuizel 2020-03-02 14:57:16 +00:00
Cargo.lock Bug 1616804 - Update image to 0.23 in WebRender. r=jrmuizel 2020-02-24 15:56:22 +00:00
Cargo.toml Bug 1605283 - Improve support for invalidation debugging and testing r=gw 2020-01-18 08:22:51 +00:00
LICENSE
README.md Bug 1587650 - Update README.md with more informative intro r=gw 2019-10-18 01:04:50 +00:00
rustfmt.toml
servo-tidy.toml Bug 1615694. Declare our render targets up front to ANGLE. r=kvark 2020-02-18 18:33:48 +00:00

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.