SPIRV-Cross/shaders-msl-no-opt/comp
Chip Davis 68908355a9 MSL: Expand subgroup support.
Add support for declaring a fixed subgroup size. Metal, like Vulkan with
`VK_EXT_subgroup_size_control`, allows the thread execution width to
vary depending on factors such as register usage. Unfortunately, this
breaks several tests that depend on the subgroup size being what the
device says it is. So we'll fix the subgroup size at the size the device
declares. The extra invocations in the subgroup will appear to be
inactive. Because of this, the ballot mask builtins are now ANDed with
the active subgroup mask.

Add support for emulating a subgroup of size 1. This is intended to be
used by Vulkan Portability implementations (e.g. MoltenVK) when the
hardware/software combo provides insufficient support for subgroups.
Luckily for us, Vulkan 1.1 only requires that the subgroup size be at
least 1.

Add support for quadgroup and SIMD-group functions which were added to
iOS in Metal 2.2 and 2.3. This will allow clients to take advantage of
expanded quadgroup and SIMD-group support in recent Metal versions and
on recent Apple GPUs (families 6 and 7).

Gut emulation of subgroup builtins in fragment shaders. It turns out
codegen for the SIMD-group functions in fragment wasn't implemented for
AMD on Mojave; it's a safe bet that it wasn't implemented for the other
drivers either. Subgroup support in fragment shaders now requires Metal
2.2.
2020-11-20 15:55:49 -06:00
..
array-copy-threadgroup-memory.comp MSL: Deal with array copies from and to threadgroup. 2019-08-27 13:18:01 +02:00
basic.dynamic-buffer.msl2.invalid.comp Move .invalid. test shaders to the more appropriate subfolders. 2019-11-06 10:40:37 +01:00
bitcast-16bit-1.invalid.comp Move .invalid. test shaders to the more appropriate subfolders. 2019-11-06 10:40:37 +01:00
bitcast-16bit-2.invalid.comp Move .invalid. test shaders to the more appropriate subfolders. 2019-11-06 10:40:37 +01:00
bitfield.comp Refactor out noopt shaders to their own folders. 2018-03-13 10:39:49 +01:00
glsl.std450.comp Test glsl.std450 more exhaustively. 2019-07-17 11:53:05 +02:00
illegal-struct-name.asm.comp Deal with illegal names in types as well. 2020-01-16 10:34:49 +01:00
int64.invalid.msl22.comp Move .invalid. test shaders to the more appropriate subfolders. 2019-11-06 10:40:37 +01:00
loop.comp Refactor out noopt shaders to their own folders. 2018-03-13 10:39:49 +01:00
return.comp Update tests for latest SPIRV-Tools and glslang. 2018-03-12 15:11:55 +01:00
std140-array-load-composite-construct.comp MSL: Fix regression with OpCompositeConstruct from std140 float[]. 2019-10-11 11:21:43 +02:00
struct-packing-scalar.nocompat.invalid.vk.comp Move .invalid. test shaders to the more appropriate subfolders. 2019-11-06 10:40:37 +01:00
subgroups.nocompat.invalid.vk.msl12.emulate-subgroup.comp MSL: Expand subgroup support. 2020-11-20 15:55:49 -06:00
subgroups.nocompat.invalid.vk.msl21.comp MSL: Cast broadcast booleans to ushort. 2020-10-23 21:55:46 -05:00
subgroups.nocompat.invalid.vk.msl21.fixed-subgroup.comp MSL: Expand subgroup support. 2020-11-20 15:55:49 -06:00
subgroups.nocompat.invalid.vk.msl21.ios.comp MSL: Cast broadcast booleans to ushort. 2020-10-23 21:55:46 -05:00
subgroups.nocompat.invalid.vk.msl22.ios.comp MSL: Expand subgroup support. 2020-11-20 15:55:49 -06:00
subgroups.nocompat.invalid.vk.msl23.ios.simd.comp MSL: Expand subgroup support. 2020-11-20 15:55:49 -06:00