100 lines
2.9 KiB
GLSL
100 lines
2.9 KiB
GLSL
#pragma clang diagnostic ignored "-Wmissing-braces"
|
|
#pragma clang diagnostic ignored "-Wunused-variable"
|
|
|
|
#include <metal_stdlib>
|
|
#include <simd/simd.h>
|
|
|
|
template <typename T, size_t Num>
|
|
struct unsafe_array
|
|
{
|
|
T __Elements[Num ? Num : 1];
|
|
|
|
constexpr size_t size() const thread { return Num; }
|
|
constexpr size_t max_size() const thread { return Num; }
|
|
constexpr bool empty() const thread { return Num == 0; }
|
|
|
|
constexpr size_t size() const device { return Num; }
|
|
constexpr size_t max_size() const device { return Num; }
|
|
constexpr bool empty() const device { return Num == 0; }
|
|
|
|
constexpr size_t size() const constant { return Num; }
|
|
constexpr size_t max_size() const constant { return Num; }
|
|
constexpr bool empty() const constant { return Num == 0; }
|
|
|
|
constexpr size_t size() const threadgroup { return Num; }
|
|
constexpr size_t max_size() const threadgroup { return Num; }
|
|
constexpr bool empty() const threadgroup { return Num == 0; }
|
|
|
|
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];
|
|
}
|
|
};
|
|
|
|
using namespace metal;
|
|
|
|
struct Boo
|
|
{
|
|
float3 a;
|
|
float3 b;
|
|
};
|
|
|
|
struct main0_out
|
|
{
|
|
Boo vVertex;
|
|
};
|
|
|
|
struct main0_in
|
|
{
|
|
float3 Boo_a [[attribute(0)]];
|
|
float3 Boo_b [[attribute(1)]];
|
|
};
|
|
|
|
kernel void main0(main0_in in [[stage_in]], uint gl_InvocationID [[thread_index_in_threadgroup]], uint gl_PrimitiveID [[threadgroup_position_in_grid]], device main0_out* spvOut [[buffer(28)]], constant uint* spvIndirectParams [[buffer(29)]], device MTLQuadTessellationFactorsHalf* spvTessLevel [[buffer(26)]], threadgroup main0_in* gl_in [[threadgroup(0)]])
|
|
{
|
|
device main0_out* gl_out = &spvOut[gl_PrimitiveID * 4];
|
|
if (gl_InvocationID < spvIndirectParams[0])
|
|
gl_in[gl_InvocationID] = in;
|
|
threadgroup_barrier(mem_flags::mem_threadgroup);
|
|
if (gl_InvocationID >= 4)
|
|
return;
|
|
Boo vInput_24;
|
|
vInput_24.a = gl_in[gl_InvocationID].Boo_a;
|
|
vInput_24.b = gl_in[gl_InvocationID].Boo_b;
|
|
gl_out[gl_InvocationID].vVertex = vInput_24;
|
|
spvTessLevel[gl_PrimitiveID].edgeTessellationFactor[0] = half(1.0);
|
|
spvTessLevel[gl_PrimitiveID].edgeTessellationFactor[1] = half(2.0);
|
|
spvTessLevel[gl_PrimitiveID].edgeTessellationFactor[2] = half(3.0);
|
|
spvTessLevel[gl_PrimitiveID].edgeTessellationFactor[3] = half(4.0);
|
|
spvTessLevel[gl_PrimitiveID].insideTessellationFactor[0] = half(1.0);
|
|
spvTessLevel[gl_PrimitiveID].insideTessellationFactor[1] = half(2.0);
|
|
}
|
|
|