SPIRV-Cross/reference/opt/shaders-msl/comp/packing-test-1.comp

29 lines
459 B
Plaintext

#include <metal_stdlib>
#include <simd/simd.h>
using namespace metal;
constant uint3 gl_WorkGroupSize = uint3(32u, 1u, 1u);
struct T1
{
packed_float3 a;
float b;
};
struct Buffer0
{
T1 buf0[1];
};
struct Buffer1
{
float buf1[1];
};
kernel void main0(device Buffer0& _15 [[buffer(1)]], device Buffer1& _34 [[buffer(2)]], uint3 gl_GlobalInvocationID [[thread_position_in_grid]])
{
_34.buf1[gl_GlobalInvocationID.x] = _15.buf0[0].b;
}