From 3570886c418d88bab1d93788aa8a95b94f638525 Mon Sep 17 00:00:00 2001 From: Nicolas Silva Date: Wed, 13 Jul 2022 14:50:32 +0200 Subject: [PATCH 1/2] Validate the range in map_async. --- wgpu-core/src/device/mod.rs | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/wgpu-core/src/device/mod.rs b/wgpu-core/src/device/mod.rs index eb96d6d7f3..6a1dc5c4c9 100644 --- a/wgpu-core/src/device/mod.rs +++ b/wgpu-core/src/device/mod.rs @@ -5428,6 +5428,16 @@ impl Global { return Err((op, e.into())); } + if range.end > buffer.size { + return Err(( + op, + BufferAccessError::OutOfBoundsOverrun { + index: range.end, + max: buffer.size, + }, + )); + } + buffer.map_state = match buffer.map_state { resource::BufferMapState::Init { .. } | resource::BufferMapState::Active { .. } => { return Err((op, BufferAccessError::AlreadyMapped)); From 21a7f2b576455ac0df788392fd6843980d2f300d Mon Sep 17 00:00:00 2001 From: Nicolas Silva Date: Wed, 13 Jul 2022 17:11:44 +0200 Subject: [PATCH 2/2] Add an entry in the changelog. --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 2d63853490..eb73612076 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -50,6 +50,7 @@ Bottom level categories: - Improve the validation and error reporting of buffer mappings by @nical in [#2848](https://github.com/gfx-rs/wgpu/pull/2848) - Fix bind group / pipeline deduplication not taking into account RenderBundle execution resetting these values by @shoebe [#2867](https://github.com/gfx-rs/wgpu/pull/2867) - Fix panics that occur when using `as_hal` functions when the hal generic type does not match the hub being looked up in by @i509VCB [#2871](https://github.com/gfx-rs/wgpu/pull/2871) +- Add some validation in map_async by @nical in [#2876](https://github.com/gfx-rs/wgpu/pull/2876) #### DX12 - `DownlevelCapabilities::default()` now returns the `ANISOTROPIC_FILTERING` flag set to true so DX12 lists `ANISOTROPIC_FILTERING` as true again by @cwfitzgerald in [#2851](https://github.com/gfx-rs/wgpu/pull/2851)