Skip to content

Commit

Permalink
ShaderModule::single_entry_point() (#2301)
Browse files Browse the repository at this point in the history
* added ShaderModule::single_entry_point() functions

* single_entry_point() always verifies it's the sole entry point, search optimizations

* single_entry_point() docs adjustments

* ShaderModule removed entry_point_map, instead entry points are searched linearly search though a Vec

---------

Co-authored-by: Firestar99 <4696087-firestar99@users.noreply.gitlab.com>
  • Loading branch information
Firestar99 and Firestar99 authored Aug 25, 2023
1 parent b3dbca4 commit 80023d2
Showing 1 changed file with 43 additions and 34 deletions.
77 changes: 43 additions & 34 deletions vulkano/src/shader/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,7 @@ use crate::{
use ahash::{HashMap, HashSet};
use bytemuck::bytes_of;
use half::f16;
use smallvec::SmallVec;
use spirv::ExecutionModel;
use std::{
borrow::Cow,
Expand All @@ -169,8 +170,7 @@ pub struct ShaderModule {
handle: ash::vk::ShaderModule,
device: InstanceOwnedDebugWrapper<Arc<Device>>,
id: NonZeroU64,
entry_point_map: HashMap<String, HashMap<ExecutionModel, usize>>,
entry_point_infos: Vec<EntryPointInfo>,
entry_point_infos: SmallVec<[EntryPointInfo; 1]>,
}

impl ShaderModule {
Expand Down Expand Up @@ -310,27 +310,11 @@ impl ShaderModule {
entry_points: impl IntoIterator<Item = EntryPointInfo>,
) -> Arc<ShaderModule> {
let ShaderModuleCreateInfo { code: _, _ne: _ } = create_info;

let mut entry_point_map: HashMap<String, HashMap<ExecutionModel, usize>> =
HashMap::default();
let entry_point_infos: Vec<_> = entry_points
.into_iter()
.enumerate()
.map(|(index, info)| {
entry_point_map
.entry(info.name.clone())
.or_default()
.insert(ExecutionModel::from(&info.execution), index);
info
})
.collect();

Arc::new(ShaderModule {
handle,
device: InstanceOwnedDebugWrapper(device),
id: Self::next_id(),
entry_point_map,
entry_point_infos,
entry_point_infos: entry_points.into_iter().collect(),
})
}

Expand Down Expand Up @@ -373,16 +357,7 @@ impl ShaderModule {
/// name exist.
#[inline]
pub fn entry_point(self: &Arc<Self>, name: &str) -> Option<EntryPoint> {
self.entry_point_map.get(name).and_then(|infos| {
if infos.len() == 1 {
infos.iter().next().map(|(_, &info_index)| EntryPoint {
module: self.clone(),
info_index,
})
} else {
None
}
})
self.single_entry_point_filter(|info| info.name == name)
}

/// Returns information about the entry point with the provided name and execution model.
Expand All @@ -393,13 +368,47 @@ impl ShaderModule {
name: &str,
execution: ExecutionModel,
) -> Option<EntryPoint> {
self.entry_point_map.get(name).and_then(|infos| {
infos.get(&execution).map(|&info_index| EntryPoint {
module: self.clone(),
info_index,
})
self.single_entry_point_filter(|info| {
info.name == name && ExecutionModel::from(&info.execution) == execution
})
}

/// checks for *exactly* one entry point matching the `filter`, otherwise returns `None`
#[inline]
fn single_entry_point_filter<P>(self: &Arc<Self>, mut filter: P) -> Option<EntryPoint>
where
P: FnMut(&EntryPointInfo) -> bool,
{
let mut iter = self
.entry_point_infos
.iter()
.enumerate()
.filter(|(_, infos)| filter(infos))
.map(|(x, _)| x);
let info_index = iter.next()?;
iter.next().is_none().then(|| EntryPoint {
module: self.clone(),
info_index,
})
}

/// Returns information about the entry point if `self` only contains a single entry point,
/// `None` otherwise.
#[inline]
pub fn single_entry_point(self: &Arc<Self>) -> Option<EntryPoint> {
self.single_entry_point_filter(|_| true)
}

/// Returns information about the entry point if `self` only contains a single entry point
/// with the provided `ExecutionModel`. Returns `None` if no entry point was found or multiple
/// entry points have been found matching the provided `ExecutionModel`.
#[inline]
pub fn single_entry_point_of_execution(
self: &Arc<Self>,
execution: ExecutionModel,
) -> Option<EntryPoint> {
self.single_entry_point_filter(|info| ExecutionModel::from(&info.execution) == execution)
}
}

impl Drop for ShaderModule {
Expand Down

0 comments on commit 80023d2

Please sign in to comment.