MSL: Fix some trivial bugs not caught by CI when adding ray query.
This commit is contained in:
parent
345a7d171c
commit
5afb3d313f
@ -0,0 +1,92 @@
|
|||||||
|
#pragma clang diagnostic ignored "-Wmissing-prototypes"
|
||||||
|
#pragma clang diagnostic ignored "-Wmissing-braces"
|
||||||
|
|
||||||
|
#include <metal_stdlib>
|
||||||
|
#include <simd/simd.h>
|
||||||
|
#if __METAL_VERSION__ >= 230
|
||||||
|
#include <metal_raytracing>
|
||||||
|
using namespace metal::raytracing;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
using namespace metal;
|
||||||
|
|
||||||
|
template<typename T, size_t Num>
|
||||||
|
struct spvUnsafeArray
|
||||||
|
{
|
||||||
|
T elements[Num ? Num : 1];
|
||||||
|
|
||||||
|
thread T& operator [] (size_t pos) thread
|
||||||
|
{
|
||||||
|
return elements[pos];
|
||||||
|
}
|
||||||
|
constexpr const thread T& operator [] (size_t pos) const thread
|
||||||
|
{
|
||||||
|
return elements[pos];
|
||||||
|
}
|
||||||
|
|
||||||
|
device T& operator [] (size_t pos) device
|
||||||
|
{
|
||||||
|
return elements[pos];
|
||||||
|
}
|
||||||
|
constexpr const device T& operator [] (size_t pos) const device
|
||||||
|
{
|
||||||
|
return elements[pos];
|
||||||
|
}
|
||||||
|
|
||||||
|
constexpr const constant T& operator [] (size_t pos) const constant
|
||||||
|
{
|
||||||
|
return elements[pos];
|
||||||
|
}
|
||||||
|
|
||||||
|
threadgroup T& operator [] (size_t pos) threadgroup
|
||||||
|
{
|
||||||
|
return elements[pos];
|
||||||
|
}
|
||||||
|
constexpr const threadgroup T& operator [] (size_t pos) const threadgroup
|
||||||
|
{
|
||||||
|
return elements[pos];
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
struct Params
|
||||||
|
{
|
||||||
|
uint ray_flags;
|
||||||
|
uint cull_mask;
|
||||||
|
char _m2_pad[8];
|
||||||
|
packed_float3 origin;
|
||||||
|
float tmin;
|
||||||
|
packed_float3 dir;
|
||||||
|
float tmax;
|
||||||
|
float thit;
|
||||||
|
};
|
||||||
|
|
||||||
|
kernel void main0(constant Params& _18 [[buffer(1)]], acceleration_structure<instancing> AS0 [[buffer(0)]], acceleration_structure<instancing> AS1 [[buffer(2)]])
|
||||||
|
{
|
||||||
|
intersection_query<instancing, triangle_data> q;
|
||||||
|
q.reset(ray(_18.origin, _18.dir, _18.tmin, _18.tmax), AS0, intersection_params());
|
||||||
|
spvUnsafeArray<intersection_query<instancing, triangle_data>, 2> q2;
|
||||||
|
q2[1].reset(ray(_18.origin, _18.dir, _18.tmin, _18.tmax), AS1, intersection_params());
|
||||||
|
bool _63 = q.next();
|
||||||
|
q2[0].abort();
|
||||||
|
q.commit_bounding_box_intersection(_18.thit);
|
||||||
|
q2[1].commit_triangle_intersection();
|
||||||
|
float _71 = q.get_ray_min_distance();
|
||||||
|
float3 _74 = q.get_world_space_ray_origin();
|
||||||
|
float3 _75 = q.get_world_space_ray_direction();
|
||||||
|
uint _80 = uint(q2[1].get_committed_intersection_type());
|
||||||
|
uint _83 = uint(q2[0].get_candidate_intersection_type()) - 1;
|
||||||
|
bool _85 = q2[1].is_candidate_non_opaque_bounding_box();
|
||||||
|
float _87 = q2[1].get_committed_distance();
|
||||||
|
float _89 = q2[1].get_candidate_triangle_distance();
|
||||||
|
int _92 = q.get_committed_user_instance_id();
|
||||||
|
int _94 = q2[0].get_candidate_instance_id();
|
||||||
|
int _96 = q2[1].get_candidate_geometry_id();
|
||||||
|
int _97 = q.get_committed_primitive_id();
|
||||||
|
float2 _100 = q2[0].get_candidate_triangle_barycentric_coord();
|
||||||
|
bool _103 = q.is_committed_triangle_front_facing();
|
||||||
|
float3 _104 = q.get_candidate_ray_direction();
|
||||||
|
float3 _106 = q2[0].get_committed_ray_origin();
|
||||||
|
float4x3 _110 = q.get_candidate_object_to_world_transform();
|
||||||
|
float4x3 _112 = q2[1].get_committed_world_to_object_transform();
|
||||||
|
}
|
||||||
|
|
@ -70,7 +70,7 @@ kernel void main0(constant Params& _18 [[buffer(1)]], acceleration_structure<ins
|
|||||||
bool res = _63;
|
bool res = _63;
|
||||||
q2[0].abort();
|
q2[0].abort();
|
||||||
q.commit_bounding_box_intersection(_18.thit);
|
q.commit_bounding_box_intersection(_18.thit);
|
||||||
_14.commit_triangle_intersection();
|
q2[1].commit_triangle_intersection();
|
||||||
float _71 = q.get_ray_min_distance();
|
float _71 = q.get_ray_min_distance();
|
||||||
float fval = _71;
|
float fval = _71;
|
||||||
float3 _74 = q.get_world_space_ray_origin();
|
float3 _74 = q.get_world_space_ray_origin();
|
||||||
|
@ -8460,7 +8460,7 @@ void CompilerMSL::emit_instruction(const Instruction &instruction)
|
|||||||
}
|
}
|
||||||
case OpRayQueryConfirmIntersectionKHR:
|
case OpRayQueryConfirmIntersectionKHR:
|
||||||
flush_variable_declaration(ops[0]);
|
flush_variable_declaration(ops[0]);
|
||||||
statement(to_expression(ops[2]), ".commit_triangle_intersection();");
|
statement(to_expression(ops[0]), ".commit_triangle_intersection();");
|
||||||
break;
|
break;
|
||||||
case OpRayQueryGenerateIntersectionKHR:
|
case OpRayQueryGenerateIntersectionKHR:
|
||||||
flush_variable_declaration(ops[0]);
|
flush_variable_declaration(ops[0]);
|
||||||
|
Loading…
Reference in New Issue
Block a user