diff --git a/ash/src/extensions/mod.rs b/ash/src/extensions/mod.rs index 4de4222..fefba9b 100644 --- a/ash/src/extensions/mod.rs +++ b/ash/src/extensions/mod.rs @@ -2,4 +2,5 @@ pub mod experimental; pub mod ext; pub mod khr; pub mod mvk; +pub mod nn; pub mod nv; diff --git a/ash/src/extensions/nn/mod.rs b/ash/src/extensions/nn/mod.rs new file mode 100644 index 0000000..e429050 --- /dev/null +++ b/ash/src/extensions/nn/mod.rs @@ -0,0 +1,3 @@ +pub use self::vi_surface::ViSurface; + +mod vi_surface; diff --git a/ash/src/extensions/nn/vi_surface.rs b/ash/src/extensions/nn/vi_surface.rs new file mode 100644 index 0000000..3d175d6 --- /dev/null +++ b/ash/src/extensions/nn/vi_surface.rs @@ -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(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 = ""] + pub unsafe fn create_vi_surface( + &self, + create_info: &vk::ViSurfaceCreateInfoNN, + allocation_callbacks: Option<&vk::AllocationCallbacks>, + ) -> VkResult { + 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 + } +}