|
|
@@ -1,9 +1,9 @@
|
|
|
float Helper_ShuffleUp(float x, uint index, uint mask, out bool valid)
|
|
|
{
|
|
|
- uint clamp = mask & 0x1fu;
|
|
|
uint segMask = (mask >> 8) & 0x1fu;
|
|
|
uint minThreadId = gl_SubGroupInvocationARB & segMask;
|
|
|
uint srcThreadId = gl_SubGroupInvocationARB - index;
|
|
|
- valid = srcThreadId >= minThreadId;
|
|
|
- return valid ? readInvocationARB(x, srcThreadId) : x;
|
|
|
+ valid = int(srcThreadId) >= int(minThreadId);
|
|
|
+ float v = readInvocationARB(x, srcThreadId);
|
|
|
+ return valid ? v : x;
|
|
|
}
|