#version 450 vec4 undeclared_errors(vec4 f4) { vec4 result; gl_SubgroupSize; // ERROR, extension not enabled (basic) gl_SubgroupInvocationID; // ERROR, extension not enabled (basic) subgroupBarrier(); // ERROR, extension not enabled (basic) subgroupMemoryBarrier(); // ERROR, extension not enabled (basic) subgroupMemoryBarrierBuffer(); // ERROR, extension not enabled (basic) subgroupMemoryBarrierImage(); // ERROR, extension not enabled (basic) subgroupElect(); // ERROR, extension not enabled (basic) gl_NumSubgroups; // ERROR, only defined in compute gl_SubgroupID; // ERROR, only defined in compute subgroupMemoryBarrierShared(); // ERROR, only defined in compute subgroupAll(true); // ERROR extension not enabled (vote) subgroupAny(false); // ERROR extension not enabled (vote) subgroupAllEqual(f4); // ERROR extension not enabled (vote) gl_SubgroupEqMask; // ERROR extension not enabled (ballot) gl_SubgroupGeMask; // ERROR extension not enabled (ballot) gl_SubgroupGtMask; // ERROR extension not enabled (ballot) gl_SubgroupLeMask; // ERROR extension not enabled (ballot) gl_SubgroupLtMask; // ERROR extension not enabled (ballot) subgroupBroadcast(f4, 0); // ERROR extension not enabled (ballot) subgroupBroadcastFirst(f4); // ERROR extension not enabled (ballot) uvec4 ballot = subgroupBallot(false); // ERROR extension not enabled (ballot) subgroupInverseBallot(uvec4(0x1)); // ERROR extension not enabled (ballot) subgroupBallotBitExtract(ballot, 0); // ERROR extension not enabled (ballot) subgroupBallotBitCount(ballot); // ERROR extension not enabled (ballot) subgroupBallotInclusiveBitCount(ballot); // ERROR extension not enabled (ballot) subgroupBallotExclusiveBitCount(ballot); // ERROR extension not enabled (ballot) subgroupBallotFindLSB(ballot); // ERROR extension not enabled (ballot) subgroupBallotFindMSB(ballot); // ERROR extension not enabled (ballot) subgroupShuffle(f4, 0); // ERROR extension not enabled (shuffle) subgroupShuffleXor(f4, 0x1); // ERROR extension not enabled (shuffle) subgroupShuffleUp(f4, 1); // ERROR extension not enabled (shuffle_relative) subgroupShuffleDown(f4, 1); // ERROR extension not enabled (shuffle_relative) result = subgroupAdd(f4); // ERROR, extension not enabled (arith) subgroupMul(f4); // ERROR, extension not enabled (arith) subgroupMin(f4); // ERROR, extension not enabled (arith) subgroupMax(f4); // ERROR, extension not enabled (arith) subgroupAnd(ballot); // ERROR, extension not enabled (arith) subgroupOr(ballot); // ERROR, extension not enabled (arith) subgroupXor(ballot); // ERROR, extension not enabled (arith) subgroupInclusiveAdd(f4); // ERROR, extension not enabled (arith) subgroupInclusiveMul(f4); // ERROR, extension not enabled (arith) subgroupInclusiveMin(f4); // ERROR, extension not enabled (arith) subgroupInclusiveMax(f4); // ERROR, extension not enabled (arith) subgroupInclusiveAnd(ballot); // ERROR, extension not enabled (arith) subgroupInclusiveOr(ballot); // ERROR, extension not enabled (arith) subgroupInclusiveXor(ballot); // ERROR, extension not enabled (arith) subgroupExclusiveAdd(f4); // ERROR, extension not enabled (arith) subgroupExclusiveMul(f4); // ERROR, extension not enabled (arith) subgroupExclusiveMin(f4); // ERROR, extension not enabled (arith) subgroupExclusiveMax(f4); // ERROR, extension not enabled (arith) subgroupExclusiveAnd(ballot); // ERROR, extension not enabled (arith) subgroupExclusiveOr(ballot); // ERROR, extension not enabled (arith) subgroupExclusiveXor(ballot); // ERROR, extension not enabled (arith) subgroupClusteredAdd(f4, 2); // ERROR, extension not enabled (clustered) subgroupClusteredMul(f4, 2); // ERROR, extension not enabled (clustered) subgroupClusteredMin(f4, 2); // ERROR, extension not enabled (clustered) subgroupClusteredMax(f4, 2); // ERROR, extension not enabled (clustered) subgroupClusteredAnd(ballot, 2); // ERROR, extension not enabled (clustered) subgroupClusteredOr(ballot, 2); // ERROR, extension not enabled (clustered) subgroupClusteredXor(ballot, 2); // ERROR, extension not enabled (clustered) subgroupQuadBroadcast(f4, 0); // ERROR, extension not enabled (quad) subgroupQuadSwapHorizontal(f4); // ERROR, extension not enabled (quad) subgroupQuadSwapVertical(f4); // ERROR, extension not enabled (quad) subgroupQuadSwapDiagonal(f4); // ERROR, extension not enabled (quad) uvec4 parti = subgroupPartitionNV(f4); // ERROR, extension not enabled (partitioned) subgroupPartitionedAddNV(f4, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedMulNV(f4, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedMinNV(f4, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedMaxNV(f4, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedAndNV(ballot, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedOrNV(ballot, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedXorNV(ballot, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedInclusiveAddNV(f4, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedInclusiveMulNV(f4, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedInclusiveMinNV(f4, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedInclusiveMaxNV(f4, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedInclusiveAndNV(ballot, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedInclusiveOrNV(ballot, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedInclusiveXorNV(ballot, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedExclusiveAddNV(f4, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedExclusiveMulNV(f4, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedExclusiveMinNV(f4, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedExclusiveMaxNV(f4, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedExclusiveAndNV(ballot, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedExclusiveOrNV(ballot, parti); // ERROR, extension not enabled (partitioned) subgroupPartitionedExclusiveXorNV(ballot, parti); // ERROR, extension not enabled (partitioned) return result; } #extension GL_KHR_shader_subgroup_basic: enable layout(location = 0) out uvec4 data; void main (void) { data = uvec4(gl_SubgroupSize, gl_SubgroupInvocationID, 0, 0); subgroupBarrier(); subgroupMemoryBarrier(); subgroupMemoryBarrierBuffer(); subgroupMemoryBarrierImage(); subgroupElect(); } #extension GL_KHR_shader_subgroup_ballot: enable void ballot_works(vec4 f4) { gl_SubgroupEqMask; gl_SubgroupGeMask; gl_SubgroupGtMask; gl_SubgroupLeMask; gl_SubgroupLtMask; subgroupBroadcast(f4, 0); subgroupBroadcastFirst(f4); uvec4 ballot = subgroupBallot(false); subgroupInverseBallot(uvec4(0x1)); subgroupBallotBitExtract(ballot, 0); subgroupBallotBitCount(ballot); subgroupBallotInclusiveBitCount(ballot); subgroupBallotExclusiveBitCount(ballot); subgroupBallotFindLSB(ballot); subgroupBallotFindMSB(ballot); } #extension GL_KHR_shader_subgroup_vote: enable void vote_works(vec4 f4) { subgroupAll(true); subgroupAny(false); subgroupAllEqual(f4); } #extension GL_KHR_shader_subgroup_shuffle: enable #extension GL_KHR_shader_subgroup_shuffle_relative: enable void shuffle_works(vec4 f4) { subgroupShuffle(f4, 0); subgroupShuffleXor(f4, 0x1); subgroupShuffleUp(f4, 1); subgroupShuffleDown(f4, 1); } #extension GL_KHR_shader_subgroup_arithmetic: enable void arith_works(vec4 f4) { uvec4 ballot; subgroupAdd(f4); subgroupMul(f4); subgroupMin(f4); subgroupMax(f4); subgroupAnd(ballot); subgroupOr(ballot); subgroupXor(ballot); subgroupInclusiveAdd(f4); subgroupInclusiveMul(f4); subgroupInclusiveMin(f4); subgroupInclusiveMax(f4); subgroupInclusiveAnd(ballot); subgroupInclusiveOr(ballot); subgroupInclusiveXor(ballot); subgroupExclusiveAdd(f4); subgroupExclusiveMul(f4); subgroupExclusiveMin(f4); subgroupExclusiveMax(f4); subgroupExclusiveAnd(ballot); subgroupExclusiveOr(ballot); subgroupExclusiveXor(ballot); } #extension GL_KHR_shader_subgroup_clustered: enable void clustered_works(vec4 f4) { uvec4 ballot = uvec4(0x55,0,0,0); subgroupClusteredAdd(f4, 2); subgroupClusteredMul(f4, 2); subgroupClusteredMin(f4, 2); subgroupClusteredMax(f4, 2); subgroupClusteredAnd(ballot, 2); subgroupClusteredOr(ballot, 2); subgroupClusteredXor(ballot, 2); } #extension GL_KHR_shader_subgroup_quad: enable void quad_works(vec4 f4) { subgroupQuadBroadcast(f4, 0); subgroupQuadSwapHorizontal(f4); subgroupQuadSwapVertical(f4); subgroupQuadSwapDiagonal(f4); } #extension GL_NV_shader_subgroup_partitioned: enable void partitioned_works(vec4 f4) { uvec4 parti = subgroupPartitionNV(f4); uvec4 ballot = uvec4(0x55,0,0,0); subgroupPartitionedAddNV(f4, parti); subgroupPartitionedMulNV(f4, parti); subgroupPartitionedMinNV(f4, parti); subgroupPartitionedMaxNV(f4, parti); subgroupPartitionedAndNV(ballot, parti); subgroupPartitionedOrNV(ballot, parti); subgroupPartitionedXorNV(ballot, parti); subgroupPartitionedInclusiveAddNV(f4, parti); subgroupPartitionedInclusiveMulNV(f4, parti); subgroupPartitionedInclusiveMinNV(f4, parti); subgroupPartitionedInclusiveMaxNV(f4, parti); subgroupPartitionedInclusiveAndNV(ballot, parti); subgroupPartitionedInclusiveOrNV(ballot, parti); subgroupPartitionedInclusiveXorNV(ballot, parti); subgroupPartitionedExclusiveAddNV(f4, parti); subgroupPartitionedExclusiveMulNV(f4, parti); subgroupPartitionedExclusiveMinNV(f4, parti); subgroupPartitionedExclusiveMaxNV(f4, parti); subgroupPartitionedExclusiveAndNV(ballot, parti); subgroupPartitionedExclusiveOrNV(ballot, parti); subgroupPartitionedExclusiveXorNV(ballot, parti); } // tests for NV_shader_sm_builtins void sm_builtins_err() { gl_WarpsPerSMNV; // ERROR, no extension gl_SMCountNV; // ERROR, no extension gl_WarpIDNV; // ERROR, no extension gl_SMIDNV; // ERROR, no extension } #ifdef GL_NV_shader_sm_builtins #extension GL_NV_shader_sm_builtins : enable #endif void sm_builtins() { gl_WarpsPerSMNV; gl_SMCountNV; gl_WarpIDNV; gl_SMIDNV; }