Skip to content

Commit

Permalink
[msl-out] add min version check for ray tracing
Browse files Browse the repository at this point in the history
  • Loading branch information
teoxoy committed Sep 20, 2023
1 parent bd2f7e6 commit f563ae3
Show file tree
Hide file tree
Showing 4 changed files with 59 additions and 28 deletions.
2 changes: 2 additions & 0 deletions src/back/msl/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,8 @@ pub enum Error {
UnsupportedArrayOf(String),
#[error("array of type '{0:?}' is not supported")]
UnsupportedArrayOfType(Handle<crate::Type>),
#[error("ray tracing is not supported prior to MSL 2.3")]
UnsupportedRayTracing,
}

#[derive(Clone, Debug, PartialEq, thiserror::Error)]
Expand Down
81 changes: 55 additions & 26 deletions src/back/msl/writer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1947,6 +1947,10 @@ impl<W: Write> Writer<W> {
}
}
crate::Expression::RayQueryGetIntersection { query, committed } => {
if context.lang_version < (2, 3) {
return Err(Error::UnsupportedRayTracing);
}

if !committed {
unimplemented!()
}
Expand Down Expand Up @@ -2899,6 +2903,10 @@ impl<W: Write> Writer<W> {
self.write_barrier(crate::Barrier::WORK_GROUP, level)?;
}
crate::Statement::RayQuery { query, ref fun } => {
if context.expression.lang_version < (2, 3) {
return Err(Error::UnsupportedRayTracing);
}

match *fun {
crate::RayQueryFunction::Initialize {
acceleration_structure,
Expand Down Expand Up @@ -3090,33 +3098,28 @@ impl<W: Write> Writer<W> {
// Work around Metal bug where `uint` is not available by default
writeln!(self.out, "using {NAMESPACE}::uint;")?;

if module.types.iter().any(|(_, t)| match t.inner {
crate::TypeInner::RayQuery => true,
_ => false,
}) {
let tab = back::INDENT;
writeln!(self.out, "struct {RAY_QUERY_TYPE} {{")?;
let full_type = format!("{RT_NAMESPACE}::intersector<{RT_NAMESPACE}::instancing, {RT_NAMESPACE}::triangle_data, {RT_NAMESPACE}::world_space_data>");
writeln!(self.out, "{tab}{full_type} {RAY_QUERY_FIELD_INTERSECTOR};")?;
writeln!(
self.out,
"{tab}{full_type}::result_type {RAY_QUERY_FIELD_INTERSECTION};"
)?;
writeln!(self.out, "{tab}bool {RAY_QUERY_FIELD_READY} = false;")?;
writeln!(self.out, "}};")?;
writeln!(self.out, "constexpr {NAMESPACE}::uint {RAY_QUERY_FUN_MAP_INTERSECTION}(const {RT_NAMESPACE}::intersection_type ty) {{")?;
let v_triangle = back::RayIntersectionType::Triangle as u32;
let v_bbox = back::RayIntersectionType::BoundingBox as u32;
writeln!(
self.out,
"{tab}return ty=={RT_NAMESPACE}::intersection_type::triangle ? {v_triangle} : "
)?;
writeln!(
self.out,
"{tab}{tab}ty=={RT_NAMESPACE}::intersection_type::bounding_box ? {v_bbox} : 0;"
)?;
writeln!(self.out, "}}")?;
for (_, ty) in module.types.iter() {
match ty.inner {
crate::TypeInner::AccelerationStructure | crate::TypeInner::RayQuery
if options.lang_version < (2, 3) =>
{
return Err(Error::UnsupportedRayTracing);
}
crate::TypeInner::RayQuery => {
self.put_ray_query_type()?;
break;
}
_ => {}
}
}
if module.special_types.ray_desc.is_some()
|| module.special_types.ray_intersection.is_some()
{
if options.lang_version < (2, 3) {
return Err(Error::UnsupportedRayTracing);
}
}

if options
.bounds_check_policies
.contains(index::BoundsCheckPolicy::ReadZeroSkipWrite)
Expand Down Expand Up @@ -3174,6 +3177,32 @@ impl<W: Write> Writer<W> {
Ok(())
}

fn put_ray_query_type(&mut self) -> BackendResult {
let tab = back::INDENT;
writeln!(self.out, "struct {RAY_QUERY_TYPE} {{")?;
let full_type = format!("{RT_NAMESPACE}::intersector<{RT_NAMESPACE}::instancing, {RT_NAMESPACE}::triangle_data, {RT_NAMESPACE}::world_space_data>");
writeln!(self.out, "{tab}{full_type} {RAY_QUERY_FIELD_INTERSECTOR};")?;
writeln!(
self.out,
"{tab}{full_type}::result_type {RAY_QUERY_FIELD_INTERSECTION};"
)?;
writeln!(self.out, "{tab}bool {RAY_QUERY_FIELD_READY} = false;")?;
writeln!(self.out, "}};")?;
writeln!(self.out, "constexpr {NAMESPACE}::uint {RAY_QUERY_FUN_MAP_INTERSECTION}(const {RT_NAMESPACE}::intersection_type ty) {{")?;
let v_triangle = back::RayIntersectionType::Triangle as u32;
let v_bbox = back::RayIntersectionType::BoundingBox as u32;
writeln!(
self.out,
"{tab}return ty=={RT_NAMESPACE}::intersection_type::triangle ? {v_triangle} : "
)?;
writeln!(
self.out,
"{tab}{tab}ty=={RT_NAMESPACE}::intersection_type::bounding_box ? {v_bbox} : 0;"
)?;
writeln!(self.out, "}}")?;
Ok(())
}

fn write_type_defs(&mut self, module: &crate::Module) -> BackendResult {
for (handle, ty) in module.types.iter() {
if !ty.needs_alias() {
Expand Down
2 changes: 1 addition & 1 deletion tests/in/ray-query.param.ron
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
version: (1, 4),
),
msl: (
lang_version: (2, 4),
lang_version: (2, 3),
spirv_cross_compatibility: false,
fake_missing_bindings: true,
zero_initialize_workgroup_memory: false,
Expand Down
2 changes: 1 addition & 1 deletion tests/out/msl/ray-query.msl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
// language: metal2.4
// language: metal2.3
#include <metal_stdlib>
#include <simd/simd.h>

Expand Down

0 comments on commit f563ae3

Please sign in to comment.