Expand description
A cross-platform graphics and compute library based on WebGPU.
To start using the API, create an Instance.
Feature flags
Backends
⚠️ WIP: Not all backends can be manually configured today. On Windows & Linux the Vulkan & GLES backends are always enabled. See #3514 for more details.
- dx12(enabled by default) — Enables the DX12 backend on Windows.
- metal(enabled by default) — Enables the Metal backend on macOS & iOS.
- webgpu(enabled by default) — Enables the WebGPU backend on Wasm. Disabled when targeting- emscripten.
- angle— Enables the GLES backend via ANGLE on macOS.
- vulkan-portability— Enables the Vulkan backend on macOS & iOS.
- webgl— Enables the GLES backend on Wasm.- ⚠️ WIP: Currently will also enable GLES dependencies on any other targets.
 
Note: In the documentation, if you see that an item depends on a backend, it means that the item is only available when that backend is enabled and the backend is supported on the current platform.
Shading language support
- wgsl(enabled by default) — Enable accepting WGSL shaders as input.
- spirv— Enable accepting SPIR-V shaders as input.
- glsl— Enable accepting GLSL shaders as input.
- naga-ir— Enable accepting Naga IR shaders as input.
Logging & Tracing
The following features do not have any effect on the WebGPU backend.
- strict_asserts— Apply run-time checks, even in release builds. These are in addition to the validation carried out at public APIs in all builds.
- api_log_info— Log all API entry points at info instead of trace level.
- trace— Allow writing of trace capture files. See- Adapter::request_device.
- replay— Allow deserializing of trace capture files that were written with the- tracefeature. To replay a trace file use the wgpu player.
Other
- 
fragile-send-sync-non-atomic-wasm— ImplementSendandSyncon Wasm, but only if atomics are not enabled.WebGL/WebGPU objects can not be shared between threads. However, it can be useful to artificially mark them as SendandSyncanyways to make it easier to write cross-platform code. This is technically very unsafe in a multithreaded environment, but on a wasm binary compiled without atomics we know we are definitely not in a multithreaded environment.
Feature Aliases
These features aren’t actually features on the crate itself, but a convenient shorthand for complicated cases.
- wgpu_core— Enabled when there is any non-webgpu backend enabled on the platform.
- naga–– Enabled when any non-wgsl shader input is enabled.
Modules
- corewgpu_coreRe-export of ourwgpu-coredependency.
- halwgpu_coreRe-export of ourwgpu-haldependency.
- nagawgpu_coreornagaRe-export of ournagadependency.
- Re-export of ourraw-window-handledependency.
- Utility structures and functions that are built on top of the mainwgpuAPI.
Macros
- include_spirvspirvMacro to load a SPIR-V module statically.
- Macro to load raw SPIR-V data statically, for use withFeatures::SPIRV_SHADER_PASSTHROUGH.
- Macro to load a WGSL module statically.
- Macro to produce an array ofVertexAttribute.
Structs
- Handle to a physical graphics and/or compute device.
- Information about an adapter.
- Represents the backends that wgpu will use.
- Handle to a binding group.
- Describes a group of bindings and the resources to be bound.
- An element of aBindGroupDescriptor, consisting of a bindable resource and the slot to bind it to.
- Handle to a binding group layout.
- Describes aBindGroupLayout.
- Describes a single binding inside a bind group.
- Describes a blend component of aBlendState.
- Describe the blend state of a render pipeline, withinColorTargetState.
- Handle to a GPU-accessible buffer.
- Error occurred when trying to async map a buffer.
- Describes the segment of a buffer to bind.
- Slice into aBuffer.
- Different ways that you can use a buffer.
- Read only view into a mapped buffer.
- Write only view into mapped buffer.
- RGBA double precision color.
- Describes the color state of a render pipeline.
- Color write mask. Disabled color channels will not be written to.
- Handle to a command buffer on the GPU.
- Describes aCommandBuffer.
- Encodes a series of GPU operations.
- In-progress recording of a compute pass.
- Describes the attachments of a compute pass.
- Describes the timestamp writes of a compute pass.
- Handle to a compute pipeline.
- Describes a compute pipeline.
- Instance::create_surface()or a related function failed.
- Describes the biasing setting for the depth target.
- Describes the depth/stencil state in a render pipeline.
- Open connection to a graphics and/or compute device.
- Lists various ways the underlying platform does not conform to the WebGPU standard.
- Binary flags listing features that may or may not be present on downlevel adapters.
- Extent of a texture related operation.
- Features that are not guaranteed to be supported.
- Describes the fragment processing in a render pipeline.
- Opaque globally-unique identifier
- View of a buffer which can be used to copy to/from a texture.
- View of a texture which can be used to copy to/from a buffer/texture.
- View of a texture which can be used to copy to a texture, including color space and alpha premultiplication information.
- Layout of a texture in a buffer’s memory.
- Subresource range within an image
- Context for all other wgpu objects. Instance of wgpu.
- Options for creating an instance.
- Instance debugging flags.
- Represents the sets of limits an adapter/device supports.
- Describes the multi-sampling state of a render pipeline.
- Pair of load and store operations for an attachment aspect.
- Origin of a copy from a 2D image.
- Origin of a copy to/from a texture.
- Handle to a pipeline layout.
- Describes aPipelineLayout.
- Flags for which pipeline data should be recorded.
- Nanosecond timestamp used by the presentation engine.
- Describes the state of primitive assembly and rasterization in a render pipeline.
- A range of push constant memory to pass to a shader stage.
- Handle to a query set.
- Handle to a command queue on a device.
- A write-only view into a staging buffer.
- Pre-prepared reusable bundle of GPU operations.
- Describes the depth/stencil attachment for render bundles.
- Encodes a series of GPU operations into a reusable “render bundle”.
- Describes aRenderBundleEncoder.
- In-progress recording of a render pass: a list of render commands in aCommandEncoder.
- Describes a color attachment to aRenderPass.
- Describes a depth/stencil attachment to aRenderPass.
- Describes the attachments of a render pass.
- Describes the timestamp writes of a render pass.
- Handle to a rendering (graphics) pipeline.
- Describes a render (graphics) pipeline.
- Options for requesting adapter.
- Requesting a device from anAdapterfailed.
- Handle to a sampler.
- Describes aSampler.
- Handle to a compiled shader module.
- Descriptor for use withDevice::create_shader_module.
- Descriptor for a shader module given by SPIR-V binary, for use withDevice::create_shader_module_spirv.
- Describes the shader stages that a binding will be visible from.
- Describes stencil state in a render pipeline.
- State of the stencil operation (fixed-pipeline stage).
- Identifier for a particular call toQueue::submit. Can be used as part of an argument toDevice::pollto block for a particular submission to finish.
- Handle to a presentable surface.
- Defines the capabilities of a given surface and adapter.
- Surface texture that can be rendered to. Result of a successful call toSurface::get_current_texture.
- Handle to a texture on the GPU.
- Feature flags for a texture format.
- Features supported by a given texture format
- Different ways that you can use a texture.
- Handle to a texture view.
- Describes aTextureView.
- Vertex inputs (attributes) to shaders.
- Describes how the vertex buffer is interpreted.
- Describes the vertex processing in a render pipeline.
Enums
- How edges should be handled in texture addressing.
- ASTC block dimensions
- ASTC RGBA channel
- Backends supported by wgpu.
- Resource that can be bound to a pipeline.
- Specific type of a binding.
- Alpha blend factor.
- Alpha blend operation.
- Specific type of a buffer binding.
- Comparison function used for depth and stencil operations.
- Specifies how the alpha channel of the textures should be handled during compositing.
- Reason for “lose the device”.
- Supported physical device types.
- Selects which DX12 shader compiler to use.
- Error type
- Filter for error scopes.
- Face of a vertex.
- Texel mixing mode when sampling between texels.
- Vertex winding order which classifies the “front” face of a triangle.
- Selects which OpenGL ES 3 minor version to request.
- Format of indices used with pipeline.
- Operation to perform to the output attachment at the start of a render pass.
- Passed toDevice::pollto control how and if it should block.
- Result of a maintain operation.
- Type of buffer mapping.
- Type of drawing mode for polygons
- Power Preference when choosing a physical adapter.
- Color spaces supported on the web.
- Behavior of the presentation engine based on frame rate.
- Primitive type the input mesh is composed of.
- Type of query contained in a QuerySet.
- Specific type of a sampler binding.
- Color variation to use when sampler addressing mode isAddressMode::ClampToBorder
- Collections of shader features a device supports if they support less than WebGPU normally allows.
- Source of a shader module.
- Operation to perform on the stencil value.
- Specific type of a sample in a texture binding.
- Operation to perform to the output attachment at the end of a render pass.
- Result of an unsuccessful call toSurface::get_current_texture.
- Status of the received surface image.
- The window/canvas/surface/swap-chain/etc. a surface is attached to, for use with safe surface creation.
- The window/canvas/surface/swap-chain/etc. a surface is attached to, for use with unsafe surface creation.
- Kind of data the texture holds.
- Dimensionality of a texture.
- Underlying texture data format.
- Specific type of a sample in a texture binding.
- Dimensions of a particular texture view.
- Vertex Format for aVertexAttribute(input).
- Whether a vertex buffer is indexed by vertex or by instance.
Constants
- Buffer to buffer copy as well as buffer clear offsets and sizes must be aligned to this number.
- Buffer-Texture copies must havebytes_per_rowaligned to this number.
- Size to align mappings.
- Alignment all push constants need
- An offset into the query resolve buffer has to be aligned to this.
- Maximum queries in a query set
- Size of a single piece of query data.
- Vertex buffer strides have to be aligned to this number.
Traits
- Type for the callback of uncaptured error handler
- WasmNotSendNon-WebAssembly, orfragile-send-sync-non-atomic-wasmand non-atomics
- WasmNotSyncNon-WebAssembly, orfragile-send-sync-non-atomic-wasmand non-atomics
- Super trait for window handles as used inSurfaceTarget.
Type Aliases
- Integral type used for buffer offsets.
- Describes aBuffer.
- Integral type used for buffer slice sizes.
- Describes aCommandEncoder.
- Describes aDevice.
- Integral type used for dynamic bind group offsets.
- View of a buffer which can be used to copy to/from a texture.
- View of a texture which can be used to copy to/from a buffer/texture.
- View of a texture which can be used to copy to a texture, including color space and alpha premultiplication information.
- Object debugging label.
- Passed toDevice::pollto control how and if it should block.
- Describes aQuerySet.
- Describes aRenderBundle.
- Additional information required when requesting an adapter.
- Integral type used for binding locations in shaders.
- Describes aSurface.
- Describes aTexture.