gecko-dev/gfx/wr/glsl-to-cxx
Lee Salzman 21640ca40f Bug 1695405 - Remove texture array support from SWGL. r=nical
Since WebRender doesn't need texture array support anymore, neither does SWGL.
This is a massive simplification which should benefit both performance and
simplicity. This patch pretty much just removes functionality but doesn't
change any functionality that is already used and relied upon.

Differential Revision: https://phabricator.services.mozilla.com/D106718
2021-03-04 04:43:23 +00:00
..
src Bug 1695405 - Remove texture array support from SWGL. r=nical 2021-03-04 04:43:23 +00:00
Cargo.toml Bug 1684334 - Fix glsl-to-cxx licensing. r=kvark 2020-12-28 14:05:17 +00:00
README.md Bug 1681870 - Fix markdown formatting of README. r=lsalzman 2020-12-11 04:13:04 +00:00

README.md

A GLSL to C++ translator.

Translates GLSL to vectorized C++. Intended for use with WebRender software backend.

Architecture

GLSL code is parsed by the glsl crate. In hir.rs we traverse the resulting AST and build a higher level representation by doing type checking and name resolution. The resulting hir tree is traversed by lib.rs to output C++ code.

The generated C++ code is 4x wider then the original glsl. i.e. a glsl 'float' becomes a C++ 'Float' which is represented by a xmm register (a vector of 4 floats). Likewise, a vec4 becomes a struct of 4 'Float's for a total of 4 xmm registers and 16 floating point values.

Vector branching is flattened to non-branching code that unconditionally runs both sides of the branch and combines the results with a mask based on the condition.

The compiler also supports scalarization. Values that are known to be the same across all vector lanes are translated to scalars instead of vectors. Branches on scalars are translated as actual branches.