2024-11-05 21:56:26 +01:00
|
|
|
% Many of these tests fail on MoltenVK because of a bug in Metal, which causes
|
|
|
|
% SIMD operations (i.e., wave operations for Apple) to be hoisted out of the
|
|
|
|
% "if"statement, thereby changing which threads (i.e., wave groups for Apple)
|
|
|
|
% appear as active. This was reported to Apple as FB15624583.
|
|
|
|
|
2024-04-30 13:54:39 +02:00
|
|
|
[require]
|
|
|
|
shader model >= 6.0
|
2024-08-01 19:13:31 -04:00
|
|
|
format r32-uint uav-load
|
2024-04-30 13:54:39 +02:00
|
|
|
|
|
|
|
[uav 0]
|
2024-08-01 21:03:46 -04:00
|
|
|
format r32-uint
|
2024-04-30 13:54:39 +02:00
|
|
|
size (buffer, 4)
|
|
|
|
|
|
|
|
0x0 0x1 0x2 0x13
|
|
|
|
|
|
|
|
[uav 1]
|
2024-08-01 21:03:46 -04:00
|
|
|
format r32-uint
|
2024-04-30 13:54:39 +02:00
|
|
|
size (buffer, 4)
|
|
|
|
|
|
|
|
0x100 0x200 0x400 0x800
|
|
|
|
|
|
|
|
[uav 2]
|
2024-08-01 21:03:46 -04:00
|
|
|
format r32-uint
|
2024-04-30 13:54:39 +02:00
|
|
|
size (buffer, 20)
|
|
|
|
|
|
|
|
0 0 0 0 0
|
|
|
|
0 0 0 0 0
|
|
|
|
0 0 0 0 0
|
|
|
|
0 0 0 0 0
|
|
|
|
|
|
|
|
[compute shader]
|
|
|
|
RWBuffer<uint> u0 : register(u0);
|
|
|
|
RWBuffer<uint> u1 : register(u1);
|
|
|
|
RWBuffer<uint> u2 : register(u2);
|
|
|
|
|
|
|
|
[numthreads(4, 1, 1)]
|
|
|
|
void main(uint id : SV_GroupIndex)
|
|
|
|
{
|
|
|
|
const unsigned int POS_COUNT = 5;
|
|
|
|
unsigned int i, pos = 0;
|
|
|
|
/* If SPV_KHR_subgroup_uniform_control_flow is not supported,
|
|
|
|
* SPIR-V doesn't guarantee reconvergence after the loop. */
|
|
|
|
for (i = 0; i < 2; ++i)
|
|
|
|
{
|
|
|
|
u2[POS_COUNT * id + pos++] = WaveActiveSum(u1[id]) + 16 * i + 1;
|
|
|
|
if (u0[id] & (1 << i))
|
|
|
|
{
|
|
|
|
/* In many programming languages this statement could be
|
|
|
|
* moved after the loop. Not here, because the set of
|
|
|
|
* active invocations is supposed to depend on whether
|
|
|
|
* we're still in the loop (i.e., before reconverging the
|
|
|
|
* invocations that diverged during the loop) or not. */
|
|
|
|
u2[POS_COUNT * id + pos++] = WaveActiveSum(u1[id]) + 16 * i + 2;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
u2[POS_COUNT * id + pos++] = WaveActiveSum(u1[id]) + 16 * i + 3;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
u2[POS_COUNT * id + pos++] = WaveActiveSum(u1[id]) + 16 * i + 4;
|
|
|
|
}
|
|
|
|
|
|
|
|
[test]
|
2024-10-21 12:42:46 +02:00
|
|
|
dispatch 1 1 1
|
2024-04-30 13:54:39 +02:00
|
|
|
probe uav 2 (0) rui (0xf01)
|
2024-11-05 21:56:26 +01:00
|
|
|
bug(mvk) probe uav 2 (1) rui (0x503)
|
2024-04-30 13:54:39 +02:00
|
|
|
probe uav 2 (2) rui (0x511)
|
2024-11-05 21:56:26 +01:00
|
|
|
bug(mvk) probe uav 2 (3) rui (0x113)
|
2024-04-30 13:54:39 +02:00
|
|
|
probe uav 2 (4) rui (0xf24)
|
|
|
|
|
|
|
|
probe uav 2 (5) rui (0xf01)
|
2024-11-05 21:56:26 +01:00
|
|
|
bug(mvk) probe uav 2 (6) rui (0xa02)
|
2024-04-30 13:54:39 +02:00
|
|
|
probe uav 2 (7) rui (0xf04)
|
|
|
|
probe uav 2 (8) rui (0)
|
|
|
|
probe uav 2 (9) rui (0)
|
|
|
|
|
|
|
|
probe uav 2 (10) rui (0xf01)
|
2024-11-05 21:56:26 +01:00
|
|
|
bug(mvk) probe uav 2 (11) rui (0x503)
|
2024-04-30 13:54:39 +02:00
|
|
|
probe uav 2 (12) rui (0x511)
|
2024-11-05 21:56:26 +01:00
|
|
|
bug(mvk) probe uav 2 (13) rui (0x412)
|
2024-04-30 13:54:39 +02:00
|
|
|
probe uav 2 (14) rui (0xf14)
|
|
|
|
|
|
|
|
probe uav 2 (15) rui (0xf01)
|
2024-11-05 21:56:26 +01:00
|
|
|
bug(mvk) probe uav 2 (16) rui (0xa02)
|
2024-04-30 13:54:39 +02:00
|
|
|
probe uav 2 (17) rui (0xf04)
|
|
|
|
probe uav 2 (18) rui (0)
|
|
|
|
probe uav 2 (19) rui (0)
|
|
|
|
|
|
|
|
[uav 2]
|
2024-08-01 21:03:46 -04:00
|
|
|
format r32-uint
|
2024-04-30 13:54:39 +02:00
|
|
|
size (buffer, 20)
|
|
|
|
|
|
|
|
0 0 0 0 0
|
|
|
|
0 0 0 0 0
|
|
|
|
0 0 0 0 0
|
|
|
|
0 0 0 0 0
|
|
|
|
|
|
|
|
[compute shader]
|
|
|
|
RWBuffer<uint> u0 : register(u0);
|
|
|
|
RWBuffer<uint> u1 : register(u1);
|
|
|
|
RWBuffer<uint> u2 : register(u2);
|
|
|
|
|
|
|
|
[numthreads(4, 1, 1)]
|
|
|
|
void main(uint id : SV_GroupIndex)
|
|
|
|
{
|
|
|
|
const unsigned int POS_COUNT = 5;
|
|
|
|
unsigned int i, pos = 0;
|
|
|
|
/* If SPV_KHR_maximal_reconvergence is not supported, SPIR-V
|
|
|
|
* doesn't guarantee reconvergence after the loop even if
|
|
|
|
* SPV_KHR_subgroup_uniform_control_flow is supported, because the
|
|
|
|
* flow wasn't fully convergent when entering the loop. */
|
|
|
|
if (!(u0[id] & 0x10))
|
|
|
|
{
|
|
|
|
for (i = 0; i < 2; ++i)
|
|
|
|
{
|
|
|
|
u2[POS_COUNT * id + pos++] = WaveActiveSum(u1[id]) + 16 * i + 1;
|
|
|
|
if (u0[id] & (1 << i))
|
|
|
|
{
|
|
|
|
u2[POS_COUNT * id + pos++] = WaveActiveSum(u1[id]) + 16 * i + 2;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
u2[POS_COUNT * id + pos++] = WaveActiveSum(u1[id]) + 16 * i + 3;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
u2[POS_COUNT * id + pos++] = WaveActiveSum(u1[id]) + 16 * i + 4;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
[test]
|
2024-10-21 12:42:46 +02:00
|
|
|
dispatch 1 1 1
|
2024-04-30 13:54:39 +02:00
|
|
|
probe uav 2 (0) rui (0x701)
|
2024-11-05 21:56:26 +01:00
|
|
|
bug(mvk) probe uav 2 (1) rui (0x503)
|
2024-04-30 13:54:39 +02:00
|
|
|
probe uav 2 (2) rui (0x511)
|
2024-11-05 21:56:26 +01:00
|
|
|
bug(mvk) probe uav 2 (3) rui (0x113)
|
2024-04-30 13:54:39 +02:00
|
|
|
probe uav 2 (4) rui (0x724)
|
|
|
|
|
|
|
|
probe uav 2 (5) rui (0x701)
|
2024-11-05 21:56:26 +01:00
|
|
|
bug(mvk) probe uav 2 (6) rui (0x202)
|
2024-04-30 13:54:39 +02:00
|
|
|
probe uav 2 (7) rui (0x704)
|
|
|
|
probe uav 2 (8) rui (0)
|
|
|
|
probe uav 2 (9) rui (0)
|
|
|
|
|
|
|
|
probe uav 2 (10) rui (0x701)
|
2024-11-05 21:56:26 +01:00
|
|
|
bug(mvk) probe uav 2 (11) rui (0x503)
|
2024-04-30 13:54:39 +02:00
|
|
|
probe uav 2 (12) rui (0x511)
|
2024-11-05 21:56:26 +01:00
|
|
|
bug(mvk) probe uav 2 (13) rui (0x412)
|
2024-04-30 13:54:39 +02:00
|
|
|
probe uav 2 (14) rui (0x714)
|
|
|
|
|
|
|
|
probe uav 2 (15) rui (0)
|
|
|
|
probe uav 2 (16) rui (0)
|
|
|
|
probe uav 2 (17) rui (0)
|
|
|
|
probe uav 2 (18) rui (0)
|
|
|
|
probe uav 2 (19) rui (0)
|