extensions: Add VK_KHR_get_surface_capabilities2 (#530)
This commit is contained in:
parent
8a46a1508a
commit
8f05905ecb
3 changed files with 86 additions and 0 deletions
|
@ -6,6 +6,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
|
|
||||||
## [Unreleased] - ReleaseDate
|
## [Unreleased] - ReleaseDate
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
- Added `VK_KHR_get_surface_capabilities2` device extension (#530)
|
||||||
|
|
||||||
## [0.35.0] - 2021-12-27
|
## [0.35.0] - 2021-12-27
|
||||||
|
|
||||||
### Changed
|
### Changed
|
||||||
|
|
80
ash/src/extensions/khr/get_surface_capabilities2.rs
Normal file
80
ash/src/extensions/khr/get_surface_capabilities2.rs
Normal file
|
@ -0,0 +1,80 @@
|
||||||
|
use crate::prelude::*;
|
||||||
|
use crate::vk;
|
||||||
|
use crate::{Entry, Instance};
|
||||||
|
use std::ffi::CStr;
|
||||||
|
use std::mem;
|
||||||
|
|
||||||
|
#[derive(Clone)]
|
||||||
|
pub struct GetSurfaceCapabilities2 {
|
||||||
|
fp: vk::KhrGetSurfaceCapabilities2Fn,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl GetSurfaceCapabilities2 {
|
||||||
|
pub fn new(entry: &Entry, instance: &Instance) -> Self {
|
||||||
|
let fp = vk::KhrGetSurfaceCapabilities2Fn::load(|name| unsafe {
|
||||||
|
mem::transmute(entry.get_instance_proc_addr(instance.handle(), name.as_ptr()))
|
||||||
|
});
|
||||||
|
Self { fp }
|
||||||
|
}
|
||||||
|
|
||||||
|
#[doc = "https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkGetPhysicalDeviceSurfaceCapabilities2KHR.html"]
|
||||||
|
pub unsafe fn get_physical_device_surface_capabilities2(
|
||||||
|
&self,
|
||||||
|
physical_device: vk::PhysicalDevice,
|
||||||
|
surface_info: &vk::PhysicalDeviceSurfaceInfo2KHR,
|
||||||
|
) -> VkResult<vk::SurfaceCapabilities2KHR> {
|
||||||
|
let mut surface_capabilities = Default::default();
|
||||||
|
self.fp
|
||||||
|
.get_physical_device_surface_capabilities2_khr(
|
||||||
|
physical_device,
|
||||||
|
surface_info,
|
||||||
|
&mut surface_capabilities,
|
||||||
|
)
|
||||||
|
.result_with_success(surface_capabilities)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Retrieve the number of elements to pass to [`Self::get_physical_device_surface_formats2()`]
|
||||||
|
pub unsafe fn get_physical_device_surface_formats2_len(
|
||||||
|
&self,
|
||||||
|
physical_device: vk::PhysicalDevice,
|
||||||
|
surface_info: &vk::PhysicalDeviceSurfaceInfo2KHR,
|
||||||
|
) -> VkResult<usize> {
|
||||||
|
let mut count = 0;
|
||||||
|
let err_code = self.fp.get_physical_device_surface_formats2_khr(
|
||||||
|
physical_device,
|
||||||
|
surface_info,
|
||||||
|
&mut count,
|
||||||
|
std::ptr::null_mut(),
|
||||||
|
);
|
||||||
|
err_code.result_with_success(count as usize)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[doc = "https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkGetPhysicalDeviceSurfaceFormats2KHR.html"]
|
||||||
|
///
|
||||||
|
/// Call [`Self::get_physical_device_surface_formats2_len()`] to query the number of elements to pass to `out`.
|
||||||
|
/// Be sure to [`Default::default()`]-initialize these elements and optionally set their `p_next` pointer.
|
||||||
|
pub unsafe fn get_physical_device_surface_formats2(
|
||||||
|
&self,
|
||||||
|
physical_device: vk::PhysicalDevice,
|
||||||
|
surface_info: &vk::PhysicalDeviceSurfaceInfo2KHR,
|
||||||
|
out: &mut [vk::SurfaceFormat2KHR],
|
||||||
|
) -> VkResult<()> {
|
||||||
|
let mut count = out.len() as u32;
|
||||||
|
let err_code = self.fp.get_physical_device_surface_formats2_khr(
|
||||||
|
physical_device,
|
||||||
|
surface_info,
|
||||||
|
&mut count,
|
||||||
|
out.as_mut_ptr(),
|
||||||
|
);
|
||||||
|
assert_eq!(count, out.len() as u32);
|
||||||
|
err_code.result()
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn name() -> &'static CStr {
|
||||||
|
vk::KhrGetSurfaceCapabilities2Fn::name()
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn fp(&self) -> &vk::KhrGetSurfaceCapabilities2Fn {
|
||||||
|
&self.fp
|
||||||
|
}
|
||||||
|
}
|
|
@ -12,6 +12,7 @@ pub use self::external_memory_fd::ExternalMemoryFd;
|
||||||
pub use self::external_semaphore_fd::ExternalSemaphoreFd;
|
pub use self::external_semaphore_fd::ExternalSemaphoreFd;
|
||||||
pub use self::get_memory_requirements2::GetMemoryRequirements2;
|
pub use self::get_memory_requirements2::GetMemoryRequirements2;
|
||||||
pub use self::get_physical_device_properties2::GetPhysicalDeviceProperties2;
|
pub use self::get_physical_device_properties2::GetPhysicalDeviceProperties2;
|
||||||
|
pub use self::get_surface_capabilities2::GetSurfaceCapabilities2;
|
||||||
pub use self::maintenance1::Maintenance1;
|
pub use self::maintenance1::Maintenance1;
|
||||||
pub use self::maintenance3::Maintenance3;
|
pub use self::maintenance3::Maintenance3;
|
||||||
pub use self::maintenance4::Maintenance4;
|
pub use self::maintenance4::Maintenance4;
|
||||||
|
@ -42,6 +43,7 @@ mod external_memory_fd;
|
||||||
mod external_semaphore_fd;
|
mod external_semaphore_fd;
|
||||||
mod get_memory_requirements2;
|
mod get_memory_requirements2;
|
||||||
mod get_physical_device_properties2;
|
mod get_physical_device_properties2;
|
||||||
|
mod get_surface_capabilities2;
|
||||||
mod maintenance1;
|
mod maintenance1;
|
||||||
mod maintenance3;
|
mod maintenance3;
|
||||||
mod maintenance4;
|
mod maintenance4;
|
||||||
|
|
Loading…
Add table
Reference in a new issue