Khronos reference front-end for GLSL and ESSL, and sample SPIR-V generator

Andrei Alexeyev 38548addf1 meson: fix missing dependency %!s(int64=5) %!d(string=hai) anos
External b56366ab75 Legalization: Skip spirv-tools tests %!s(int64=7) %!d(string=hai) anos
OGLCompilersDLL c3df791145 Add a basic Meson build system for use as a subproject %!s(int64=5) %!d(string=hai) anos
SPIRV 38548addf1 meson: fix missing dependency %!s(int64=5) %!d(string=hai) anos
StandAlone 1905069857 Add option to unwrap I/O block aggregates in reflection %!s(int64=5) %!d(string=hai) anos
Test e442a03897 GLSL: Fix tessellation control shader bounding box support. (#1730) %!s(int64=5) %!d(string=hai) anos
build_overrides 257b25c81f Add BUILD.gn configuration. %!s(int64=6) %!d(string=hai) anos
glslang 0f98c8daae [meson] add support for nv/amd exts, hlsl, optimization %!s(int64=5) %!d(string=hai) anos
gtests be63facd80 Handle buffer references vs 'const' %!s(int64=5) %!d(string=hai) anos
hlsl 0560138e66 Fixup leak of TString %!s(int64=5) %!d(string=hai) anos
ndk_test 5ba79d5904 Add NDK build files %!s(int64=5) %!d(string=hai) anos
.appveyor.yml ebfd91a719 Remove Unix executable permission from text files %!s(int64=5) %!d(string=hai) anos
.clang-format e592652665 Increase column limit to 120. %!s(int64=8) %!d(string=hai) anos
.gitattributes 00054da5e6 Infrastructure: Fix .gitattributes typo eof -> eol. Also update README %!s(int64=5) %!d(string=hai) anos
.gitignore cd1f169c6a Enable HLSL legalization %!s(int64=7) %!d(string=hai) anos
.travis.yml d03da06ac1 Remove execute permissions %!s(int64=6) %!d(string=hai) anos
Android.mk 5ba79d5904 Add NDK build files %!s(int64=5) %!d(string=hai) anos
BUILD.gn bd0f5ad278 Merge pull request #1733 from null77/fix-msvc-warn %!s(int64=5) %!d(string=hai) anos
CMakeLists.txt 424612c0e7 build: Do not cache debug library suffix %!s(int64=5) %!d(string=hai) anos
CODE_OF_CONDUCT.md 4685f3246e Create CODE_OF_CONDUCT.md %!s(int64=6) %!d(string=hai) anos
ChooseMSVCCRT.cmake 71241d8221 Allow choice of DLL or static CRT libraries through CMake options. %!s(int64=10) %!d(string=hai) anos
LICENSE.txt b23d232ec5 Licensing. Fixes #958. Add licenes file and update copyrights. %!s(int64=5) %!d(string=hai) anos
README-spirv-remap.txt a8456415b8 WIP: SPV Remapper: add remapper test framework %!s(int64=8) %!d(string=hai) anos
README.md 00054da5e6 Infrastructure: Fix .gitattributes typo eof -> eol. Also update README %!s(int64=5) %!d(string=hai) anos
known_good.json 938ab9a6e5 Update SPIRV-Tools and Headers %!s(int64=5) %!d(string=hai) anos
known_good_khr.json d03da06ac1 Remove execute permissions %!s(int64=6) %!d(string=hai) anos
make-revision c6c80a6e48 Versioning: Address #1255: Move to semantic versioning. %!s(int64=6) %!d(string=hai) anos
meson.build 0f98c8daae [meson] add support for nv/amd exts, hlsl, optimization %!s(int64=5) %!d(string=hai) anos
meson_options.txt 0f98c8daae [meson] add support for nv/amd exts, hlsl, optimization %!s(int64=5) %!d(string=hai) anos
update_glslang_sources.py 0cb8ad55f6 tooling: Fix update sources script for Python 3 %!s(int64=6) %!d(string=hai) anos

README-spirv-remap.txt


VERSION
--------------------------------------------------------------------------------
spirv-remap 0.97

INTRO:
--------------------------------------------------------------------------------
spirv-remap is a utility to improve compression of SPIR-V binary files via
entropy reduction, plus optional stripping of debug information and
load/store optimization. It transforms SPIR-V to SPIR-V, remapping IDs. The
resulting modules have an increased ID range (IDs are not as tightly packed
around zero), but will compress better when multiple modules are compressed
together, since compressor's dictionary can find better cross module
commonality.

Remapping is accomplished via canonicalization. Thus, modules can be
compressed one at a time with no loss of quality relative to operating on
many modules at once. The command line tool operates on multiple modules
only in the trivial repetition sense, for ease of use. The remapper API
only accepts a single module at a time.

There are two modes of use: command line, and a C++11 API. Both are
described below.

spirv-remap is currently in an alpha state. Although there are no known
remapping defects, it has only been exercised on one real world game shader
workload.


FEEDBACK
--------------------------------------------------------------------------------
Report defects, enhancements requests, code improvements, etc to:
spvremapper@lunarg.com


COMMAND LINE USAGE:
--------------------------------------------------------------------------------
Examples are given with a verbosity of one (-v), but more verbosity can be
had via -vv, -vvv, etc, or an integer parameter to --verbose, such as
"--verbose 4". With no verbosity, the command is silent and returns 0 on
success, and a positive integer error on failure.

Pre-built binaries for several OSs are available. Examples presented are
for Linux. Command line arguments can be provided in any order.

1. Basic ID remapping

Perform ID remapping on all shaders in "*.spv", writing new files with
the same basenames to /tmp/out_dir.

spirv-remap -v --map all --input *.spv --output /tmp/out_dir

2. Perform all possible size reductions

spirv-remap-linux-64 -v --do-everything --input *.spv --output /tmp/out_dir

Note that --do-everything is a synonym for:

--map all --dce all --opt all --strip all

API USAGE:
--------------------------------------------------------------------------------

The public interface to the remapper is defined in SPIRV/SPVRemapper.h as follows:

namespace spv {

class spirvbin_t
{
public:
enum Options { ... };
spirvbin_t(int verbose = 0); // construct

// remap an existing binary in memory
void remap(std::vector& spv, std::uint32_t opts = DO_EVERYTHING);

// Type for error/log handler functions
typedef std::function errorfn_t;
typedef std::function logfn_t;

// Register error/log handling functions (can be c/c++ fn, lambda fn, or functor)
static void registerErrorHandler(errorfn_t handler) { errorHandler = handler; }
static void registerLogHandler(logfn_t handler) { logHandler = handler; }
};

} // namespace spv

The class definition is in SPVRemapper.cpp.

remap() accepts an std::vector of SPIR-V words, modifies them per the
request given in 'opts', and leaves the 'spv' container with the result.
It is safe to instantiate one spirvbin_t per thread and process a different
SPIR-V in each.

The "opts" parameter to remap() accepts a bit mask of desired remapping
options. See REMAPPING AND OPTIMIZATION OPTIONS.

On error, the function supplied to registerErrorHandler() will be invoked.
This can be a standard C/C++ function, a lambda function, or a functor.
The default handler simply calls exit(5); The error handler is a static
member, so need only be set up once, not once per spirvbin_t instance.

Log messages are supplied to registerLogHandler(). By default, log
messages are eaten silently. The log handler is also a static member.

BUILD DEPENDENCIES:
--------------------------------------------------------------------------------
1. C++11 compatible compiler
2. cmake
3. glslang


BUILDING
--------------------------------------------------------------------------------
The standalone remapper is built along side glslangValidator through its
normal build process.


REMAPPING AND OPTIMIZATION OPTIONS
--------------------------------------------------------------------------------
API:
These are bits defined under spv::spirvbin_t::, and can be
bitwise or-ed together as desired.

MAP_TYPES = canonicalize type IDs
MAP_NAMES = canonicalize named data
MAP_FUNCS = canonicalize function bodies
DCE_FUNCS = remove dead functions
DCE_VARS = remove dead variables
DCE_TYPES = remove dead types
OPT_LOADSTORE = optimize unneeded load/stores
MAP_ALL = (MAP_TYPES | MAP_NAMES | MAP_FUNCS)
DCE_ALL = (DCE_FUNCS | DCE_VARS | DCE_TYPES)
OPT_ALL = (OPT_LOADSTORE)
ALL_BUT_STRIP = (MAP_ALL | DCE_ALL | OPT_ALL)
DO_EVERYTHING = (STRIP | ALL_BUT_STRIP)