Add VK_NN_vi_surface extension (#398)
This commit is contained in:
parent
81b8e3a24a
commit
3094084c1f
3 changed files with 58 additions and 0 deletions
|
@ -2,4 +2,5 @@ pub mod experimental;
|
||||||
pub mod ext;
|
pub mod ext;
|
||||||
pub mod khr;
|
pub mod khr;
|
||||||
pub mod mvk;
|
pub mod mvk;
|
||||||
|
pub mod nn;
|
||||||
pub mod nv;
|
pub mod nv;
|
||||||
|
|
3
ash/src/extensions/nn/mod.rs
Normal file
3
ash/src/extensions/nn/mod.rs
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
pub use self::vi_surface::ViSurface;
|
||||||
|
|
||||||
|
mod vi_surface;
|
54
ash/src/extensions/nn/vi_surface.rs
Normal file
54
ash/src/extensions/nn/vi_surface.rs
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
#![allow(dead_code)]
|
||||||
|
use crate::prelude::*;
|
||||||
|
use crate::version::{EntryV1_0, InstanceV1_0};
|
||||||
|
use crate::vk;
|
||||||
|
use crate::RawPtr;
|
||||||
|
use std::ffi::CStr;
|
||||||
|
use std::mem;
|
||||||
|
|
||||||
|
#[derive(Clone)]
|
||||||
|
pub struct ViSurface {
|
||||||
|
handle: vk::Instance,
|
||||||
|
vi_surface_fn: vk::NnViSurfaceFn,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ViSurface {
|
||||||
|
pub fn new<E: EntryV1_0, I: InstanceV1_0>(entry: &E, instance: &I) -> ViSurface {
|
||||||
|
let surface_fn = vk::NnViSurfaceFn::load(|name| unsafe {
|
||||||
|
mem::transmute(entry.get_instance_proc_addr(instance.handle(), name.as_ptr()))
|
||||||
|
});
|
||||||
|
ViSurface {
|
||||||
|
handle: instance.handle(),
|
||||||
|
vi_surface_fn: surface_fn,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn name() -> &'static CStr {
|
||||||
|
vk::NnViSurfaceFn::name()
|
||||||
|
}
|
||||||
|
|
||||||
|
#[doc = "<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkCreateViSurfaceNN.html>"]
|
||||||
|
pub unsafe fn create_vi_surface(
|
||||||
|
&self,
|
||||||
|
create_info: &vk::ViSurfaceCreateInfoNN,
|
||||||
|
allocation_callbacks: Option<&vk::AllocationCallbacks>,
|
||||||
|
) -> VkResult<vk::SurfaceKHR> {
|
||||||
|
let mut surface = mem::zeroed();
|
||||||
|
self.vi_surface_fn
|
||||||
|
.create_vi_surface_nn(
|
||||||
|
self.handle,
|
||||||
|
create_info,
|
||||||
|
allocation_callbacks.as_raw_ptr(),
|
||||||
|
&mut surface,
|
||||||
|
)
|
||||||
|
.result_with_success(surface)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn fp(&self) -> &vk::NnViSurfaceFn {
|
||||||
|
&self.vi_surface_fn
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn instance(&self) -> vk::Instance {
|
||||||
|
self.handle
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue