diff --git a/wgpu-hal/src/vulkan/adapter.rs b/wgpu-hal/src/vulkan/adapter.rs index ca086f2f2f..b19fb347ee 100644 --- a/wgpu-hal/src/vulkan/adapter.rs +++ b/wgpu-hal/src/vulkan/adapter.rs @@ -1308,6 +1308,7 @@ impl super::Adapter { let shared = Arc::new(super::DeviceShared { raw: raw_device, family_index, + queue_index, handle_is_owned, instance: Arc::clone(&self.instance), physical_device: self.raw, diff --git a/wgpu-hal/src/vulkan/device.rs b/wgpu-hal/src/vulkan/device.rs index cdeea06bcc..ecb526136f 100644 --- a/wgpu-hal/src/vulkan/device.rs +++ b/wgpu-hal/src/vulkan/device.rs @@ -719,6 +719,14 @@ impl super::Device { self.shared.physical_device } + pub fn raw_queue(&self) -> ash::vk::Queue { + unsafe { + self.shared + .raw + .get_device_queue(self.queue_family_index(), self.shared.queue_index) + } + } + pub fn enabled_device_extensions(&self) -> &[&'static CStr] { &self.shared.enabled_extensions } diff --git a/wgpu-hal/src/vulkan/mod.rs b/wgpu-hal/src/vulkan/mod.rs index 3a7ff095d4..24d4d8cb7e 100644 --- a/wgpu-hal/src/vulkan/mod.rs +++ b/wgpu-hal/src/vulkan/mod.rs @@ -313,6 +313,7 @@ impl UpdateAfterBindTypes { struct DeviceShared { raw: ash::Device, family_index: u32, + queue_index: u32, handle_is_owned: bool, instance: Arc, physical_device: ash::vk::PhysicalDevice,