2097c30985
Fairly minor differences, so can keep them side by side without too much effort. NV support is effectively deprecated now however. - Add OpConvertUToAccelerationStructureKHR - Ignore/Terminate ray is now a terminator in KHR, but a call in NV. - Fix some bugs with reportIntersection.
32 lines
959 B
Plaintext
32 lines
959 B
Plaintext
#version 460
|
|
#extension GL_EXT_ray_tracing : require
|
|
|
|
struct Payload
|
|
{
|
|
float a;
|
|
float b;
|
|
};
|
|
|
|
struct Block
|
|
{
|
|
float a;
|
|
float b;
|
|
Payload c;
|
|
Payload d;
|
|
};
|
|
|
|
layout(set = 0, binding = 1) uniform accelerationStructureEXT as;
|
|
layout(location = 0) rayPayloadEXT Payload payload2;
|
|
layout(location = 1) rayPayloadEXT float payload1;
|
|
layout(location = 2) rayPayloadEXT Block _71;
|
|
layout(set = 0, binding = 0, rgba8) uniform writeonly image2D image;
|
|
|
|
void main()
|
|
{
|
|
traceRayEXT(as, 0u, 255u, 0u, 1u, 0u, vec3(1.0, 0.0, 0.0), 0.0, vec3(0.0, 1.0, 0.0), 1000.0, 1);
|
|
traceRayEXT(as, 0u, 255u, 0u, 1u, 0u, vec3(1.0, 0.0, 0.0), 0.0, vec3(0.0, 1.0, 0.0), 1000.0, 0);
|
|
traceRayEXT(as, 0u, 255u, 0u, 1u, 0u, vec3(1.0, 0.0, 0.0), 0.0, vec3(0.0, 1.0, 0.0), 1000.0, 2);
|
|
imageStore(image, ivec2(gl_LaunchIDEXT.xy), (vec4(payload1) + (vec4(payload2.a) + vec4(payload2.b))) + vec4(((((_71.a + _71.b) + _71.c.a) + _71.c.b) + _71.d.a) + _71.d.b));
|
|
}
|
|
|