CMake-only fork of https://dawn.googlesource.com/dawn with cleaned, vendored dependencies
Go to file
James Price 4d3af66bbd tint/msl: Preserve trailing vec3 padding
In order to preserve padding properly for MSL, we need to use its
packed_vec type for all vec3 types in storage buffers, not just struct
members. This commit includes a complete rewrite of the PackedVec3
transform to achieve this. The key details are:

* An internal `__packed_vec3<>` type was added, which corresponds to a
  `type::Vector` with an additional flag to indicate that it will be
  emitted as packed vector.

* The `PackedVec3` transform replaces all vec3 types used in
  host-shareable address spaces with the internal `__packed_vec3`
  type. This includes vec3 types that appear as the store type of a
  pointer.

* When used as an array element, these `__packed_vec3` types are
  wrapped in a struct that contains a single `__packed_vec3`
  member. This allows us to add an `@align()` attribute that ensures
  that `array<vec3<T>>` still has the correct array element stride.

* When the `vec3<T>` appears as a struct member in the input program,
  we apply the `@align()` to that member to ensure that we do not
  change its offset.

* Matrix types with three rows that are used in memory are replaced
  with an array of columns, where each column uses a `__packed_vec3`
  inside an aligned wrapper structure as above.

* Accesses to host-shareable memory that involve any of these types
  invoke a "pack" or "unpack" helper function to convert them to the
  equivalent type that uses `__packed_vec3` or a regular `vec3` as
  required.

* The `chromium_internal_relaxed_uniform_layout` extension is used to
  avoid issues where modifying a type in the uniform address space
  triggers stricter layout validation rules.

Bug: tint:1571
Fixed: tint:1837
Change-Id: Idaf2da2f5bcb2be00c85ec657edfb614186476bb
Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/121200
Reviewed-by: Ben Clayton <bclayton@google.com>
Commit-Queue: James Price <jrprice@google.com>
Kokoro: Kokoro <noreply+kokoro@google.com>
2023-02-27 20:21:03 +00:00
.vscode tools/setup-build: Support x86 2022-10-13 12:55:42 +00:00
build_overrides remove use_system_libwayland 2023-01-25 19:32:15 +00:00
docs tint: Validate @must_use on functions and builtins 2023-02-22 16:18:22 +00:00
generator OpenGL: only load extension procs if extension supported. 2023-02-27 19:31:08 +00:00
include Add basic Adapter blocklist 2023-02-13 17:10:44 +00:00
infra Kokoro: Fix windows builds 2023-02-05 10:52:57 +00:00
scripts Fix perf_test_runner.py to run with python3 2023-02-08 00:48:37 +00:00
src tint/msl: Preserve trailing vec3 padding 2023-02-27 20:21:03 +00:00
test tint/msl: Preserve trailing vec3 padding 2023-02-27 20:21:03 +00:00
third_party Roll third_party/webgpu-cts/ 13410d18b..6e39b5d2f (14 commits) 2023-02-25 18:13:43 +00:00
tools tint: Update constructor / conversion terminology 2023-02-22 20:04:40 +00:00
webgpu-cts Dawn/Tint: Polyfill reflect vec2<f32> for D3D12 FXC on Intel 2023-02-27 02:59:50 +00:00
.clang-format Add InsertBraces: true to .clang-format 2022-05-19 20:08:19 +00:00
.clang-tidy Update some forward declarations. 2022-05-30 18:00:58 +00:00
.gitattributes Pipeline cache D3D12 backend impl 2022-06-02 15:16:20 +00:00
.gitignore .gitignore: Rm src/dawn/node/tools/bin/ 2023-02-05 11:03:44 +00:00
.gn Roll third_party/angle/ 52c42e5a8..4aa0975e6 (35 commits) 2022-05-25 16:06:54 +00:00
AUTHORS Merge remote-tracking branch 'tint/main' into HEAD 2022-04-06 15:37:27 -04:00
BUILD.gn Remove old src/include folder 2022-06-18 16:16:11 +00:00
CMakeLists.txt code-coverage / turbocov fixes 2023-01-26 15:57:27 +00:00
CMakeSettings.json Normalize all line endings to LF 2022-04-08 14:18:28 +00:00
CODE_OF_CONDUCT.md Initial commit 2020-03-02 15:47:43 -05:00
CONTRIBUTING.md Combine contributing files. 2022-04-10 22:14:00 +00:00
CPPLINT.cfg Fixup CQ and Kokoro lint mismatches. 2022-04-13 16:14:26 +00:00
DEPS Roll ANGLE from ef6d14737424 to f524e4b8a244 (1 revision) 2023-02-27 09:20:25 +00:00
DIR_METADATA Move metadata in OWNERS files to DIR_METADATA files 2021-02-04 01:26:43 +00:00
Doxyfile tint: add pretty printers for gdb and lldb 2022-10-27 20:17:45 +00:00
LICENSE Fix google3 license related issues 2021-12-02 21:25:58 +00:00
OWNERS Set OWNERS to * on .txt files needed for CTS rolls 2023-02-13 10:17:04 +00:00
PRESUBMIT.py tools: Move idlgen and run-cts to from dawn/node to tools/ 2022-12-12 23:06:43 +00:00
README.chromium Fix addition of README.md's content to README.chromium 2022-08-09 14:09:00 +00:00
README.md Fix addition of README.md's content to README.chromium 2022-08-09 14:09:00 +00:00
codereview.settings codereview.setings: default to not squashing on git cl upload 2021-03-10 18:35:58 +00:00
dawn.json Add ExternalTexture::Refresh() and ExternalTexture::Expire() 2023-02-24 02:09:38 +00:00
dawn_wire.json Add Buffer.GetMapState() 2022-12-19 19:06:51 +00:00
go.mod go.mod: Pin github.com/sergi/go-diff to v1.1.0 2022-09-21 14:12:33 +00:00
go.sum go.mod: Pin github.com/sergi/go-diff to v1.1.0 2022-09-21 14:12:33 +00:00
go_presubmit_support.py Reland "Add expectations.txt validation to presubmit" 2022-12-08 21:57:55 +00:00
tint_overrides_with_defaults.gni Revert "Add GN build option to build using generated files." 2022-11-02 17:07:25 +00:00

README.md

Dawn's logo: a sun rising behind a stylized mountain inspired by the WebGPU logo. The text "Dawn" is written below it.

Dawn, a WebGPU implementation

Dawn is an open-source and cross-platform implementation of the work-in-progress WebGPU standard. More precisely it implements webgpu.h that is a one-to-one mapping with the WebGPU IDL. Dawn is meant to be integrated as part of a larger system and is the underlying implementation of WebGPU in Chromium.

Dawn provides several WebGPU building blocks:

  • WebGPU C/C++ headers that applications and other building blocks use.
    • The webgpu.h version that Dawn implements.
    • A C++ wrapper for the webgpu.h.
  • A "native" implementation of WebGPU using platforms' GPU APIs: D3D12, Metal, Vulkan and OpenGL. See per API support for more details.
  • A client-server implementation of WebGPU for applications that are in a sandbox without access to native drivers
  • Tint is a compiler for the WebGPU Shader Language (WGSL) that can be used in standalone to convert shaders from and to WGSL.

Helpful links:

Documentation table of content

Developer documentation:

User documentation: (TODO, figure out what overlaps with the webgpu.h docs)

Status

(TODO)

License

Apache 2.0 Public License, please see LICENSE.

Disclaimer

This is not an officially supported Google product.