Skip to content

Commit

Permalink
Add opt-in crate feature
Browse files Browse the repository at this point in the history
  • Loading branch information
daxpedda committed Jun 21, 2023
1 parent e894565 commit 68d2a92
Show file tree
Hide file tree
Showing 19 changed files with 1,044 additions and 294 deletions.
2 changes: 2 additions & 0 deletions wgpu-core/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,8 @@ serial-pass = ["serde", "wgt/serde", "arrayvec/serde"]
id32 = []
# Enable `ShaderModuleSource::Wgsl`
wgsl = ["naga/wgsl-in"]
# Implement `Send` and `Sync` on Wasm.
unsound_send_sync_threadless_wasm32 = ["hal/unsound_send_sync_threadless_wasm32", "wgt/unsound_send_sync_threadless_wasm32"]

[dependencies]
arrayvec = "0.7"
Expand Down
16 changes: 14 additions & 2 deletions wgpu-core/src/command/bundle.rs
Original file line number Diff line number Diff line change
Expand Up @@ -746,9 +746,21 @@ pub struct RenderBundle<A: HalApi> {
pub(crate) life_guard: LifeGuard,
}

#[cfg(not(target_arch = "wasm32"))]
#[cfg(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
))]
unsafe impl<A: HalApi> Send for RenderBundle<A> {}
#[cfg(not(target_arch = "wasm32"))]
#[cfg(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
))]
unsafe impl<A: HalApi> Sync for RenderBundle<A> {}

impl<A: HalApi> RenderBundle<A> {
Expand Down
24 changes: 21 additions & 3 deletions wgpu-core/src/device/queue.rs
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,13 @@ pub struct SubmittedWorkDoneClosureC {
pub user_data: *mut u8,
}

#[cfg(not(target_arch = "wasm32"))]
#[cfg(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
))]
unsafe impl Send for SubmittedWorkDoneClosureC {}

pub struct SubmittedWorkDoneClosure {
Expand All @@ -46,9 +52,21 @@ pub struct SubmittedWorkDoneClosure {
inner: SubmittedWorkDoneClosureInner,
}

#[cfg(not(target_arch = "wasm32"))]
#[cfg(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
))]
type SubmittedWorkDoneCallback = Box<dyn FnOnce() + Send + 'static>;
#[cfg(target_arch = "wasm32")]
#[cfg(not(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
)))]
type SubmittedWorkDoneCallback = Box<dyn FnOnce() + 'static>;

enum SubmittedWorkDoneClosureInner {
Expand Down
16 changes: 14 additions & 2 deletions wgpu-core/src/error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -162,9 +162,21 @@ pub fn format_pretty_any(
#[derive(Debug)]
pub struct ContextError {
pub string: &'static str,
#[cfg(not(target_arch = "wasm32"))]
#[cfg(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
))]
pub cause: Box<dyn Error + Send + Sync + 'static>,
#[cfg(target_arch = "wasm32")]
#[cfg(not(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
)))]
pub cause: Box<dyn Error + 'static>,
pub label_key: &'static str,
pub label: String,
Expand Down
11 changes: 10 additions & 1 deletion wgpu-core/src/global.rs
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,16 @@ impl<G: GlobalIdentityHandlerFactory> Drop for Global<G> {
}
}

#[cfg(all(test, not(target_arch = "wasm32")))]
#[cfg(all(
test,
any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
)
))]
fn _test_send_sync(global: &Global<crate::identity::IdentityManagerFactory>) {
fn test_internal<T: Send + Sync>(_: T) {}
test_internal(global)
Expand Down
40 changes: 35 additions & 5 deletions wgpu-core/src/resource.rs
Original file line number Diff line number Diff line change
Expand Up @@ -79,9 +79,21 @@ pub(crate) enum BufferMapState<A: hal::Api> {
Idle,
}

#[cfg(not(target_arch = "wasm32"))]
#[cfg(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
))]
unsafe impl<A: hal::Api> Send for BufferMapState<A> {}
#[cfg(not(target_arch = "wasm32"))]
#[cfg(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
))]
unsafe impl<A: hal::Api> Sync for BufferMapState<A> {}

#[repr(C)]
Expand All @@ -90,7 +102,13 @@ pub struct BufferMapCallbackC {
pub user_data: *mut u8,
}

#[cfg(not(target_arch = "wasm32"))]
#[cfg(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
))]
unsafe impl Send for BufferMapCallbackC {}

pub struct BufferMapCallback {
Expand All @@ -99,9 +117,21 @@ pub struct BufferMapCallback {
inner: Option<BufferMapCallbackInner>,
}

#[cfg(not(target_arch = "wasm32"))]
#[cfg(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
))]
type BufferMapCallbackCallback = Box<dyn FnOnce(BufferAccessResult) + Send + 'static>;
#[cfg(target_arch = "wasm32")]
#[cfg(not(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
)))]
type BufferMapCallbackCallback = Box<dyn FnOnce(BufferAccessResult) + 'static>;

enum BufferMapCallbackInner {
Expand Down
1 change: 1 addition & 0 deletions wgpu-hal/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ dx12 = ["naga/hlsl-out", "d3d12", "bit-set", "range-alloc", "winapi/std", "winap
windows_rs = ["gpu-allocator"]
dxc_shader_compiler = ["hassle-rs"]
renderdoc = ["libloading", "renderdoc-sys"]
unsound_send_sync_threadless_wasm32 = ["wgt/unsound_send_sync_threadless_wasm32"]

[[example]]
name = "halmark"
Expand Down
13 changes: 13 additions & 0 deletions wgpu-hal/src/gles/adapter.rs
Original file line number Diff line number Diff line change
Expand Up @@ -936,6 +936,19 @@ impl super::AdapterShared {
}
}

#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Sync for super::Adapter {}
#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Send for super::Adapter {}

#[cfg(test)]
mod tests {
use super::super::Adapter;
Expand Down
13 changes: 13 additions & 0 deletions wgpu-hal/src/gles/device.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1320,3 +1320,16 @@ impl crate::Device<super::Api> for super::Device {
}
}
}

#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Sync for super::Device {}
#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Send for super::Device {}
81 changes: 79 additions & 2 deletions wgpu-hal/src/gles/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -246,6 +246,19 @@ pub struct Buffer {
data: Option<Arc<std::sync::Mutex<Vec<u8>>>>,
}

#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Sync for Buffer {}
#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Send for Buffer {}

#[derive(Clone, Debug)]
pub enum TextureInner {
Renderbuffer {
Expand All @@ -262,6 +275,19 @@ pub enum TextureInner {
},
}

#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Sync for TextureInner {}
#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Send for TextureInner {}

impl TextureInner {
fn as_native(&self) -> (glow::Texture, BindTarget) {
match *self {
Expand Down Expand Up @@ -450,6 +476,19 @@ struct UniformDesc {
utype: u32,
}

#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Sync for UniformDesc {}
#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Send for UniformDesc {}

/// For each texture in the pipeline layout, store the index of the only
/// sampler (in this layout) that the texture is used with.
type SamplerBindMap = [Option<u8>; MAX_TEXTURE_SLOTS];
Expand Down Expand Up @@ -512,10 +551,36 @@ pub struct RenderPipeline {
alpha_to_coverage_enabled: bool,
}

#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Sync for RenderPipeline {}
#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Send for RenderPipeline {}

pub struct ComputePipeline {
inner: Arc<PipelineInner>,
}

#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Sync for ComputePipeline {}
#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Send for ComputePipeline {}

#[derive(Debug)]
pub struct QuerySet {
queries: Box<[glow::Query]>,
Expand All @@ -528,9 +593,21 @@ pub struct Fence {
pending: Vec<(crate::FenceValue, glow::Fence)>,
}

#[cfg(not(target_arch = "wasm32"))]
#[cfg(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
))]
unsafe impl Send for Fence {}
#[cfg(not(target_arch = "wasm32"))]
#[cfg(any(
not(target_arch = "wasm32"),
all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
)
))]
unsafe impl Sync for Fence {}

impl Fence {
Expand Down
13 changes: 13 additions & 0 deletions wgpu-hal/src/gles/queue.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1524,3 +1524,16 @@ impl crate::Queue<super::Api> for super::Queue {
1.0
}
}

#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Sync for super::Queue {}
#[cfg(all(
target_arch = "wasm32",
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Send for super::Queue {}
22 changes: 22 additions & 0 deletions wgpu-hal/src/gles/web.rs
Original file line number Diff line number Diff line change
Expand Up @@ -106,6 +106,17 @@ impl Instance {
}
}

#[cfg(all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Sync for Instance {}
#[cfg(all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Send for Instance {}

impl crate::Instance<super::Api> for Instance {
unsafe fn init(_desc: &crate::InstanceDescriptor) -> Result<Self, crate::InstanceError> {
Ok(Instance {
Expand Down Expand Up @@ -167,6 +178,17 @@ pub struct Surface {
srgb_present_program: Option<glow::Program>,
}

#[cfg(all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Sync for Surface {}
#[cfg(all(
feature = "unsound_send_sync_threadless_wasm32",
not(target_feature = "atomics")
))]
unsafe impl Send for Surface {}

#[derive(Clone, Debug)]
enum Canvas {
Canvas(web_sys::HtmlCanvasElement),
Expand Down
Loading

0 comments on commit 68d2a92

Please sign in to comment.