Use intradoc-links and explain the various loading methods
This commit is contained in:
parent
06b4f8ef35
commit
d6e049f340
7 changed files with 32 additions and 17 deletions
|
@ -11,9 +11,9 @@ use ash::extensions::ext; // portability extensions
|
||||||
///
|
///
|
||||||
/// # Safety
|
/// # Safety
|
||||||
///
|
///
|
||||||
/// In order for the created `SurfaceKHR` to be valid for the duration of its
|
/// In order for the created [`vk::SurfaceKHR`] to be valid for the duration of its
|
||||||
/// usage, the `Instance` this was called on must be dropped later than the
|
/// usage, the [`Instance`] this was called on must be dropped later than the
|
||||||
/// resulting `SurfaceKHR`.
|
/// resulting [`vk::SurfaceKHR`].
|
||||||
pub unsafe fn create_surface<L>(
|
pub unsafe fn create_surface<L>(
|
||||||
entry: &EntryCustom<L>,
|
entry: &EntryCustom<L>,
|
||||||
instance: &Instance,
|
instance: &Instance,
|
||||||
|
|
|
@ -489,7 +489,7 @@ impl Device {
|
||||||
.result_with_success(event)
|
.result_with_success(event)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns true if the event was set, and false if the event was reset, otherwise it will
|
/// Returns [`true`] if the event was set, and [`false`] if the event was reset, otherwise it will
|
||||||
/// return the error code.
|
/// return the error code.
|
||||||
#[doc = "<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkGetEventStatus.html>"]
|
#[doc = "<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkGetEventStatus.html>"]
|
||||||
pub unsafe fn get_event_status(&self, event: vk::Event) -> VkResult<bool> {
|
pub unsafe fn get_event_status(&self, event: vk::Event) -> VkResult<bool> {
|
||||||
|
|
|
@ -10,7 +10,12 @@ use std::os::raw::c_char;
|
||||||
use std::os::raw::c_void;
|
use std::os::raw::c_void;
|
||||||
use std::ptr;
|
use std::ptr;
|
||||||
|
|
||||||
/// Function loader
|
/// Holds a custom type `L` to load symbols from (usually a handle to a `dlopen`ed library),
|
||||||
|
/// the [`vkGetInstanceProcAddr`][vk::StaticFn::get_instance_proc_addr()] loader function from
|
||||||
|
/// this library (in [`vk::StaticFn`]), and Vulkan's "entry point" functions (resolved with `NULL`
|
||||||
|
/// `instance`) as listed in [`vkGetInstanceProcAddr`'s description].
|
||||||
|
///
|
||||||
|
/// [`vkGetInstanceProcAddr`'s description]: https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkGetInstanceProcAddr.html#_description
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct EntryCustom<L> {
|
pub struct EntryCustom<L> {
|
||||||
static_fn: vk::StaticFn,
|
static_fn: vk::StaticFn,
|
||||||
|
@ -95,9 +100,9 @@ impl<L> EntryCustom<L> {
|
||||||
#[doc = "<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkCreateInstance.html>"]
|
#[doc = "<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkCreateInstance.html>"]
|
||||||
///
|
///
|
||||||
/// # Safety
|
/// # Safety
|
||||||
/// In order for the created `Instance` to be valid for the duration of its
|
/// In order for the created [`Instance`] to be valid for the duration of its
|
||||||
/// usage, the `Entry` this was called on must be dropped later than the
|
/// usage, the [`Entry`](Self) this was called on must be dropped later than the
|
||||||
/// resulting `Instance`.
|
/// resulting [`Instance`].
|
||||||
pub unsafe fn create_instance(
|
pub unsafe fn create_instance(
|
||||||
&self,
|
&self,
|
||||||
create_info: &vk::InstanceCreateInfo,
|
create_info: &vk::InstanceCreateInfo,
|
||||||
|
@ -170,6 +175,8 @@ impl<L> EntryCustom<L> {
|
||||||
|
|
||||||
#[deprecated = "This function is unavailable and therefore panics on Vulkan 1.0, please use `try_enumerate_instance_version` instead"]
|
#[deprecated = "This function is unavailable and therefore panics on Vulkan 1.0, please use `try_enumerate_instance_version` instead"]
|
||||||
#[doc = "<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkEnumerateInstanceVersion.html>"]
|
#[doc = "<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkEnumerateInstanceVersion.html>"]
|
||||||
|
///
|
||||||
|
/// Please use [`Self::try_enumerate_instance_version`] instead.
|
||||||
pub fn enumerate_instance_version(&self) -> VkResult<u32> {
|
pub fn enumerate_instance_version(&self) -> VkResult<u32> {
|
||||||
unsafe {
|
unsafe {
|
||||||
let mut api_version = 0;
|
let mut api_version = 0;
|
||||||
|
|
|
@ -22,9 +22,6 @@ const LIB_PATH: &str = "libvulkan.so";
|
||||||
#[cfg(any(target_os = "macos", target_os = "ios"))]
|
#[cfg(any(target_os = "macos", target_os = "ios"))]
|
||||||
const LIB_PATH: &str = "libvulkan.dylib";
|
const LIB_PATH: &str = "libvulkan.dylib";
|
||||||
|
|
||||||
/// Function loader
|
|
||||||
pub type Entry = EntryCustom<Arc<Library>>;
|
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub enum LoadingError {
|
pub enum LoadingError {
|
||||||
LibraryLoadFailure(libloading::Error),
|
LibraryLoadFailure(libloading::Error),
|
||||||
|
@ -55,7 +52,10 @@ impl From<MissingEntryPoint> for LoadingError {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl EntryCustom<Arc<Library>> {
|
/// Default function loader
|
||||||
|
pub type Entry = EntryCustom<Arc<Library>>;
|
||||||
|
|
||||||
|
impl Entry {
|
||||||
/// Load default Vulkan library for the current platform
|
/// Load default Vulkan library for the current platform
|
||||||
///
|
///
|
||||||
/// # Safety
|
/// # Safety
|
||||||
|
|
|
@ -246,9 +246,9 @@ impl Instance {
|
||||||
#[doc = "<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkCreateDevice.html>"]
|
#[doc = "<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkCreateDevice.html>"]
|
||||||
///
|
///
|
||||||
/// # Safety
|
/// # Safety
|
||||||
/// In order for the created `Device` to be valid for the duration of its
|
/// In order for the created [`Device`] to be valid for the duration of its
|
||||||
/// usage, the `Instance` this was called on must be dropped later than the
|
/// usage, the [`Instance`] this was called on must be dropped later than the
|
||||||
/// resulting `Device`.
|
/// resulting [`Device`].
|
||||||
pub unsafe fn create_device(
|
pub unsafe fn create_device(
|
||||||
&self,
|
&self,
|
||||||
physical_device: vk::PhysicalDevice,
|
physical_device: vk::PhysicalDevice,
|
||||||
|
|
|
@ -25,6 +25,12 @@
|
||||||
//! # Ok(()) }
|
//! # Ok(()) }
|
||||||
//! ```
|
//! ```
|
||||||
//!
|
//!
|
||||||
|
//! ## Getting started
|
||||||
|
//! Load the Vulkan library at the default location using [`Entry::new()`][EntryCustom<_>::new()],
|
||||||
|
//! or at a custom location using [`Entry::with_library("path/to/vulkan")`][EntryCustom<_>::with_library()].
|
||||||
|
//! These loaders use [`libloading`]. If you wish to perform function loading yourself
|
||||||
|
//! call [`EntryCustom::new_custom()`] with a closure turning function names
|
||||||
|
//! into function pointers.
|
||||||
|
|
||||||
pub use crate::device::Device;
|
pub use crate::device::Device;
|
||||||
pub use crate::entry::{EntryCustom, InstanceError};
|
pub use crate::entry::{EntryCustom, InstanceError};
|
||||||
|
@ -39,10 +45,12 @@ mod entry_libloading;
|
||||||
mod instance;
|
mod instance;
|
||||||
pub mod prelude;
|
pub mod prelude;
|
||||||
pub mod util;
|
pub mod util;
|
||||||
|
/// Raw Vulkan bindings and types, generated from `vk.xml`
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
pub mod vk;
|
pub mod vk;
|
||||||
|
|
||||||
// macros of vk need to be defined beforehand
|
// macros of vk need to be defined beforehand
|
||||||
|
/// Wrappers for Vulkan extensions
|
||||||
pub mod extensions;
|
pub mod extensions;
|
||||||
|
|
||||||
pub trait RawPtr<T> {
|
pub trait RawPtr<T> {
|
||||||
|
|
|
@ -5,12 +5,12 @@ use std::mem::size_of;
|
||||||
use std::os::raw::c_void;
|
use std::os::raw::c_void;
|
||||||
use std::{io, slice};
|
use std::{io, slice};
|
||||||
|
|
||||||
/// `Align` handles dynamic alignment. The is useful for dynamic uniform buffers where
|
/// [`Align`] handles dynamic alignment. The is useful for dynamic uniform buffers where
|
||||||
/// the alignment might be different. For example a 4x4 f32 matrix has a size of 64 bytes
|
/// the alignment might be different. For example a 4x4 f32 matrix has a size of 64 bytes
|
||||||
/// but the min alignment for a dynamic uniform buffer might be 256 bytes. A slice of `&[Mat4x4<f32>]`
|
/// but the min alignment for a dynamic uniform buffer might be 256 bytes. A slice of `&[Mat4x4<f32>]`
|
||||||
/// has a memory layout of `[[64 bytes], [64 bytes], [64 bytes]]`, but it might need to have a memory
|
/// has a memory layout of `[[64 bytes], [64 bytes], [64 bytes]]`, but it might need to have a memory
|
||||||
/// layout of `[[256 bytes], [256 bytes], [256 bytes]]`.
|
/// layout of `[[256 bytes], [256 bytes], [256 bytes]]`.
|
||||||
/// `Align::copy_from_slice` will copy a slice of `&[T]` directly into the host memory without
|
/// [`Align::copy_from_slice`] will copy a slice of `&[T]` directly into the host memory without
|
||||||
/// an additional allocation and with the correct alignment.
|
/// an additional allocation and with the correct alignment.
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct Align<T> {
|
pub struct Align<T> {
|
||||||
|
|
Loading…
Add table
Reference in a new issue