Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(deps): update rust crate wgpu_upstream to 0.20.0 #36

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

renovate[bot]
Copy link

@renovate renovate bot commented Sep 26, 2023

This PR contains the following updates:

Package Type Update Change
wgpu_upstream (source) dependencies minor 0.17.1 -> 0.20.0

Release Notes

gfx-rs/wgpu (wgpu_upstream)

v0.20.1

Compare Source

This release included v0.21.0 of wgpu-core and wgpu-hal, due to breaking changes needed to solve vulkan validation issues.

Bug Fixes

This release fixes the validation errors whenever a surface is used with the vulkan backend. By @​cwfitzgerald in #​5681.

General
Metal
Vulkan
  • Fix enablement of subgroup ops extension on Vulkan devices that don't support Vulkan 1.3. By @​cwfitzgerald in #​5624.
GLES / OpenGL
  • Fix regression on OpenGL (EGL) where non-sRGB still used sRGB #​5642
Naga
  • Work around shader consumers that have bugs handling switch statements with a single body for all cases. These are now written as do {} while(false); loops in hlsl-out and glsl-out. By @​Imberflur in #​5654
  • In hlsl-out, defer continue statements in switches by setting a flag and breaking from the switch. This allows such constructs to work with FXC which does not support continue within a switch. By @​Imberflur in #​5654

v0.20.0

Compare Source

Major Changes
Pipeline overridable constants

Wgpu supports now pipeline-overridable constants

This allows you to define constants in wgsl like this:

override some_factor: f32 = 42.1337; // Specifies a default of 42.1337 if it's not set.

And then set them at runtime like so on your pipeline consuming this shader:

// ...
fragment: Some(wgpu::FragmentState {
    compilation_options: wgpu::PipelineCompilationOptions {
        constants: &[("some_factor".to_owned(), 0.1234)].into(), // Sets `some_factor` to 0.1234.
        ..Default::default()
    },
    // ...
}),
// ...

By @​teoxoy & @​jimblandy in #​5500

Changed feature requirements for timestamps

Due to a specification change write_timestamp is no longer supported on WebGPU.
wgpu::CommandEncoder::write_timestamp requires now the new wgpu::Features::TIMESTAMP_QUERY_INSIDE_ENCODERS feature which is available on all native backends but not on WebGPU.

By @​wumpf in #​5188

Wgsl const evaluation for many more built-ins

Many numeric built-ins have had a constant evaluation implementation added for them, which allows them to be used in a const context:

abs, acos, acosh, asin, asinh, atan, atanh, cos, cosh, round, saturate, sin, sinh, sqrt, step, tan, tanh, ceil, countLeadingZeros, countOneBits, countTrailingZeros, degrees, exp, exp2, floor, fract, fma, inverseSqrt, log, log2, max, min, radians, reverseBits, sign, trunc

By @​ErichDonGubler in #​4879, #​5098

New native-only wgsl features
Subgroup operations

The following subgroup operations are available in wgsl now:

subgroupBallot, subgroupAll, subgroupAny, subgroupAdd, subgroupMul, subgroupMin, subgroupMax, subgroupAnd, subgroupOr, subgroupXor, subgroupExclusiveAdd, subgroupExclusiveMul, subgroupInclusiveAdd, subgroupInclusiveMul, subgroupBroadcastFirst, subgroupBroadcast, subgroupShuffle, subgroupShuffleDown, subgroupShuffleUp, subgroupShuffleXor

Availability is governed by the following feature flags:

  • wgpu::Features::SUBGROUP for all operations except subgroupBarrier in fragment & compute, supported on Vulkan, DX12 and Metal.
  • wgpu::Features::SUBGROUP_VERTEX, for all operations except subgroupBarrier general operations in vertex shaders, supported on Vulkan
  • wgpu::Features::SUBGROUP_BARRIER, for support of the subgroupBarrier operation, supported on Vulkan & Metal

Note that there currently some differences between wgpu's native-only implementation and the open WebGPU proposal.

By @​exrook and @​lichtso in #​5301

Signed and unsigned 64 bit integer support in shaders.

wgpu::Features::SHADER_INT64 enables 64 bit integer signed and unsigned integer variables in wgsl (i64 and u64 respectively).
Supported on Vulkan, DX12 (requires DXC) and Metal (with MSL 2.3+ support).

By @​atlv24 and @​cwfitzgerald in #​5154

New features
General
  • Implemented the Unorm10_10_10_2 VertexFormat by @​McMackety in #​5477
  • wgpu-types's trace and replay features have been replaced by the serde feature. By @​KirmesBude in #​5149
  • wgpu-core's serial-pass feature has been removed. Use serde instead. By @​KirmesBude in #​5149
  • Added InstanceFlags::GPU_BASED_VALIDATION, which enables GPU-based validation for shaders. This is currently only supported on the DX12 and Vulkan backends; other platforms ignore this flag, for now. By @​ErichDonGubler in #​5146, #​5046.
    • When set, this flag implies InstanceFlags::VALIDATION.
    • This has been added to the set of flags set by InstanceFlags::advanced_debugging. Since the overhead is potentially very large, the flag is not enabled by default in debug builds when using InstanceFlags::from_build_config.
    • As with other instance flags, this flag can be changed in calls to InstanceFlags::with_env with the new WGPU_GPU_BASED_VALIDATION environment variable.
  • wgpu::Instance can now report which wgpu::Backends are available based on the build configuration. By @​wumpf #​5167
    -wgpu::Instance::any_backend_feature_enabled()
    +!wgpu::Instance::enabled_backend_features().is_empty()
  • Breaking change: wgpu_core::pipeline::ProgrammableStageDescriptor is now optional. By @​ErichDonGubler in #​5305.
  • Features::downlevel{_webgl2,}_features was made const by @​MultisampledNight in #​5343
  • Breaking change: wgpu_core::pipeline::ShaderError has been moved to naga. By @​stefnotch in #​5410
  • More as_hal methods and improvements by @​JMS55 in #​5452
    • Added wgpu::CommandEncoder::as_hal_mut
    • Added wgpu::TextureView::as_hal
    • wgpu::Texture::as_hal now returns a user-defined type to match the other as_hal functions
Naga
  • Allow user to select which MSL version to use via --metal-version with Naga CLI. By @​pcleavelin in #​5392
  • Support arrayLength for runtime-sized arrays inside binding arrays (for WGSL input and SPIR-V output). By @​kvark in #​5428
  • Added --shader-stage and --input-kind options to naga-cli for specifying vertex/fragment/compute shaders, and frontend. by @​ratmice in #​5411
  • Added a create_validator function to wgpu_core Device to create naga Validators. By @​atlv24 #​5606
WebGPU
GLES / OpenGL
Metal
DX12
Other performance improvements
  • Simplify and speed up the allocation of internal IDs. By @​nical in #​5229
  • Use memory pooling for UsageScopes to avoid frequent large allocations. by @​robtfm in #​5414
  • Eager release of GPU resources comes from device.trackers. By @​bradwerth in #​5075
  • Support disabling zero-initialization of workgroup local memory in compute shaders. By @​DJMcNab in #​5508
Documentation
Bug Fixes
General
  • Fix serde feature not compiling for wgpu-types. By @​KirmesBude in #​5149
  • Fix the validation of vertex and index ranges. By @​nical in #​5144 and #​5156
  • Fix panic when creating a surface while no backend is available. By @​wumpf #​5166
  • Correctly compute minimum buffer size for array-typed storage and uniform vars. By @​jimblandy #​5222
  • Fix timeout when presenting a surface where no work has been done. By @​waywardmonkeys in #​5200
  • Fix registry leaks with de-duplicated resources. By @​nical in #​5244
  • Fix linking when targeting android. By @​ashdnazg in #​5326.
  • Failing to set the device lost closure will call the closure before returning. By @​bradwerth in #​5358.
  • Fix deadlocks caused by recursive read-write lock acquisitions #​5426.
  • Remove exposed C symbols (extern "C" + [no_mangle]) from RenderPass & ComputePass recording. By @​wumpf in #​5409.
  • Fix surfaces being only compatible with first backend enabled on an instance, causing failures when manually specifying an adapter. By @​Wumpf in #​5535.
Naga
  • In spv-in, remove unnecessary "gl_PerVertex" name check so unused builtins will always be skipped. Prevents validation errors caused by capability requirements of these builtins #​4915. By @​Imberflur in #​5227.
  • In spv-out, check for acceleration and ray-query types when enabling ray-query extension to prevent validation error. By @​Vecvec in #​5463
  • Add a limit for curly brace nesting in WGSL parsing, plus a note about stack size requirements. By @​ErichDonGubler in #​5447.
  • In hlsl-out, fix accesses on zero value expressions by generating helper functions for Expression::ZeroValue. By @​Imberflur in #​5587.
  • Fix behavior of extractBits and insertBits when offset + count overflows the bit width. By @​cwfitzgerald in #​5305
  • Fix behavior of integer clamp when min argument > max argument. By @​cwfitzgerald in #​5300.
  • Fix TypeInner::scalar_width to be consistent with the rest of the codebase and return values in bytes not bits. By @​atlv24 in #​5532.
GLES / OpenGL
  • GLSL 410 does not support layout(binding = ...), enable only for GLSL 420. By @​bes in #​5357
  • Fixes for being able to use an OpenGL 4.1 core context provided by macOS with wgpu. By @​bes in #​5331.
  • Fix crash when holding multiple devices on wayland/surfaceless. By @​ashdnazg in #​5351.
  • Fix first_instance getting ignored in draw indexed when ARB_shader_draw_parameters feature is present and base_vertex is 0. By @​valaphee in #​5482
Vulkan
  • Set object labels when the DEBUG flag is set, even if the VALIDATION flag is disabled. By @​DJMcNab in #​5345.
  • Add safety check to wgpu_hal::vulkan::CommandEncoder to make sure discard_encoding is not called in the closed state. By @​villuna in #​5557
  • Fix SPIR-V type capability requests to not depend on LocalType caching. By @​atlv24 in #​5590
  • Upgrade ash to 0.38. By @​MarijnS95 in #​5504.
Tests
  • Fix intermittent crashes on Linux in the multithreaded_compute test. By @​jimblandy in #​5129.
  • Refactor tests to read feature flags by name instead of a hardcoded hexadecimal u64. By @​atlv24 in #​5155.
  • Add test that verifies that we can drop the queue before using the device to create a command encoder. By @​Davidster in #​5211

v0.19.4

Compare Source

Bug Fixes
General
  • Don't depend on bind group and bind group layout entry order in backends. This caused incorrect severely incorrect command execution and, in some cases, crashes. By @​ErichDonGubler in #​5421.
  • Properly clean up all write_buffer/texture temporary resources. By @​robtfm in #​5413.
  • Fix deadlock in certain situations when mapping buffers using wgpu-profiler. By @​cwfitzgerald in #​5517
WebGPU

v0.19.3

Compare Source

This release includes wgpu, wgpu-core, and wgpu-hal. All other crates are unchanged.

Major Changes
Vendored WebGPU Bindings from web_sys

--cfg=web_sys_unstable_apis is no longer needed in your RUSTFLAGS to compile for WebGPU!!!

While WebGPU's javascript api is stable in the browsers, the web_sys bindings for WebGPU are still improving. As such they are hidden behind the special cfg --cfg=web_sys_unstable_apis and are not available by default. Everyone who wanted to use our WebGPU backend needed to enable this cfg in their RUSTFLAGS. This was very inconvenient and made it hard to use WebGPU, especially when WebGPU is enabled by default. Additionally, the unstable APIs don't adhere to semver, so there were repeated breakages.

To combat this problem we have decided to vendor the web_sys bindings for WebGPU within the crate. Notably we are not forking the bindings, merely vendoring, so any improvements we make to the bindings will be contributed directly to upstream web_sys.

By @​cwfitzgerald in #​5325.

Bug Fixes
General
  • Fix an issue where command encoders weren't properly freed if an error occurred during command encoding. By @​ErichDonGubler in #​5251.
  • Fix incorrect validation causing all indexed draws on render bundles to fail. By @​wumpf in #​5430.
Android

v0.19.2

Compare Source

This release includes wgpu, wgpu-core, wgpu-hal, wgpu-types, and naga. All other crates are unchanged.

Added/New Features
General
OpenGL
wgsl-out
Documentation
Bug Fixes
General
DX12
  • Fix panic! when dropping Instance without InstanceFlags::VALIDATION. By @​hakolao in #​5134
OpenGL
  • Fix internal format for the Etc2Rgba8Unorm format. By @​andristarr in #​5178
  • Try to load libX11.so.6 in addition to libX11.so on linux. #​5307
  • Make use of GL_EXT_texture_shadow_lod to support sampling a cube depth texture with an explicit LOD. By @​cmrschwarz in #5171.
glsl-in

v0.19.1

Compare Source

This release includes wgpu and wgpu-hal. The rest of the crates are unchanged since 0.19.0.

Bug Fixes
DX12
OpenGL
  • In Surface::configure and Surface::present on Windows, fix the current GL context not being unset when releasing the lock that guards access to making the context current. This was causing other threads to panic when trying to make the context current. By @​Imberflur in #​5087.
WebGPU
  • Improve error message when compiling WebGPU backend on wasm without the web_sys_unstable_apis set. By @​rukai in #​5104
Documentation
  • Document Wayland specific behavior related to SurfaceTexture::present. By @​i509VCB in #​5093.

v0.19.0

Compare Source

This release includes:

  • wgpu
  • wgpu-core
  • wgpu-hal
  • wgpu-types
  • wgpu-info
  • naga (skipped from 0.14 to 0.19)
  • naga-cli (skipped from 0.14 to 0.19)
  • d3d12 (skipped from 0.7 to 0.19)
Improved Multithreading through internal use of Reference Counting

Large refactoring of wgpu’s internals aiming at reducing lock contention, and providing better performance when using wgpu on multiple threads.

Check the blog post!

By @​gents83 in #​3626 and thanks also to @​jimblandy, @​nical, @​Wumpf, @​Elabajaba & @​cwfitzgerald

All Public Dependencies are Re-Exported

All of wgpu's public dependencies are now re-exported at the top level so that users don't need to take their own dependencies.
This includes:

  • wgpu-core
  • wgpu-hal
  • naga
  • raw_window_handle
  • web_sys
Feature Flag Changes
WebGPU & WebGL in the same Binary

Enabling webgl no longer removes the webgpu backend.

Instead, there's a new (default enabled) webgpu feature that allows to explicitly opt-out of webgpu if so desired.
If both webgl & webgpu are enabled, wgpu::Instance decides upon creation whether to target wgpu-core/WebGL or WebGPU.
This means that adapter selection is not handled as with regular adapters, but still allows to decide at runtime whether
webgpu or the webgl backend should be used using a single wasm binary.
By @​wumpf in #​5044

naga-ir Dedicated Feature

The naga-ir feature has been added to allow you to add naga module shaders without guessing about what other features needed to be enabled to get access to it.
By @​cwfitzgerald in #​5063.

expose-ids Feature available unconditionally

This feature allowed you to call global_id on any wgpu opaque handle to get a unique hashable identity for the given resource. This is now available without the feature flag.
By @​cwfitzgerald in #​4841.

dx12 and metal Backend Crate Features

wgpu now exposes backend feature for the Direct3D 12 (dx12) and Metal (metal) backend. These are enabled by default, but don't do anything when not targeting the corresponding OS.
By @​daxpedda in #​4815.

Direct3D 11 Backend Removal

This backend had no functionality, and with the recent support for GL on Desktop, which allows wgpu to run on older devices, there was no need to keep this backend.
By @​valaphee in #​4828.

WGPU_ALLOW_UNDERLYING_NONCOMPLIANT_ADAPTER Environment Variable

This adds a way to allow a Vulkan driver which is non-compliant per VK_KHR_driver_properties to be enumerated. This is intended for testing new Vulkan drivers which are not Vulkan compliant yet.
By @​i509VCB in #​4754.

DeviceExt::create_texture_with_data allows Mip-Major Data

Previously, DeviceExt::create_texture_with_data only allowed data to be provided in layer major order. There is now a order parameter which allows you to specify if the data is in layer major or mip major order.

    let tex = ctx.device.create_texture_with_data(
        &queue,
        &descriptor,
+       wgpu::util::TextureDataOrder::LayerMajor,
        src_data,
    );

By @​cwfitzgerald in #​4780.

Safe & unified Surface Creation

It is now possible to safely create a wgpu::Surface with wgpu::Instance::create_surface() by letting wgpu::Surface hold a lifetime to window.
Passing an owned value window to Surface will return a wgpu::Surface<'static>.

All possible safe variants (owned windows and web canvases) are grouped using wgpu::SurfaceTarget.
Conversion to wgpu::SurfaceTarget is automatic for any type implementing raw-window-handle's HasWindowHandle & HasDisplayHandle traits, i.e. most window types.
For web canvas types this has to be done explicitly:

let surface: wgpu::Surface<'static> = instance.create_surface(wgpu::SurfaceTarget::Canvas(my_canvas))?;

All unsafe variants are now grouped under wgpu::Instance::create_surface_unsafe which takes the
wgpu::SurfaceTargetUnsafe enum and always returns wgpu::Surface<'static>.

In order to create a wgpu::Surface<'static> without passing ownership of the window use
wgpu::SurfaceTargetUnsafe::from_window:

let surface = unsafe {
  instance.create_surface_unsafe(wgpu::SurfaceTargetUnsafe::from_window(&my_window))?
};

The easiest way to make this code safe is to use shared ownership:

let window: Arc<winit::Window>;
// ...
let surface = instance.create_surface(window.clone())?;

All platform specific surface creation using points have moved into SurfaceTargetUnsafe as well.
For example:

Safety by @​daxpedda in #​4597
Unification by @​wumpf in #​4984

Add partial Support for WGSL Abstract Types

Abstract types make numeric literals easier to use, by
automatically converting literals and other constant expressions
from abstract numeric types to concrete types when safe and
necessary. For example, to build a vector of floating-point
numbers, Naga previously made you write:

vec3<f32>(1.0, 2.0, 3.0)

With this change, you can now simply write:

vec3<f32>(1, 2, 3)

Even though the literals are abstract integers, Naga recognizes
that it is safe and necessary to convert them to f32 values in
order to build the vector. You can also use abstract values as
initializers for global constants and global and local variables,
like this:

var unit_x: vec2<f32> = vec2(1, 0);

The literals 1 and 0 are abstract integers, and the expression
vec2(1, 0) is an abstract vector. However, Naga recognizes that
it can convert that to the concrete type vec2<f32> to satisfy
the given type of unit_x.
The WGSL specification permits abstract integers and
floating-point values in almost all contexts, but Naga's support
for this is still incomplete. Many WGSL operators and builtin
functions are specified to produce abstract results when applied
to abstract inputs, but for now Naga simply concretizes them all
before applying the operation. We will expand Naga's abstract type
support in subsequent pull requests.
As part of this work, the public types naga::ScalarKind and
naga::Literal now have new variants, AbstractInt and AbstractFloat.

By @​jimblandy in #​4743, #​4755.

Instance::enumerate_adapters now returns Vec<Adapter> instead of an ExactSizeIterator

This allows us to support WebGPU and WebGL in the same binary.

- let adapters: Vec<Adapter> = instance.enumerate_adapters(wgpu::Backends::all()).collect();
+ let adapters: Vec<Adapter> = instance.enumerate_adapters(wgpu::Backends::all());

By @​wumpf in #​5044

device.poll() now returns a MaintainResult instead of a bool

This is a forward looking change, as we plan to add more information to the MaintainResult in the future.
This enum has the same data as the boolean, but with some useful helper functions.

- let queue_finished: bool = device.poll(wgpu::Maintain::Wait);
+ let queue_finished: bool = device.poll(wgpu::Maintain::Wait).is_queue_empty();

By @​cwfitzgerald in #​5053

New Features
General
  • Added DownlevelFlags::VERTEX_AND_INSTANCE_INDEX_RESPECTS_RESPECTIVE_FIRST_VALUE_IN_INDIRECT_DRAW to know if @builtin(vertex_index) and @builtin(instance_index) will respect the first_vertex / first_instance in indirect calls. If this is not present, both will always start counting from 0. Currently enabled on all backends except DX12. By @​cwfitzgerald in #​4722.
  • Added support for the FLOAT32_FILTERABLE feature (web and native, corresponds to WebGPU's float32-filterable). By @​almarklein in #​4759.
  • GPU buffer memory is released during "lose the device". By @​bradwerth in #​4851.
  • wgpu and wgpu-core cargo feature flags are now documented on docs.rs. By @​wumpf in #​4886.
  • DeviceLostClosure is guaranteed to be invoked exactly once. By @​bradwerth in #​4862.
  • Log vulkan validation layer messages during instance creation and destruction: By @​exrook in #​4586.
  • TextureFormat::block_size is deprecated, use TextureFormat::block_copy_size instead: By @​wumpf in #​4647.
  • Rename of DispatchIndirect, DrawIndexedIndirect, and DrawIndirect types in the wgpu::util module to DispatchIndirectArgs, DrawIndexedIndirectArgs, and DrawIndirectArgs. By @​cwfitzgerald in #​4723.
  • Make the size parameter of encoder.clear_buffer an Option<u64> instead of Option<NonZero<u64>>. By @​nical in #​4737.
  • Reduce the info log level noise. By @​nical in #​4769, #​4711 and #​4772
  • Rename features & limits fields of DeviceDescriptor to required_features & required_limits. By @​teoxoy in #​4803.
  • SurfaceConfiguration now exposes desired_maximum_frame_latency which was previously hard-coded to 2. By setting it to 1 you can reduce latency under the risk of making GPU & CPU work sequential. Currently, on DX12 this affects the MaximumFrameLatency, on all other backends except OpenGL the size of the swapchain (on OpenGL this has no effect). By @​emilk & @​wumpf in #​4899
OpenGL
  • @builtin(instance_index) now properly reflects the range provided in the draw call instead of always counting from 0. By @​cwfitzgerald in #​4722.
  • Desktop GL now supports POLYGON_MODE_LINE and POLYGON_MODE_POINT. By @​valaphee in #​4836.
Naga
  • Naga's WGSL front end now allows operators to produce values with abstract types, rather than concretizing their operands. By @​jimblandy in #​4850 and #​4870.
  • Naga's WGSL front and back ends now have experimental support for 64-bit floating-point literals: 1.0lf denotes an f64 value. There has been experimental support for an f64 type for a while, but until now there was no syntax for writing literals with that type. As before, Naga module validation rejects f64 values unless naga::valid::Capabilities::FLOAT64 is requested. By @​jimblandy in #​4747.
  • Naga constant evaluation can now process binary operators whose operands are both vectors. By @​jimblandy in #​4861.
  • Add --bulk-validate option to Naga CLI. By @​jimblandy in #​4871.
  • Naga's cargo xtask validate now runs validation jobs in parallel, using the jobserver protocol to limit concurrency, and offers a validate all subcommand, which runs all available validation types. By @​jimblandy in #​4902.
  • Remove span and validate features. Always fully validate shader modules, and always track source positions for use in error messages. By @​teoxoy in #​4706.
  • Introduce a new Scalar struct type for use in Naga's IR, and update all frontend, middle, and backend code appropriately. By @​jimblandy in #​4673.
  • Add more metal keywords. By @​fornwall in #​4707.
  • Add a new naga::Literal variant, I64, for signed 64-bit literals. #​4711.
  • Emit and init struct member padding always. By @​ErichDonGubler in #​4701.
  • In WGSL output, always include the i suffix on i32 literals. By @​jimblandy in #​4863.
  • In WGSL output, always include the f suffix on f32 literals. By @​jimblandy in #​4869.
Bug Fixes
General
DX12
  • Fixed D3D12_SUBRESOURCE_FOOTPRINT calculation for block compressed textures which caused a crash with Queue::write_texture on DX12. By @​DTZxPorter in #​4990.
Vulkan
  • Use VK_EXT_robustness2 only when not using an outdated intel iGPU driver. By @​TheoDulka in #​4602.
WebGPU
  • Allow calling BufferSlice::get_mapped_range multiple times on the same buffer slice (instead of throwing a Javascript exception). By @​DouglasDwyer in #​4726.
WGL
  • Create a hidden window per wgpu::Instance instead of sharing a global one. By @​Zoxc in #​4603
Naga
  • Make module compaction preserve the module's named types, even if they are unused. By @​jimblandy in #​4734.
  • Improve algorithm used by module compaction. By @​jimblandy in #​4662.
  • When reading GLSL, fix the argument types of the double-precision floating-point overloads of the dot, reflect, distance, and ldexp builtin functions. Correct the WGSL generated for constructing 64-bit floating-point matrices. Add tests for all the above. By @​jimblandy in #​4684.
  • Allow Naga's IR types to represent matrices with elements elements of any scalar kind. This makes it possible for Naga IR types to represent WGSL abstract matrices. By @​jimblandy in #​4735.
  • Preserve the source spans for constants and expressions correctly across module compaction. By @​jimblandy in #​4696.
  • Record the names of WGSL alias declarations in Naga IR Types. By @​jimblandy in #​4733.
Metal
Examples
  • remove winit dependency from hello-compute example. By @​psvri in #​4699
  • hello-compute example fix failure with wgpu error: Validation Error if arguments are missing. By @​vilcans in #​4939.
  • Made the examples page not crash on Chrome on Android, and responsive to screen sizes. By @​Dinnerbone in #​4958.

v0.18.0

Compare Source

For naga changelogs at or before v0.14.0. See naga's changelog.

Desktop OpenGL 3.3+ Support on Windows

We now support OpenGL on Windows! This brings support for a vast majority of the hardware that used to be covered by our DX11 backend. As of this writing we support OpenGL 3.3+, though there are efforts to reduce that further.

This allows us to cover the last 12 years of Intel GPUs (starting with Ivy Bridge; aka 3xxx), and the last 16 years of AMD (starting with Terascale; aka HD 2000) / NVidia GPUs (starting with Tesla; aka GeForce 8xxx).

By @​Zoxc in #​4248

Timestamp Queries Supported on Metal and OpenGL

Timestamp queries are now supported on both Metal and Desktop OpenGL. On Apple chips on Metal, they only support timestamp queries in command buffers or in the renderpass descriptor,
they do not support them inside a pass.

Metal: By @​Wumpf in #​4008
OpenGL: By @​Zoxc in #​4267

Render/Compute Pass Query Writes

Addition of the TimestampWrites type to compute and render pass descriptors to allow profiling on tilers which do not support timestamps inside passes.

Added an example to demonstrate the various kinds of timestamps.

Additionally, metal now supports timestamp queries!

By @​FL33TW00D & @​wumpf in #​3636.

Occlusion Queries

We now support binary occlusion queries! This allows you to determine if any of the draw calls within the query drew any pixels.

Use the new occlusion_query_set field on RenderPassDescriptor to give a query set that occlusion queries will write to.

let mut rpass = encoder.begin_render_pass(&wgpu::RenderPassDescriptor {
    // ...
+   occlusion_query_set: Some(&my_occlusion_query_set),
});

Within the renderpass do the following to write the occlusion query results to the query set at the given index:

rpass.begin_occlusion_query(index);
rpass.draw(...);
rpass.draw(...);
rpass.end_occlusion_query();

These are binary occlusion queries, so the result will be either 0 or an unspecified non-zero value.

By @​Valaphee in #​3402

Shader Improvements
// WGSL constant expressions are now supported!
const BLAH: u32 = 1u + 1u;

// `rgb10a2uint` and `bgra8unorm` can now be used as a storage image format.
var image: texture_storage_2d<rgb10a2uint, write>;
var image: texture_storage_2d<bgra8unorm, write>;

// You can now use dual source blending!
struct FragmentOutput{
    @&#8203;location(0) source1: vec4<f32>,
    @&#8203;location(0) @&#8203;second_blend_source source2: vec4<f32>,
}

// `modf`/`frexp` now return structures
let result = modf(1.5);
result.fract == 0.5;
result.whole == 1.0;

let result = frexp(1.5);
result.fract == 0.75;
result.exponent == 2i;

// `modf`/`frexp` are currently disabled on GLSL and SPIR-V input.
Shader Validation Improvements
// Cannot get pointer to a workgroup variable
fn func(p: ptr<workgroup, u32>); // ERROR

// Cannot create Inf/NaN through constant expressions
const INF: f32 = 3.40282347e+38 + 1.0; // ERROR
const NAN: f32 = 0.0 / 0.0; // ERROR

// `outerProduct` function removed

// Error on repeated or missing `@workgroup_size()`
@&#8203;workgroup_size(1) @&#8203;workgroup_size(2) // ERROR
fn compute_main() {}

// Error on repeated attributes.
fn fragment_main(@&#8203;location(0) @&#8203;location(0) location_0: f32) // ERROR
RenderPass StoreOp is now Enumeration

wgpu::Operations::store used to be an underdocumented boolean value,
causing misunderstandings of the effect of setting it to false.

The API now more closely resembles WebGPU which distinguishes between store and discard,
see WebGPU spec on GPUStoreOp.

// ...
depth_ops: Some(wgpu::Operations {
    load: wgpu::LoadOp::Clear(1.0),
-   store: false,
+   store: wgpu::StoreOp::Discard,
}),
// ...

By @​wumpf in #​4147

Instance Descriptor Settings

The instance descriptor grew two more fields: flags and gles_minor_version.

flags allow you to toggle the underlying api validation layers, debug information about shaders and objects in capture programs, and the ability to discard labels

gles_minor_version is a rather niche feature that allows you to force the GLES backend to use a specific minor version, this is useful to get ANGLE to enable more than GLES 3.0.

let instance = wgpu::Instance::new(InstanceDescriptor {
    ...
+   flags: wgpu::InstanceFlags::default()
+   gles_minor_version: wgpu::Gles3MinorVersion::Automatic,
});

gles_minor_version: By @​PJB3005 in #​3998
flags: By @​nical in #​4230

Many New Examples!
Revamped Testing Suite

Our testing harness was completely revamped and now automatically runs against all gpus in the system, shows the expected status of every test, and is tolerant to flakes.

Additionally, we have filled out our CI to now run the latest versions of WARP and Mesa. This means we can test even more features on CI than before.

By @​cwfitzgerald in #​3873

The GLES backend is now optional on macOS

The angle feature flag has to be set for the GLES backend to be ena


Configuration

📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

This PR was generated by Mend Renovate. View the repository job log.

@renovate renovate bot force-pushed the renovate/wgpu_upstream-0.x branch from 148c143 to e8c7f16 Compare September 27, 2023 19:31
@renovate renovate bot changed the title fix(deps): update rust crate wgpu_upstream to 0.17.0 fix(deps): update rust crate wgpu_upstream to 0.17.1 Sep 27, 2023
@renovate renovate bot changed the title fix(deps): update rust crate wgpu_upstream to 0.17.1 fix(deps): update rust crate wgpu_upstream to 0.17.1 - autoclosed Oct 19, 2023
@renovate renovate bot closed this Oct 19, 2023
@renovate renovate bot deleted the renovate/wgpu_upstream-0.x branch October 19, 2023 00:44
@renovate renovate bot changed the title fix(deps): update rust crate wgpu_upstream to 0.17.1 - autoclosed fix(deps): update rust crate wgpu_upstream to 0.17.1 Oct 25, 2023
@renovate renovate bot reopened this Oct 25, 2023
@renovate renovate bot restored the renovate/wgpu_upstream-0.x branch October 25, 2023 18:55
@renovate renovate bot changed the title fix(deps): update rust crate wgpu_upstream to 0.17.1 fix(deps): update rust crate wgpu_upstream to 0.18.0 Oct 25, 2023
@renovate renovate bot force-pushed the renovate/wgpu_upstream-0.x branch 2 times, most recently from c15481e to 7424c8b Compare October 31, 2023 18:47
@zmitchell
Copy link
Owner

Blocked until egui_wgpu upgrades to 0.18.0

@renovate renovate bot force-pushed the renovate/wgpu_upstream-0.x branch from 7424c8b to 7013e99 Compare January 17, 2024 23:20
@renovate renovate bot changed the title fix(deps): update rust crate wgpu_upstream to 0.18.0 fix(deps): update rust crate wgpu_upstream to 0.19.0 Jan 17, 2024
Copy link
Author

renovate bot commented Jan 17, 2024

⚠ Artifact update problem

Renovate failed to update artifacts related to this branch. You probably do not want to merge this PR as-is.

♻ Renovate will retry this branch, including artifacts, only when one of the following happens:

  • any of the package files in this branch needs updating, or
  • the branch becomes conflicted, or
  • you click the rebase/retry checkbox if found above, or
  • you rename this PR's title to start with "rebase!" to trigger it manually

The artifact failure details are included below:

File name: Cargo.lock
Command failed: cargo update --config net.git-fetch-with-cli=true --manifest-path splatter_wgpu/Cargo.toml --package wgpu@0.17.1 --precise 0.20.0
    Updating crates.io index
error: failed to select a version for the requirement `wgpu = "^0.17.0"`
candidate versions found which didn't match: 0.20.0
location searched: crates.io index
required by package `egui-wgpu v0.23.0`
    ... which satisfies dependency `egui-wgpu = "^0.23"` (locked to 0.23.0) of package `splatter_egui v0.1.0 (/tmp/renovate/repos/github/zmitchell/splatter/splatter_egui)`
perhaps a crate was updated and forgotten to be re-vendored?

File name: Cargo.lock
Command failed: cargo update --config net.git-fetch-with-cli=true --manifest-path splatter/Cargo.toml --package wgpu@0.17.1 --precise 0.20.0
    Updating crates.io index
error: failed to select a version for the requirement `wgpu = "^0.17.0"`
candidate versions found which didn't match: 0.20.0
location searched: crates.io index
required by package `egui-wgpu v0.23.0`
    ... which satisfies dependency `egui-wgpu = "^0.23"` (locked to 0.23.0) of package `splatter_egui v0.1.0 (/tmp/renovate/repos/github/zmitchell/splatter/splatter_egui)`
perhaps a crate was updated and forgotten to be re-vendored?

@renovate renovate bot force-pushed the renovate/wgpu_upstream-0.x branch from 7013e99 to 8c0d677 Compare January 22, 2024 01:07
@renovate renovate bot changed the title fix(deps): update rust crate wgpu_upstream to 0.19.0 fix(deps): update rust crate wgpu_upstream to 0.19.1 Jan 22, 2024
@renovate renovate bot force-pushed the renovate/wgpu_upstream-0.x branch from 8c0d677 to cc34f01 Compare March 1, 2024 00:14
@renovate renovate bot changed the title fix(deps): update rust crate wgpu_upstream to 0.19.1 fix(deps): update rust crate wgpu_upstream to 0.19.2 Mar 1, 2024
@renovate renovate bot force-pushed the renovate/wgpu_upstream-0.x branch from cc34f01 to 1aca08e Compare March 2, 2024 17:03
@renovate renovate bot changed the title fix(deps): update rust crate wgpu_upstream to 0.19.2 fix(deps): update rust crate wgpu_upstream to 0.19.3 Mar 2, 2024
@renovate renovate bot force-pushed the renovate/wgpu_upstream-0.x branch from 1aca08e to 36ce375 Compare April 18, 2024 01:58
@renovate renovate bot changed the title fix(deps): update rust crate wgpu_upstream to 0.19.3 fix(deps): update rust crate wgpu_upstream to 0.19.4 Apr 18, 2024
@renovate renovate bot force-pushed the renovate/wgpu_upstream-0.x branch from 36ce375 to e400d43 Compare April 29, 2024 01:51
@renovate renovate bot changed the title fix(deps): update rust crate wgpu_upstream to 0.19.4 fix(deps): update rust crate wgpu_upstream to 0.20.0 Apr 29, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant