Skip to content

Implementation Status

Dzmitry Malyshau edited this page Dec 22, 2021 · 54 revisions
Clone this wiki locally

This page shows the current implementation status of the WebGPU API spec in browsers. It also lists some resources (samples, demos) for enthusiastic web developers. Also note the WebGPU Shading Language spec that's hosted separately.

The mailing list is a good place to ask questions or provide feedback on the API.

You can also join the chat on Matrix in the "Web Graphics" Matrix Community: The general WebGPU channel is

Implementation Status

Chromium (Chrome, Edge, etc.)

Work is in progress in Chrome Canary and Edge Canary

Android Chrome OS Linux Mac Windows
👷 Behind a flag/origin trial 👷 Behind a flag 👷 Behind a flag/origin trial 👷 Behind a flag/origin trial
  • A pre-release version of WebGPU is available in Chrome on Mac/Windows/Chrome OS, via Origin Trial.
  • For details, look at the Dawn bug tracker, bugs under Chromium root issue 852089, and in the Blink>WebGPU component. Check these before filing new bugs.
  • Note Chromium currently supports SPIR-V, but support will be removed in favor of WGSL, which is under development.
  • As GPU sandboxing isn't fully implemented yet for the WebGPU API, it is possible to read GPU data for other processes and tabs. Avoid leaving it enabled when browsing the untrusted web.
  • The chrome://flags/#enable-unsafe-webgpu flag must be enabled on supported platforms. Linux experimental support requires running browser with --enable-features=Vulkan switch.

Firefox and Servo

These browser implementations are based on wgpu project in Rust.

Platform-independent features:

  • WGSL shaders
    • validation
    • overridable constants
    • behavioral analysis
    • uniformity analysis (present currently, but not up to spec)
  • buffer mapping
  • core features:
    • render bundles
    • compute
  • errors
    • error model
    • error scopes
    • graceful device lost handling
  • presentation
Platform-dependent features Vulkan D3D12 Metal
present surface sharing
bounds checks ✔️ ✔️ (not needed) ✔️ (missing vertex pulling)


Work is in progress in Nightly, enabled by the "dom.webgpu.enabled" pref. It requires WebRender, which may be enabled by "gfx.webrender.all" pref if it's not already enabled by default. It's been shown to work on Windows 7/10, macOS, Linux (with Vulkan support), and even Android (also with Vulkan).

All the issues and feature requests are tracked by the Graphics: WebGPU component in BugZilla.


Work in progress, enabled by "dom.webgpu.enabled" pref.

Safari (In Progress)

Work is in progress in Safari Technology Preview.

To enable WebGPU, first make sure the Develop menu is visible using SafariPreferencesAdvancedShow Develop menu in menu bar. Then, in the Develop menu, make sure Experimental FeaturesWebGPU is checked. Avoid leaving it enabled when browsing the untrusted web.

Bugs can be viewed and filed here.