CMake-only fork of https://dawn.googlesource.com/dawn with cleaned, vendored dependencies
e7c23721b9
This CL adds support for generating the OpSMod, OpUMod and OpFMod SPIR-V instructions. Bug: tint:5 Change-Id: I9e2183535ba24a2d0bb4257dd797a62151fe04a1 Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/19506 Reviewed-by: David Neto <dneto@google.com> |
||
---|---|---|
build_overrides | ||
fuzz | ||
samples | ||
src | ||
test | ||
third_party | ||
tools | ||
.clang-format | ||
.gitignore | ||
.gn | ||
BUILD.gn | ||
CMakeLists.txt | ||
CODE_OF_CONDUCT.md | ||
CONTRIBUTING.md | ||
CPPLINT.cfg | ||
DEPS | ||
Doxyfile | ||
LICENSE | ||
README.md | ||
standalone.gclient | ||
tint.gni |
README.md
Tint
Tint is a compiler for the WebGPU Shader Language (WGSL).
This is not an officially supported Google product.
Requirements
- Git
- CMake (3.10.2 or later)
- Ninja (or other build tool)
- Python, for fetching dependencies
- depot_tools in your path
Build options
TINT_BUILD_SPV_READER
: enable the SPIR-V input reader (off by default)TINT_BUILD_WGSL_READER
: enable the WGSL input reader (on by default)TINT_BUILD_SPV_WRITER
: enable the SPIR-V output writer (on by default)TINT_BUILD_WGSL_WRITER
: enable the WGSL output writer (on by default)
Building
Tint uses Chromium dependency management so you need to install depot_tools and add it to your PATH.
Getting source & dependencies
# Clone the repo as "tint"
git clone https://dawn.googlesource.com/tint tint && cd tint
# Bootstrap the gclient configuration
cp standalone.gclient .gclient
# Fetch external dependencies and toolchains with gclient
gclient sync
Compiling using CMake + Ninja
mkdir -p out/Debug
cd out/Debug
cmake -GNinja ../..
ninja # or autoninja
Compiling using CMake + make
mkdir -p out/Debug
cd out/Debug
cmake ../..
make # -j N for N-way parallel build
Issues
Please file any issues or feature requests at https://bugs.chromium.org/p/tint/issues/entry
Contributing
Please see the CONTRIBUTING and CODE_OF_CONDUCT files on how to contribute to Tint.