Don't link Vulkan by default (#526)
This was found to be unreasonably disruptive to downstream CI configurations.
This commit is contained in:
parent
61d37734f8
commit
7cf3b4f09e
8 changed files with 61 additions and 40 deletions
|
@ -4,6 +4,13 @@ All notable changes to this project will be documented in this file.
|
|||
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
||||
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||
|
||||
## Unreleased
|
||||
|
||||
### Changed
|
||||
|
||||
- `loaded` feature enabled by default in place of `linked` to relax default constraints on the build environment
|
||||
- `Entry::new` renamed to `Entry::linked`
|
||||
|
||||
## [0.34.0] - 2021-12-22
|
||||
|
||||
### Added
|
||||
|
|
|
@ -22,6 +22,7 @@ raw-window-metal = "0.1"
|
|||
|
||||
[dev-dependencies]
|
||||
winit = "0.19.4"
|
||||
ash = { path = "../ash", version = "0.34", default-features = false, features = ["linked"] }
|
||||
|
||||
[[example]]
|
||||
name = "winit"
|
||||
|
|
|
@ -15,7 +15,7 @@ fn main() -> Result<(), Box<dyn Error>> {
|
|||
.build(&events_loop)?;
|
||||
|
||||
unsafe {
|
||||
let entry = ash::Entry::new();
|
||||
let entry = ash::Entry::linked();
|
||||
let surface_extensions = ash_window::enumerate_required_extensions(&window)?;
|
||||
let instance_extensions = surface_extensions
|
||||
.iter()
|
||||
|
|
|
@ -14,7 +14,7 @@ edition = "2018"
|
|||
libloading = { version = "0.7", optional = true }
|
||||
|
||||
[features]
|
||||
default = ["linked", "debug"]
|
||||
default = ["loaded", "debug"]
|
||||
# Link the Vulkan loader at compile time.
|
||||
linked = []
|
||||
# Support searching for the Vulkan loader manually at runtime.
|
||||
|
|
|
@ -29,40 +29,12 @@ pub struct Entry {
|
|||
/// Vulkan core 1.0
|
||||
#[allow(non_camel_case_types)]
|
||||
impl Entry {
|
||||
/// Load entry points from a Vulkan loader linked at compile time
|
||||
///
|
||||
/// Note that instance/device functions are still fetched via `vkGetInstanceProcAddr` and
|
||||
/// `vkGetDeviceProcAddr` for maximum performance.
|
||||
///
|
||||
/// ```no_run
|
||||
/// use ash::{vk, Entry};
|
||||
/// # fn main() -> Result<(), Box<dyn std::error::Error>> {
|
||||
/// let entry = Entry::new();
|
||||
/// let app_info = vk::ApplicationInfo {
|
||||
/// api_version: vk::make_api_version(0, 1, 0, 0),
|
||||
/// ..Default::default()
|
||||
/// };
|
||||
/// let create_info = vk::InstanceCreateInfo {
|
||||
/// p_application_info: &app_info,
|
||||
/// ..Default::default()
|
||||
/// };
|
||||
/// let instance = unsafe { entry.create_instance(&create_info, None)? };
|
||||
/// # Ok(()) }
|
||||
/// ```
|
||||
#[cfg(feature = "linked")]
|
||||
#[cfg_attr(docsrs, doc(cfg(feature = "linked")))]
|
||||
pub fn new() -> Self {
|
||||
// Sound because we're linking to Vulkan, which provides a vkGetInstanceProcAddr that has
|
||||
// defined behavior in this use.
|
||||
unsafe {
|
||||
Self::from_static_fn(vk::StaticFn {
|
||||
get_instance_proc_addr: vkGetInstanceProcAddr,
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
/// Load default Vulkan library for the current platform
|
||||
///
|
||||
/// Prefer this over [`linked`](Self::linked) when your application can gracefully handle
|
||||
/// environments that lack Vulkan support, and when the build environment might not have Vulkan
|
||||
/// development packages installed (e.g. the Vulkan SDK, or Ubuntu's `libvulkan-dev`).
|
||||
///
|
||||
/// # Safety
|
||||
/// `dlopen`ing native libraries is inherently unsafe. The safety guidelines
|
||||
/// for [`Library::new()`] and [`Library::get()`] apply here.
|
||||
|
@ -103,6 +75,43 @@ impl Entry {
|
|||
Self::load_from(LIB_PATH)
|
||||
}
|
||||
|
||||
/// Load entry points from a Vulkan loader linked at compile time
|
||||
///
|
||||
/// Compared to [`load`](Self::load), this is infallible, but requires that the build
|
||||
/// environment have Vulkan development packages installed (e.g. the Vulkan SDK, or Ubuntu's
|
||||
/// `libvulkan-dev`), and prevents the resulting binary from starting in environments that do not
|
||||
/// support Vulkan.
|
||||
///
|
||||
/// Note that instance/device functions are still fetched via `vkGetInstanceProcAddr` and
|
||||
/// `vkGetDeviceProcAddr` for maximum performance.
|
||||
///
|
||||
/// ```no_run
|
||||
/// use ash::{vk, Entry};
|
||||
/// # fn main() -> Result<(), Box<dyn std::error::Error>> {
|
||||
/// let entry = Entry::linked();
|
||||
/// let app_info = vk::ApplicationInfo {
|
||||
/// api_version: vk::make_api_version(0, 1, 0, 0),
|
||||
/// ..Default::default()
|
||||
/// };
|
||||
/// let create_info = vk::InstanceCreateInfo {
|
||||
/// p_application_info: &app_info,
|
||||
/// ..Default::default()
|
||||
/// };
|
||||
/// let instance = unsafe { entry.create_instance(&create_info, None)? };
|
||||
/// # Ok(()) }
|
||||
/// ```
|
||||
#[cfg(feature = "linked")]
|
||||
#[cfg_attr(docsrs, doc(cfg(feature = "linked")))]
|
||||
pub fn linked() -> Self {
|
||||
// Sound because we're linking to Vulkan, which provides a vkGetInstanceProcAddr that has
|
||||
// defined behavior in this use.
|
||||
unsafe {
|
||||
Self::from_static_fn(vk::StaticFn {
|
||||
get_instance_proc_addr: vkGetInstanceProcAddr,
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
/// Load Vulkan library at `path`
|
||||
///
|
||||
/// # Safety
|
||||
|
@ -162,7 +171,7 @@ impl Entry {
|
|||
/// ```no_run
|
||||
/// # use ash::{Entry, vk};
|
||||
/// # fn main() -> Result<(), Box<dyn std::error::Error>> {
|
||||
/// let entry = Entry::new();
|
||||
/// let entry = Entry::linked();
|
||||
/// match entry.try_enumerate_instance_version()? {
|
||||
/// // Vulkan 1.1+
|
||||
/// Some(version) => {
|
||||
|
@ -278,9 +287,10 @@ impl Entry {
|
|||
}
|
||||
|
||||
#[cfg(feature = "linked")]
|
||||
#[cfg_attr(docsrs, doc(cfg(feature = "linked")))]
|
||||
impl Default for Entry {
|
||||
fn default() -> Self {
|
||||
Self::new()
|
||||
Self::linked()
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -14,7 +14,7 @@
|
|||
//! ```no_run
|
||||
//! use ash::{vk, Entry};
|
||||
//! # fn main() -> Result<(), Box<dyn std::error::Error>> {
|
||||
//! let entry = Entry::new();
|
||||
//! let entry = Entry::linked();
|
||||
//! let app_info = vk::ApplicationInfo {
|
||||
//! api_version: vk::make_api_version(0, 1, 0, 0),
|
||||
//! ..Default::default()
|
||||
|
@ -29,7 +29,7 @@
|
|||
//!
|
||||
//! ## Getting started
|
||||
//!
|
||||
//! Load the Vulkan library linked at compile time using [`Entry::new()`], or load it at runtime
|
||||
//! Load the Vulkan library linked at compile time using [`Entry::linked()`], or load it at runtime
|
||||
//! using [`Entry::load()`], which uses `libloading`. If you want to perform entry point loading
|
||||
//! yourself, call [`Entry::from_static_fn()`].
|
||||
|
||||
|
|
|
@ -7,5 +7,8 @@ edition = "2018"
|
|||
[dependencies]
|
||||
winit = "0.25.0"
|
||||
image = "0.10.4"
|
||||
ash = { path = "../ash" }
|
||||
# The examples require the validation layers, which means the SDK or
|
||||
# equivalent development packages should be present, so we can link
|
||||
# directly and benefit from the infallible `Entry` constructor.
|
||||
ash = { path = "../ash", default-features = false, features = ["linked", "debug"] }
|
||||
ash-window = { path = "../ash-window" }
|
||||
|
|
|
@ -217,7 +217,7 @@ impl ExampleBase {
|
|||
))
|
||||
.build(&event_loop)
|
||||
.unwrap();
|
||||
let entry = Entry::new();
|
||||
let entry = Entry::linked();
|
||||
let app_name = CString::new("VulkanTriangle").unwrap();
|
||||
|
||||
let layer_names = [CStr::from_bytes_with_nul_unchecked(
|
||||
|
|
Loading…
Add table
Reference in a new issue