diff --git a/ash/src/device.rs b/ash/src/device.rs index 8b9cbc0..8623be2 100644 --- a/ash/src/device.rs +++ b/ash/src/device.rs @@ -34,7 +34,7 @@ pub trait DeviceV1_1: DeviceV1_0 { } } - unsafe fn get_device_group_peer_memory_features( + unsafe fn get_device_group_peer_memory_features( &self, heap_index: u32, local_device_index: u32, @@ -84,33 +84,31 @@ pub trait DeviceV1_1: DeviceV1_0 { unsafe fn get_image_memory_requirements2( &self, info: &vk::ImageMemoryRequirementsInfo2, - ) -> vk::MemoryRequirements2 { - let mut image_memory_requirements = mem::uninitialized(); + out: &mut vk::MemoryRequirements2, + ) { self.fp_v1_1().get_image_memory_requirements2( self.handle(), info, - &mut image_memory_requirements, + out, ); - image_memory_requirements } unsafe fn get_buffer_memory_requirements2( &self, info: &vk::BufferMemoryRequirementsInfo2, - ) -> vk::MemoryRequirements2 { - let mut image_memory_requirements = mem::uninitialized(); + out: &mut vk::MemoryRequirements2, + ) { self.fp_v1_1().get_buffer_memory_requirements2( self.handle(), info, - &mut image_memory_requirements, + out, ); - image_memory_requirements } - unsafe fn get_image_sparse_memory_requirements2( + unsafe fn get_image_sparse_memory_requirements2_len( &self, info: &vk::ImageSparseMemoryRequirementsInfo2, - ) -> Vec { + ) -> usize { let mut count = mem::uninitialized(); self.fp_v1_1().get_image_sparse_memory_requirements2( self.handle(), @@ -118,15 +116,21 @@ pub trait DeviceV1_1: DeviceV1_0 { &mut count, ptr::null_mut(), ); - let mut requirements = Vec::with_capacity(count as usize); + count as usize + } + + unsafe fn get_image_sparse_memory_requirements2( + &self, + info: &vk::ImageSparseMemoryRequirementsInfo2, + out: &mut [vk::SparseImageMemoryRequirements2], + ) { + let mut count = out.len() as u32; self.fp_v1_1().get_image_sparse_memory_requirements2( self.handle(), info, &mut count, - requirements.as_mut_ptr(), + out.as_mut_ptr(), ); - requirements.set_len(count as usize); - requirements } unsafe fn trim_command_pool( @@ -215,14 +219,13 @@ pub trait DeviceV1_1: DeviceV1_0 { unsafe fn get_descriptor_set_layout_support( &self, create_info: &vk::DescriptorSetLayoutCreateInfo, - ) -> vk::DescriptorSetLayoutSupport { - let mut descriptor_set_layout_support = mem::uninitialized(); + out: &mut vk::DescriptorSetLayoutSupport, + ) { self.fp_v1_1().get_descriptor_set_layout_support( self.handle(), create_info, - &mut descriptor_set_layout_support, + out, ); - descriptor_set_layout_support } } diff --git a/ash/src/instance.rs b/ash/src/instance.rs index 6137c1d..df5146c 100644 --- a/ash/src/instance.rs +++ b/ash/src/instance.rs @@ -14,10 +14,7 @@ pub struct Instance { instance_fn_1_1: vk::InstanceFnV1_1, } impl Instance { - pub unsafe fn load( - static_fn: &vk::StaticFn, - instance: vk::Instance, - ) -> Self { + pub unsafe fn load(static_fn: &vk::StaticFn, instance: vk::Instance) -> Self { let instance_fn_1_0 = vk::InstanceFnV1_0::load(|name| { mem::transmute(static_fn.get_instance_proc_addr(instance, name.as_ptr())) }); @@ -72,25 +69,32 @@ impl InstanceV1_1 for Instance { pub trait InstanceV1_1: InstanceV1_0 { fn fp_v1_1(&self) -> &vk::InstanceFnV1_1; - unsafe fn enumerate_physical_device_groups( - &self, - ) -> VkResult> { + unsafe fn enumerate_physical_device_groups_len(&self) -> usize { let mut group_count = mem::uninitialized(); self.fp_v1_1().enumerate_physical_device_groups( self.handle(), &mut group_count, ptr::null_mut(), ); - let mut physical_device_groups = Vec::with_capacity(group_count as usize); - let err_code = self.fp_v1_1().enumerate_physical_device_groups( - self.handle(), - &mut group_count, - physical_device_groups.as_mut_ptr(), - ); - physical_device_groups.set_len(group_count as usize); - match err_code { - vk::Result::SUCCESS => Ok(physical_device_groups), - _ => Err(err_code), + group_count as usize + } + + fn enumerate_physical_device_groups( + &self, + out: &mut [vk::PhysicalDeviceGroupProperties], + ) -> VkResult<()> { + unsafe { + let mut group_count = out.len() as u32; + let err_code = self.fp_v1_1().enumerate_physical_device_groups( + self.handle(), + &mut group_count, + out.as_mut_ptr(), + ); + if err_code == vk::Result::SUCCESS { + Ok(()) + } else { + Err(err_code) + } } } @@ -107,14 +111,10 @@ pub trait InstanceV1_1: InstanceV1_0 { &self, physical_device: vk::PhysicalDevice, format: vk::Format, - ) -> vk::FormatProperties2 { - let mut format_prop = mem::uninitialized(); - self.fp_v1_1().get_physical_device_format_properties2( - physical_device, - format, - &mut format_prop, - ); - format_prop + out: &mut vk::FormatProperties2, + ) { + self.fp_v1_1() + .get_physical_device_format_properties2(physical_device, format, out); } unsafe fn get_physical_device_image_format_properties2( @@ -164,18 +164,17 @@ pub trait InstanceV1_1: InstanceV1_0 { unsafe fn get_physical_device_memory_properties2( &self, physical_device: vk::PhysicalDevice, - ) -> vk::PhysicalDeviceMemoryProperties2 { - let mut memory_prop = mem::uninitialized(); + out: &mut vk::PhysicalDeviceMemoryProperties2, + ) { self.fp_v1_1() - .get_physical_device_memory_properties2(physical_device, &mut memory_prop); - memory_prop + .get_physical_device_memory_properties2(physical_device, out); } - unsafe fn get_physical_device_sparse_image_format_properties2( + unsafe fn get_physical_device_sparse_image_format_properties2_len( &self, physical_device: vk::PhysicalDevice, format_info: &vk::PhysicalDeviceSparseImageFormatInfo2, - ) -> Vec { + ) -> usize { let mut format_count = 0; self.fp_v1_1() .get_physical_device_sparse_image_format_properties2( @@ -184,61 +183,65 @@ pub trait InstanceV1_1: InstanceV1_0 { &mut format_count, ptr::null_mut(), ); - let mut format_prop = Vec::with_capacity(format_count as usize); + format_count as usize + } + + unsafe fn get_physical_device_sparse_image_format_properties2( + &self, + physical_device: vk::PhysicalDevice, + format_info: &vk::PhysicalDeviceSparseImageFormatInfo2, + out: &mut [vk::SparseImageFormatProperties2], + ) { + let mut format_count = out.len() as u32; self.fp_v1_1() .get_physical_device_sparse_image_format_properties2( physical_device, format_info, &mut format_count, - format_prop.as_mut_ptr(), + out.as_mut_ptr(), ); - format_prop.set_len(format_count as usize); - format_prop } unsafe fn get_physical_device_external_buffer_properties( &self, physical_device: vk::PhysicalDevice, external_buffer_info: &vk::PhysicalDeviceExternalBufferInfo, - ) -> vk::ExternalBufferProperties { - let mut image_format_prop = mem::uninitialized(); + out: &mut vk::ExternalBufferProperties, + ) { self.fp_v1_1() .get_physical_device_external_buffer_properties( physical_device, external_buffer_info, - &mut image_format_prop, + out, ); - image_format_prop } unsafe fn get_physical_device_external_fence_properties( &self, physical_device: vk::PhysicalDevice, external_fence_info: &vk::PhysicalDeviceExternalFenceInfo, - ) -> vk::ExternalFenceProperties { - let mut fence_prop = mem::uninitialized(); + out: &mut vk::ExternalFenceProperties, + ) { self.fp_v1_1() .get_physical_device_external_fence_properties( physical_device, external_fence_info, - &mut fence_prop, + out, ); - fence_prop } unsafe fn get_physical_device_external_semaphore_properties( &self, physical_device: vk::PhysicalDevice, external_semaphore_info: &vk::PhysicalDeviceExternalSemaphoreInfo, - ) -> vk::ExternalSemaphoreProperties { - let mut semaphore_prop = mem::uninitialized(); + out: &mut vk::ExternalSemaphoreProperties, + ) { self.fp_v1_1() .get_physical_device_external_semaphore_properties( physical_device, external_semaphore_info, - &mut semaphore_prop, + out, ); - semaphore_prop } }