CMake-only fork of https://dawn.googlesource.com/dawn with cleaned, vendored dependencies
Go to file
Yunchao He 2a87c84c56 Add end2end tests to expose buffer size error on D3D12
When we do B2T or T2B copy from/to a buffer with paddings,
D3D12 may wrongly calculate the required buffer size.

For example, if copySize = {1, 1, 2}, offset = 0, bytesPerRow =
256, and rowsPerImage = 2 (there is 1-row padding for every image),
and we are copying a non-compressed format like rgba8unorm,
the required minimum buffer size should be:
offset + bytesPerRow * rowsPerImage * (copySize.depthOrArrayLayers - 1)
+ bytesPerRow * (copySize.height - 1) + bytesPerBlock * copySize.width.
It is 0 + 256 * 2 * (2 - 1) + 256 * (1 - 1) + 4 * 1 = 516.

The required minimum buffer on D3D12 (including WARP) size is:
offset + bytesPerRow * rowsPerImage * (copySize.depthOrArrayLayers - 1)
+ bytesPerRow * (rowsPerImage - 1) + bytesPerBlock * copySize.width.
Or offset + bytesPerRow * rowsPerImage * copySize.depthOrArrayLayers
+ bytesPerBlock * copySize.width - bytesPerRow.
It is 0 + 256 * 2 * (2 - 1) + 256 * (2 - 1) + 4 * 1 = 772.

It looks like D3D12 requires unnecessary buffer storage for
rowsPerImagePadding in the last image. It does respect
bytesPerRowPadding in the last row and doesn't require storage for
that part, though.

You can verify the buffer size requirement on D3D12 backend with the
new tests via --enable-backend-validation. The validation layer
says that D3D12 requires 772 bytes but we only provide a 516-bytes
buffer, and leads to E_INVALIDARG (Error code 0x80070057) when run
mD3d12CommandList->Close() in CommandRecordingContext::ExecuteCommandList
and causes device lost.

Bug: dawn:1278, dawn:1288, dawn:1289
Change-Id: Icfb792dec60ff7444cb20b3c283709cdb165f80a
Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/85341
Reviewed-by: Austin Eng <enga@chromium.org>
Commit-Queue: Yunchao He <yunchao.he@intel.com>
2022-04-02 00:18:00 +00:00
.vscode .vscode: Fix quotations in windows 'gn gen' task 2021-07-21 14:07:49 +00:00
build_overrides Nuke SPIRV-Cross. 2022-02-11 00:45:51 +00:00
docs Adds new chained struct for device creation to specify cache options. 2022-03-01 22:59:40 +00:00
generator Adds a generated file with the dawn git hash encoded at build time. 2022-03-31 05:09:04 +00:00
include Wrap multiplanar iosurface in wgpuTexture 2022-03-28 06:59:22 +00:00
infra Generate shorter bucket names in luci-scheduler.cfg. 2022-02-10 09:02:02 +00:00
samples/dawn Fix deprecated API usages in samples 2022-03-31 09:30:35 +00:00
scripts Try to use the vulkan-headers from vulkan-deps instead of third_party/khronos. 2022-04-01 05:22:55 +00:00
src Add end2end tests to expose buffer size error on D3D12 2022-04-02 00:18:00 +00:00
test/tint Add proxies for Tint targets used by Chromium 2022-03-31 19:54:15 +00:00
third_party Initial Android surface 2022-03-25 13:18:46 +00:00
tools tools: Add src/cts/query 2022-04-01 16:31:15 +00:00
webgpu-cts Unskip some CTS tests using the new harness 2022-03-28 18:13:22 +00:00
.clang-format Use C++17 nested namespaces instead of manually nesting them. 2022-01-06 09:22:17 +00:00
.gitattributes Add .gitattributes to normalize EOL 2019-07-15 12:23:18 +00:00
.gitignore tools: Add src/container 2022-03-30 21:12:14 +00:00
.gn Roll build dependencies to enable C++17 2022-01-05 15:54:08 +00:00
AUTHORS Rename NXT -> Dawn in the comments 2018-07-18 22:54:06 +02:00
BUILD.gn Remove old src/tests/BUILD.gn 2022-02-10 19:41:24 +00:00
CMakeLists.txt Initial Android surface 2022-03-25 13:18:46 +00:00
DEPS Roll vulkan-deps from 6d732e01d9ea to f8cb281b77d2 (6 revisions) 2022-04-01 19:22:20 +00:00
DIR_METADATA Move metadata in OWNERS files to DIR_METADATA files 2021-02-04 01:26:43 +00:00
LICENSE Fix google3 license related issues 2021-12-02 21:25:58 +00:00
OWNERS Shuffle 'docs' directories 2022-01-27 18:33:47 +00:00
PRESUBMIT.py Force Python 3 in presubmit 2021-07-20 17:57:20 +00:00
README.chromium Add component to OWNERS and fixup repo URL in README.chromium 2018-09-25 20:53:37 +00:00
README.md Shuffle 'docs' directories 2022-01-27 18:33:47 +00:00
codereview.settings codereview.setings: default to not squashing on git cl upload 2021-03-10 18:35:58 +00:00
dawn.json Implement WGPUTextureDescriptor.viewFormats and sampling reinterpretation 2022-03-31 03:53:04 +00:00
dawn_wire.json Initial Android surface 2022-03-25 13:18:46 +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 on Windows 10
    • Metal on macOS and iOS
    • Vulkan on Windows, Linux, ChromeOS, Android and Fuchsia
    • OpenGL as best effort where available
  • A client-server implementation of WebGPU for applications that are in a sandbox without access to native drivers

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.