diff options
author | Istvan Miklos <istvan.miklos@h-lab.eu> | 2020-01-06 14:04:38 +0100 |
---|---|---|
committer | Istvan Miklos <istvan.miklos@h-lab.eu> | 2020-01-16 10:53:51 +0100 |
commit | 9cf007472b364ea60445e6aaa5e91f67ef3d1894 (patch) | |
tree | 913d22e397a02b455cb7d198feabc7e0e33f8a6a /components/script/dom/identityhub.rs | |
parent | 95614f57f147699f15a8f103c7def1cdfcdc7d1f (diff) | |
download | servo-9cf007472b364ea60445e6aaa5e91f67ef3d1894.tar.gz servo-9cf007472b364ea60445e6aaa5e91f67ef3d1894.zip |
Initial implementation of GPUBindGroupLayout for WebGPU
Added WebIDL bindings for `GPUBindGroupLayout`, `GPUBindGroupLayoutDescriptor`, `GPUBindingType`, `GPUShaderStage`
and `GPUBindGroupLayoutBinding` (Note: The servo's codegen doesn't like the name, because its already occupied).
Implemented the `createBindGroupLayout` function of `GPUDevice`.
Diffstat (limited to 'components/script/dom/identityhub.rs')
-rw-r--r-- | components/script/dom/identityhub.rs | 24 |
1 files changed, 22 insertions, 2 deletions
diff --git a/components/script/dom/identityhub.rs b/components/script/dom/identityhub.rs index 64e4cad3867..91543d2ea3f 100644 --- a/components/script/dom/identityhub.rs +++ b/components/script/dom/identityhub.rs @@ -5,7 +5,7 @@ use smallvec::SmallVec; use webgpu::wgpu::{ hub::IdentityManager, - id::{AdapterId, BufferId, DeviceId}, + id::{AdapterId, BindGroupLayoutId, BufferId, DeviceId}, Backend, }; @@ -14,6 +14,7 @@ pub struct IdentityHub { adapters: IdentityManager, devices: IdentityManager, buffers: IdentityManager, + bind_group_layouts: IdentityManager, backend: Backend, } @@ -23,6 +24,7 @@ impl IdentityHub { adapters: IdentityManager::default(), devices: IdentityManager::default(), buffers: IdentityManager::default(), + bind_group_layouts: IdentityManager::default(), backend, } } @@ -35,9 +37,13 @@ impl IdentityHub { self.devices.alloc(self.backend) } - pub fn create_buffer_id(&mut self) -> BufferId { + fn create_buffer_id(&mut self) -> BufferId { self.buffers.alloc(self.backend) } + + fn create_bind_group_layout_id(&mut self) -> BindGroupLayoutId { + self.bind_group_layouts.alloc(self.backend) + } } #[derive(Debug)] @@ -119,4 +125,18 @@ impl Identities { _ => self.dummy_hub.create_buffer_id(), } } + + pub fn create_bind_group_layout_id(&mut self, backend: Backend) -> BindGroupLayoutId { + match backend { + #[cfg(any(target_os = "linux", target_os = "windows"))] + Backend::Vulkan => self.vk_hub.create_bind_group_layout_id(), + #[cfg(target_os = "windows")] + Backend::Dx12 => self.dx12_hub.create_bind_group_layout_id(), + #[cfg(target_os = "windows")] + Backend::Dx11 => self.dx11_hub.create_bind_group_layout_id(), + #[cfg(any(target_os = "ios", target_os = "macos"))] + Backend::Metal => self.metal_hub.create_bind_group_layout_id(), + _ => self.dummy_hub.create_bind_group_layout_id(), + } + } } |