Cargo Features
wgpu-core has no features set by default.
[dependencies]
wgpu-core = { version = "24.0.0", features = ["counters", "api_log_info", "resource_log_info", "renderdoc", "strict_asserts", "indirect-validation", "serde", "trace", "observe_locks", "replay", "raw-window-handle", "wgsl", "glsl", "spirv", "fragile-send-sync-non-atomic-wasm", "metal", "vulkan", "gles", "dx12"] }
- counters
-
Internally count resources and events for debugging purposes. If the counters feature is disabled, the counting infrastructure is removed from the build and the exposed counters always return 0.
Enables counters of wgpu-types
- api_log_info
-
Log all API entry points at info instead of trace level.
Also, promotes certain debug log calls to info. - resource_log_info
-
Log resource lifecycle management at info instead of trace level.
- renderdoc
-
Support the Renderdoc graphics debugger: https://renderdoc.org/
- 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.
Enables strict_asserts of wgpu-types
- indirect-validation
-
Validates indirect draw/dispatch calls. This will also enable naga's WGSL frontend since we use a WGSL compute shader to do the validation.
- serde observe_locks? replay? trace?
-
Enables serialization via
serde
on common wgpu types.Enables serde, serde of arrayvec, serde of wgpu-types
- trace = serde
-
Enable API tracing.
Enables ron, serialize of naga
Affects
trace::Trace
,device::trace
… - observe_locks
-
Enable lock order observation.
Enables ron, serde_derive of serde
- replay = serde
-
Enable API replaying
Enables deserialize of naga
Affects
device::trace
… - raw-window-handle
-
Enable creating instances using raw-window-handle
Enables raw-window-handle
- wgsl
-
Enable
ShaderModuleSource::Wgsl
- glsl
-
Enable
ShaderModuleSource::Glsl
- spirv
-
Enable
ShaderModuleSource::SpirV
- fragile-send-sync-non-atomic-wasm
-
Implement
Send
andSync
on 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
Send
andSync
anyways 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.Enables fragile-send-sync-non-atomic-wasm of wgpu-hal and wgpu-types
- metal
-
Backends, passed through to wgpu-hal
Enable the
metal
backend. - vulkan
-
Enable the
vulkan
backend. - gles
-
Enable the
GLES
backend.This is used for all of GLES, OpenGL, and WebGL.
- dx12
-
Enable the
dx12
backend.