cargo fmt
This commit is contained in:
parent
b622fd7993
commit
eb70d0e899
19 changed files with 1455 additions and 1480 deletions
|
@ -85,10 +85,8 @@ pub trait EntryV1_0 {
|
||||||
return Err(InstanceError::VkError(err_code));
|
return Err(InstanceError::VkError(err_code));
|
||||||
}
|
}
|
||||||
let instance_fp =
|
let instance_fp =
|
||||||
<Self::Fp as FunctionPointers>::InstanceFp::load(
|
<Self::Fp as FunctionPointers>::InstanceFp::load(&self.static_fn(), instance)
|
||||||
&self.static_fn(),
|
.map_err(InstanceError::LoadError)?;
|
||||||
instance,
|
|
||||||
).map_err(InstanceError::LoadError)?;
|
|
||||||
Ok(Instance::from_raw(instance, instance_fp))
|
Ok(Instance::from_raw(instance, instance_fp))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -161,9 +159,8 @@ impl<V: FunctionPointers> Entry<V> {
|
||||||
.unwrap_or(ptr::null_mut())
|
.unwrap_or(ptr::null_mut())
|
||||||
}).map_err(LoadingError::StaticLoadError)?;
|
}).map_err(LoadingError::StaticLoadError)?;
|
||||||
|
|
||||||
let entry_fn = unsafe {
|
let entry_fn =
|
||||||
V::EntryFp::load(&static_fn)
|
unsafe { V::EntryFp::load(&static_fn) }.map_err(LoadingError::EntryLoadError)?;
|
||||||
}.map_err(LoadingError::EntryLoadError)?;
|
|
||||||
|
|
||||||
Ok(Entry {
|
Ok(Entry {
|
||||||
static_fn,
|
static_fn,
|
||||||
|
|
|
@ -18,10 +18,7 @@ impl AndroidSurface {
|
||||||
instance: &I,
|
instance: &I,
|
||||||
) -> Result<AndroidSurface, Vec<&'static str>> {
|
) -> Result<AndroidSurface, Vec<&'static str>> {
|
||||||
let surface_fn = vk::AndroidSurfaceFn::load(|name| unsafe {
|
let surface_fn = vk::AndroidSurfaceFn::load(|name| unsafe {
|
||||||
mem::transmute(entry.get_instance_proc_addr(
|
mem::transmute(entry.get_instance_proc_addr(instance.handle(), name.as_ptr()))
|
||||||
instance.handle(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(AndroidSurface {
|
Ok(AndroidSurface {
|
||||||
handle: instance.handle(),
|
handle: instance.handle(),
|
||||||
|
|
|
@ -3,7 +3,7 @@ use prelude::*;
|
||||||
use std::mem;
|
use std::mem;
|
||||||
use vk;
|
use vk;
|
||||||
use std::ffi::CStr;
|
use std::ffi::CStr;
|
||||||
use version::{InstanceV1_0, DeviceV1_0};
|
use version::{DeviceV1_0, InstanceV1_0};
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct DebugMarker {
|
pub struct DebugMarker {
|
||||||
|
@ -13,13 +13,10 @@ pub struct DebugMarker {
|
||||||
impl DebugMarker {
|
impl DebugMarker {
|
||||||
pub fn new<I: InstanceV1_0, D: DeviceV1_0>(
|
pub fn new<I: InstanceV1_0, D: DeviceV1_0>(
|
||||||
instance: &I,
|
instance: &I,
|
||||||
device: &D
|
device: &D,
|
||||||
) -> Result<DebugMarker, Vec<&'static str>> {
|
) -> Result<DebugMarker, Vec<&'static str>> {
|
||||||
let debug_marker_fn = vk::DebugMarkerFn::load(|name| unsafe {
|
let debug_marker_fn = vk::DebugMarkerFn::load(|name| unsafe {
|
||||||
mem::transmute(instance.get_device_proc_addr(
|
mem::transmute(instance.get_device_proc_addr(device.handle(), name.as_ptr()))
|
||||||
device.handle(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(DebugMarker {
|
Ok(DebugMarker {
|
||||||
debug_marker_fn: debug_marker_fn,
|
debug_marker_fn: debug_marker_fn,
|
||||||
|
@ -33,46 +30,36 @@ impl DebugMarker {
|
||||||
pub unsafe fn debug_marker_set_object_name_ext(
|
pub unsafe fn debug_marker_set_object_name_ext(
|
||||||
&self,
|
&self,
|
||||||
device: vk::Device,
|
device: vk::Device,
|
||||||
name_info: &vk::DebugMarkerObjectNameInfoEXT
|
name_info: &vk::DebugMarkerObjectNameInfoEXT,
|
||||||
) -> VkResult<()> {
|
) -> VkResult<()> {
|
||||||
let err_code = self.debug_marker_fn.debug_marker_set_object_name_ext(
|
let err_code = self.debug_marker_fn
|
||||||
device,
|
.debug_marker_set_object_name_ext(device, name_info);
|
||||||
name_info
|
|
||||||
);
|
|
||||||
match err_code {
|
match err_code {
|
||||||
vk::Result::Success => Ok(()),
|
vk::Result::Success => Ok(()),
|
||||||
_ => Err(err_code)
|
_ => Err(err_code),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub unsafe fn cmd_debug_marker_begin_ext(
|
pub unsafe fn cmd_debug_marker_begin_ext(
|
||||||
&self,
|
&self,
|
||||||
command_buffer: vk::CommandBuffer,
|
command_buffer: vk::CommandBuffer,
|
||||||
marker_info: &vk::DebugMarkerMarkerInfoEXT
|
marker_info: &vk::DebugMarkerMarkerInfoEXT,
|
||||||
) {
|
) {
|
||||||
self.debug_marker_fn.cmd_debug_marker_begin_ext(
|
self.debug_marker_fn
|
||||||
command_buffer,
|
.cmd_debug_marker_begin_ext(command_buffer, marker_info);
|
||||||
marker_info
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub unsafe fn cmd_debug_marker_end_ext(
|
pub unsafe fn cmd_debug_marker_end_ext(&self, command_buffer: vk::CommandBuffer) {
|
||||||
&self,
|
self.debug_marker_fn
|
||||||
command_buffer: vk::CommandBuffer,
|
.cmd_debug_marker_end_ext(command_buffer);
|
||||||
) {
|
|
||||||
self.debug_marker_fn.cmd_debug_marker_end_ext(
|
|
||||||
command_buffer,
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub unsafe fn cmd_debug_marker_insert_ext(
|
pub unsafe fn cmd_debug_marker_insert_ext(
|
||||||
&self,
|
&self,
|
||||||
command_buffer: vk::CommandBuffer,
|
command_buffer: vk::CommandBuffer,
|
||||||
marker_info: &vk::DebugMarkerMarkerInfoEXT
|
marker_info: &vk::DebugMarkerMarkerInfoEXT,
|
||||||
) {
|
) {
|
||||||
self.debug_marker_fn.cmd_debug_marker_insert_ext(
|
self.debug_marker_fn
|
||||||
command_buffer,
|
.cmd_debug_marker_insert_ext(command_buffer, marker_info);
|
||||||
marker_info
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,10 +18,7 @@ impl DebugReport {
|
||||||
instance: &I,
|
instance: &I,
|
||||||
) -> Result<DebugReport, Vec<&'static str>> {
|
) -> Result<DebugReport, Vec<&'static str>> {
|
||||||
let debug_report_fn = vk::DebugReportFn::load(|name| unsafe {
|
let debug_report_fn = vk::DebugReportFn::load(|name| unsafe {
|
||||||
mem::transmute(entry.get_instance_proc_addr(
|
mem::transmute(entry.get_instance_proc_addr(instance.handle(), name.as_ptr()))
|
||||||
instance.handle(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(DebugReport {
|
Ok(DebugReport {
|
||||||
handle: instance.handle(),
|
handle: instance.handle(),
|
||||||
|
|
|
@ -4,7 +4,7 @@ use std::mem;
|
||||||
use vk;
|
use vk;
|
||||||
use std::ffi::CStr;
|
use std::ffi::CStr;
|
||||||
use RawPtr;
|
use RawPtr;
|
||||||
use version::{InstanceV1_0, DeviceV1_0};
|
use version::{DeviceV1_0, InstanceV1_0};
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct DisplaySwapchain {
|
pub struct DisplaySwapchain {
|
||||||
|
@ -18,10 +18,7 @@ impl DisplaySwapchain {
|
||||||
device: &D,
|
device: &D,
|
||||||
) -> Result<DisplaySwapchain, Vec<&'static str>> {
|
) -> Result<DisplaySwapchain, Vec<&'static str>> {
|
||||||
let swapchain_fn = vk::DisplaySwapchainFn::load(|name| unsafe {
|
let swapchain_fn = vk::DisplaySwapchainFn::load(|name| unsafe {
|
||||||
mem::transmute(instance.get_device_proc_addr(
|
mem::transmute(instance.get_device_proc_addr(device.handle(), name.as_ptr()))
|
||||||
device.handle(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(DisplaySwapchain {
|
Ok(DisplaySwapchain {
|
||||||
handle: device.handle(),
|
handle: device.handle(),
|
||||||
|
|
|
@ -18,10 +18,7 @@ impl IOSSurface {
|
||||||
instance: &I,
|
instance: &I,
|
||||||
) -> Result<IOSSurface, Vec<&'static str>> {
|
) -> Result<IOSSurface, Vec<&'static str>> {
|
||||||
let surface_fn = vk::IOSSurfaceFn::load(|name| unsafe {
|
let surface_fn = vk::IOSSurfaceFn::load(|name| unsafe {
|
||||||
mem::transmute(entry.get_instance_proc_addr(
|
mem::transmute(entry.get_instance_proc_addr(instance.handle(), name.as_ptr()))
|
||||||
instance.handle(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(IOSSurface {
|
Ok(IOSSurface {
|
||||||
handle: instance.handle(),
|
handle: instance.handle(),
|
||||||
|
|
|
@ -18,10 +18,7 @@ impl MacOSSurface {
|
||||||
instance: &I,
|
instance: &I,
|
||||||
) -> Result<MacOSSurface, Vec<&'static str>> {
|
) -> Result<MacOSSurface, Vec<&'static str>> {
|
||||||
let surface_fn = vk::MacOSSurfaceFn::load(|name| unsafe {
|
let surface_fn = vk::MacOSSurfaceFn::load(|name| unsafe {
|
||||||
mem::transmute(entry.get_instance_proc_addr(
|
mem::transmute(entry.get_instance_proc_addr(instance.handle(), name.as_ptr()))
|
||||||
instance.handle(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(MacOSSurface {
|
Ok(MacOSSurface {
|
||||||
handle: instance.handle(),
|
handle: instance.handle(),
|
||||||
|
|
|
@ -18,10 +18,7 @@ impl MirSurface {
|
||||||
instance: &I,
|
instance: &I,
|
||||||
) -> Result<MirSurface, Vec<&'static str>> {
|
) -> Result<MirSurface, Vec<&'static str>> {
|
||||||
let surface_fn = vk::MirSurfaceFn::load(|name| unsafe {
|
let surface_fn = vk::MirSurfaceFn::load(|name| unsafe {
|
||||||
mem::transmute(entry.get_instance_proc_addr(
|
mem::transmute(entry.get_instance_proc_addr(instance.handle(), name.as_ptr()))
|
||||||
instance.handle(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(MirSurface {
|
Ok(MirSurface {
|
||||||
handle: instance.handle(),
|
handle: instance.handle(),
|
||||||
|
|
|
@ -19,10 +19,7 @@ impl Surface {
|
||||||
instance: &I,
|
instance: &I,
|
||||||
) -> Result<Surface, Vec<&'static str>> {
|
) -> Result<Surface, Vec<&'static str>> {
|
||||||
let surface_fn = vk::SurfaceFn::load(|name| unsafe {
|
let surface_fn = vk::SurfaceFn::load(|name| unsafe {
|
||||||
mem::transmute(entry.get_instance_proc_addr(
|
mem::transmute(entry.get_instance_proc_addr(instance.handle(), name.as_ptr()))
|
||||||
instance.handle(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(Surface {
|
Ok(Surface {
|
||||||
handle: instance.handle(),
|
handle: instance.handle(),
|
||||||
|
|
|
@ -5,7 +5,7 @@ use std::mem;
|
||||||
use vk;
|
use vk;
|
||||||
use std::ffi::CStr;
|
use std::ffi::CStr;
|
||||||
use RawPtr;
|
use RawPtr;
|
||||||
use version::{InstanceV1_0, DeviceV1_0};
|
use version::{DeviceV1_0, InstanceV1_0};
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct Swapchain {
|
pub struct Swapchain {
|
||||||
|
@ -19,10 +19,7 @@ impl Swapchain {
|
||||||
device: &D,
|
device: &D,
|
||||||
) -> Result<Swapchain, Vec<&'static str>> {
|
) -> Result<Swapchain, Vec<&'static str>> {
|
||||||
let swapchain_fn = vk::SwapchainFn::load(|name| unsafe {
|
let swapchain_fn = vk::SwapchainFn::load(|name| unsafe {
|
||||||
mem::transmute(instance.get_device_proc_addr(
|
mem::transmute(instance.get_device_proc_addr(device.handle(), name.as_ptr()))
|
||||||
device.handle(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(Swapchain {
|
Ok(Swapchain {
|
||||||
handle: device.handle(),
|
handle: device.handle(),
|
||||||
|
|
|
@ -18,10 +18,7 @@ impl WaylandSurface {
|
||||||
instance: &I,
|
instance: &I,
|
||||||
) -> Result<WaylandSurface, Vec<&'static str>> {
|
) -> Result<WaylandSurface, Vec<&'static str>> {
|
||||||
let surface_fn = vk::WaylandSurfaceFn::load(|name| unsafe {
|
let surface_fn = vk::WaylandSurfaceFn::load(|name| unsafe {
|
||||||
mem::transmute(entry.get_instance_proc_addr(
|
mem::transmute(entry.get_instance_proc_addr(instance.handle(), name.as_ptr()))
|
||||||
instance.handle(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(WaylandSurface {
|
Ok(WaylandSurface {
|
||||||
handle: instance.handle(),
|
handle: instance.handle(),
|
||||||
|
|
|
@ -18,10 +18,7 @@ impl Win32Surface {
|
||||||
instance: &I,
|
instance: &I,
|
||||||
) -> Result<Win32Surface, Vec<&'static str>> {
|
) -> Result<Win32Surface, Vec<&'static str>> {
|
||||||
let surface_fn = vk::Win32SurfaceFn::load(|name| unsafe {
|
let surface_fn = vk::Win32SurfaceFn::load(|name| unsafe {
|
||||||
mem::transmute(entry.get_instance_proc_addr(
|
mem::transmute(entry.get_instance_proc_addr(instance.handle(), name.as_ptr()))
|
||||||
instance.handle(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(Win32Surface {
|
Ok(Win32Surface {
|
||||||
handle: instance.handle(),
|
handle: instance.handle(),
|
||||||
|
|
|
@ -18,10 +18,7 @@ impl XcbSurface {
|
||||||
instance: &I,
|
instance: &I,
|
||||||
) -> Result<XcbSurface, Vec<&'static str>> {
|
) -> Result<XcbSurface, Vec<&'static str>> {
|
||||||
let surface_fn = vk::XcbSurfaceFn::load(|name| unsafe {
|
let surface_fn = vk::XcbSurfaceFn::load(|name| unsafe {
|
||||||
mem::transmute(entry.get_instance_proc_addr(
|
mem::transmute(entry.get_instance_proc_addr(instance.handle(), name.as_ptr()))
|
||||||
instance.handle(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(XcbSurface {
|
Ok(XcbSurface {
|
||||||
handle: instance.handle(),
|
handle: instance.handle(),
|
||||||
|
|
|
@ -18,10 +18,7 @@ impl XlibSurface {
|
||||||
instance: &I,
|
instance: &I,
|
||||||
) -> Result<XlibSurface, Vec<&'static str>> {
|
) -> Result<XlibSurface, Vec<&'static str>> {
|
||||||
let surface_fn = vk::XlibSurfaceFn::load(|name| unsafe {
|
let surface_fn = vk::XlibSurfaceFn::load(|name| unsafe {
|
||||||
mem::transmute(entry.get_instance_proc_addr(
|
mem::transmute(entry.get_instance_proc_addr(instance.handle(), name.as_ptr()))
|
||||||
instance.handle(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(XlibSurface {
|
Ok(XlibSurface {
|
||||||
handle: instance.handle(),
|
handle: instance.handle(),
|
||||||
|
|
|
@ -85,8 +85,7 @@ pub trait InstanceV1_0 {
|
||||||
if err_code != vk::Result::Success {
|
if err_code != vk::Result::Success {
|
||||||
return Err(DeviceError::VkError(err_code));
|
return Err(DeviceError::VkError(err_code));
|
||||||
}
|
}
|
||||||
let device_fn =
|
let device_fn = <<Self as InstanceV1_0>::Fp as FunctionPointers>::DeviceFp::load(
|
||||||
<<Self as InstanceV1_0>::Fp as FunctionPointers>::DeviceFp::load(
|
|
||||||
self.fp_v1_0(),
|
self.fp_v1_0(),
|
||||||
device,
|
device,
|
||||||
).map_err(|err| DeviceError::LoadError(err))?;
|
).map_err(|err| DeviceError::LoadError(err))?;
|
||||||
|
@ -102,10 +101,8 @@ pub trait InstanceV1_0 {
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe fn destroy_instance(&self, allocation_callbacks: Option<&vk::AllocationCallbacks>) {
|
unsafe fn destroy_instance(&self, allocation_callbacks: Option<&vk::AllocationCallbacks>) {
|
||||||
self.fp_v1_0().destroy_instance(
|
self.fp_v1_0()
|
||||||
self.handle(),
|
.destroy_instance(self.handle(), allocation_callbacks.as_raw_ptr());
|
||||||
allocation_callbacks.as_raw_ptr(),
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_physical_device_format_properties(
|
fn get_physical_device_format_properties(
|
||||||
|
@ -158,10 +155,8 @@ pub trait InstanceV1_0 {
|
||||||
) -> vk::PhysicalDeviceMemoryProperties {
|
) -> vk::PhysicalDeviceMemoryProperties {
|
||||||
unsafe {
|
unsafe {
|
||||||
let mut memory_prop = mem::uninitialized();
|
let mut memory_prop = mem::uninitialized();
|
||||||
self.fp_v1_0().get_physical_device_memory_properties(
|
self.fp_v1_0()
|
||||||
physical_device,
|
.get_physical_device_memory_properties(physical_device, &mut memory_prop);
|
||||||
&mut memory_prop,
|
|
||||||
);
|
|
||||||
memory_prop
|
memory_prop
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -172,10 +167,8 @@ pub trait InstanceV1_0 {
|
||||||
) -> vk::PhysicalDeviceProperties {
|
) -> vk::PhysicalDeviceProperties {
|
||||||
unsafe {
|
unsafe {
|
||||||
let mut prop = mem::uninitialized();
|
let mut prop = mem::uninitialized();
|
||||||
self.fp_v1_0().get_physical_device_properties(
|
self.fp_v1_0()
|
||||||
physical_device,
|
.get_physical_device_properties(physical_device, &mut prop);
|
||||||
&mut prop,
|
|
||||||
);
|
|
||||||
prop
|
prop
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -208,10 +201,8 @@ pub trait InstanceV1_0 {
|
||||||
) -> vk::PhysicalDeviceFeatures {
|
) -> vk::PhysicalDeviceFeatures {
|
||||||
unsafe {
|
unsafe {
|
||||||
let mut prop = mem::uninitialized();
|
let mut prop = mem::uninitialized();
|
||||||
self.fp_v1_0().get_physical_device_features(
|
self.fp_v1_0()
|
||||||
physical_device,
|
.get_physical_device_features(physical_device, &mut prop);
|
||||||
&mut prop,
|
|
||||||
);
|
|
||||||
prop
|
prop
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -219,11 +210,8 @@ pub trait InstanceV1_0 {
|
||||||
fn enumerate_physical_devices(&self) -> VkResult<Vec<vk::PhysicalDevice>> {
|
fn enumerate_physical_devices(&self) -> VkResult<Vec<vk::PhysicalDevice>> {
|
||||||
unsafe {
|
unsafe {
|
||||||
let mut num = mem::uninitialized();
|
let mut num = mem::uninitialized();
|
||||||
self.fp_v1_0().enumerate_physical_devices(
|
self.fp_v1_0()
|
||||||
self.handle(),
|
.enumerate_physical_devices(self.handle(), &mut num, ptr::null_mut());
|
||||||
&mut num,
|
|
||||||
ptr::null_mut(),
|
|
||||||
);
|
|
||||||
let mut physical_devices = Vec::<vk::PhysicalDevice>::with_capacity(num as usize);
|
let mut physical_devices = Vec::<vk::PhysicalDevice>::with_capacity(num as usize);
|
||||||
let err_code = self.fp_v1_0().enumerate_physical_devices(
|
let err_code = self.fp_v1_0().enumerate_physical_devices(
|
||||||
self.handle(),
|
self.handle(),
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
extern crate libc;
|
|
||||||
extern crate shared_library;
|
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
extern crate lazy_static;
|
extern crate lazy_static;
|
||||||
pub use instance::{Instance, DeviceError};
|
extern crate libc;
|
||||||
|
extern crate shared_library;
|
||||||
|
pub use instance::{DeviceError, Instance};
|
||||||
pub use device::Device;
|
pub use device::Device;
|
||||||
pub use entry::{Entry, InstanceError, LoadingError};
|
pub use entry::{Entry, InstanceError, LoadingError};
|
||||||
|
|
||||||
|
|
|
@ -36,10 +36,7 @@ impl EntryLoader for EntryFpV1_0 {
|
||||||
}
|
}
|
||||||
unsafe fn load(static_fn: &vk::StaticFn) -> Result<Self, Vec<&'static str>> {
|
unsafe fn load(static_fn: &vk::StaticFn) -> Result<Self, Vec<&'static str>> {
|
||||||
let entry_fn = vk::EntryFnV1_0::load(|name| {
|
let entry_fn = vk::EntryFnV1_0::load(|name| {
|
||||||
mem::transmute(static_fn.get_instance_proc_addr(
|
mem::transmute(static_fn.get_instance_proc_addr(vk::Instance::null(), name.as_ptr()))
|
||||||
vk::Instance::null(),
|
|
||||||
name.as_ptr(),
|
|
||||||
))
|
|
||||||
})?;
|
})?;
|
||||||
Ok(EntryFpV1_0 { entry_fn: entry_fn })
|
Ok(EntryFpV1_0 { entry_fn: entry_fn })
|
||||||
}
|
}
|
||||||
|
@ -73,7 +70,9 @@ impl DeviceLoader for DeviceFpV1_0 {
|
||||||
let device_fn = vk::DeviceFnV1_0::load(|name| {
|
let device_fn = vk::DeviceFnV1_0::load(|name| {
|
||||||
mem::transmute(instance_fn.get_device_proc_addr(device, name.as_ptr()))
|
mem::transmute(instance_fn.get_device_proc_addr(device, name.as_ptr()))
|
||||||
})?;
|
})?;
|
||||||
Ok(DeviceFpV1_0 { device_fn: device_fn })
|
Ok(DeviceFpV1_0 {
|
||||||
|
device_fn: device_fn,
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -88,7 +87,9 @@ impl InstanceLoader for InstanceFpV1_0 {
|
||||||
let instance_fn = vk::InstanceFnV1_0::load(|name| {
|
let instance_fn = vk::InstanceFnV1_0::load(|name| {
|
||||||
mem::transmute(static_fn.get_instance_proc_addr(instance, name.as_ptr()))
|
mem::transmute(static_fn.get_instance_proc_addr(instance, name.as_ptr()))
|
||||||
})?;
|
})?;
|
||||||
Ok(InstanceFpV1_0 { instance_fn: instance_fn })
|
Ok(InstanceFpV1_0 {
|
||||||
|
instance_fn: instance_fn,
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
170
ash/src/vk.rs
170
ash/src/vk.rs
|
@ -1301,10 +1301,9 @@ pub mod types {
|
||||||
impl fmt::Debug for LayerProperties {
|
impl fmt::Debug for LayerProperties {
|
||||||
fn fmt(&self, fmt: &mut fmt::Formatter) -> ::std::result::Result<(), fmt::Error> {
|
fn fmt(&self, fmt: &mut fmt::Formatter) -> ::std::result::Result<(), fmt::Error> {
|
||||||
fmt.debug_struct("LayerProperties")
|
fmt.debug_struct("LayerProperties")
|
||||||
.field(
|
.field("layer_name", &unsafe {
|
||||||
"layer_name",
|
CStr::from_ptr(&self.layer_name[0])
|
||||||
&unsafe { CStr::from_ptr(&self.layer_name[0]) },
|
})
|
||||||
)
|
|
||||||
.field("spec_version", &self.spec_version)
|
.field("spec_version", &self.spec_version)
|
||||||
.field("implementation_version", &self.implementation_version)
|
.field("implementation_version", &self.implementation_version)
|
||||||
.field("description", &unsafe {
|
.field("description", &unsafe {
|
||||||
|
@ -2542,7 +2541,7 @@ pub mod types {
|
||||||
pub s_type: StructureType,
|
pub s_type: StructureType,
|
||||||
pub p_next: *const c_void,
|
pub p_next: *const c_void,
|
||||||
pub p_marker_name: *const c_char,
|
pub p_marker_name: *const c_char,
|
||||||
pub color: [f32; 4]
|
pub color: [f32; 4],
|
||||||
}
|
}
|
||||||
|
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
|
@ -2600,7 +2599,7 @@ pub mod types {
|
||||||
#[derive(Copy, Clone)]
|
#[derive(Copy, Clone)]
|
||||||
pub union ClearValue {
|
pub union ClearValue {
|
||||||
pub depth: ClearDepthStencilValue,
|
pub depth: ClearDepthStencilValue,
|
||||||
pub color: ClearColorValue
|
pub color: ClearColorValue,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
|
@ -3434,13 +3433,19 @@ pub mod types {
|
||||||
pub const FORMAT_FEATURE_COLOR_ATTACHMENT_BLEND_BIT: FormatFeatureFlags =
|
pub const FORMAT_FEATURE_COLOR_ATTACHMENT_BLEND_BIT: FormatFeatureFlags =
|
||||||
FormatFeatureFlags { flags: 0b100000000 };
|
FormatFeatureFlags { flags: 0b100000000 };
|
||||||
pub const FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT: FormatFeatureFlags =
|
pub const FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT: FormatFeatureFlags =
|
||||||
FormatFeatureFlags { flags: 0b1000000000 };
|
FormatFeatureFlags {
|
||||||
pub const FORMAT_FEATURE_BLIT_SRC_BIT: FormatFeatureFlags =
|
flags: 0b1000000000,
|
||||||
FormatFeatureFlags { flags: 0b10000000000 };
|
};
|
||||||
pub const FORMAT_FEATURE_BLIT_DST_BIT: FormatFeatureFlags =
|
pub const FORMAT_FEATURE_BLIT_SRC_BIT: FormatFeatureFlags = FormatFeatureFlags {
|
||||||
FormatFeatureFlags { flags: 0b100000000000 };
|
flags: 0b10000000000,
|
||||||
|
};
|
||||||
|
pub const FORMAT_FEATURE_BLIT_DST_BIT: FormatFeatureFlags = FormatFeatureFlags {
|
||||||
|
flags: 0b100000000000,
|
||||||
|
};
|
||||||
pub const FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT: FormatFeatureFlags =
|
pub const FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT: FormatFeatureFlags =
|
||||||
FormatFeatureFlags { flags: 0b1000000000000 };
|
FormatFeatureFlags {
|
||||||
|
flags: 0b1000000000000,
|
||||||
|
};
|
||||||
vk_bitflags_wrapped!(FormatFeatureFlags, 0b1111111111111, Flags);
|
vk_bitflags_wrapped!(FormatFeatureFlags, 0b1111111111111, Flags);
|
||||||
|
|
||||||
pub const IMAGE_USAGE_TRANSFER_SRC_BIT: ImageUsageFlags = ImageUsageFlags { flags: 0b1 };
|
pub const IMAGE_USAGE_TRANSFER_SRC_BIT: ImageUsageFlags = ImageUsageFlags { flags: 0b1 };
|
||||||
|
@ -3515,22 +3520,30 @@ pub mod types {
|
||||||
PipelineStageFlags { flags: 0b10000000 };
|
PipelineStageFlags { flags: 0b10000000 };
|
||||||
pub const PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT: PipelineStageFlags =
|
pub const PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT: PipelineStageFlags =
|
||||||
PipelineStageFlags { flags: 0b100000000 };
|
PipelineStageFlags { flags: 0b100000000 };
|
||||||
pub const PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT: PipelineStageFlags =
|
pub const PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT: PipelineStageFlags = PipelineStageFlags {
|
||||||
PipelineStageFlags { flags: 0b1000000000 };
|
flags: 0b1000000000,
|
||||||
pub const PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT: PipelineStageFlags =
|
};
|
||||||
PipelineStageFlags { flags: 0b10000000000 };
|
pub const PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT: PipelineStageFlags = PipelineStageFlags {
|
||||||
pub const PIPELINE_STAGE_COMPUTE_SHADER_BIT: PipelineStageFlags =
|
flags: 0b10000000000,
|
||||||
PipelineStageFlags { flags: 0b100000000000 };
|
};
|
||||||
pub const PIPELINE_STAGE_TRANSFER_BIT: PipelineStageFlags =
|
pub const PIPELINE_STAGE_COMPUTE_SHADER_BIT: PipelineStageFlags = PipelineStageFlags {
|
||||||
PipelineStageFlags { flags: 0b1000000000000 };
|
flags: 0b100000000000,
|
||||||
pub const PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT: PipelineStageFlags =
|
};
|
||||||
PipelineStageFlags { flags: 0b10000000000000 };
|
pub const PIPELINE_STAGE_TRANSFER_BIT: PipelineStageFlags = PipelineStageFlags {
|
||||||
pub const PIPELINE_STAGE_HOST_BIT: PipelineStageFlags =
|
flags: 0b1000000000000,
|
||||||
PipelineStageFlags { flags: 0b100000000000000 };
|
};
|
||||||
pub const PIPELINE_STAGE_ALL_GRAPHICS_BIT: PipelineStageFlags =
|
pub const PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT: PipelineStageFlags = PipelineStageFlags {
|
||||||
PipelineStageFlags { flags: 0b1000000000000000 };
|
flags: 0b10000000000000,
|
||||||
pub const PIPELINE_STAGE_ALL_COMMANDS_BIT: PipelineStageFlags =
|
};
|
||||||
PipelineStageFlags { flags: 0b10000000000000000 };
|
pub const PIPELINE_STAGE_HOST_BIT: PipelineStageFlags = PipelineStageFlags {
|
||||||
|
flags: 0b100000000000000,
|
||||||
|
};
|
||||||
|
pub const PIPELINE_STAGE_ALL_GRAPHICS_BIT: PipelineStageFlags = PipelineStageFlags {
|
||||||
|
flags: 0b1000000000000000,
|
||||||
|
};
|
||||||
|
pub const PIPELINE_STAGE_ALL_COMMANDS_BIT: PipelineStageFlags = PipelineStageFlags {
|
||||||
|
flags: 0b10000000000000000,
|
||||||
|
};
|
||||||
vk_bitflags_wrapped!(PipelineStageFlags, 0b11111111111111111, Flags);
|
vk_bitflags_wrapped!(PipelineStageFlags, 0b11111111111111111, Flags);
|
||||||
|
|
||||||
pub const IMAGE_ASPECT_COLOR_BIT: ImageAspectFlags = ImageAspectFlags { flags: 0b1 };
|
pub const IMAGE_ASPECT_COLOR_BIT: ImageAspectFlags = ImageAspectFlags { flags: 0b1 };
|
||||||
|
@ -3556,18 +3569,30 @@ pub mod types {
|
||||||
|
|
||||||
pub const QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_VERTICES_BIT: QueryPipelineStatisticFlags =
|
pub const QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_VERTICES_BIT: QueryPipelineStatisticFlags =
|
||||||
QueryPipelineStatisticFlags { flags: 0b1 };
|
QueryPipelineStatisticFlags { flags: 0b1 };
|
||||||
pub const QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_PRIMITIVES_BIT: QueryPipelineStatisticFlags = QueryPipelineStatisticFlags {flags: 0b10};
|
pub const QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_PRIMITIVES_BIT: QueryPipelineStatisticFlags =
|
||||||
pub const QUERY_PIPELINE_STATISTIC_VERTEX_SHADER_INVOCATIONS_BIT: QueryPipelineStatisticFlags = QueryPipelineStatisticFlags {flags: 0b100};
|
QueryPipelineStatisticFlags { flags: 0b10 };
|
||||||
pub const QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_INVOCATIONS_BIT: QueryPipelineStatisticFlags = QueryPipelineStatisticFlags {flags: 0b1000};
|
pub const QUERY_PIPELINE_STATISTIC_VERTEX_SHADER_INVOCATIONS_BIT: QueryPipelineStatisticFlags =
|
||||||
pub const QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_PRIMITIVES_BIT: QueryPipelineStatisticFlags = QueryPipelineStatisticFlags {flags: 0b10000};
|
QueryPipelineStatisticFlags { flags: 0b100 };
|
||||||
|
pub const QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_INVOCATIONS_BIT:
|
||||||
|
QueryPipelineStatisticFlags = QueryPipelineStatisticFlags { flags: 0b1000 };
|
||||||
|
pub const QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_PRIMITIVES_BIT: QueryPipelineStatisticFlags =
|
||||||
|
QueryPipelineStatisticFlags { flags: 0b10000 };
|
||||||
pub const QUERY_PIPELINE_STATISTIC_CLIPPING_INVOCATIONS_BIT: QueryPipelineStatisticFlags =
|
pub const QUERY_PIPELINE_STATISTIC_CLIPPING_INVOCATIONS_BIT: QueryPipelineStatisticFlags =
|
||||||
QueryPipelineStatisticFlags { flags: 0b100000 };
|
QueryPipelineStatisticFlags { flags: 0b100000 };
|
||||||
pub const QUERY_PIPELINE_STATISTIC_CLIPPING_PRIMITIVES_BIT: QueryPipelineStatisticFlags =
|
pub const QUERY_PIPELINE_STATISTIC_CLIPPING_PRIMITIVES_BIT: QueryPipelineStatisticFlags =
|
||||||
QueryPipelineStatisticFlags { flags: 0b1000000 };
|
QueryPipelineStatisticFlags { flags: 0b1000000 };
|
||||||
pub const QUERY_PIPELINE_STATISTIC_FRAGMENT_SHADER_INVOCATIONS_BIT: QueryPipelineStatisticFlags = QueryPipelineStatisticFlags {flags: 0b10000000};
|
pub const QUERY_PIPELINE_STATISTIC_FRAGMENT_SHADER_INVOCATIONS_BIT:
|
||||||
pub const QUERY_PIPELINE_STATISTIC_TESSELLATION_CONTROL_SHADER_PATCHES_BIT: QueryPipelineStatisticFlags = QueryPipelineStatisticFlags {flags: 0b100000000};
|
QueryPipelineStatisticFlags = QueryPipelineStatisticFlags { flags: 0b10000000 };
|
||||||
pub const QUERY_PIPELINE_STATISTIC_TESSELLATION_EVALUATION_SHADER_INVOCATIONS_BIT: QueryPipelineStatisticFlags = QueryPipelineStatisticFlags {flags: 0b1000000000};
|
pub const QUERY_PIPELINE_STATISTIC_TESSELLATION_CONTROL_SHADER_PATCHES_BIT:
|
||||||
pub const QUERY_PIPELINE_STATISTIC_COMPUTE_SHADER_INVOCATIONS_BIT: QueryPipelineStatisticFlags = QueryPipelineStatisticFlags {flags: 0b10000000000};
|
QueryPipelineStatisticFlags = QueryPipelineStatisticFlags { flags: 0b100000000 };
|
||||||
|
pub const QUERY_PIPELINE_STATISTIC_TESSELLATION_EVALUATION_SHADER_INVOCATIONS_BIT:
|
||||||
|
QueryPipelineStatisticFlags = QueryPipelineStatisticFlags {
|
||||||
|
flags: 0b1000000000,
|
||||||
|
};
|
||||||
|
pub const QUERY_PIPELINE_STATISTIC_COMPUTE_SHADER_INVOCATIONS_BIT: QueryPipelineStatisticFlags =
|
||||||
|
QueryPipelineStatisticFlags {
|
||||||
|
flags: 0b10000000000,
|
||||||
|
};
|
||||||
vk_bitflags_wrapped!(QueryPipelineStatisticFlags, 0b11111111111, Flags);
|
vk_bitflags_wrapped!(QueryPipelineStatisticFlags, 0b11111111111, Flags);
|
||||||
|
|
||||||
pub const QUERY_RESULT_64_BIT: QueryResultFlags = QueryResultFlags { flags: 0b1 };
|
pub const QUERY_RESULT_64_BIT: QueryResultFlags = QueryResultFlags { flags: 0b1 };
|
||||||
|
@ -3620,8 +3645,9 @@ pub mod types {
|
||||||
pub const SHADER_STAGE_FRAGMENT_BIT: ShaderStageFlags = ShaderStageFlags { flags: 0b10000 };
|
pub const SHADER_STAGE_FRAGMENT_BIT: ShaderStageFlags = ShaderStageFlags { flags: 0b10000 };
|
||||||
pub const SHADER_STAGE_COMPUTE_BIT: ShaderStageFlags = ShaderStageFlags { flags: 0b100000 };
|
pub const SHADER_STAGE_COMPUTE_BIT: ShaderStageFlags = ShaderStageFlags { flags: 0b100000 };
|
||||||
pub const SHADER_STAGE_ALL_GRAPHICS: ShaderStageFlags = ShaderStageFlags { flags: 0b11111 };
|
pub const SHADER_STAGE_ALL_GRAPHICS: ShaderStageFlags = ShaderStageFlags { flags: 0b11111 };
|
||||||
pub const SHADER_STAGE_ALL: ShaderStageFlags =
|
pub const SHADER_STAGE_ALL: ShaderStageFlags = ShaderStageFlags {
|
||||||
ShaderStageFlags { flags: 0b1111111111111111111111111111111 };
|
flags: 0b1111111111111111111111111111111,
|
||||||
|
};
|
||||||
vk_bitflags_wrapped!(ShaderStageFlags, 0b1111111111111111111111111111111, Flags);
|
vk_bitflags_wrapped!(ShaderStageFlags, 0b1111111111111111111111111111111, Flags);
|
||||||
|
|
||||||
pub const CULL_MODE_NONE: CullModeFlags = CullModeFlags { flags: 0b0 };
|
pub const CULL_MODE_NONE: CullModeFlags = CullModeFlags { flags: 0b0 };
|
||||||
|
@ -3653,16 +3679,30 @@ pub mod types {
|
||||||
pub const ACCESS_SHADER_WRITE_BIT: AccessFlags = AccessFlags { flags: 0b1000000 };
|
pub const ACCESS_SHADER_WRITE_BIT: AccessFlags = AccessFlags { flags: 0b1000000 };
|
||||||
pub const ACCESS_COLOR_ATTACHMENT_READ_BIT: AccessFlags = AccessFlags { flags: 0b10000000 };
|
pub const ACCESS_COLOR_ATTACHMENT_READ_BIT: AccessFlags = AccessFlags { flags: 0b10000000 };
|
||||||
pub const ACCESS_COLOR_ATTACHMENT_WRITE_BIT: AccessFlags = AccessFlags { flags: 0b100000000 };
|
pub const ACCESS_COLOR_ATTACHMENT_WRITE_BIT: AccessFlags = AccessFlags { flags: 0b100000000 };
|
||||||
pub const ACCESS_DEPTH_STENCIL_ATTACHMENT_READ_BIT: AccessFlags =
|
pub const ACCESS_DEPTH_STENCIL_ATTACHMENT_READ_BIT: AccessFlags = AccessFlags {
|
||||||
AccessFlags { flags: 0b1000000000 };
|
flags: 0b1000000000,
|
||||||
pub const ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT: AccessFlags =
|
};
|
||||||
AccessFlags { flags: 0b10000000000 };
|
pub const ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT: AccessFlags = AccessFlags {
|
||||||
pub const ACCESS_TRANSFER_READ_BIT: AccessFlags = AccessFlags { flags: 0b100000000000 };
|
flags: 0b10000000000,
|
||||||
pub const ACCESS_TRANSFER_WRITE_BIT: AccessFlags = AccessFlags { flags: 0b1000000000000 };
|
};
|
||||||
pub const ACCESS_HOST_READ_BIT: AccessFlags = AccessFlags { flags: 0b10000000000000 };
|
pub const ACCESS_TRANSFER_READ_BIT: AccessFlags = AccessFlags {
|
||||||
pub const ACCESS_HOST_WRITE_BIT: AccessFlags = AccessFlags { flags: 0b100000000000000 };
|
flags: 0b100000000000,
|
||||||
pub const ACCESS_MEMORY_READ_BIT: AccessFlags = AccessFlags { flags: 0b1000000000000000 };
|
};
|
||||||
pub const ACCESS_MEMORY_WRITE_BIT: AccessFlags = AccessFlags { flags: 0b10000000000000000 };
|
pub const ACCESS_TRANSFER_WRITE_BIT: AccessFlags = AccessFlags {
|
||||||
|
flags: 0b1000000000000,
|
||||||
|
};
|
||||||
|
pub const ACCESS_HOST_READ_BIT: AccessFlags = AccessFlags {
|
||||||
|
flags: 0b10000000000000,
|
||||||
|
};
|
||||||
|
pub const ACCESS_HOST_WRITE_BIT: AccessFlags = AccessFlags {
|
||||||
|
flags: 0b100000000000000,
|
||||||
|
};
|
||||||
|
pub const ACCESS_MEMORY_READ_BIT: AccessFlags = AccessFlags {
|
||||||
|
flags: 0b1000000000000000,
|
||||||
|
};
|
||||||
|
pub const ACCESS_MEMORY_WRITE_BIT: AccessFlags = AccessFlags {
|
||||||
|
flags: 0b10000000000000000,
|
||||||
|
};
|
||||||
vk_bitflags_wrapped!(AccessFlags, 0b11111111111111111, Flags);
|
vk_bitflags_wrapped!(AccessFlags, 0b11111111111111111, Flags);
|
||||||
|
|
||||||
pub const DEPENDENCY_BY_REGION_BIT: DependencyFlags = DependencyFlags { flags: 0b1 };
|
pub const DEPENDENCY_BY_REGION_BIT: DependencyFlags = DependencyFlags { flags: 0b1 };
|
||||||
|
@ -3750,45 +3790,43 @@ pub mod types {
|
||||||
DebugReportFlagsEXT { flags: 0b10000 };
|
DebugReportFlagsEXT { flags: 0b10000 };
|
||||||
vk_bitflags_wrapped!(DebugReportFlagsEXT, 0b11111, Flags);
|
vk_bitflags_wrapped!(DebugReportFlagsEXT, 0b11111, Flags);
|
||||||
|
|
||||||
|
pub type PFN_vkAllocationFunction =
|
||||||
pub type PFN_vkAllocationFunction = unsafe extern "system" fn(*mut c_void,
|
unsafe extern "system" fn(*mut c_void, size_t, size_t, SystemAllocationScope)
|
||||||
size_t,
|
|
||||||
size_t,
|
|
||||||
SystemAllocationScope)
|
|
||||||
-> *mut c_void;
|
-> *mut c_void;
|
||||||
|
|
||||||
pub type PFN_vkReallocationFunction = unsafe extern "system" fn(*mut c_void,
|
pub type PFN_vkReallocationFunction =
|
||||||
*mut c_void,
|
unsafe extern "system" fn(*mut c_void, *mut c_void, size_t, size_t, SystemAllocationScope)
|
||||||
size_t,
|
|
||||||
size_t,
|
|
||||||
SystemAllocationScope)
|
|
||||||
-> *mut c_void;
|
-> *mut c_void;
|
||||||
|
|
||||||
pub type PFN_vkFreeFunction = unsafe extern "system" fn(*mut c_void, *mut c_void);
|
pub type PFN_vkFreeFunction = unsafe extern "system" fn(*mut c_void, *mut c_void);
|
||||||
|
|
||||||
pub type PFN_vkInternalAllocationNotification =
|
pub type PFN_vkInternalAllocationNotification =
|
||||||
unsafe extern "system" fn(*mut c_void,
|
unsafe extern "system" fn(
|
||||||
|
*mut c_void,
|
||||||
size_t,
|
size_t,
|
||||||
InternalAllocationType,
|
InternalAllocationType,
|
||||||
SystemAllocationScope);
|
SystemAllocationScope,
|
||||||
|
);
|
||||||
|
|
||||||
pub type PFN_vkInternalFreeNotification = unsafe extern "system" fn(*mut c_void,
|
pub type PFN_vkInternalFreeNotification = unsafe extern "system" fn(
|
||||||
|
*mut c_void,
|
||||||
size_t,
|
size_t,
|
||||||
InternalAllocationType,
|
InternalAllocationType,
|
||||||
SystemAllocationScope);
|
SystemAllocationScope,
|
||||||
|
);
|
||||||
|
|
||||||
pub type PFN_vkVoidFunction = unsafe extern "system" fn();
|
pub type PFN_vkVoidFunction = unsafe extern "system" fn();
|
||||||
|
|
||||||
pub type PFN_vkDebugReportCallbackEXT = unsafe extern "system" fn(DebugReportFlagsEXT,
|
pub type PFN_vkDebugReportCallbackEXT = unsafe extern "system" fn(
|
||||||
|
DebugReportFlagsEXT,
|
||||||
DebugReportObjectTypeEXT,
|
DebugReportObjectTypeEXT,
|
||||||
uint64_t,
|
uint64_t,
|
||||||
size_t,
|
size_t,
|
||||||
int32_t,
|
int32_t,
|
||||||
*const c_char,
|
*const c_char,
|
||||||
*const c_char,
|
*const c_char,
|
||||||
*mut c_void)
|
*mut c_void,
|
||||||
-> Bool32;
|
) -> Bool32;
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
// FIX: Need better error handling for extensions
|
// FIX: Need better error handling for extensions
|
||||||
|
|
|
@ -26,7 +26,7 @@ pub struct Vector3 {
|
||||||
pub x: f32,
|
pub x: f32,
|
||||||
pub y: f32,
|
pub y: f32,
|
||||||
pub z: f32,
|
pub z: f32,
|
||||||
pub _pad: f32
|
pub _pad: f32,
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
|
@ -70,8 +70,8 @@ fn main() {
|
||||||
dst_subpass: Default::default(),
|
dst_subpass: Default::default(),
|
||||||
src_stage_mask: vk::PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT,
|
src_stage_mask: vk::PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT,
|
||||||
src_access_mask: Default::default(),
|
src_access_mask: Default::default(),
|
||||||
dst_access_mask: vk::ACCESS_COLOR_ATTACHMENT_READ_BIT |
|
dst_access_mask: vk::ACCESS_COLOR_ATTACHMENT_READ_BIT
|
||||||
vk::ACCESS_COLOR_ATTACHMENT_WRITE_BIT,
|
| vk::ACCESS_COLOR_ATTACHMENT_WRITE_BIT,
|
||||||
dst_stage_mask: vk::PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT,
|
dst_stage_mask: vk::PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT,
|
||||||
};
|
};
|
||||||
let subpass = vk::SubpassDescription {
|
let subpass = vk::SubpassDescription {
|
||||||
|
@ -198,9 +198,8 @@ fn main() {
|
||||||
let vertex_input_buffer = base.device
|
let vertex_input_buffer = base.device
|
||||||
.create_buffer(&vertex_input_buffer_info, None)
|
.create_buffer(&vertex_input_buffer_info, None)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let vertex_input_buffer_memory_req = base.device.get_buffer_memory_requirements(
|
let vertex_input_buffer_memory_req = base.device
|
||||||
vertex_input_buffer,
|
.get_buffer_memory_requirements(vertex_input_buffer);
|
||||||
);
|
|
||||||
let vertex_input_buffer_memory_index =
|
let vertex_input_buffer_memory_index =
|
||||||
find_memorytype_index(
|
find_memorytype_index(
|
||||||
&vertex_input_buffer_memory_req,
|
&vertex_input_buffer_memory_req,
|
||||||
|
@ -240,7 +239,7 @@ fn main() {
|
||||||
x: 1.0,
|
x: 1.0,
|
||||||
y: 1.0,
|
y: 1.0,
|
||||||
z: 1.0,
|
z: 1.0,
|
||||||
_pad: 0.0
|
_pad: 0.0,
|
||||||
};
|
};
|
||||||
let uniform_color_buffer_info = vk::BufferCreateInfo {
|
let uniform_color_buffer_info = vk::BufferCreateInfo {
|
||||||
s_type: vk::StructureType::BufferCreateInfo,
|
s_type: vk::StructureType::BufferCreateInfo,
|
||||||
|
@ -255,9 +254,8 @@ fn main() {
|
||||||
let uniform_color_buffer = base.device
|
let uniform_color_buffer = base.device
|
||||||
.create_buffer(&uniform_color_buffer_info, None)
|
.create_buffer(&uniform_color_buffer_info, None)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let uniform_color_buffer_memory_req = base.device.get_buffer_memory_requirements(
|
let uniform_color_buffer_memory_req = base.device
|
||||||
uniform_color_buffer,
|
.get_buffer_memory_requirements(uniform_color_buffer);
|
||||||
);
|
|
||||||
let uniform_color_buffer_memory_index =
|
let uniform_color_buffer_memory_index =
|
||||||
find_memorytype_index(
|
find_memorytype_index(
|
||||||
&uniform_color_buffer_memory_req,
|
&uniform_color_buffer_memory_req,
|
||||||
|
@ -388,9 +386,8 @@ fn main() {
|
||||||
.bind_image_memory(texture_image, texture_memory, 0)
|
.bind_image_memory(texture_image, texture_memory, 0)
|
||||||
.expect("Unable to bind depth image memory");
|
.expect("Unable to bind depth image memory");
|
||||||
|
|
||||||
|
record_submit_commandbuffer(
|
||||||
|
&base.device,
|
||||||
record_submit_commandbuffer(&base.device,
|
|
||||||
base.setup_command_buffer,
|
base.setup_command_buffer,
|
||||||
base.present_queue,
|
base.present_queue,
|
||||||
&[vk::PIPELINE_STAGE_TOP_OF_PIPE_BIT],
|
&[vk::PIPELINE_STAGE_TOP_OF_PIPE_BIT],
|
||||||
|
@ -415,14 +412,17 @@ fn main() {
|
||||||
layer_count: 1,
|
layer_count: 1,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
device.cmd_pipeline_barrier(texture_command_buffer,
|
device.cmd_pipeline_barrier(
|
||||||
|
texture_command_buffer,
|
||||||
vk::PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT,
|
vk::PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT,
|
||||||
vk::PIPELINE_STAGE_TRANSFER_BIT,
|
vk::PIPELINE_STAGE_TRANSFER_BIT,
|
||||||
vk::DependencyFlags::empty(),
|
vk::DependencyFlags::empty(),
|
||||||
&[],
|
&[],
|
||||||
&[],
|
&[],
|
||||||
&[texture_barrier]);
|
&[texture_barrier],
|
||||||
let buffer_copy_regions = [vk::BufferImageCopy {
|
);
|
||||||
|
let buffer_copy_regions = [
|
||||||
|
vk::BufferImageCopy {
|
||||||
image_subresource: vk::ImageSubresourceLayers {
|
image_subresource: vk::ImageSubresourceLayers {
|
||||||
aspect_mask: vk::IMAGE_ASPECT_COLOR_BIT,
|
aspect_mask: vk::IMAGE_ASPECT_COLOR_BIT,
|
||||||
mip_level: 0,
|
mip_level: 0,
|
||||||
|
@ -439,12 +439,15 @@ fn main() {
|
||||||
buffer_image_height: 0,
|
buffer_image_height: 0,
|
||||||
buffer_row_length: 0,
|
buffer_row_length: 0,
|
||||||
image_offset: vk::Offset3D { x: 0, y: 0, z: 0 },
|
image_offset: vk::Offset3D { x: 0, y: 0, z: 0 },
|
||||||
}];
|
},
|
||||||
device.cmd_copy_buffer_to_image(texture_command_buffer,
|
];
|
||||||
|
device.cmd_copy_buffer_to_image(
|
||||||
|
texture_command_buffer,
|
||||||
image_buffer,
|
image_buffer,
|
||||||
texture_image,
|
texture_image,
|
||||||
vk::ImageLayout::TransferDstOptimal,
|
vk::ImageLayout::TransferDstOptimal,
|
||||||
&buffer_copy_regions);
|
&buffer_copy_regions,
|
||||||
|
);
|
||||||
let texture_barrier_end = vk::ImageMemoryBarrier {
|
let texture_barrier_end = vk::ImageMemoryBarrier {
|
||||||
s_type: vk::StructureType::ImageMemoryBarrier,
|
s_type: vk::StructureType::ImageMemoryBarrier,
|
||||||
p_next: ptr::null(),
|
p_next: ptr::null(),
|
||||||
|
@ -463,14 +466,17 @@ fn main() {
|
||||||
layer_count: 1,
|
layer_count: 1,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
device.cmd_pipeline_barrier(texture_command_buffer,
|
device.cmd_pipeline_barrier(
|
||||||
|
texture_command_buffer,
|
||||||
vk::PIPELINE_STAGE_TRANSFER_BIT,
|
vk::PIPELINE_STAGE_TRANSFER_BIT,
|
||||||
vk::PIPELINE_STAGE_FRAGMENT_SHADER_BIT,
|
vk::PIPELINE_STAGE_FRAGMENT_SHADER_BIT,
|
||||||
vk::DependencyFlags::empty(),
|
vk::DependencyFlags::empty(),
|
||||||
&[],
|
&[],
|
||||||
&[],
|
&[],
|
||||||
&[texture_barrier_end]);
|
&[texture_barrier_end],
|
||||||
});
|
);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
||||||
let sampler_info = vk::SamplerCreateInfo {
|
let sampler_info = vk::SamplerCreateInfo {
|
||||||
s_type: vk::StructureType::SamplerCreateInfo,
|
s_type: vk::StructureType::SamplerCreateInfo,
|
||||||
|
@ -564,7 +570,6 @@ fn main() {
|
||||||
p_bindings: desc_layout_bindings.as_ptr(),
|
p_bindings: desc_layout_bindings.as_ptr(),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
let desc_set_layouts = [
|
let desc_set_layouts = [
|
||||||
base.device
|
base.device
|
||||||
.create_descriptor_set_layout(&descriptor_info, None)
|
.create_descriptor_set_layout(&descriptor_info, None)
|
||||||
|
@ -856,13 +861,14 @@ fn main() {
|
||||||
|
|
||||||
let graphic_pipeline = graphics_pipelines[0];
|
let graphic_pipeline = graphics_pipelines[0];
|
||||||
|
|
||||||
|
|
||||||
base.render_loop(|| {
|
base.render_loop(|| {
|
||||||
let present_index = base.swapchain_loader
|
let present_index = base.swapchain_loader
|
||||||
.acquire_next_image_khr(base.swapchain,
|
.acquire_next_image_khr(
|
||||||
|
base.swapchain,
|
||||||
std::u64::MAX,
|
std::u64::MAX,
|
||||||
base.present_complete_semaphore,
|
base.present_complete_semaphore,
|
||||||
vk::Fence::null())
|
vk::Fence::null(),
|
||||||
|
)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let clear_values = [
|
let clear_values = [
|
||||||
vk::ClearValue {
|
vk::ClearValue {
|
||||||
|
@ -948,14 +954,10 @@ fn main() {
|
||||||
base.device.destroy_pipeline(pipeline, None);
|
base.device.destroy_pipeline(pipeline, None);
|
||||||
}
|
}
|
||||||
base.device.destroy_pipeline_layout(pipeline_layout, None);
|
base.device.destroy_pipeline_layout(pipeline_layout, None);
|
||||||
base.device.destroy_shader_module(
|
base.device
|
||||||
vertex_shader_module,
|
.destroy_shader_module(vertex_shader_module, None);
|
||||||
None,
|
base.device
|
||||||
);
|
.destroy_shader_module(fragment_shader_module, None);
|
||||||
base.device.destroy_shader_module(
|
|
||||||
fragment_shader_module,
|
|
||||||
None,
|
|
||||||
);
|
|
||||||
base.device.free_memory(image_buffer_memory, None);
|
base.device.free_memory(image_buffer_memory, None);
|
||||||
base.device.destroy_buffer(image_buffer, None);
|
base.device.destroy_buffer(image_buffer, None);
|
||||||
base.device.free_memory(texture_memory, None);
|
base.device.free_memory(texture_memory, None);
|
||||||
|
@ -968,10 +970,8 @@ fn main() {
|
||||||
base.device.free_memory(vertex_input_buffer_memory, None);
|
base.device.free_memory(vertex_input_buffer_memory, None);
|
||||||
base.device.destroy_buffer(vertex_input_buffer, None);
|
base.device.destroy_buffer(vertex_input_buffer, None);
|
||||||
for &descriptor_set_layout in desc_set_layouts.iter() {
|
for &descriptor_set_layout in desc_set_layouts.iter() {
|
||||||
base.device.destroy_descriptor_set_layout(
|
base.device
|
||||||
descriptor_set_layout,
|
.destroy_descriptor_set_layout(descriptor_set_layout, None);
|
||||||
None,
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
base.device.destroy_descriptor_pool(descriptor_pool, None);
|
base.device.destroy_descriptor_pool(descriptor_pool, None);
|
||||||
base.device.destroy_sampler(sampler, None);
|
base.device.destroy_sampler(sampler, None);
|
||||||
|
|
Loading…
Add table
Reference in a new issue