Updated glslang.
This commit is contained in:
parent
5177f2e0af
commit
d58fca554c
1
3rdparty/glslang/BUILD.gn
vendored
1
3rdparty/glslang/BUILD.gn
vendored
@ -167,6 +167,7 @@ source_set("glslang_sources") {
|
||||
"-Wno-sign-compare",
|
||||
"-Wno-unused-variable",
|
||||
"-Wno-missing-field-initializers",
|
||||
"-Wno-newline-eof",
|
||||
]
|
||||
}
|
||||
if (is_win && !is_clang) {
|
||||
|
59
3rdparty/glslang/CMakeLists.txt
vendored
59
3rdparty/glslang/CMakeLists.txt
vendored
@ -28,9 +28,10 @@ option(ENABLE_SPVREMAPPER "Enables building of SPVRemapper" ON)
|
||||
|
||||
option(ENABLE_GLSLANG_BINARIES "Builds glslangValidator and spirv-remap" ON)
|
||||
|
||||
option(ENABLE_GLSLANG_WEB "Reduces glslang to minumum needed for web use" OFF)
|
||||
option(ENABLE_EMSCRIPTEN_SINGLE_FILE "If using emscripten, enables SINGLE_FILE build" OFF)
|
||||
option(ENABLE_EMSCRIPTEN_ENVIRONMENT_NODE "If using emscripten, builds to run on Node instead of Web" OFF)
|
||||
option(ENABLE_GLSLANG_WEB "Reduces glslang to minimum needed for web use" OFF)
|
||||
option(ENABLE_GLSLANG_WEB_DEVEL "For ENABLE_GLSLANG_WEB builds, enables compilation error messages" OFF)
|
||||
option(ENABLE_EMSCRIPTEN_SINGLE_FILE "If using Emscripten, enables SINGLE_FILE build" OFF)
|
||||
option(ENABLE_EMSCRIPTEN_ENVIRONMENT_NODE "If using Emscripten, builds to run on Node instead of Web" OFF)
|
||||
|
||||
CMAKE_DEPENDENT_OPTION(ENABLE_HLSL "Enables HLSL input support" ON "NOT ENABLE_GLSLANG_WEB" OFF)
|
||||
|
||||
@ -70,6 +71,9 @@ endif(ENABLE_HLSL)
|
||||
|
||||
if(ENABLE_GLSLANG_WEB)
|
||||
add_definitions(-DGLSLANG_WEB)
|
||||
if(ENABLE_GLSLANG_WEB_DEVEL)
|
||||
add_definitions(-DGLSLANG_WEB_DEVEL)
|
||||
endif(ENABLE_GLSLANG_WEB_DEVEL)
|
||||
endif(ENABLE_GLSLANG_WEB)
|
||||
|
||||
if(WIN32)
|
||||
@ -98,38 +102,29 @@ elseif(${CMAKE_CXX_COMPILER_ID} MATCHES "MSVC")
|
||||
add_compile_options(/GR-) # Disable RTTI
|
||||
endif()
|
||||
|
||||
if(ENABLE_GLSLANG_WEB)
|
||||
if(EMSCRIPTEN)
|
||||
add_compile_options(-Os -fno-exceptions)
|
||||
add_compile_options("SHELL: -s WASM=1")
|
||||
add_compile_options("SHELL: -s WASM_OBJECT_FILES=0")
|
||||
add_link_options(-Os)
|
||||
add_link_options("SHELL: -s FILESYSTEM=0")
|
||||
add_link_options("SHELL: --llvm-lto 1")
|
||||
add_link_options("SHELL: --closure 1")
|
||||
add_link_options("SHELL: -s ALLOW_MEMORY_GROWTH=1")
|
||||
if(EMSCRIPTEN)
|
||||
add_compile_options(-Os -fno-exceptions)
|
||||
add_compile_options("SHELL: -s WASM=1")
|
||||
add_compile_options("SHELL: -s WASM_OBJECT_FILES=0")
|
||||
add_link_options(-Os)
|
||||
add_link_options("SHELL: -s FILESYSTEM=0")
|
||||
add_link_options("SHELL: --llvm-lto 1")
|
||||
add_link_options("SHELL: --closure 1")
|
||||
add_link_options("SHELL: -s ALLOW_MEMORY_GROWTH=1")
|
||||
|
||||
add_link_options("SHELL: -s MODULARIZE=1")
|
||||
if(ENABLE_EMSCRIPTEN_SINGLE_FILE)
|
||||
add_link_options("SHELL: -s SINGLE_FILE=1")
|
||||
endif(ENABLE_EMSCRIPTEN_SINGLE_FILE)
|
||||
|
||||
if(ENABLE_EMSCRIPTEN_ENVIRONMENT_NODE)
|
||||
add_link_options("SHELL: -s ENVIRONMENT=node")
|
||||
add_link_options("SHELL: -s BINARYEN_ASYNC_COMPILATION=0")
|
||||
if(ENABLE_EMSCRIPTEN_SINGLE_FILE)
|
||||
add_link_options("SHELL: -s SINGLE_FILE=1")
|
||||
endif(ENABLE_EMSCRIPTEN_SINGLE_FILE)
|
||||
else()
|
||||
if(ENABLE_GLSLANG_WEB)
|
||||
if(MSVC)
|
||||
add_compile_options(/Os /GR-)
|
||||
else()
|
||||
add_link_options("SHELL: -s ENVIRONMENT=web,worker")
|
||||
add_link_options("SHELL: -s EXPORT_ES6=1")
|
||||
add_compile_options(-Os -fno-exceptions)
|
||||
add_link_options(-Os)
|
||||
endif()
|
||||
else()
|
||||
if(MSVC)
|
||||
add_compile_options(/Os /GR-)
|
||||
else()
|
||||
add_compile_options(-Os -fno-exceptions)
|
||||
add_link_options(-Os)
|
||||
endif()
|
||||
endif(EMSCRIPTEN)
|
||||
endif(ENABLE_GLSLANG_WEB)
|
||||
endif(ENABLE_GLSLANG_WEB)
|
||||
endif(EMSCRIPTEN)
|
||||
|
||||
# Request C++11
|
||||
if(${CMAKE_VERSION} VERSION_LESS 3.1)
|
||||
|
32
3rdparty/glslang/README.md
vendored
32
3rdparty/glslang/README.md
vendored
@ -166,26 +166,30 @@ when executed from the glslang subdirectory of the glslang repository.
|
||||
With no arguments it builds the full grammar, and with a "web" argument,
|
||||
the web grammar subset (see more about the web subset in the next section).
|
||||
|
||||
### WASM for the the Web
|
||||
### Building to WASM for the Web and Node
|
||||
|
||||
Use the steps in [Build Steps](#build-steps), which following notes/exceptions:
|
||||
Use the steps in [Build Steps](#build-steps), with the following notes/exceptions:
|
||||
* For building the web subset of core glslang:
|
||||
+ `m4` also needs a `-DGLSLANG_WEB` argument, or simply execute `updateGrammar web` from the glslang subdirectory
|
||||
+ turn off the CMAKE options for `BUILD_TESTING`, `ENABLE_OPT`, and `INSTALL_GTEST`,
|
||||
while turning on `ENABLE_GLSLANG_WEB`
|
||||
+ execute `updateGrammar web` from the glslang subdirectory
|
||||
(or if using your own scripts, `m4` needs a `-DGLSLANG_WEB` argument)
|
||||
+ set `-DENABLE_HLSL=OFF -DBUILD_TESTING=OFF -DENABLE_OPT=OFF -DINSTALL_GTEST=OFF`
|
||||
+ turn on `-DENABLE_GLSLANG_WEB=ON`
|
||||
+ optionally, for GLSL compilation error messages, turn on `-DENABLE_GLSLANG_WEB_DEVEL=ON`
|
||||
* `emsdk` needs to be present in your executable search path, *PATH* for
|
||||
Bash-like enivironments
|
||||
+ Instructions located
|
||||
[here](https://emscripten.org/docs/getting_started/downloads.html#sdk-download-and-install)
|
||||
* Do not checkout SPIRV-Tools into `External`
|
||||
+ Does not work correctly with emscripten out of the box and we don't want it
|
||||
in the build anyway. *TBD* Have build ignore SPIRV-Tools for web build
|
||||
* Wrap call to `cmake` using `emconfigure` with ENABLE_GLSLANG_WEB=ON:
|
||||
+ e.g. For Linux, `emconfigure cmake -DCMAKE_BUILD_TYPE=Release
|
||||
-DENABLE_GLSLANG_WEB=ON -DCMAKE_INSTALL_PREFIX="$(pwd)/install" ..`
|
||||
* To get a 'true' minimized build, make sure to use `brotli` to compress the .js
|
||||
+ [Instructions located
|
||||
here](https://emscripten.org/docs/getting_started/downloads.html#sdk-download-and-install)
|
||||
* Wrap cmake call: `emcmake cmake`
|
||||
* To get a fully minimized build, make sure to use `brotli` to compress the .js
|
||||
and .wasm files
|
||||
|
||||
Example:
|
||||
|
||||
```sh
|
||||
emcmake cmake -DCMAKE_BUILD_TYPE=Release -DENABLE_GLSLANG_WEB=ON \
|
||||
-DENABLE_HLSL=OFF -DBUILD_TESTING=OFF -DENABLE_OPT=OFF -DINSTALL_GTEST=OFF ..
|
||||
```
|
||||
|
||||
Testing
|
||||
-------
|
||||
|
||||
|
2
3rdparty/glslang/SPIRV/GLSL.ext.KHR.h
vendored
2
3rdparty/glslang/SPIRV/GLSL.ext.KHR.h
vendored
@ -40,7 +40,7 @@ static const char* const E_SPV_KHR_8bit_storage = "SPV_KHR_8bit_
|
||||
static const char* const E_SPV_KHR_storage_buffer_storage_class = "SPV_KHR_storage_buffer_storage_class";
|
||||
static const char* const E_SPV_KHR_post_depth_coverage = "SPV_KHR_post_depth_coverage";
|
||||
static const char* const E_SPV_KHR_vulkan_memory_model = "SPV_KHR_vulkan_memory_model";
|
||||
static const char* const E_SPV_EXT_physical_storage_buffer = "SPV_EXT_physical_storage_buffer";
|
||||
static const char* const E_SPV_KHR_physical_storage_buffer = "SPV_KHR_physical_storage_buffer";
|
||||
static const char* const E_SPV_EXT_fragment_shader_interlock = "SPV_EXT_fragment_shader_interlock";
|
||||
static const char* const E_SPV_KHR_shader_clock = "SPV_KHR_shader_clock";
|
||||
|
||||
|
58
3rdparty/glslang/SPIRV/GlslangToSpv.cpp
vendored
58
3rdparty/glslang/SPIRV/GlslangToSpv.cpp
vendored
@ -217,11 +217,6 @@ protected:
|
||||
bool isTrivial(const glslang::TIntermTyped* node);
|
||||
spv::Id createShortCircuit(glslang::TOperator, glslang::TIntermTyped& left, glslang::TIntermTyped& right);
|
||||
spv::Id getExtBuiltins(const char* name);
|
||||
void addPre13Extension(const char* ext)
|
||||
{
|
||||
if (builder.getSpvVersion() < glslang::EShTargetSpv_1_3)
|
||||
builder.addExtension(ext);
|
||||
}
|
||||
std::pair<spv::Id, spv::Id> getForcedType(spv::BuiltIn, const glslang::TType&);
|
||||
spv::Id translateForcedType(spv::Id object);
|
||||
spv::Id createCompositeConstruct(spv::Id typeId, std::vector<spv::Id> constituents);
|
||||
@ -517,7 +512,7 @@ spv::Decoration TGlslangToSpvTraverser::TranslateNonUniformDecoration(const glsl
|
||||
{
|
||||
#ifndef GLSLANG_WEB
|
||||
if (qualifier.isNonUniform()) {
|
||||
builder.addExtension("SPV_EXT_descriptor_indexing");
|
||||
builder.addIncorporatedExtension("SPV_EXT_descriptor_indexing", spv::Spv_1_5);
|
||||
builder.addCapability(spv::CapabilityShaderNonUniformEXT);
|
||||
return spv::DecorationNonUniformEXT;
|
||||
} else
|
||||
@ -701,7 +696,7 @@ spv::BuiltIn TGlslangToSpvTraverser::TranslateBuiltInDecoration(glslang::TBuiltI
|
||||
glslangIntermediate->getStage() == EShLangTessControl ||
|
||||
glslangIntermediate->getStage() == EShLangTessEvaluation) {
|
||||
|
||||
builder.addExtension(spv::E_SPV_EXT_shader_viewport_index_layer);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_EXT_shader_viewport_index_layer, spv::Spv_1_5);
|
||||
builder.addCapability(spv::CapabilityShaderViewportIndexLayerEXT);
|
||||
}
|
||||
return spv::BuiltInViewportIndex;
|
||||
@ -726,23 +721,23 @@ spv::BuiltIn TGlslangToSpvTraverser::TranslateBuiltInDecoration(glslang::TBuiltI
|
||||
glslangIntermediate->getStage() == EShLangTessControl ||
|
||||
glslangIntermediate->getStage() == EShLangTessEvaluation) {
|
||||
|
||||
builder.addExtension(spv::E_SPV_EXT_shader_viewport_index_layer);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_EXT_shader_viewport_index_layer, spv::Spv_1_5);
|
||||
builder.addCapability(spv::CapabilityShaderViewportIndexLayerEXT);
|
||||
}
|
||||
return spv::BuiltInLayer;
|
||||
|
||||
case glslang::EbvBaseVertex:
|
||||
addPre13Extension(spv::E_SPV_KHR_shader_draw_parameters);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_shader_draw_parameters, spv::Spv_1_3);
|
||||
builder.addCapability(spv::CapabilityDrawParameters);
|
||||
return spv::BuiltInBaseVertex;
|
||||
|
||||
case glslang::EbvBaseInstance:
|
||||
addPre13Extension(spv::E_SPV_KHR_shader_draw_parameters);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_shader_draw_parameters, spv::Spv_1_3);
|
||||
builder.addCapability(spv::CapabilityDrawParameters);
|
||||
return spv::BuiltInBaseInstance;
|
||||
|
||||
case glslang::EbvDrawId:
|
||||
addPre13Extension(spv::E_SPV_KHR_shader_draw_parameters);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_shader_draw_parameters, spv::Spv_1_3);
|
||||
builder.addCapability(spv::CapabilityDrawParameters);
|
||||
return spv::BuiltInDrawIndex;
|
||||
|
||||
@ -874,12 +869,12 @@ spv::BuiltIn TGlslangToSpvTraverser::TranslateBuiltInDecoration(glslang::TBuiltI
|
||||
return spv::BuiltInBaryCoordPullModelAMD;
|
||||
|
||||
case glslang::EbvDeviceIndex:
|
||||
addPre13Extension(spv::E_SPV_KHR_device_group);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_device_group, spv::Spv_1_3);
|
||||
builder.addCapability(spv::CapabilityDeviceGroup);
|
||||
return spv::BuiltInDeviceIndex;
|
||||
|
||||
case glslang::EbvViewIndex:
|
||||
addPre13Extension(spv::E_SPV_KHR_multiview);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_multiview, spv::Spv_1_3);
|
||||
builder.addCapability(spv::CapabilityMultiView);
|
||||
return spv::BuiltInViewIndex;
|
||||
|
||||
@ -1192,7 +1187,7 @@ spv::StorageClass TGlslangToSpvTraverser::TranslateStorageClass(const glslang::T
|
||||
}
|
||||
|
||||
if (glslangIntermediate->usingStorageBuffer() && type.getQualifier().storage == glslang::EvqBuffer) {
|
||||
addPre13Extension(spv::E_SPV_KHR_storage_buffer_storage_class);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_storage_buffer_storage_class, spv::Spv_1_3);
|
||||
return spv::StorageClassStorageBuffer;
|
||||
}
|
||||
|
||||
@ -1253,13 +1248,13 @@ void TGlslangToSpvTraverser::addIndirectionIndexCapabilities(const glslang::TTyp
|
||||
// assume a dynamically uniform index
|
||||
if (baseType.getBasicType() == glslang::EbtSampler) {
|
||||
if (baseType.getQualifier().hasAttachment()) {
|
||||
builder.addExtension("SPV_EXT_descriptor_indexing");
|
||||
builder.addIncorporatedExtension("SPV_EXT_descriptor_indexing", spv::Spv_1_5);
|
||||
builder.addCapability(spv::CapabilityInputAttachmentArrayDynamicIndexingEXT);
|
||||
} else if (baseType.isImage() && baseType.getSampler().isBuffer()) {
|
||||
builder.addExtension("SPV_EXT_descriptor_indexing");
|
||||
builder.addIncorporatedExtension("SPV_EXT_descriptor_indexing", spv::Spv_1_5);
|
||||
builder.addCapability(spv::CapabilityStorageTexelBufferArrayDynamicIndexingEXT);
|
||||
} else if (baseType.isTexture() && baseType.getSampler().isBuffer()) {
|
||||
builder.addExtension("SPV_EXT_descriptor_indexing");
|
||||
builder.addIncorporatedExtension("SPV_EXT_descriptor_indexing", spv::Spv_1_5);
|
||||
builder.addCapability(spv::CapabilityUniformTexelBufferArrayDynamicIndexingEXT);
|
||||
}
|
||||
}
|
||||
@ -1404,13 +1399,13 @@ TGlslangToSpvTraverser::TGlslangToSpvTraverser(unsigned int spvVersion, const gl
|
||||
|
||||
if (glslangIntermediate->usingPhysicalStorageBuffer()) {
|
||||
addressingModel = spv::AddressingModelPhysicalStorageBuffer64EXT;
|
||||
builder.addExtension(spv::E_SPV_EXT_physical_storage_buffer);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_physical_storage_buffer, spv::Spv_1_5);
|
||||
builder.addCapability(spv::CapabilityPhysicalStorageBufferAddressesEXT);
|
||||
};
|
||||
if (glslangIntermediate->usingVulkanMemoryModel()) {
|
||||
memoryModel = spv::MemoryModelVulkanKHR;
|
||||
builder.addCapability(spv::CapabilityVulkanMemoryModelKHR);
|
||||
builder.addExtension(spv::E_SPV_KHR_vulkan_memory_model);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_vulkan_memory_model, spv::Spv_1_5);
|
||||
}
|
||||
builder.setMemoryModel(addressingModel, memoryModel);
|
||||
|
||||
@ -3242,11 +3237,11 @@ spv::Id TGlslangToSpvTraverser::createSpvVariable(const glslang::TIntermSymbol*
|
||||
switch (storageClass) {
|
||||
case spv::StorageClassInput:
|
||||
case spv::StorageClassOutput:
|
||||
addPre13Extension(spv::E_SPV_KHR_16bit_storage);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_16bit_storage, spv::Spv_1_3);
|
||||
builder.addCapability(spv::CapabilityStorageInputOutput16);
|
||||
break;
|
||||
case spv::StorageClassUniform:
|
||||
addPre13Extension(spv::E_SPV_KHR_16bit_storage);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_16bit_storage, spv::Spv_1_3);
|
||||
if (node->getType().getQualifier().storage == glslang::EvqBuffer)
|
||||
builder.addCapability(spv::CapabilityStorageUniformBufferBlock16);
|
||||
else
|
||||
@ -3254,12 +3249,12 @@ spv::Id TGlslangToSpvTraverser::createSpvVariable(const glslang::TIntermSymbol*
|
||||
break;
|
||||
#ifndef GLSLANG_WEB
|
||||
case spv::StorageClassPushConstant:
|
||||
addPre13Extension(spv::E_SPV_KHR_16bit_storage);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_16bit_storage, spv::Spv_1_3);
|
||||
builder.addCapability(spv::CapabilityStoragePushConstant16);
|
||||
break;
|
||||
case spv::StorageClassStorageBuffer:
|
||||
case spv::StorageClassPhysicalStorageBufferEXT:
|
||||
addPre13Extension(spv::E_SPV_KHR_16bit_storage);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_16bit_storage, spv::Spv_1_3);
|
||||
builder.addCapability(spv::CapabilityStorageUniformBufferBlock16);
|
||||
break;
|
||||
#endif
|
||||
@ -3274,13 +3269,13 @@ spv::Id TGlslangToSpvTraverser::createSpvVariable(const glslang::TIntermSymbol*
|
||||
|
||||
if (node->getType().contains8BitInt()) {
|
||||
if (storageClass == spv::StorageClassPushConstant) {
|
||||
builder.addExtension(spv::E_SPV_KHR_8bit_storage);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_8bit_storage, spv::Spv_1_5);
|
||||
builder.addCapability(spv::CapabilityStoragePushConstant8);
|
||||
} else if (storageClass == spv::StorageClassUniform) {
|
||||
builder.addExtension(spv::E_SPV_KHR_8bit_storage);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_8bit_storage, spv::Spv_1_5);
|
||||
builder.addCapability(spv::CapabilityUniformAndStorageBuffer8BitAccess);
|
||||
} else if (storageClass == spv::StorageClassStorageBuffer) {
|
||||
builder.addExtension(spv::E_SPV_KHR_8bit_storage);
|
||||
builder.addIncorporatedExtension(spv::E_SPV_KHR_8bit_storage, spv::Spv_1_5);
|
||||
builder.addCapability(spv::CapabilityStorageBuffer8BitAccess);
|
||||
} else {
|
||||
builder.addCapability(spv::CapabilityInt8);
|
||||
@ -3537,7 +3532,7 @@ spv::Id TGlslangToSpvTraverser::convertGlslangToSpvType(const glslang::TType& ty
|
||||
else {
|
||||
#ifndef GLSLANG_WEB
|
||||
if (!lastBufferBlockMember) {
|
||||
builder.addExtension("SPV_EXT_descriptor_indexing");
|
||||
builder.addIncorporatedExtension("SPV_EXT_descriptor_indexing", spv::Spv_1_5);
|
||||
builder.addCapability(spv::CapabilityRuntimeDescriptorArrayEXT);
|
||||
}
|
||||
spvType = builder.makeRuntimeArray(spvType);
|
||||
@ -6278,6 +6273,10 @@ spv::Id TGlslangToSpvTraverser::createConversion(glslang::TOperator op, OpDecora
|
||||
case glslang::EOpConvPtrToUint64:
|
||||
convOp = spv::OpConvertPtrToU;
|
||||
break;
|
||||
case glslang::EOpConvPtrToUvec2:
|
||||
case glslang::EOpConvUvec2ToPtr:
|
||||
convOp = spv::OpBitcast;
|
||||
break;
|
||||
#endif
|
||||
|
||||
default:
|
||||
@ -6837,8 +6836,9 @@ spv::Id TGlslangToSpvTraverser::createSubgroupOperation(glslang::TOperator op, s
|
||||
default: assert(0 && "Unhandled subgroup operation!");
|
||||
}
|
||||
|
||||
const bool isUnsigned = typeProxy == glslang::EbtUint || typeProxy == glslang::EbtUint64;
|
||||
const bool isFloat = typeProxy == glslang::EbtFloat || typeProxy == glslang::EbtDouble;
|
||||
|
||||
const bool isUnsigned = isTypeUnsignedInt(typeProxy);
|
||||
const bool isFloat = isTypeFloat(typeProxy);
|
||||
const bool isBool = typeProxy == glslang::EbtBool;
|
||||
|
||||
spv::Op opCode = spv::OpNop;
|
||||
|
6
3rdparty/glslang/SPIRV/SpvBuilder.h
vendored
6
3rdparty/glslang/SPIRV/SpvBuilder.h
vendored
@ -67,6 +67,7 @@ typedef enum {
|
||||
Spv_1_2 = (1 << 16) | (2 << 8),
|
||||
Spv_1_3 = (1 << 16) | (3 << 8),
|
||||
Spv_1_4 = (1 << 16) | (4 << 8),
|
||||
Spv_1_5 = (1 << 16) | (5 << 8),
|
||||
} SpvVersion;
|
||||
|
||||
class Builder {
|
||||
@ -105,6 +106,11 @@ public:
|
||||
void addModuleProcessed(const std::string& p) { moduleProcesses.push_back(p.c_str()); }
|
||||
void setEmitOpLines() { emitOpLines = true; }
|
||||
void addExtension(const char* ext) { extensions.insert(ext); }
|
||||
void addIncorporatedExtension(const char* ext, SpvVersion incorporatedVersion)
|
||||
{
|
||||
if (getSpvVersion() < static_cast<unsigned>(incorporatedVersion))
|
||||
addExtension(ext);
|
||||
}
|
||||
void addInclude(const std::string& name, const std::string& text)
|
||||
{
|
||||
spv::Id incId = getStringId(name);
|
||||
|
4
3rdparty/glslang/SPIRV/SpvPostProcess.cpp
vendored
4
3rdparty/glslang/SPIRV/SpvPostProcess.cpp
vendored
@ -363,12 +363,12 @@ void Builder::postProcess()
|
||||
Instruction* type = groupedTypes[OpTypePointer][t];
|
||||
if (type->getImmediateOperand(0) == (unsigned)StorageClassPhysicalStorageBufferEXT) {
|
||||
if (containsType(type->getIdOperand(1), OpTypeInt, 8)) {
|
||||
addExtension(spv::E_SPV_KHR_8bit_storage);
|
||||
addIncorporatedExtension(spv::E_SPV_KHR_8bit_storage, spv::Spv_1_5);
|
||||
addCapability(spv::CapabilityStorageBuffer8BitAccess);
|
||||
}
|
||||
if (containsType(type->getIdOperand(1), OpTypeInt, 16) ||
|
||||
containsType(type->getIdOperand(1), OpTypeFloat, 16)) {
|
||||
addExtension(spv::E_SPV_KHR_16bit_storage);
|
||||
addIncorporatedExtension(spv::E_SPV_KHR_16bit_storage, spv::Spv_1_3);
|
||||
addCapability(spv::CapabilityStorageBuffer16BitAccess);
|
||||
}
|
||||
}
|
||||
|
44
3rdparty/glslang/SPIRV/spirv.hpp
vendored
44
3rdparty/glslang/SPIRV/spirv.hpp
vendored
@ -91,6 +91,7 @@ enum AddressingModel {
|
||||
AddressingModelLogical = 0,
|
||||
AddressingModelPhysical32 = 1,
|
||||
AddressingModelPhysical64 = 2,
|
||||
AddressingModelPhysicalStorageBuffer64 = 5348,
|
||||
AddressingModelPhysicalStorageBuffer64EXT = 5348,
|
||||
AddressingModelMax = 0x7fffffff,
|
||||
};
|
||||
@ -99,6 +100,7 @@ enum MemoryModel {
|
||||
MemoryModelSimple = 0,
|
||||
MemoryModelGLSL450 = 1,
|
||||
MemoryModelOpenCL = 2,
|
||||
MemoryModelVulkan = 3,
|
||||
MemoryModelVulkanKHR = 3,
|
||||
MemoryModelMax = 0x7fffffff,
|
||||
};
|
||||
@ -183,6 +185,7 @@ enum StorageClass {
|
||||
StorageClassHitAttributeNV = 5339,
|
||||
StorageClassIncomingRayPayloadNV = 5342,
|
||||
StorageClassShaderRecordBufferNV = 5343,
|
||||
StorageClassPhysicalStorageBuffer = 5349,
|
||||
StorageClassPhysicalStorageBufferEXT = 5349,
|
||||
StorageClassMax = 0x7fffffff,
|
||||
};
|
||||
@ -311,9 +314,13 @@ enum ImageOperandsShift {
|
||||
ImageOperandsConstOffsetsShift = 5,
|
||||
ImageOperandsSampleShift = 6,
|
||||
ImageOperandsMinLodShift = 7,
|
||||
ImageOperandsMakeTexelAvailableShift = 8,
|
||||
ImageOperandsMakeTexelAvailableKHRShift = 8,
|
||||
ImageOperandsMakeTexelVisibleShift = 9,
|
||||
ImageOperandsMakeTexelVisibleKHRShift = 9,
|
||||
ImageOperandsNonPrivateTexelShift = 10,
|
||||
ImageOperandsNonPrivateTexelKHRShift = 10,
|
||||
ImageOperandsVolatileTexelShift = 11,
|
||||
ImageOperandsVolatileTexelKHRShift = 11,
|
||||
ImageOperandsSignExtendShift = 12,
|
||||
ImageOperandsZeroExtendShift = 13,
|
||||
@ -330,9 +337,13 @@ enum ImageOperandsMask {
|
||||
ImageOperandsConstOffsetsMask = 0x00000020,
|
||||
ImageOperandsSampleMask = 0x00000040,
|
||||
ImageOperandsMinLodMask = 0x00000080,
|
||||
ImageOperandsMakeTexelAvailableMask = 0x00000100,
|
||||
ImageOperandsMakeTexelAvailableKHRMask = 0x00000100,
|
||||
ImageOperandsMakeTexelVisibleMask = 0x00000200,
|
||||
ImageOperandsMakeTexelVisibleKHRMask = 0x00000200,
|
||||
ImageOperandsNonPrivateTexelMask = 0x00000400,
|
||||
ImageOperandsNonPrivateTexelKHRMask = 0x00000400,
|
||||
ImageOperandsVolatileTexelMask = 0x00000800,
|
||||
ImageOperandsVolatileTexelKHRMask = 0x00000800,
|
||||
ImageOperandsSignExtendMask = 0x00001000,
|
||||
ImageOperandsZeroExtendMask = 0x00002000,
|
||||
@ -448,8 +459,11 @@ enum Decoration {
|
||||
DecorationPerViewNV = 5272,
|
||||
DecorationPerTaskNV = 5273,
|
||||
DecorationPerVertexNV = 5285,
|
||||
DecorationNonUniform = 5300,
|
||||
DecorationNonUniformEXT = 5300,
|
||||
DecorationRestrictPointer = 5355,
|
||||
DecorationRestrictPointerEXT = 5355,
|
||||
DecorationAliasedPointer = 5356,
|
||||
DecorationAliasedPointerEXT = 5356,
|
||||
DecorationCounterBuffer = 5634,
|
||||
DecorationHlslCounterBufferGOOGLE = 5634,
|
||||
@ -630,8 +644,11 @@ enum MemorySemanticsShift {
|
||||
MemorySemanticsCrossWorkgroupMemoryShift = 9,
|
||||
MemorySemanticsAtomicCounterMemoryShift = 10,
|
||||
MemorySemanticsImageMemoryShift = 11,
|
||||
MemorySemanticsOutputMemoryShift = 12,
|
||||
MemorySemanticsOutputMemoryKHRShift = 12,
|
||||
MemorySemanticsMakeAvailableShift = 13,
|
||||
MemorySemanticsMakeAvailableKHRShift = 13,
|
||||
MemorySemanticsMakeVisibleShift = 14,
|
||||
MemorySemanticsMakeVisibleKHRShift = 14,
|
||||
MemorySemanticsVolatileShift = 15,
|
||||
MemorySemanticsMax = 0x7fffffff,
|
||||
@ -649,8 +666,11 @@ enum MemorySemanticsMask {
|
||||
MemorySemanticsCrossWorkgroupMemoryMask = 0x00000200,
|
||||
MemorySemanticsAtomicCounterMemoryMask = 0x00000400,
|
||||
MemorySemanticsImageMemoryMask = 0x00000800,
|
||||
MemorySemanticsOutputMemoryMask = 0x00001000,
|
||||
MemorySemanticsOutputMemoryKHRMask = 0x00001000,
|
||||
MemorySemanticsMakeAvailableMask = 0x00002000,
|
||||
MemorySemanticsMakeAvailableKHRMask = 0x00002000,
|
||||
MemorySemanticsMakeVisibleMask = 0x00004000,
|
||||
MemorySemanticsMakeVisibleKHRMask = 0x00004000,
|
||||
MemorySemanticsVolatileMask = 0x00008000,
|
||||
};
|
||||
@ -659,8 +679,11 @@ enum MemoryAccessShift {
|
||||
MemoryAccessVolatileShift = 0,
|
||||
MemoryAccessAlignedShift = 1,
|
||||
MemoryAccessNontemporalShift = 2,
|
||||
MemoryAccessMakePointerAvailableShift = 3,
|
||||
MemoryAccessMakePointerAvailableKHRShift = 3,
|
||||
MemoryAccessMakePointerVisibleShift = 4,
|
||||
MemoryAccessMakePointerVisibleKHRShift = 4,
|
||||
MemoryAccessNonPrivatePointerShift = 5,
|
||||
MemoryAccessNonPrivatePointerKHRShift = 5,
|
||||
MemoryAccessMax = 0x7fffffff,
|
||||
};
|
||||
@ -670,8 +693,11 @@ enum MemoryAccessMask {
|
||||
MemoryAccessVolatileMask = 0x00000001,
|
||||
MemoryAccessAlignedMask = 0x00000002,
|
||||
MemoryAccessNontemporalMask = 0x00000004,
|
||||
MemoryAccessMakePointerAvailableMask = 0x00000008,
|
||||
MemoryAccessMakePointerAvailableKHRMask = 0x00000008,
|
||||
MemoryAccessMakePointerVisibleMask = 0x00000010,
|
||||
MemoryAccessMakePointerVisibleKHRMask = 0x00000010,
|
||||
MemoryAccessNonPrivatePointerMask = 0x00000020,
|
||||
MemoryAccessNonPrivatePointerKHRMask = 0x00000020,
|
||||
};
|
||||
|
||||
@ -681,6 +707,7 @@ enum Scope {
|
||||
ScopeWorkgroup = 2,
|
||||
ScopeSubgroup = 3,
|
||||
ScopeInvocation = 4,
|
||||
ScopeQueueFamily = 5,
|
||||
ScopeQueueFamilyKHR = 5,
|
||||
ScopeMax = 0x7fffffff,
|
||||
};
|
||||
@ -781,6 +808,8 @@ enum Capability {
|
||||
CapabilityGroupNonUniformShuffleRelative = 66,
|
||||
CapabilityGroupNonUniformClustered = 67,
|
||||
CapabilityGroupNonUniformQuad = 68,
|
||||
CapabilityShaderLayer = 69,
|
||||
CapabilityShaderViewportIndex = 70,
|
||||
CapabilitySubgroupBallotKHR = 4423,
|
||||
CapabilityDrawParameters = 4427,
|
||||
CapabilitySubgroupVoteKHR = 4431,
|
||||
@ -825,21 +854,36 @@ enum Capability {
|
||||
CapabilityFragmentDensityEXT = 5291,
|
||||
CapabilityShadingRateNV = 5291,
|
||||
CapabilityGroupNonUniformPartitionedNV = 5297,
|
||||
CapabilityShaderNonUniform = 5301,
|
||||
CapabilityShaderNonUniformEXT = 5301,
|
||||
CapabilityRuntimeDescriptorArray = 5302,
|
||||
CapabilityRuntimeDescriptorArrayEXT = 5302,
|
||||
CapabilityInputAttachmentArrayDynamicIndexing = 5303,
|
||||
CapabilityInputAttachmentArrayDynamicIndexingEXT = 5303,
|
||||
CapabilityUniformTexelBufferArrayDynamicIndexing = 5304,
|
||||
CapabilityUniformTexelBufferArrayDynamicIndexingEXT = 5304,
|
||||
CapabilityStorageTexelBufferArrayDynamicIndexing = 5305,
|
||||
CapabilityStorageTexelBufferArrayDynamicIndexingEXT = 5305,
|
||||
CapabilityUniformBufferArrayNonUniformIndexing = 5306,
|
||||
CapabilityUniformBufferArrayNonUniformIndexingEXT = 5306,
|
||||
CapabilitySampledImageArrayNonUniformIndexing = 5307,
|
||||
CapabilitySampledImageArrayNonUniformIndexingEXT = 5307,
|
||||
CapabilityStorageBufferArrayNonUniformIndexing = 5308,
|
||||
CapabilityStorageBufferArrayNonUniformIndexingEXT = 5308,
|
||||
CapabilityStorageImageArrayNonUniformIndexing = 5309,
|
||||
CapabilityStorageImageArrayNonUniformIndexingEXT = 5309,
|
||||
CapabilityInputAttachmentArrayNonUniformIndexing = 5310,
|
||||
CapabilityInputAttachmentArrayNonUniformIndexingEXT = 5310,
|
||||
CapabilityUniformTexelBufferArrayNonUniformIndexing = 5311,
|
||||
CapabilityUniformTexelBufferArrayNonUniformIndexingEXT = 5311,
|
||||
CapabilityStorageTexelBufferArrayNonUniformIndexing = 5312,
|
||||
CapabilityStorageTexelBufferArrayNonUniformIndexingEXT = 5312,
|
||||
CapabilityRayTracingNV = 5340,
|
||||
CapabilityVulkanMemoryModel = 5345,
|
||||
CapabilityVulkanMemoryModelKHR = 5345,
|
||||
CapabilityVulkanMemoryModelDeviceScope = 5346,
|
||||
CapabilityVulkanMemoryModelDeviceScopeKHR = 5346,
|
||||
CapabilityPhysicalStorageBufferAddresses = 5347,
|
||||
CapabilityPhysicalStorageBufferAddressesEXT = 5347,
|
||||
CapabilityComputeDerivativeGroupLinearNV = 5350,
|
||||
CapabilityCooperativeMatrixNV = 5357,
|
||||
|
8
3rdparty/glslang/StandAlone/StandAlone.cpp
vendored
8
3rdparty/glslang/StandAlone/StandAlone.cpp
vendored
@ -615,8 +615,12 @@ void ProcessArguments(std::vector<std::unique_ptr<glslang::TWorkItem>>& workItem
|
||||
} else if (strcmp(argv[1], "spirv1.4") == 0) {
|
||||
TargetLanguage = glslang::EShTargetSpv;
|
||||
TargetVersion = glslang::EShTargetSpv_1_4;
|
||||
} else if (strcmp(argv[1], "spirv1.5") == 0) {
|
||||
TargetLanguage = glslang::EShTargetSpv;
|
||||
TargetVersion = glslang::EShTargetSpv_1_5;
|
||||
} else
|
||||
Error("--target-env expected one of: vulkan1.0, vulkan1.1, opengl, spirv1.0, spirv1.1, spirv1.2, or spirv1.3");
|
||||
Error("--target-env expected one of: vulkan1.0, vulkan1.1, opengl,\n"
|
||||
"spirv1.0, spirv1.1, spirv1.2, spirv1.3, spirv1.4, or spirv1.5");
|
||||
}
|
||||
bumpArg();
|
||||
} else if (lowerword == "variable-name" || // synonyms
|
||||
@ -1618,7 +1622,7 @@ void usage()
|
||||
" --stdin read from stdin instead of from a file;\n"
|
||||
" requires providing the shader stage using -S\n"
|
||||
" --target-env {vulkan1.0 | vulkan1.1 | opengl | \n"
|
||||
" spirv1.0 | spirv1.1 | spirv1.2 | spirv1.3}\n"
|
||||
" spirv1.0 | spirv1.1 | spirv1.2 | spirv1.3 | spirv1.4 | spirv1.5}\n"
|
||||
" set execution environment that emitted code\n"
|
||||
" will execute in (versus source language\n"
|
||||
" semantics selected by --client) defaults:\n"
|
||||
|
3
3rdparty/glslang/Test/430.comp
vendored
3
3rdparty/glslang/Test/430.comp
vendored
@ -48,6 +48,9 @@ shared vec4 s;
|
||||
layout(location = 2) shared vec4 sl; // ERROR
|
||||
shared float fs = 4.2; // ERROR
|
||||
|
||||
layout(local_size_y = 1) in;
|
||||
layout(local_size_y = 2) in; // ERROR, changing
|
||||
layout(local_size_y = 1) in;
|
||||
layout(local_size_x = 2, local_size_y = 3, local_size_z = 4) out; // ERROR
|
||||
|
||||
int arrX[gl_WorkGroupSize.x];
|
||||
|
155
3rdparty/glslang/Test/baseResults/430.comp.out
vendored
155
3rdparty/glslang/Test/baseResults/430.comp.out
vendored
@ -8,14 +8,15 @@ ERROR: 0:45: 'out' : global storage output qualifier cannot be used in a compute
|
||||
ERROR: 0:48: 'shared' : cannot apply layout qualifiers to a shared variable
|
||||
ERROR: 0:48: 'location' : can only apply to uniform, buffer, in, or out storage qualifiers
|
||||
ERROR: 0:49: 'shared' : cannot initialize this type of qualifier
|
||||
ERROR: 0:51: 'local_size' : can only apply to 'in'
|
||||
ERROR: 0:51: 'local_size' : can only apply to 'in'
|
||||
ERROR: 0:51: 'local_size' : can only apply to 'in'
|
||||
ERROR: 0:65: 'assign' : l-value required "ro" (can't modify a readonly buffer)
|
||||
ERROR: 0:77: '=' : cannot convert from ' temp double' to ' temp int'
|
||||
ERROR: 0:81: 'input block' : not supported in this stage: compute
|
||||
ERROR: 0:85: 'output block' : not supported in this stage: compute
|
||||
ERROR: 16 compilation errors. No code generated.
|
||||
ERROR: 0:52: 'local_size' : cannot change previously set size
|
||||
ERROR: 0:54: 'local_size' : can only apply to 'in'
|
||||
ERROR: 0:54: 'local_size' : can only apply to 'in'
|
||||
ERROR: 0:54: 'local_size' : can only apply to 'in'
|
||||
ERROR: 0:68: 'assign' : l-value required "ro" (can't modify a readonly buffer)
|
||||
ERROR: 0:80: '=' : cannot convert from ' temp double' to ' temp int'
|
||||
ERROR: 0:84: 'input block' : not supported in this stage: compute
|
||||
ERROR: 0:88: 'output block' : not supported in this stage: compute
|
||||
ERROR: 17 compilation errors. No code generated.
|
||||
|
||||
|
||||
Shader version: 430
|
||||
@ -51,77 +52,77 @@ ERROR: node is still EOpNull!
|
||||
0:39 10 (const int)
|
||||
0:39 true case
|
||||
0:40 Barrier ( global void)
|
||||
0:63 Function Definition: foo( ( global void)
|
||||
0:63 Function Parameters:
|
||||
0:65 Sequence
|
||||
0:65 move second child to first child ( temp float)
|
||||
0:65 direct index (layout( column_major shared) readonly temp float)
|
||||
0:65 values: direct index for structure (layout( column_major shared) readonly buffer unsized 3-element array of float)
|
||||
0:65 'ro' (layout( column_major shared) readonly buffer block{layout( column_major shared) readonly buffer int value, layout( column_major shared) readonly buffer unsized 3-element array of float values})
|
||||
0:65 Constant:
|
||||
0:65 1 (const int)
|
||||
0:65 Constant:
|
||||
0:65 2 (const int)
|
||||
0:65 Constant:
|
||||
0:65 4.700000
|
||||
0:66 array length ( temp int)
|
||||
0:66 values: direct index for structure (layout( column_major shared) readonly buffer unsized 3-element array of float)
|
||||
0:66 'ro' (layout( column_major shared) readonly buffer block{layout( column_major shared) readonly buffer int value, layout( column_major shared) readonly buffer unsized 3-element array of float values})
|
||||
0:66 Constant:
|
||||
0:66 1 (const int)
|
||||
0:67 Barrier ( global void)
|
||||
0:72 Function Definition: fooaoeu( ( global void)
|
||||
0:72 Function Parameters:
|
||||
0:73 Sequence
|
||||
0:73 Sequence
|
||||
0:73 move second child to first child ( temp 2-component vector of int)
|
||||
0:73 'storePos' ( temp 2-component vector of int)
|
||||
0:73 Convert uint to int ( temp 2-component vector of int)
|
||||
0:73 vector swizzle ( temp 2-component vector of uint)
|
||||
0:73 'gl_GlobalInvocationID' ( in 3-component vector of uint GlobalInvocationID)
|
||||
0:73 Sequence
|
||||
0:73 Constant:
|
||||
0:73 0 (const int)
|
||||
0:73 Constant:
|
||||
0:73 1 (const int)
|
||||
0:74 Sequence
|
||||
0:74 move second child to first child ( temp double)
|
||||
0:74 'localCoef' ( temp double)
|
||||
0:74 Convert float to double ( temp double)
|
||||
0:74 length ( global float)
|
||||
0:74 divide ( temp 2-component vector of float)
|
||||
0:74 Convert int to float ( temp 2-component vector of float)
|
||||
0:74 subtract ( temp 2-component vector of int)
|
||||
0:74 Convert uint to int ( temp 2-component vector of int)
|
||||
0:74 vector swizzle ( temp 2-component vector of uint)
|
||||
0:74 'gl_LocalInvocationID' ( in 3-component vector of uint LocalInvocationID)
|
||||
0:74 Sequence
|
||||
0:74 Constant:
|
||||
0:74 0 (const int)
|
||||
0:74 Constant:
|
||||
0:74 1 (const int)
|
||||
0:74 Constant:
|
||||
0:74 8 (const int)
|
||||
0:74 Constant:
|
||||
0:74 8.000000
|
||||
0:75 Sequence
|
||||
0:75 move second child to first child ( temp 4-component vector of double)
|
||||
0:75 'aa' ( temp 4-component vector of double)
|
||||
0:75 Constant:
|
||||
0:75 0.400000
|
||||
0:75 0.200000
|
||||
0:75 0.300000
|
||||
0:75 0.400000
|
||||
0:66 Function Definition: foo( ( global void)
|
||||
0:66 Function Parameters:
|
||||
0:68 Sequence
|
||||
0:68 move second child to first child ( temp float)
|
||||
0:68 direct index (layout( column_major shared) readonly temp float)
|
||||
0:68 values: direct index for structure (layout( column_major shared) readonly buffer unsized 3-element array of float)
|
||||
0:68 'ro' (layout( column_major shared) readonly buffer block{layout( column_major shared) readonly buffer int value, layout( column_major shared) readonly buffer unsized 3-element array of float values})
|
||||
0:68 Constant:
|
||||
0:68 1 (const int)
|
||||
0:68 Constant:
|
||||
0:68 2 (const int)
|
||||
0:68 Constant:
|
||||
0:68 4.700000
|
||||
0:69 array length ( temp int)
|
||||
0:69 values: direct index for structure (layout( column_major shared) readonly buffer unsized 3-element array of float)
|
||||
0:69 'ro' (layout( column_major shared) readonly buffer block{layout( column_major shared) readonly buffer int value, layout( column_major shared) readonly buffer unsized 3-element array of float values})
|
||||
0:69 Constant:
|
||||
0:69 1 (const int)
|
||||
0:70 Barrier ( global void)
|
||||
0:75 Function Definition: fooaoeu( ( global void)
|
||||
0:75 Function Parameters:
|
||||
0:76 Sequence
|
||||
0:76 Sequence
|
||||
0:76 move second child to first child ( temp double)
|
||||
0:76 'globalCoef' ( temp double)
|
||||
0:76 Constant:
|
||||
0:76 1.000000
|
||||
0:76 move second child to first child ( temp 2-component vector of int)
|
||||
0:76 'storePos' ( temp 2-component vector of int)
|
||||
0:76 Convert uint to int ( temp 2-component vector of int)
|
||||
0:76 vector swizzle ( temp 2-component vector of uint)
|
||||
0:76 'gl_GlobalInvocationID' ( in 3-component vector of uint GlobalInvocationID)
|
||||
0:76 Sequence
|
||||
0:76 Constant:
|
||||
0:76 0 (const int)
|
||||
0:76 Constant:
|
||||
0:76 1 (const int)
|
||||
0:77 Sequence
|
||||
0:77 move second child to first child ( temp double)
|
||||
0:77 'localCoef' ( temp double)
|
||||
0:77 Convert float to double ( temp double)
|
||||
0:77 length ( global float)
|
||||
0:77 divide ( temp 2-component vector of float)
|
||||
0:77 Convert int to float ( temp 2-component vector of float)
|
||||
0:77 subtract ( temp 2-component vector of int)
|
||||
0:77 Convert uint to int ( temp 2-component vector of int)
|
||||
0:77 vector swizzle ( temp 2-component vector of uint)
|
||||
0:77 'gl_LocalInvocationID' ( in 3-component vector of uint LocalInvocationID)
|
||||
0:77 Sequence
|
||||
0:77 Constant:
|
||||
0:77 0 (const int)
|
||||
0:77 Constant:
|
||||
0:77 1 (const int)
|
||||
0:77 Constant:
|
||||
0:77 8 (const int)
|
||||
0:77 Constant:
|
||||
0:77 8.000000
|
||||
0:78 Sequence
|
||||
0:78 move second child to first child ( temp double)
|
||||
0:78 'di' ( temp double)
|
||||
0:78 Convert int to double ( temp double)
|
||||
0:78 'i' ( temp int)
|
||||
0:78 move second child to first child ( temp 4-component vector of double)
|
||||
0:78 'aa' ( temp 4-component vector of double)
|
||||
0:78 Constant:
|
||||
0:78 0.400000
|
||||
0:78 0.200000
|
||||
0:78 0.300000
|
||||
0:78 0.400000
|
||||
0:79 Sequence
|
||||
0:79 move second child to first child ( temp double)
|
||||
0:79 'globalCoef' ( temp double)
|
||||
0:79 Constant:
|
||||
0:79 1.000000
|
||||
0:81 Sequence
|
||||
0:81 move second child to first child ( temp double)
|
||||
0:81 'di' ( temp double)
|
||||
0:81 Convert int to double ( temp double)
|
||||
0:81 'i' ( temp int)
|
||||
0:? Linker Objects
|
||||
0:? 'gl_WorkGroupSize' ( const 3-component vector of uint WorkGroupSize)
|
||||
0:? 2 (const uint)
|
||||
|
@ -40,6 +40,13 @@ ERROR: node is still EOpNull!
|
||||
0:27 2 (const int)
|
||||
0:28 'nu_li' ( nonuniform temp int)
|
||||
0:29 'nu_li' ( nonuniform temp int)
|
||||
0:30 move second child to first child ( temp int)
|
||||
0:30 'nu_li' ( nonuniform temp int)
|
||||
0:30 indirect index ( nonuniform temp int)
|
||||
0:30 'table' ( temp 5-element array of int)
|
||||
0:30 copy object ( nonuniform temp int)
|
||||
0:30 Constant:
|
||||
0:30 3 (const int)
|
||||
0:? Linker Objects
|
||||
0:? 'nonuniformEXT' ( global int)
|
||||
0:? 'nu_inv4' ( smooth nonuniform in 4-component vector of float)
|
||||
@ -83,6 +90,13 @@ ERROR: node is still EOpNull!
|
||||
0:27 2 (const int)
|
||||
0:28 'nu_li' ( nonuniform temp int)
|
||||
0:29 'nu_li' ( nonuniform temp int)
|
||||
0:30 move second child to first child ( temp int)
|
||||
0:30 'nu_li' ( nonuniform temp int)
|
||||
0:30 indirect index ( nonuniform temp int)
|
||||
0:30 'table' ( temp 5-element array of int)
|
||||
0:30 copy object ( nonuniform temp int)
|
||||
0:30 Constant:
|
||||
0:30 3 (const int)
|
||||
0:? Linker Objects
|
||||
0:? 'nonuniformEXT' ( global int)
|
||||
0:? 'nu_inv4' ( smooth nonuniform in 4-component vector of float)
|
||||
|
@ -6,7 +6,7 @@ spv.bufferhandle1.frag
|
||||
Capability Shader
|
||||
Capability VulkanMemoryModelKHR
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
Extension "SPV_KHR_vulkan_memory_model"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
|
@ -6,7 +6,7 @@ spv.bufferhandle10.frag
|
||||
Capability Shader
|
||||
Capability VulkanMemoryModelKHR
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
Extension "SPV_KHR_vulkan_memory_model"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
|
@ -9,8 +9,8 @@ WARNING: 0:6: '' : all default precisions are highp; use precision statements to
|
||||
Capability Shader
|
||||
Capability StorageBuffer8BitAccess
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_8bit_storage"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
|
@ -9,8 +9,8 @@ WARNING: 0:6: '' : all default precisions are highp; use precision statements to
|
||||
Capability Shader
|
||||
Capability StorageUniformBufferBlock16
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_16bit_storage"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
|
@ -5,7 +5,7 @@ spv.bufferhandle13.frag
|
||||
|
||||
Capability Shader
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
|
@ -5,7 +5,7 @@ spv.bufferhandle14.frag
|
||||
|
||||
Capability Shader
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
EntryPoint Fragment 4 "main"
|
||||
|
@ -8,7 +8,7 @@ WARNING: 0:16: '' : all default precisions are highp; use precision statements t
|
||||
|
||||
Capability Shader
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
|
@ -6,7 +6,7 @@ spv.bufferhandle16.frag
|
||||
Capability Shader
|
||||
Capability Int64
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
EntryPoint Fragment 4 "main"
|
||||
|
@ -6,7 +6,7 @@ spv.bufferhandle18.frag
|
||||
Capability Shader
|
||||
Capability Int64
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
EntryPoint Fragment 4 "main"
|
||||
|
@ -5,7 +5,7 @@ spv.bufferhandle2.frag
|
||||
|
||||
Capability Shader
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
|
@ -5,7 +5,7 @@ spv.bufferhandle3.frag
|
||||
|
||||
Capability Shader
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
|
@ -5,7 +5,7 @@ spv.bufferhandle4.frag
|
||||
|
||||
Capability Shader
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
|
@ -5,7 +5,7 @@ spv.bufferhandle5.frag
|
||||
|
||||
Capability Shader
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
EntryPoint Fragment 4 "main"
|
||||
|
@ -5,7 +5,7 @@ spv.bufferhandle6.frag
|
||||
|
||||
Capability Shader
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
|
@ -5,7 +5,7 @@ spv.bufferhandle7.frag
|
||||
|
||||
Capability Shader
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
|
@ -5,7 +5,7 @@ spv.bufferhandle8.frag
|
||||
|
||||
Capability Shader
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
|
@ -6,7 +6,7 @@ spv.bufferhandle9.frag
|
||||
Capability Shader
|
||||
Capability Int64
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
|
133
3rdparty/glslang/Test/baseResults/spv.bufferhandleUvec2.frag.out
vendored
Executable file
133
3rdparty/glslang/Test/baseResults/spv.bufferhandleUvec2.frag.out
vendored
Executable file
@ -0,0 +1,133 @@
|
||||
spv.bufferhandleUvec2.frag
|
||||
// Module Version 10000
|
||||
// Generated by (magic number): 80007
|
||||
// Id's are bound by 71
|
||||
|
||||
Capability Shader
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel PhysicalStorageBuffer64EXT GLSL450
|
||||
EntryPoint Fragment 4 "main" 16 19
|
||||
ExecutionMode 4 OriginUpperLeft
|
||||
Source GLSL 450
|
||||
SourceExtension "GL_EXT_buffer_reference"
|
||||
SourceExtension "GL_EXT_buffer_reference_uvec2"
|
||||
Name 4 "main"
|
||||
Name 8 "blockType"
|
||||
MemberName 8(blockType) 0 "a"
|
||||
MemberName 8(blockType) 1 "b"
|
||||
MemberName 8(blockType) 2 "c"
|
||||
MemberName 8(blockType) 3 "d"
|
||||
MemberName 8(blockType) 4 "e"
|
||||
Name 13 "b1"
|
||||
Name 16 "h"
|
||||
Name 19 "i"
|
||||
Name 34 "b2"
|
||||
Name 37 "b3"
|
||||
Name 46 "j"
|
||||
Name 54 "carry"
|
||||
Name 55 "ResType"
|
||||
Name 68 "t2"
|
||||
MemberName 68(t2) 0 "f"
|
||||
MemberName 68(t2) 1 "g"
|
||||
Name 70 "t"
|
||||
MemberDecorate 8(blockType) 0 Offset 0
|
||||
MemberDecorate 8(blockType) 1 Offset 4
|
||||
MemberDecorate 8(blockType) 2 Offset 8
|
||||
MemberDecorate 8(blockType) 3 Offset 12
|
||||
MemberDecorate 8(blockType) 4 Offset 16
|
||||
Decorate 8(blockType) Block
|
||||
Decorate 13(b1) DecorationAliasedPointerEXT
|
||||
Decorate 16(h) Flat
|
||||
Decorate 19(i) Flat
|
||||
Decorate 34(b2) DecorationAliasedPointerEXT
|
||||
Decorate 37(b3) DecorationAliasedPointerEXT
|
||||
MemberDecorate 68(t2) 0 Offset 0
|
||||
MemberDecorate 68(t2) 1 Offset 8
|
||||
Decorate 68(t2) Block
|
||||
Decorate 70(t) DescriptorSet 0
|
||||
Decorate 70(t) Binding 0
|
||||
2: TypeVoid
|
||||
3: TypeFunction 2
|
||||
TypeForwardPointer 6 PhysicalStorageBufferEXT
|
||||
7: TypeInt 32 1
|
||||
8(blockType): TypeStruct 7(int) 7(int) 7(int) 7(int) 7(int)
|
||||
6: TypePointer PhysicalStorageBufferEXT 8(blockType)
|
||||
9: TypeInt 32 0
|
||||
10: 9(int) Constant 2
|
||||
11: TypeArray 6(ptr) 10
|
||||
12: TypePointer Function 11
|
||||
14: TypeVector 9(int) 2
|
||||
15: TypePointer Input 14(ivec2)
|
||||
16(h): 15(ptr) Variable Input
|
||||
19(i): 15(ptr) Variable Input
|
||||
23: 7(int) Constant 0
|
||||
24: TypePointer Function 6(ptr)
|
||||
27: 7(int) Constant 1
|
||||
30: TypePointer PhysicalStorageBufferEXT 7(int)
|
||||
45: TypePointer Function 14(ivec2)
|
||||
49: 9(int) Constant 0
|
||||
50: TypePointer Function 9(int)
|
||||
53: 9(int) Constant 256
|
||||
55(ResType): TypeStruct 9(int) 9(int)
|
||||
61: 9(int) Constant 1
|
||||
68(t2): TypeStruct 6(ptr) 6(ptr)
|
||||
69: TypePointer StorageBuffer 68(t2)
|
||||
70(t): 69(ptr) Variable StorageBuffer
|
||||
4(main): 2 Function None 3
|
||||
5: Label
|
||||
13(b1): 12(ptr) Variable Function
|
||||
34(b2): 24(ptr) Variable Function
|
||||
37(b3): 24(ptr) Variable Function
|
||||
46(j): 45(ptr) Variable Function
|
||||
54(carry): 50(ptr) Variable Function
|
||||
17: 14(ivec2) Load 16(h)
|
||||
18: 6(ptr) Bitcast 17
|
||||
20: 14(ivec2) Load 19(i)
|
||||
21: 6(ptr) Bitcast 20
|
||||
22: 11 CompositeConstruct 18 21
|
||||
Store 13(b1) 22
|
||||
25: 24(ptr) AccessChain 13(b1) 23
|
||||
26: 6(ptr) Load 25
|
||||
28: 24(ptr) AccessChain 13(b1) 27
|
||||
29: 6(ptr) Load 28
|
||||
31: 30(ptr) AccessChain 29 27
|
||||
32: 7(int) Load 31 Aligned 4
|
||||
33: 30(ptr) AccessChain 26 23
|
||||
Store 33 32 Aligned 16
|
||||
35: 14(ivec2) Load 16(h)
|
||||
36: 6(ptr) Bitcast 35
|
||||
Store 34(b2) 36
|
||||
38: 14(ivec2) Load 19(i)
|
||||
39: 6(ptr) Bitcast 38
|
||||
Store 37(b3) 39
|
||||
40: 6(ptr) Load 34(b2)
|
||||
41: 6(ptr) Load 37(b3)
|
||||
42: 30(ptr) AccessChain 41 27
|
||||
43: 7(int) Load 42 Aligned 4
|
||||
44: 30(ptr) AccessChain 40 23
|
||||
Store 44 43 Aligned 16
|
||||
47: 6(ptr) Load 34(b2)
|
||||
48: 14(ivec2) Bitcast 47
|
||||
Store 46(j) 48
|
||||
51: 50(ptr) AccessChain 46(j) 49
|
||||
52: 9(int) Load 51
|
||||
56: 55(ResType) IAddCarry 52 53
|
||||
57: 9(int) CompositeExtract 56 1
|
||||
Store 54(carry) 57
|
||||
58: 9(int) CompositeExtract 56 0
|
||||
59: 50(ptr) AccessChain 46(j) 49
|
||||
Store 59 58
|
||||
60: 9(int) Load 54(carry)
|
||||
62: 50(ptr) AccessChain 46(j) 61
|
||||
63: 9(int) Load 62
|
||||
64: 9(int) IAdd 63 60
|
||||
65: 50(ptr) AccessChain 46(j) 61
|
||||
Store 65 64
|
||||
66: 14(ivec2) Load 46(j)
|
||||
67: 6(ptr) Bitcast 66
|
||||
Store 34(b2) 67
|
||||
Return
|
||||
FunctionEnd
|
@ -9,8 +9,8 @@ spv.coopmat.comp
|
||||
Capability VulkanMemoryModelKHR
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Capability CooperativeMatrixNV
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_16bit_storage"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
Extension "SPV_KHR_vulkan_memory_model"
|
||||
Extension "SPV_NV_cooperative_matrix"
|
||||
|
@ -10,8 +10,8 @@ spv.intcoopmat.comp
|
||||
Capability VulkanMemoryModelKHR
|
||||
Capability PhysicalStorageBufferAddressesEXT
|
||||
Capability CooperativeMatrixNV
|
||||
Extension "SPV_EXT_physical_storage_buffer"
|
||||
Extension "SPV_KHR_8bit_storage"
|
||||
Extension "SPV_KHR_physical_storage_buffer"
|
||||
Extension "SPV_KHR_storage_buffer_storage_class"
|
||||
Extension "SPV_KHR_vulkan_memory_model"
|
||||
Extension "SPV_NV_cooperative_matrix"
|
||||
|
@ -11,7 +11,7 @@ spv.specConstant.vert
|
||||
Source GLSL 400
|
||||
Name 4 "main"
|
||||
Name 9 "arraySize"
|
||||
Name 14 "foo(vf4[s2769];"
|
||||
Name 14 "foo(vf4[s4393];"
|
||||
Name 13 "p"
|
||||
Name 17 "builtin_spec_constant("
|
||||
Name 20 "color"
|
||||
@ -102,10 +102,10 @@ spv.specConstant.vert
|
||||
Store 20(color) 46
|
||||
48: 10 Load 22(ucol)
|
||||
Store 47(param) 48
|
||||
49: 2 FunctionCall 14(foo(vf4[s2769];) 47(param)
|
||||
49: 2 FunctionCall 14(foo(vf4[s4393];) 47(param)
|
||||
Return
|
||||
FunctionEnd
|
||||
14(foo(vf4[s2769];): 2 Function None 12
|
||||
14(foo(vf4[s4393];): 2 Function None 12
|
||||
13(p): 11(ptr) FunctionParameter
|
||||
15: Label
|
||||
54: 24(ptr) AccessChain 53(dupUcol) 23
|
||||
|
4280
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesArithmetic.comp.out
vendored
Normal file
4280
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesArithmetic.comp.out
vendored
Normal file
File diff suppressed because it is too large
Load Diff
557
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesArithmeticNeg.comp.out
vendored
Normal file
557
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesArithmeticNeg.comp.out
vendored
Normal file
@ -0,0 +1,557 @@
|
||||
spv.subgroupExtendedTypesArithmeticNeg.comp
|
||||
ERROR: 0:26: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:27: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:28: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:29: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:31: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:32: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:33: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:34: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:36: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:37: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:38: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:39: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:41: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:42: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:43: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:44: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:46: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:47: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:48: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:49: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:51: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:52: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:53: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:54: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:56: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:57: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:58: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:59: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:61: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:62: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:63: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:64: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:66: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:67: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:68: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:69: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:71: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:72: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:73: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:74: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:76: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:77: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:78: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:79: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:81: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:82: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:83: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:84: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:86: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:87: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:88: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:89: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:91: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:92: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:93: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:94: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:96: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:97: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:98: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:99: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:101: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:102: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:103: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:104: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:106: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:107: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:108: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:109: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:111: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:112: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:113: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:114: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:116: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:117: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:118: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:119: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:121: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:122: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:123: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:124: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:126: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:127: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:128: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:129: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:131: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:132: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:133: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:134: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:136: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:137: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:138: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:139: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:141: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:142: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:143: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:144: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:146: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:147: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:148: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:149: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:151: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:152: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:153: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:154: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:156: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:157: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:158: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:159: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:161: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:162: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:163: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:164: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:166: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:167: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:168: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:169: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:171: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:172: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:173: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:174: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:176: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:177: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:178: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:179: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:181: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:182: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:183: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:184: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:186: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:187: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:188: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:189: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:191: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:192: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:193: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:194: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:196: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:197: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:198: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:199: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:201: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:202: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:203: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:204: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:206: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:207: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:208: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:209: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:211: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:212: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:213: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:214: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:216: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:217: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:218: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:219: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:221: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:222: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:223: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:224: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:226: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:227: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:228: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:229: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:231: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:232: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:233: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:234: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:236: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:237: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:238: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:239: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:241: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:242: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:243: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:244: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:246: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:247: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:248: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:249: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:251: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:252: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:253: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:254: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:256: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:257: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:258: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:259: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:261: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:262: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:263: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:264: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:266: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:267: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:268: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:269: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:271: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:272: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:273: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:274: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:276: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:277: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:278: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:279: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:281: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:282: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:283: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:284: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:286: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:287: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:288: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:289: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:291: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:292: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:293: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:294: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:296: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:297: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:298: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:299: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:301: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:302: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:303: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:304: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:306: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:307: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:308: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:309: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:311: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:312: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:313: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:314: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:316: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:317: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:318: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:319: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:321: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:322: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:323: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:324: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:326: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:327: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:328: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:329: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:331: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:332: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:333: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:334: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:336: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:337: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:338: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:339: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:341: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:342: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:343: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:344: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:346: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:347: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:348: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:349: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:351: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:352: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:353: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:354: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:356: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:357: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:358: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:359: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:361: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:362: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:363: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:364: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:366: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:367: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:368: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:369: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:371: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:372: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:373: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:374: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:376: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:377: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:378: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:379: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:381: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:382: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:383: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:384: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:386: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:387: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:388: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:389: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:391: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:392: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:393: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:394: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:396: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:397: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:398: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:399: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:401: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:402: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:403: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:404: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:406: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:407: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:408: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:409: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:411: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:412: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:413: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:414: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:416: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:417: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:418: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:419: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:421: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:422: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:423: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:424: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:426: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:427: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:428: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:429: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:431: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:432: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:433: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:434: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:436: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:437: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:438: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:439: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:441: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:442: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:443: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:444: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:446: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:447: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:448: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:449: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:451: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:452: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:453: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:454: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:456: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:457: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:458: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:459: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:461: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:462: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:463: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:464: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:466: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:467: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:468: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:469: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:471: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:472: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:473: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:474: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:476: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:477: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:478: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:479: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:481: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:482: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:483: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:484: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:486: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:487: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:488: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:489: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:491: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:492: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:493: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:494: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:496: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:497: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:498: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:499: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:501: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:502: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:503: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:504: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:506: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:507: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:508: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:509: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:511: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:512: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:513: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:514: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:516: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:517: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:518: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:519: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:521: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:522: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:523: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:524: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:526: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:527: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:528: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:529: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:531: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:532: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:533: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:534: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:536: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:537: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:538: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:539: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:541: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:542: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:543: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:544: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:546: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:547: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:548: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:549: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:551: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:552: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:553: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:554: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:556: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:557: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:558: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:559: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:561: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:562: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:563: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:564: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:566: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:567: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:568: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:569: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:571: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:572: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:573: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:574: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:576: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:577: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:578: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:579: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:581: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:582: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:583: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:584: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:586: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:587: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:588: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:589: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:591: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:592: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:593: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:594: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:596: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:597: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:598: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:599: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:601: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:602: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:603: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:604: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:606: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:607: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:608: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:609: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:611: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:612: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:613: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:614: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:616: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:617: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:618: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:619: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:621: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:622: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:623: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:624: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:626: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:627: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:628: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:629: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:631: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:632: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:633: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:634: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:636: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:637: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:638: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:639: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:641: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:642: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:643: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:644: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:646: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:647: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:648: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:649: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:651: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:652: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:653: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:654: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:656: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:657: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:658: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:659: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:661: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:662: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:663: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:664: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:666: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:667: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:668: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:669: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:671: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:672: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:673: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:674: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:676: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:677: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:678: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:679: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:681: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:682: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:683: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:684: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:686: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:687: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:688: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:689: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:691: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:692: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:693: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:694: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:696: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:697: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:698: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:699: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:701: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:702: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:703: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:704: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:706: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:707: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:708: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:709: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:711: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:712: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:713: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:714: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 552 compilation errors. No code generated.
|
||||
|
||||
|
||||
SPIR-V is not generated for failed compile or link
|
560
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesBallot.comp.out
vendored
Normal file
560
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesBallot.comp.out
vendored
Normal file
@ -0,0 +1,560 @@
|
||||
spv.subgroupExtendedTypesBallot.comp
|
||||
// Module Version 10300
|
||||
// Generated by (magic number): 80007
|
||||
// Id's are bound by 441
|
||||
|
||||
Capability Shader
|
||||
Capability Float16
|
||||
Capability Int64
|
||||
Capability Int16
|
||||
Capability Int8
|
||||
Capability GroupNonUniform
|
||||
Capability GroupNonUniformBallot
|
||||
Capability StorageUniformBufferBlock16
|
||||
Capability StorageBuffer8BitAccess
|
||||
Extension "SPV_KHR_8bit_storage"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel Logical GLSL450
|
||||
EntryPoint GLCompute 4 "main" 10 12
|
||||
ExecutionMode 4 LocalSize 8 1 1
|
||||
Source GLSL 450
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_float16"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int16"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int64"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int8"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_float16"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int16"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int64"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int8"
|
||||
SourceExtension "GL_KHR_shader_subgroup_ballot"
|
||||
SourceExtension "GL_KHR_shader_subgroup_basic"
|
||||
Name 4 "main"
|
||||
Name 8 "invocation"
|
||||
Name 10 "gl_SubgroupInvocationID"
|
||||
Name 12 "gl_SubgroupSize"
|
||||
Name 31 "Buffers"
|
||||
MemberName 31(Buffers) 0 "i8"
|
||||
MemberName 31(Buffers) 1 "u8"
|
||||
MemberName 31(Buffers) 2 "i16"
|
||||
MemberName 31(Buffers) 3 "u16"
|
||||
MemberName 31(Buffers) 4 "i64"
|
||||
MemberName 31(Buffers) 5 "u64"
|
||||
MemberName 31(Buffers) 6 "f16"
|
||||
Name 34 "data"
|
||||
Decorate 10(gl_SubgroupInvocationID) RelaxedPrecision
|
||||
Decorate 10(gl_SubgroupInvocationID) BuiltIn SubgroupLocalInvocationId
|
||||
Decorate 11 RelaxedPrecision
|
||||
Decorate 12(gl_SubgroupSize) RelaxedPrecision
|
||||
Decorate 12(gl_SubgroupSize) BuiltIn SubgroupSize
|
||||
Decorate 13 RelaxedPrecision
|
||||
Decorate 14 RelaxedPrecision
|
||||
Decorate 16 RelaxedPrecision
|
||||
MemberDecorate 31(Buffers) 0 Offset 0
|
||||
MemberDecorate 31(Buffers) 1 Offset 4
|
||||
MemberDecorate 31(Buffers) 2 Offset 8
|
||||
MemberDecorate 31(Buffers) 3 Offset 16
|
||||
MemberDecorate 31(Buffers) 4 Offset 32
|
||||
MemberDecorate 31(Buffers) 5 Offset 64
|
||||
MemberDecorate 31(Buffers) 6 Offset 96
|
||||
Decorate 31(Buffers) Block
|
||||
Decorate 34(data) DescriptorSet 0
|
||||
Decorate 34(data) Binding 0
|
||||
Decorate 440 BuiltIn WorkgroupSize
|
||||
2: TypeVoid
|
||||
3: TypeFunction 2
|
||||
6: TypeInt 32 0
|
||||
7: TypePointer Function 6(int)
|
||||
9: TypePointer Input 6(int)
|
||||
10(gl_SubgroupInvocationID): 9(ptr) Variable Input
|
||||
12(gl_SubgroupSize): 9(ptr) Variable Input
|
||||
15: 6(int) Constant 4
|
||||
17: TypeInt 8 1
|
||||
18: TypeVector 17(int8_t) 4
|
||||
19: TypeInt 8 0
|
||||
20: TypeVector 19(int8_t) 4
|
||||
21: TypeInt 16 1
|
||||
22: TypeVector 21(int16_t) 4
|
||||
23: TypeInt 16 0
|
||||
24: TypeVector 23(int16_t) 4
|
||||
25: TypeInt 64 1
|
||||
26: TypeVector 25(int64_t) 4
|
||||
27: TypeInt 64 0
|
||||
28: TypeVector 27(int64_t) 4
|
||||
29: TypeFloat 16
|
||||
30: TypeVector 29(float16_t) 4
|
||||
31(Buffers): TypeStruct 18(i8vec4) 20(i8vec4) 22(i16vec4) 24(i16vec4) 26(i64vec4) 28(i64vec4) 30(f16vec4)
|
||||
32: TypeArray 31(Buffers) 15
|
||||
33: TypePointer StorageBuffer 32
|
||||
34(data): 33(ptr) Variable StorageBuffer
|
||||
36: TypeInt 32 1
|
||||
37: 36(int) Constant 0
|
||||
38: 6(int) Constant 0
|
||||
39: TypePointer StorageBuffer 17(int8_t)
|
||||
42: 6(int) Constant 3
|
||||
46: 36(int) Constant 1
|
||||
47: TypeVector 17(int8_t) 2
|
||||
48: TypePointer StorageBuffer 18(i8vec4)
|
||||
57: 36(int) Constant 2
|
||||
58: TypeVector 17(int8_t) 3
|
||||
67: 36(int) Constant 3
|
||||
99: TypePointer StorageBuffer 19(int8_t)
|
||||
105: TypeVector 19(int8_t) 2
|
||||
106: TypePointer StorageBuffer 20(i8vec4)
|
||||
115: TypeVector 19(int8_t) 3
|
||||
155: TypePointer StorageBuffer 21(int16_t)
|
||||
161: TypeVector 21(int16_t) 2
|
||||
162: TypePointer StorageBuffer 22(i16vec4)
|
||||
171: TypeVector 21(int16_t) 3
|
||||
211: TypePointer StorageBuffer 23(int16_t)
|
||||
217: TypeVector 23(int16_t) 2
|
||||
218: TypePointer StorageBuffer 24(i16vec4)
|
||||
227: TypeVector 23(int16_t) 3
|
||||
267: 36(int) Constant 4
|
||||
268: TypePointer StorageBuffer 25(int64_t)
|
||||
274: TypeVector 25(int64_t) 2
|
||||
275: TypePointer StorageBuffer 26(i64vec4)
|
||||
284: TypeVector 25(int64_t) 3
|
||||
324: 36(int) Constant 5
|
||||
325: TypePointer StorageBuffer 27(int64_t)
|
||||
331: TypeVector 27(int64_t) 2
|
||||
332: TypePointer StorageBuffer 28(i64vec4)
|
||||
341: TypeVector 27(int64_t) 3
|
||||
381: 36(int) Constant 6
|
||||
382: TypePointer StorageBuffer 29(float16_t)
|
||||
388: TypeVector 29(float16_t) 2
|
||||
389: TypePointer StorageBuffer 30(f16vec4)
|
||||
398: TypeVector 29(float16_t) 3
|
||||
437: TypeVector 6(int) 3
|
||||
438: 6(int) Constant 8
|
||||
439: 6(int) Constant 1
|
||||
440: 437(ivec3) ConstantComposite 438 439 439
|
||||
4(main): 2 Function None 3
|
||||
5: Label
|
||||
8(invocation): 7(ptr) Variable Function
|
||||
11: 6(int) Load 10(gl_SubgroupInvocationID)
|
||||
13: 6(int) Load 12(gl_SubgroupSize)
|
||||
14: 6(int) IAdd 11 13
|
||||
16: 6(int) UMod 14 15
|
||||
Store 8(invocation) 16
|
||||
35: 6(int) Load 8(invocation)
|
||||
40: 39(ptr) AccessChain 34(data) 37 37 38
|
||||
41: 17(int8_t) Load 40
|
||||
43: 17(int8_t) GroupNonUniformBroadcast 42 41 42
|
||||
44: 39(ptr) AccessChain 34(data) 35 37 38
|
||||
Store 44 43
|
||||
45: 6(int) Load 8(invocation)
|
||||
49: 48(ptr) AccessChain 34(data) 46 37
|
||||
50: 18(i8vec4) Load 49
|
||||
51: 47(i8vec2) VectorShuffle 50 50 0 1
|
||||
52: 47(i8vec2) GroupNonUniformBroadcast 42 51 42
|
||||
53: 48(ptr) AccessChain 34(data) 45 37
|
||||
54: 18(i8vec4) Load 53
|
||||
55: 18(i8vec4) VectorShuffle 54 52 4 5 2 3
|
||||
Store 53 55
|
||||
56: 6(int) Load 8(invocation)
|
||||
59: 48(ptr) AccessChain 34(data) 57 37
|
||||
60: 18(i8vec4) Load 59
|
||||
61: 58(i8vec3) VectorShuffle 60 60 0 1 2
|
||||
62: 58(i8vec3) GroupNonUniformBroadcast 42 61 42
|
||||
63: 48(ptr) AccessChain 34(data) 56 37
|
||||
64: 18(i8vec4) Load 63
|
||||
65: 18(i8vec4) VectorShuffle 64 62 4 5 6 3
|
||||
Store 63 65
|
||||
66: 6(int) Load 8(invocation)
|
||||
68: 48(ptr) AccessChain 34(data) 67 37
|
||||
69: 18(i8vec4) Load 68
|
||||
70: 18(i8vec4) GroupNonUniformBroadcast 42 69 42
|
||||
71: 48(ptr) AccessChain 34(data) 66 37
|
||||
Store 71 70
|
||||
72: 6(int) Load 8(invocation)
|
||||
73: 39(ptr) AccessChain 34(data) 37 37 38
|
||||
74: 17(int8_t) Load 73
|
||||
75: 17(int8_t) GroupNonUniformBroadcastFirst 42 74
|
||||
76: 39(ptr) AccessChain 34(data) 72 37 38
|
||||
Store 76 75
|
||||
77: 6(int) Load 8(invocation)
|
||||
78: 48(ptr) AccessChain 34(data) 46 37
|
||||
79: 18(i8vec4) Load 78
|
||||
80: 47(i8vec2) VectorShuffle 79 79 0 1
|
||||
81: 47(i8vec2) GroupNonUniformBroadcastFirst 42 80
|
||||
82: 48(ptr) AccessChain 34(data) 77 37
|
||||
83: 18(i8vec4) Load 82
|
||||
84: 18(i8vec4) VectorShuffle 83 81 4 5 2 3
|
||||
Store 82 84
|
||||
85: 6(int) Load 8(invocation)
|
||||
86: 48(ptr) AccessChain 34(data) 57 37
|
||||
87: 18(i8vec4) Load 86
|
||||
88: 58(i8vec3) VectorShuffle 87 87 0 1 2
|
||||
89: 58(i8vec3) GroupNonUniformBroadcastFirst 42 88
|
||||
90: 48(ptr) AccessChain 34(data) 85 37
|
||||
91: 18(i8vec4) Load 90
|
||||
92: 18(i8vec4) VectorShuffle 91 89 4 5 6 3
|
||||
Store 90 92
|
||||
93: 6(int) Load 8(invocation)
|
||||
94: 48(ptr) AccessChain 34(data) 67 37
|
||||
95: 18(i8vec4) Load 94
|
||||
96: 18(i8vec4) GroupNonUniformBroadcastFirst 42 95
|
||||
97: 48(ptr) AccessChain 34(data) 93 37
|
||||
Store 97 96
|
||||
98: 6(int) Load 8(invocation)
|
||||
100: 99(ptr) AccessChain 34(data) 37 46 38
|
||||
101: 19(int8_t) Load 100
|
||||
102: 19(int8_t) GroupNonUniformBroadcast 42 101 42
|
||||
103: 99(ptr) AccessChain 34(data) 98 46 38
|
||||
Store 103 102
|
||||
104: 6(int) Load 8(invocation)
|
||||
107: 106(ptr) AccessChain 34(data) 46 46
|
||||
108: 20(i8vec4) Load 107
|
||||
109: 105(i8vec2) VectorShuffle 108 108 0 1
|
||||
110: 105(i8vec2) GroupNonUniformBroadcast 42 109 42
|
||||
111: 106(ptr) AccessChain 34(data) 104 46
|
||||
112: 20(i8vec4) Load 111
|
||||
113: 20(i8vec4) VectorShuffle 112 110 4 5 2 3
|
||||
Store 111 113
|
||||
114: 6(int) Load 8(invocation)
|
||||
116: 106(ptr) AccessChain 34(data) 57 46
|
||||
117: 20(i8vec4) Load 116
|
||||
118: 115(i8vec3) VectorShuffle 117 117 0 1 2
|
||||
119: 115(i8vec3) GroupNonUniformBroadcast 42 118 42
|
||||
120: 106(ptr) AccessChain 34(data) 114 46
|
||||
121: 20(i8vec4) Load 120
|
||||
122: 20(i8vec4) VectorShuffle 121 119 4 5 6 3
|
||||
Store 120 122
|
||||
123: 6(int) Load 8(invocation)
|
||||
124: 106(ptr) AccessChain 34(data) 67 46
|
||||
125: 20(i8vec4) Load 124
|
||||
126: 20(i8vec4) GroupNonUniformBroadcast 42 125 42
|
||||
127: 106(ptr) AccessChain 34(data) 123 46
|
||||
Store 127 126
|
||||
128: 6(int) Load 8(invocation)
|
||||
129: 99(ptr) AccessChain 34(data) 37 46 38
|
||||
130: 19(int8_t) Load 129
|
||||
131: 19(int8_t) GroupNonUniformBroadcastFirst 42 130
|
||||
132: 99(ptr) AccessChain 34(data) 128 46 38
|
||||
Store 132 131
|
||||
133: 6(int) Load 8(invocation)
|
||||
134: 106(ptr) AccessChain 34(data) 46 46
|
||||
135: 20(i8vec4) Load 134
|
||||
136: 105(i8vec2) VectorShuffle 135 135 0 1
|
||||
137: 105(i8vec2) GroupNonUniformBroadcastFirst 42 136
|
||||
138: 106(ptr) AccessChain 34(data) 133 46
|
||||
139: 20(i8vec4) Load 138
|
||||
140: 20(i8vec4) VectorShuffle 139 137 4 5 2 3
|
||||
Store 138 140
|
||||
141: 6(int) Load 8(invocation)
|
||||
142: 106(ptr) AccessChain 34(data) 57 46
|
||||
143: 20(i8vec4) Load 142
|
||||
144: 115(i8vec3) VectorShuffle 143 143 0 1 2
|
||||
145: 115(i8vec3) GroupNonUniformBroadcastFirst 42 144
|
||||
146: 106(ptr) AccessChain 34(data) 141 46
|
||||
147: 20(i8vec4) Load 146
|
||||
148: 20(i8vec4) VectorShuffle 147 145 4 5 6 3
|
||||
Store 146 148
|
||||
149: 6(int) Load 8(invocation)
|
||||
150: 106(ptr) AccessChain 34(data) 67 46
|
||||
151: 20(i8vec4) Load 150
|
||||
152: 20(i8vec4) GroupNonUniformBroadcastFirst 42 151
|
||||
153: 106(ptr) AccessChain 34(data) 149 46
|
||||
Store 153 152
|
||||
154: 6(int) Load 8(invocation)
|
||||
156: 155(ptr) AccessChain 34(data) 37 57 38
|
||||
157: 21(int16_t) Load 156
|
||||
158: 21(int16_t) GroupNonUniformBroadcast 42 157 42
|
||||
159: 155(ptr) AccessChain 34(data) 154 57 38
|
||||
Store 159 158
|
||||
160: 6(int) Load 8(invocation)
|
||||
163: 162(ptr) AccessChain 34(data) 46 57
|
||||
164: 22(i16vec4) Load 163
|
||||
165:161(i16vec2) VectorShuffle 164 164 0 1
|
||||
166:161(i16vec2) GroupNonUniformBroadcast 42 165 42
|
||||
167: 162(ptr) AccessChain 34(data) 160 57
|
||||
168: 22(i16vec4) Load 167
|
||||
169: 22(i16vec4) VectorShuffle 168 166 4 5 2 3
|
||||
Store 167 169
|
||||
170: 6(int) Load 8(invocation)
|
||||
172: 162(ptr) AccessChain 34(data) 57 57
|
||||
173: 22(i16vec4) Load 172
|
||||
174:171(i16vec3) VectorShuffle 173 173 0 1 2
|
||||
175:171(i16vec3) GroupNonUniformBroadcast 42 174 42
|
||||
176: 162(ptr) AccessChain 34(data) 170 57
|
||||
177: 22(i16vec4) Load 176
|
||||
178: 22(i16vec4) VectorShuffle 177 175 4 5 6 3
|
||||
Store 176 178
|
||||
179: 6(int) Load 8(invocation)
|
||||
180: 162(ptr) AccessChain 34(data) 67 57
|
||||
181: 22(i16vec4) Load 180
|
||||
182: 22(i16vec4) GroupNonUniformBroadcast 42 181 42
|
||||
183: 162(ptr) AccessChain 34(data) 179 57
|
||||
Store 183 182
|
||||
184: 6(int) Load 8(invocation)
|
||||
185: 155(ptr) AccessChain 34(data) 37 57 38
|
||||
186: 21(int16_t) Load 185
|
||||
187: 21(int16_t) GroupNonUniformBroadcastFirst 42 186
|
||||
188: 155(ptr) AccessChain 34(data) 184 57 38
|
||||
Store 188 187
|
||||
189: 6(int) Load 8(invocation)
|
||||
190: 162(ptr) AccessChain 34(data) 46 57
|
||||
191: 22(i16vec4) Load 190
|
||||
192:161(i16vec2) VectorShuffle 191 191 0 1
|
||||
193:161(i16vec2) GroupNonUniformBroadcastFirst 42 192
|
||||
194: 162(ptr) AccessChain 34(data) 189 57
|
||||
195: 22(i16vec4) Load 194
|
||||
196: 22(i16vec4) VectorShuffle 195 193 4 5 2 3
|
||||
Store 194 196
|
||||
197: 6(int) Load 8(invocation)
|
||||
198: 162(ptr) AccessChain 34(data) 57 57
|
||||
199: 22(i16vec4) Load 198
|
||||
200:171(i16vec3) VectorShuffle 199 199 0 1 2
|
||||
201:171(i16vec3) GroupNonUniformBroadcastFirst 42 200
|
||||
202: 162(ptr) AccessChain 34(data) 197 57
|
||||
203: 22(i16vec4) Load 202
|
||||
204: 22(i16vec4) VectorShuffle 203 201 4 5 6 3
|
||||
Store 202 204
|
||||
205: 6(int) Load 8(invocation)
|
||||
206: 162(ptr) AccessChain 34(data) 67 57
|
||||
207: 22(i16vec4) Load 206
|
||||
208: 22(i16vec4) GroupNonUniformBroadcastFirst 42 207
|
||||
209: 162(ptr) AccessChain 34(data) 205 57
|
||||
Store 209 208
|
||||
210: 6(int) Load 8(invocation)
|
||||
212: 211(ptr) AccessChain 34(data) 37 67 38
|
||||
213: 23(int16_t) Load 212
|
||||
214: 23(int16_t) GroupNonUniformBroadcast 42 213 42
|
||||
215: 211(ptr) AccessChain 34(data) 210 67 38
|
||||
Store 215 214
|
||||
216: 6(int) Load 8(invocation)
|
||||
219: 218(ptr) AccessChain 34(data) 46 67
|
||||
220: 24(i16vec4) Load 219
|
||||
221:217(i16vec2) VectorShuffle 220 220 0 1
|
||||
222:217(i16vec2) GroupNonUniformBroadcast 42 221 42
|
||||
223: 218(ptr) AccessChain 34(data) 216 67
|
||||
224: 24(i16vec4) Load 223
|
||||
225: 24(i16vec4) VectorShuffle 224 222 4 5 2 3
|
||||
Store 223 225
|
||||
226: 6(int) Load 8(invocation)
|
||||
228: 218(ptr) AccessChain 34(data) 57 67
|
||||
229: 24(i16vec4) Load 228
|
||||
230:227(i16vec3) VectorShuffle 229 229 0 1 2
|
||||
231:227(i16vec3) GroupNonUniformBroadcast 42 230 42
|
||||
232: 218(ptr) AccessChain 34(data) 226 67
|
||||
233: 24(i16vec4) Load 232
|
||||
234: 24(i16vec4) VectorShuffle 233 231 4 5 6 3
|
||||
Store 232 234
|
||||
235: 6(int) Load 8(invocation)
|
||||
236: 218(ptr) AccessChain 34(data) 67 67
|
||||
237: 24(i16vec4) Load 236
|
||||
238: 24(i16vec4) GroupNonUniformBroadcast 42 237 42
|
||||
239: 218(ptr) AccessChain 34(data) 235 67
|
||||
Store 239 238
|
||||
240: 6(int) Load 8(invocation)
|
||||
241: 211(ptr) AccessChain 34(data) 37 67 38
|
||||
242: 23(int16_t) Load 241
|
||||
243: 23(int16_t) GroupNonUniformBroadcastFirst 42 242
|
||||
244: 211(ptr) AccessChain 34(data) 240 67 38
|
||||
Store 244 243
|
||||
245: 6(int) Load 8(invocation)
|
||||
246: 218(ptr) AccessChain 34(data) 46 67
|
||||
247: 24(i16vec4) Load 246
|
||||
248:217(i16vec2) VectorShuffle 247 247 0 1
|
||||
249:217(i16vec2) GroupNonUniformBroadcastFirst 42 248
|
||||
250: 218(ptr) AccessChain 34(data) 245 67
|
||||
251: 24(i16vec4) Load 250
|
||||
252: 24(i16vec4) VectorShuffle 251 249 4 5 2 3
|
||||
Store 250 252
|
||||
253: 6(int) Load 8(invocation)
|
||||
254: 218(ptr) AccessChain 34(data) 57 67
|
||||
255: 24(i16vec4) Load 254
|
||||
256:227(i16vec3) VectorShuffle 255 255 0 1 2
|
||||
257:227(i16vec3) GroupNonUniformBroadcastFirst 42 256
|
||||
258: 218(ptr) AccessChain 34(data) 253 67
|
||||
259: 24(i16vec4) Load 258
|
||||
260: 24(i16vec4) VectorShuffle 259 257 4 5 6 3
|
||||
Store 258 260
|
||||
261: 6(int) Load 8(invocation)
|
||||
262: 218(ptr) AccessChain 34(data) 67 67
|
||||
263: 24(i16vec4) Load 262
|
||||
264: 24(i16vec4) GroupNonUniformBroadcastFirst 42 263
|
||||
265: 218(ptr) AccessChain 34(data) 261 67
|
||||
Store 265 264
|
||||
266: 6(int) Load 8(invocation)
|
||||
269: 268(ptr) AccessChain 34(data) 37 267 38
|
||||
270: 25(int64_t) Load 269
|
||||
271: 25(int64_t) GroupNonUniformBroadcast 42 270 42
|
||||
272: 268(ptr) AccessChain 34(data) 266 267 38
|
||||
Store 272 271
|
||||
273: 6(int) Load 8(invocation)
|
||||
276: 275(ptr) AccessChain 34(data) 46 267
|
||||
277: 26(i64vec4) Load 276
|
||||
278:274(i64vec2) VectorShuffle 277 277 0 1
|
||||
279:274(i64vec2) GroupNonUniformBroadcast 42 278 42
|
||||
280: 275(ptr) AccessChain 34(data) 273 267
|
||||
281: 26(i64vec4) Load 280
|
||||
282: 26(i64vec4) VectorShuffle 281 279 4 5 2 3
|
||||
Store 280 282
|
||||
283: 6(int) Load 8(invocation)
|
||||
285: 275(ptr) AccessChain 34(data) 57 267
|
||||
286: 26(i64vec4) Load 285
|
||||
287:284(i64vec3) VectorShuffle 286 286 0 1 2
|
||||
288:284(i64vec3) GroupNonUniformBroadcast 42 287 42
|
||||
289: 275(ptr) AccessChain 34(data) 283 267
|
||||
290: 26(i64vec4) Load 289
|
||||
291: 26(i64vec4) VectorShuffle 290 288 4 5 6 3
|
||||
Store 289 291
|
||||
292: 6(int) Load 8(invocation)
|
||||
293: 275(ptr) AccessChain 34(data) 67 267
|
||||
294: 26(i64vec4) Load 293
|
||||
295: 26(i64vec4) GroupNonUniformBroadcast 42 294 42
|
||||
296: 275(ptr) AccessChain 34(data) 292 267
|
||||
Store 296 295
|
||||
297: 6(int) Load 8(invocation)
|
||||
298: 268(ptr) AccessChain 34(data) 37 267 38
|
||||
299: 25(int64_t) Load 298
|
||||
300: 25(int64_t) GroupNonUniformBroadcastFirst 42 299
|
||||
301: 268(ptr) AccessChain 34(data) 297 267 38
|
||||
Store 301 300
|
||||
302: 6(int) Load 8(invocation)
|
||||
303: 275(ptr) AccessChain 34(data) 46 267
|
||||
304: 26(i64vec4) Load 303
|
||||
305:274(i64vec2) VectorShuffle 304 304 0 1
|
||||
306:274(i64vec2) GroupNonUniformBroadcastFirst 42 305
|
||||
307: 275(ptr) AccessChain 34(data) 302 267
|
||||
308: 26(i64vec4) Load 307
|
||||
309: 26(i64vec4) VectorShuffle 308 306 4 5 2 3
|
||||
Store 307 309
|
||||
310: 6(int) Load 8(invocation)
|
||||
311: 275(ptr) AccessChain 34(data) 57 267
|
||||
312: 26(i64vec4) Load 311
|
||||
313:284(i64vec3) VectorShuffle 312 312 0 1 2
|
||||
314:284(i64vec3) GroupNonUniformBroadcastFirst 42 313
|
||||
315: 275(ptr) AccessChain 34(data) 310 267
|
||||
316: 26(i64vec4) Load 315
|
||||
317: 26(i64vec4) VectorShuffle 316 314 4 5 6 3
|
||||
Store 315 317
|
||||
318: 6(int) Load 8(invocation)
|
||||
319: 275(ptr) AccessChain 34(data) 67 267
|
||||
320: 26(i64vec4) Load 319
|
||||
321: 26(i64vec4) GroupNonUniformBroadcastFirst 42 320
|
||||
322: 275(ptr) AccessChain 34(data) 318 267
|
||||
Store 322 321
|
||||
323: 6(int) Load 8(invocation)
|
||||
326: 325(ptr) AccessChain 34(data) 37 324 38
|
||||
327: 27(int64_t) Load 326
|
||||
328: 27(int64_t) GroupNonUniformBroadcast 42 327 42
|
||||
329: 325(ptr) AccessChain 34(data) 323 324 38
|
||||
Store 329 328
|
||||
330: 6(int) Load 8(invocation)
|
||||
333: 332(ptr) AccessChain 34(data) 46 324
|
||||
334: 28(i64vec4) Load 333
|
||||
335:331(i64vec2) VectorShuffle 334 334 0 1
|
||||
336:331(i64vec2) GroupNonUniformBroadcast 42 335 42
|
||||
337: 332(ptr) AccessChain 34(data) 330 324
|
||||
338: 28(i64vec4) Load 337
|
||||
339: 28(i64vec4) VectorShuffle 338 336 4 5 2 3
|
||||
Store 337 339
|
||||
340: 6(int) Load 8(invocation)
|
||||
342: 332(ptr) AccessChain 34(data) 57 324
|
||||
343: 28(i64vec4) Load 342
|
||||
344:341(i64vec3) VectorShuffle 343 343 0 1 2
|
||||
345:341(i64vec3) GroupNonUniformBroadcast 42 344 42
|
||||
346: 332(ptr) AccessChain 34(data) 340 324
|
||||
347: 28(i64vec4) Load 346
|
||||
348: 28(i64vec4) VectorShuffle 347 345 4 5 6 3
|
||||
Store 346 348
|
||||
349: 6(int) Load 8(invocation)
|
||||
350: 332(ptr) AccessChain 34(data) 67 324
|
||||
351: 28(i64vec4) Load 350
|
||||
352: 28(i64vec4) GroupNonUniformBroadcast 42 351 42
|
||||
353: 332(ptr) AccessChain 34(data) 349 324
|
||||
Store 353 352
|
||||
354: 6(int) Load 8(invocation)
|
||||
355: 325(ptr) AccessChain 34(data) 37 324 38
|
||||
356: 27(int64_t) Load 355
|
||||
357: 27(int64_t) GroupNonUniformBroadcastFirst 42 356
|
||||
358: 325(ptr) AccessChain 34(data) 354 324 38
|
||||
Store 358 357
|
||||
359: 6(int) Load 8(invocation)
|
||||
360: 332(ptr) AccessChain 34(data) 46 324
|
||||
361: 28(i64vec4) Load 360
|
||||
362:331(i64vec2) VectorShuffle 361 361 0 1
|
||||
363:331(i64vec2) GroupNonUniformBroadcastFirst 42 362
|
||||
364: 332(ptr) AccessChain 34(data) 359 324
|
||||
365: 28(i64vec4) Load 364
|
||||
366: 28(i64vec4) VectorShuffle 365 363 4 5 2 3
|
||||
Store 364 366
|
||||
367: 6(int) Load 8(invocation)
|
||||
368: 332(ptr) AccessChain 34(data) 57 324
|
||||
369: 28(i64vec4) Load 368
|
||||
370:341(i64vec3) VectorShuffle 369 369 0 1 2
|
||||
371:341(i64vec3) GroupNonUniformBroadcastFirst 42 370
|
||||
372: 332(ptr) AccessChain 34(data) 367 324
|
||||
373: 28(i64vec4) Load 372
|
||||
374: 28(i64vec4) VectorShuffle 373 371 4 5 6 3
|
||||
Store 372 374
|
||||
375: 6(int) Load 8(invocation)
|
||||
376: 332(ptr) AccessChain 34(data) 67 324
|
||||
377: 28(i64vec4) Load 376
|
||||
378: 28(i64vec4) GroupNonUniformBroadcastFirst 42 377
|
||||
379: 332(ptr) AccessChain 34(data) 375 324
|
||||
Store 379 378
|
||||
380: 6(int) Load 8(invocation)
|
||||
383: 382(ptr) AccessChain 34(data) 37 381 38
|
||||
384:29(float16_t) Load 383
|
||||
385:29(float16_t) GroupNonUniformBroadcast 42 384 42
|
||||
386: 382(ptr) AccessChain 34(data) 380 381 38
|
||||
Store 386 385
|
||||
387: 6(int) Load 8(invocation)
|
||||
390: 389(ptr) AccessChain 34(data) 46 381
|
||||
391: 30(f16vec4) Load 390
|
||||
392:388(f16vec2) VectorShuffle 391 391 0 1
|
||||
393:388(f16vec2) GroupNonUniformBroadcast 42 392 42
|
||||
394: 389(ptr) AccessChain 34(data) 387 381
|
||||
395: 30(f16vec4) Load 394
|
||||
396: 30(f16vec4) VectorShuffle 395 393 4 5 2 3
|
||||
Store 394 396
|
||||
397: 6(int) Load 8(invocation)
|
||||
399: 389(ptr) AccessChain 34(data) 57 381
|
||||
400: 30(f16vec4) Load 399
|
||||
401:398(f16vec3) VectorShuffle 400 400 0 1 2
|
||||
402:398(f16vec3) GroupNonUniformBroadcast 42 401 42
|
||||
403: 389(ptr) AccessChain 34(data) 397 381
|
||||
404: 30(f16vec4) Load 403
|
||||
405: 30(f16vec4) VectorShuffle 404 402 4 5 6 3
|
||||
Store 403 405
|
||||
406: 6(int) Load 8(invocation)
|
||||
407: 389(ptr) AccessChain 34(data) 67 381
|
||||
408: 30(f16vec4) Load 407
|
||||
409: 30(f16vec4) GroupNonUniformBroadcast 42 408 42
|
||||
410: 389(ptr) AccessChain 34(data) 406 381
|
||||
Store 410 409
|
||||
411: 6(int) Load 8(invocation)
|
||||
412: 382(ptr) AccessChain 34(data) 37 381 38
|
||||
413:29(float16_t) Load 412
|
||||
414:29(float16_t) GroupNonUniformBroadcastFirst 42 413
|
||||
415: 382(ptr) AccessChain 34(data) 411 381 38
|
||||
Store 415 414
|
||||
416: 6(int) Load 8(invocation)
|
||||
417: 389(ptr) AccessChain 34(data) 46 381
|
||||
418: 30(f16vec4) Load 417
|
||||
419:388(f16vec2) VectorShuffle 418 418 0 1
|
||||
420:388(f16vec2) GroupNonUniformBroadcastFirst 42 419
|
||||
421: 389(ptr) AccessChain 34(data) 416 381
|
||||
422: 30(f16vec4) Load 421
|
||||
423: 30(f16vec4) VectorShuffle 422 420 4 5 2 3
|
||||
Store 421 423
|
||||
424: 6(int) Load 8(invocation)
|
||||
425: 389(ptr) AccessChain 34(data) 57 381
|
||||
426: 30(f16vec4) Load 425
|
||||
427:398(f16vec3) VectorShuffle 426 426 0 1 2
|
||||
428:398(f16vec3) GroupNonUniformBroadcastFirst 42 427
|
||||
429: 389(ptr) AccessChain 34(data) 424 381
|
||||
430: 30(f16vec4) Load 429
|
||||
431: 30(f16vec4) VectorShuffle 430 428 4 5 6 3
|
||||
Store 429 431
|
||||
432: 6(int) Load 8(invocation)
|
||||
433: 389(ptr) AccessChain 34(data) 67 381
|
||||
434: 30(f16vec4) Load 433
|
||||
435: 30(f16vec4) GroupNonUniformBroadcastFirst 42 434
|
||||
436: 389(ptr) AccessChain 34(data) 432 381
|
||||
Store 436 435
|
||||
Return
|
||||
FunctionEnd
|
61
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesBallotNeg.comp.out
vendored
Normal file
61
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesBallotNeg.comp.out
vendored
Normal file
@ -0,0 +1,61 @@
|
||||
spv.subgroupExtendedTypesBallotNeg.comp
|
||||
ERROR: 0:26: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:27: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:28: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:29: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:30: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:31: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:32: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:33: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:35: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:36: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:37: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:38: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:39: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:40: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:41: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:42: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:44: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:45: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:46: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:47: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:48: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:49: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:50: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:51: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:53: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:54: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:55: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:56: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:57: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:58: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:59: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:60: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:62: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:63: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:64: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:65: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:66: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:67: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:68: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:69: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:71: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:72: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:73: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:74: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:75: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:76: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:77: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:78: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:80: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:81: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:82: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:83: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:84: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:85: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:86: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:87: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 56 compilation errors. No code generated.
|
||||
|
||||
|
||||
SPIR-V is not generated for failed compile or link
|
9
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesBasic.comp.out
vendored
Normal file
9
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesBasic.comp.out
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
spv.subgroupExtendedTypesBasic.comp
|
||||
ERROR: #version: compute shaders require es profile with version 310 or above, or non-es profile with version 420 or above
|
||||
ERROR: #version: statement must appear first in es-profile shader; before comments or newlines
|
||||
ERROR: 1 compilation errors. No code generated.
|
||||
|
||||
|
||||
ERROR: Linking compute stage: Missing entry point: Each stage requires one entry point
|
||||
|
||||
SPIR-V is not generated for failed compile or link
|
1520
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesClustered.comp.out
vendored
Normal file
1520
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesClustered.comp.out
vendored
Normal file
File diff suppressed because it is too large
Load Diff
189
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesClusteredNeg.comp.out
vendored
Normal file
189
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesClusteredNeg.comp.out
vendored
Normal file
@ -0,0 +1,189 @@
|
||||
spv.subgroupExtendedTypesClusteredNeg.comp
|
||||
ERROR: 0:26: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:27: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:28: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:29: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:31: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:32: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:33: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:34: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:36: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:37: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:38: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:39: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:41: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:42: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:43: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:44: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:46: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:47: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:48: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:49: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:51: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:52: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:53: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:54: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:56: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:57: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:58: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:59: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:61: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:62: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:63: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:64: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:66: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:67: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:68: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:69: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:71: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:72: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:73: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:74: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:76: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:77: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:78: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:79: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:81: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:82: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:83: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:84: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:86: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:87: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:88: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:89: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:91: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:92: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:93: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:94: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:96: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:97: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:98: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:99: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:101: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:102: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:103: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:104: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:106: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:107: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:108: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:109: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:111: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:112: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:113: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:114: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:116: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:117: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:118: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:119: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:121: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:122: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:123: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:124: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:126: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:127: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:128: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:129: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:131: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:132: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:133: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:134: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:136: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:137: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:138: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:139: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:141: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:142: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:143: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:144: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:146: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:147: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:148: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:149: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:151: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:152: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:153: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:154: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:156: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:157: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:158: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:159: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:161: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:162: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:163: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:164: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:166: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:167: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:168: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:169: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:171: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:172: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:173: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:174: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:176: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:177: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:178: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:179: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:181: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:182: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:183: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:184: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:186: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:187: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:188: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:189: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:191: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:192: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:193: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:194: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:196: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:197: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:198: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:199: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:201: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:202: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:203: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:204: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:206: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:207: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:208: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:209: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:211: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:212: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:213: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:214: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:216: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:217: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:218: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:219: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:221: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:222: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:223: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:224: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:226: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:227: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:228: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:229: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:231: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:232: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:233: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:234: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:236: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:237: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:238: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:239: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:241: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:242: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:243: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:244: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:246: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:247: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:248: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:249: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:251: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:252: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:253: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:254: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 184 compilation errors. No code generated.
|
||||
|
||||
|
||||
SPIR-V is not generated for failed compile or link
|
1835
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesPartitioned.comp.out
vendored
Normal file
1835
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesPartitioned.comp.out
vendored
Normal file
File diff suppressed because it is too large
Load Diff
217
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesPartitionedNeg.comp.out
vendored
Normal file
217
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesPartitionedNeg.comp.out
vendored
Normal file
@ -0,0 +1,217 @@
|
||||
spv.subgroupExtendedTypesPartitionedNeg.comp
|
||||
ERROR: 0:27: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:28: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:29: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:30: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:32: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:33: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:34: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:35: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:37: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:38: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:39: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:40: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:42: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:43: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:44: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:45: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:47: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:48: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:49: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:50: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:52: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:53: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:54: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:55: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:57: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:58: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:59: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:60: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:62: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:63: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:64: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:65: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:67: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:68: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:69: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:70: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:72: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:73: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:74: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:75: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:77: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:78: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:79: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:80: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:82: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:83: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:84: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:85: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:87: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:88: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:89: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:90: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:92: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:93: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:94: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:95: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:97: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:98: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:99: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:100: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:102: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:103: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:104: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:105: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:107: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:108: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:109: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:110: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:112: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:113: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:114: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:115: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:117: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:118: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:119: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:120: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:122: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:123: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:124: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:125: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:127: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:128: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:129: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:130: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:132: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:133: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:134: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:135: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:137: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:138: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:139: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:140: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:142: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:143: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:144: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:145: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:147: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:148: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:149: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:150: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:152: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:153: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:154: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:155: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:157: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:158: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:159: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:160: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:162: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:163: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:164: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:165: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:167: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:168: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:169: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:170: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:172: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:173: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:174: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:175: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:177: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:178: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:179: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:180: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:182: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:183: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:184: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:185: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:187: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:188: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:189: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:190: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:192: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:193: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:194: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:195: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:197: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:198: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:199: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:200: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:202: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:203: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:204: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:205: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:207: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:208: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:209: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:210: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:212: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:213: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:214: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:215: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:217: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:218: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:219: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:220: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:222: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:223: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:224: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:225: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:227: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:228: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:229: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:230: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:232: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:233: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:234: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:235: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:237: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:238: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:239: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:240: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:242: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:243: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:244: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:245: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:247: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:248: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:249: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:250: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:252: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:253: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:254: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:255: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:257: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:258: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:259: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:260: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:262: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:263: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:264: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:265: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:267: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:268: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:269: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:270: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:272: ' temp highp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:273: ' temp highp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:274: ' temp highp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:275: 'layout( column_major std430) buffer highp 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:277: ' temp highp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:278: ' temp highp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:279: ' temp highp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:280: 'layout( column_major std430) buffer highp 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:282: ' temp highp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:283: ' temp highp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:284: ' temp highp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:285: 'layout( column_major std430) buffer highp 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:287: ' temp highp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:288: ' temp highp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:289: ' temp highp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:290: 'layout( column_major std430) buffer highp 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 212 compilation errors. No code generated.
|
||||
|
||||
|
||||
SPIR-V is not generated for failed compile or link
|
981
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesQuad.comp.out
vendored
Normal file
981
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesQuad.comp.out
vendored
Normal file
@ -0,0 +1,981 @@
|
||||
spv.subgroupExtendedTypesQuad.comp
|
||||
// Module Version 10300
|
||||
// Generated by (magic number): 80007
|
||||
// Id's are bound by 806
|
||||
|
||||
Capability Shader
|
||||
Capability Float16
|
||||
Capability Int64
|
||||
Capability Int16
|
||||
Capability Int8
|
||||
Capability GroupNonUniform
|
||||
Capability GroupNonUniformQuad
|
||||
Capability StorageUniformBufferBlock16
|
||||
Capability StorageBuffer8BitAccess
|
||||
Extension "SPV_KHR_8bit_storage"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel Logical GLSL450
|
||||
EntryPoint GLCompute 4 "main" 10 12
|
||||
ExecutionMode 4 LocalSize 8 1 1
|
||||
Source GLSL 450
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_float16"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int16"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int64"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int8"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_float16"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int16"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int64"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int8"
|
||||
SourceExtension "GL_KHR_shader_subgroup_basic"
|
||||
SourceExtension "GL_KHR_shader_subgroup_quad"
|
||||
Name 4 "main"
|
||||
Name 8 "invocation"
|
||||
Name 10 "gl_SubgroupInvocationID"
|
||||
Name 12 "gl_SubgroupSize"
|
||||
Name 31 "Buffers"
|
||||
MemberName 31(Buffers) 0 "i8"
|
||||
MemberName 31(Buffers) 1 "u8"
|
||||
MemberName 31(Buffers) 2 "i16"
|
||||
MemberName 31(Buffers) 3 "u16"
|
||||
MemberName 31(Buffers) 4 "i64"
|
||||
MemberName 31(Buffers) 5 "u64"
|
||||
MemberName 31(Buffers) 6 "f16"
|
||||
Name 34 "data"
|
||||
Decorate 10(gl_SubgroupInvocationID) RelaxedPrecision
|
||||
Decorate 10(gl_SubgroupInvocationID) BuiltIn SubgroupLocalInvocationId
|
||||
Decorate 11 RelaxedPrecision
|
||||
Decorate 12(gl_SubgroupSize) RelaxedPrecision
|
||||
Decorate 12(gl_SubgroupSize) BuiltIn SubgroupSize
|
||||
Decorate 13 RelaxedPrecision
|
||||
Decorate 14 RelaxedPrecision
|
||||
Decorate 16 RelaxedPrecision
|
||||
MemberDecorate 31(Buffers) 0 Offset 0
|
||||
MemberDecorate 31(Buffers) 1 Offset 4
|
||||
MemberDecorate 31(Buffers) 2 Offset 8
|
||||
MemberDecorate 31(Buffers) 3 Offset 16
|
||||
MemberDecorate 31(Buffers) 4 Offset 32
|
||||
MemberDecorate 31(Buffers) 5 Offset 64
|
||||
MemberDecorate 31(Buffers) 6 Offset 96
|
||||
Decorate 31(Buffers) Block
|
||||
Decorate 34(data) DescriptorSet 0
|
||||
Decorate 34(data) Binding 0
|
||||
Decorate 805 BuiltIn WorkgroupSize
|
||||
2: TypeVoid
|
||||
3: TypeFunction 2
|
||||
6: TypeInt 32 0
|
||||
7: TypePointer Function 6(int)
|
||||
9: TypePointer Input 6(int)
|
||||
10(gl_SubgroupInvocationID): 9(ptr) Variable Input
|
||||
12(gl_SubgroupSize): 9(ptr) Variable Input
|
||||
15: 6(int) Constant 4
|
||||
17: TypeInt 8 1
|
||||
18: TypeVector 17(int8_t) 4
|
||||
19: TypeInt 8 0
|
||||
20: TypeVector 19(int8_t) 4
|
||||
21: TypeInt 16 1
|
||||
22: TypeVector 21(int16_t) 4
|
||||
23: TypeInt 16 0
|
||||
24: TypeVector 23(int16_t) 4
|
||||
25: TypeInt 64 1
|
||||
26: TypeVector 25(int64_t) 4
|
||||
27: TypeInt 64 0
|
||||
28: TypeVector 27(int64_t) 4
|
||||
29: TypeFloat 16
|
||||
30: TypeVector 29(float16_t) 4
|
||||
31(Buffers): TypeStruct 18(i8vec4) 20(i8vec4) 22(i16vec4) 24(i16vec4) 26(i64vec4) 28(i64vec4) 30(f16vec4)
|
||||
32: TypeArray 31(Buffers) 15
|
||||
33: TypePointer StorageBuffer 32
|
||||
34(data): 33(ptr) Variable StorageBuffer
|
||||
36: TypeInt 32 1
|
||||
37: 36(int) Constant 0
|
||||
38: 6(int) Constant 0
|
||||
39: TypePointer StorageBuffer 17(int8_t)
|
||||
42: 6(int) Constant 1
|
||||
43: 6(int) Constant 3
|
||||
47: 36(int) Constant 1
|
||||
48: TypeVector 17(int8_t) 2
|
||||
49: TypePointer StorageBuffer 18(i8vec4)
|
||||
58: 36(int) Constant 2
|
||||
59: TypeVector 17(int8_t) 3
|
||||
68: 36(int) Constant 3
|
||||
128: 6(int) Constant 2
|
||||
153: TypePointer StorageBuffer 19(int8_t)
|
||||
159: TypeVector 19(int8_t) 2
|
||||
160: TypePointer StorageBuffer 20(i8vec4)
|
||||
169: TypeVector 19(int8_t) 3
|
||||
261: TypePointer StorageBuffer 21(int16_t)
|
||||
267: TypeVector 21(int16_t) 2
|
||||
268: TypePointer StorageBuffer 22(i16vec4)
|
||||
277: TypeVector 21(int16_t) 3
|
||||
369: TypePointer StorageBuffer 23(int16_t)
|
||||
375: TypeVector 23(int16_t) 2
|
||||
376: TypePointer StorageBuffer 24(i16vec4)
|
||||
385: TypeVector 23(int16_t) 3
|
||||
477: 36(int) Constant 4
|
||||
478: TypePointer StorageBuffer 25(int64_t)
|
||||
484: TypeVector 25(int64_t) 2
|
||||
485: TypePointer StorageBuffer 26(i64vec4)
|
||||
494: TypeVector 25(int64_t) 3
|
||||
586: 36(int) Constant 5
|
||||
587: TypePointer StorageBuffer 27(int64_t)
|
||||
593: TypeVector 27(int64_t) 2
|
||||
594: TypePointer StorageBuffer 28(i64vec4)
|
||||
603: TypeVector 27(int64_t) 3
|
||||
695: 36(int) Constant 6
|
||||
696: TypePointer StorageBuffer 29(float16_t)
|
||||
702: TypeVector 29(float16_t) 2
|
||||
703: TypePointer StorageBuffer 30(f16vec4)
|
||||
712: TypeVector 29(float16_t) 3
|
||||
803: TypeVector 6(int) 3
|
||||
804: 6(int) Constant 8
|
||||
805: 803(ivec3) ConstantComposite 804 42 42
|
||||
4(main): 2 Function None 3
|
||||
5: Label
|
||||
8(invocation): 7(ptr) Variable Function
|
||||
11: 6(int) Load 10(gl_SubgroupInvocationID)
|
||||
13: 6(int) Load 12(gl_SubgroupSize)
|
||||
14: 6(int) IAdd 11 13
|
||||
16: 6(int) UMod 14 15
|
||||
Store 8(invocation) 16
|
||||
35: 6(int) Load 8(invocation)
|
||||
40: 39(ptr) AccessChain 34(data) 37 37 38
|
||||
41: 17(int8_t) Load 40
|
||||
44: 17(int8_t) GroupNonUniformQuadBroadcast 43 41 42
|
||||
45: 39(ptr) AccessChain 34(data) 35 37 38
|
||||
Store 45 44
|
||||
46: 6(int) Load 8(invocation)
|
||||
50: 49(ptr) AccessChain 34(data) 47 37
|
||||
51: 18(i8vec4) Load 50
|
||||
52: 48(i8vec2) VectorShuffle 51 51 0 1
|
||||
53: 48(i8vec2) GroupNonUniformQuadBroadcast 43 52 42
|
||||
54: 49(ptr) AccessChain 34(data) 46 37
|
||||
55: 18(i8vec4) Load 54
|
||||
56: 18(i8vec4) VectorShuffle 55 53 4 5 2 3
|
||||
Store 54 56
|
||||
57: 6(int) Load 8(invocation)
|
||||
60: 49(ptr) AccessChain 34(data) 58 37
|
||||
61: 18(i8vec4) Load 60
|
||||
62: 59(i8vec3) VectorShuffle 61 61 0 1 2
|
||||
63: 59(i8vec3) GroupNonUniformQuadBroadcast 43 62 42
|
||||
64: 49(ptr) AccessChain 34(data) 57 37
|
||||
65: 18(i8vec4) Load 64
|
||||
66: 18(i8vec4) VectorShuffle 65 63 4 5 6 3
|
||||
Store 64 66
|
||||
67: 6(int) Load 8(invocation)
|
||||
69: 49(ptr) AccessChain 34(data) 68 37
|
||||
70: 18(i8vec4) Load 69
|
||||
71: 18(i8vec4) GroupNonUniformQuadBroadcast 43 70 42
|
||||
72: 49(ptr) AccessChain 34(data) 67 37
|
||||
Store 72 71
|
||||
73: 6(int) Load 8(invocation)
|
||||
74: 39(ptr) AccessChain 34(data) 37 37 38
|
||||
75: 17(int8_t) Load 74
|
||||
76: 17(int8_t) GroupNonUniformQuadSwap 43 75 38
|
||||
77: 39(ptr) AccessChain 34(data) 73 37 38
|
||||
Store 77 76
|
||||
78: 6(int) Load 8(invocation)
|
||||
79: 49(ptr) AccessChain 34(data) 47 37
|
||||
80: 18(i8vec4) Load 79
|
||||
81: 48(i8vec2) VectorShuffle 80 80 0 1
|
||||
82: 48(i8vec2) GroupNonUniformQuadSwap 43 81 38
|
||||
83: 49(ptr) AccessChain 34(data) 78 37
|
||||
84: 18(i8vec4) Load 83
|
||||
85: 18(i8vec4) VectorShuffle 84 82 4 5 2 3
|
||||
Store 83 85
|
||||
86: 6(int) Load 8(invocation)
|
||||
87: 49(ptr) AccessChain 34(data) 58 37
|
||||
88: 18(i8vec4) Load 87
|
||||
89: 59(i8vec3) VectorShuffle 88 88 0 1 2
|
||||
90: 59(i8vec3) GroupNonUniformQuadSwap 43 89 38
|
||||
91: 49(ptr) AccessChain 34(data) 86 37
|
||||
92: 18(i8vec4) Load 91
|
||||
93: 18(i8vec4) VectorShuffle 92 90 4 5 6 3
|
||||
Store 91 93
|
||||
94: 6(int) Load 8(invocation)
|
||||
95: 49(ptr) AccessChain 34(data) 68 37
|
||||
96: 18(i8vec4) Load 95
|
||||
97: 18(i8vec4) GroupNonUniformQuadSwap 43 96 38
|
||||
98: 49(ptr) AccessChain 34(data) 94 37
|
||||
Store 98 97
|
||||
99: 6(int) Load 8(invocation)
|
||||
100: 39(ptr) AccessChain 34(data) 37 37 38
|
||||
101: 17(int8_t) Load 100
|
||||
102: 17(int8_t) GroupNonUniformQuadSwap 43 101 42
|
||||
103: 39(ptr) AccessChain 34(data) 99 37 38
|
||||
Store 103 102
|
||||
104: 6(int) Load 8(invocation)
|
||||
105: 49(ptr) AccessChain 34(data) 47 37
|
||||
106: 18(i8vec4) Load 105
|
||||
107: 48(i8vec2) VectorShuffle 106 106 0 1
|
||||
108: 48(i8vec2) GroupNonUniformQuadSwap 43 107 42
|
||||
109: 49(ptr) AccessChain 34(data) 104 37
|
||||
110: 18(i8vec4) Load 109
|
||||
111: 18(i8vec4) VectorShuffle 110 108 4 5 2 3
|
||||
Store 109 111
|
||||
112: 6(int) Load 8(invocation)
|
||||
113: 49(ptr) AccessChain 34(data) 58 37
|
||||
114: 18(i8vec4) Load 113
|
||||
115: 59(i8vec3) VectorShuffle 114 114 0 1 2
|
||||
116: 59(i8vec3) GroupNonUniformQuadSwap 43 115 42
|
||||
117: 49(ptr) AccessChain 34(data) 112 37
|
||||
118: 18(i8vec4) Load 117
|
||||
119: 18(i8vec4) VectorShuffle 118 116 4 5 6 3
|
||||
Store 117 119
|
||||
120: 6(int) Load 8(invocation)
|
||||
121: 49(ptr) AccessChain 34(data) 68 37
|
||||
122: 18(i8vec4) Load 121
|
||||
123: 18(i8vec4) GroupNonUniformQuadSwap 43 122 42
|
||||
124: 49(ptr) AccessChain 34(data) 120 37
|
||||
Store 124 123
|
||||
125: 6(int) Load 8(invocation)
|
||||
126: 39(ptr) AccessChain 34(data) 37 37 38
|
||||
127: 17(int8_t) Load 126
|
||||
129: 17(int8_t) GroupNonUniformQuadSwap 43 127 128
|
||||
130: 39(ptr) AccessChain 34(data) 125 37 38
|
||||
Store 130 129
|
||||
131: 6(int) Load 8(invocation)
|
||||
132: 49(ptr) AccessChain 34(data) 47 37
|
||||
133: 18(i8vec4) Load 132
|
||||
134: 48(i8vec2) VectorShuffle 133 133 0 1
|
||||
135: 48(i8vec2) GroupNonUniformQuadSwap 43 134 128
|
||||
136: 49(ptr) AccessChain 34(data) 131 37
|
||||
137: 18(i8vec4) Load 136
|
||||
138: 18(i8vec4) VectorShuffle 137 135 4 5 2 3
|
||||
Store 136 138
|
||||
139: 6(int) Load 8(invocation)
|
||||
140: 49(ptr) AccessChain 34(data) 58 37
|
||||
141: 18(i8vec4) Load 140
|
||||
142: 59(i8vec3) VectorShuffle 141 141 0 1 2
|
||||
143: 59(i8vec3) GroupNonUniformQuadSwap 43 142 128
|
||||
144: 49(ptr) AccessChain 34(data) 139 37
|
||||
145: 18(i8vec4) Load 144
|
||||
146: 18(i8vec4) VectorShuffle 145 143 4 5 6 3
|
||||
Store 144 146
|
||||
147: 6(int) Load 8(invocation)
|
||||
148: 49(ptr) AccessChain 34(data) 68 37
|
||||
149: 18(i8vec4) Load 148
|
||||
150: 18(i8vec4) GroupNonUniformQuadSwap 43 149 128
|
||||
151: 49(ptr) AccessChain 34(data) 147 37
|
||||
Store 151 150
|
||||
152: 6(int) Load 8(invocation)
|
||||
154: 153(ptr) AccessChain 34(data) 37 47 38
|
||||
155: 19(int8_t) Load 154
|
||||
156: 19(int8_t) GroupNonUniformQuadBroadcast 43 155 42
|
||||
157: 153(ptr) AccessChain 34(data) 152 47 38
|
||||
Store 157 156
|
||||
158: 6(int) Load 8(invocation)
|
||||
161: 160(ptr) AccessChain 34(data) 47 47
|
||||
162: 20(i8vec4) Load 161
|
||||
163: 159(i8vec2) VectorShuffle 162 162 0 1
|
||||
164: 159(i8vec2) GroupNonUniformQuadBroadcast 43 163 42
|
||||
165: 160(ptr) AccessChain 34(data) 158 47
|
||||
166: 20(i8vec4) Load 165
|
||||
167: 20(i8vec4) VectorShuffle 166 164 4 5 2 3
|
||||
Store 165 167
|
||||
168: 6(int) Load 8(invocation)
|
||||
170: 160(ptr) AccessChain 34(data) 58 47
|
||||
171: 20(i8vec4) Load 170
|
||||
172: 169(i8vec3) VectorShuffle 171 171 0 1 2
|
||||
173: 169(i8vec3) GroupNonUniformQuadBroadcast 43 172 42
|
||||
174: 160(ptr) AccessChain 34(data) 168 47
|
||||
175: 20(i8vec4) Load 174
|
||||
176: 20(i8vec4) VectorShuffle 175 173 4 5 6 3
|
||||
Store 174 176
|
||||
177: 6(int) Load 8(invocation)
|
||||
178: 160(ptr) AccessChain 34(data) 68 47
|
||||
179: 20(i8vec4) Load 178
|
||||
180: 20(i8vec4) GroupNonUniformQuadBroadcast 43 179 42
|
||||
181: 160(ptr) AccessChain 34(data) 177 47
|
||||
Store 181 180
|
||||
182: 6(int) Load 8(invocation)
|
||||
183: 153(ptr) AccessChain 34(data) 37 47 38
|
||||
184: 19(int8_t) Load 183
|
||||
185: 19(int8_t) GroupNonUniformQuadSwap 43 184 38
|
||||
186: 153(ptr) AccessChain 34(data) 182 47 38
|
||||
Store 186 185
|
||||
187: 6(int) Load 8(invocation)
|
||||
188: 160(ptr) AccessChain 34(data) 47 47
|
||||
189: 20(i8vec4) Load 188
|
||||
190: 159(i8vec2) VectorShuffle 189 189 0 1
|
||||
191: 159(i8vec2) GroupNonUniformQuadSwap 43 190 38
|
||||
192: 160(ptr) AccessChain 34(data) 187 47
|
||||
193: 20(i8vec4) Load 192
|
||||
194: 20(i8vec4) VectorShuffle 193 191 4 5 2 3
|
||||
Store 192 194
|
||||
195: 6(int) Load 8(invocation)
|
||||
196: 160(ptr) AccessChain 34(data) 58 47
|
||||
197: 20(i8vec4) Load 196
|
||||
198: 169(i8vec3) VectorShuffle 197 197 0 1 2
|
||||
199: 169(i8vec3) GroupNonUniformQuadSwap 43 198 38
|
||||
200: 160(ptr) AccessChain 34(data) 195 47
|
||||
201: 20(i8vec4) Load 200
|
||||
202: 20(i8vec4) VectorShuffle 201 199 4 5 6 3
|
||||
Store 200 202
|
||||
203: 6(int) Load 8(invocation)
|
||||
204: 160(ptr) AccessChain 34(data) 68 47
|
||||
205: 20(i8vec4) Load 204
|
||||
206: 20(i8vec4) GroupNonUniformQuadSwap 43 205 38
|
||||
207: 160(ptr) AccessChain 34(data) 203 47
|
||||
Store 207 206
|
||||
208: 6(int) Load 8(invocation)
|
||||
209: 153(ptr) AccessChain 34(data) 37 47 38
|
||||
210: 19(int8_t) Load 209
|
||||
211: 19(int8_t) GroupNonUniformQuadSwap 43 210 42
|
||||
212: 153(ptr) AccessChain 34(data) 208 47 38
|
||||
Store 212 211
|
||||
213: 6(int) Load 8(invocation)
|
||||
214: 160(ptr) AccessChain 34(data) 47 47
|
||||
215: 20(i8vec4) Load 214
|
||||
216: 159(i8vec2) VectorShuffle 215 215 0 1
|
||||
217: 159(i8vec2) GroupNonUniformQuadSwap 43 216 42
|
||||
218: 160(ptr) AccessChain 34(data) 213 47
|
||||
219: 20(i8vec4) Load 218
|
||||
220: 20(i8vec4) VectorShuffle 219 217 4 5 2 3
|
||||
Store 218 220
|
||||
221: 6(int) Load 8(invocation)
|
||||
222: 160(ptr) AccessChain 34(data) 58 47
|
||||
223: 20(i8vec4) Load 222
|
||||
224: 169(i8vec3) VectorShuffle 223 223 0 1 2
|
||||
225: 169(i8vec3) GroupNonUniformQuadSwap 43 224 42
|
||||
226: 160(ptr) AccessChain 34(data) 221 47
|
||||
227: 20(i8vec4) Load 226
|
||||
228: 20(i8vec4) VectorShuffle 227 225 4 5 6 3
|
||||
Store 226 228
|
||||
229: 6(int) Load 8(invocation)
|
||||
230: 160(ptr) AccessChain 34(data) 68 47
|
||||
231: 20(i8vec4) Load 230
|
||||
232: 20(i8vec4) GroupNonUniformQuadSwap 43 231 42
|
||||
233: 160(ptr) AccessChain 34(data) 229 47
|
||||
Store 233 232
|
||||
234: 6(int) Load 8(invocation)
|
||||
235: 153(ptr) AccessChain 34(data) 37 47 38
|
||||
236: 19(int8_t) Load 235
|
||||
237: 19(int8_t) GroupNonUniformQuadSwap 43 236 128
|
||||
238: 153(ptr) AccessChain 34(data) 234 47 38
|
||||
Store 238 237
|
||||
239: 6(int) Load 8(invocation)
|
||||
240: 160(ptr) AccessChain 34(data) 47 47
|
||||
241: 20(i8vec4) Load 240
|
||||
242: 159(i8vec2) VectorShuffle 241 241 0 1
|
||||
243: 159(i8vec2) GroupNonUniformQuadSwap 43 242 128
|
||||
244: 160(ptr) AccessChain 34(data) 239 47
|
||||
245: 20(i8vec4) Load 244
|
||||
246: 20(i8vec4) VectorShuffle 245 243 4 5 2 3
|
||||
Store 244 246
|
||||
247: 6(int) Load 8(invocation)
|
||||
248: 160(ptr) AccessChain 34(data) 58 47
|
||||
249: 20(i8vec4) Load 248
|
||||
250: 169(i8vec3) VectorShuffle 249 249 0 1 2
|
||||
251: 169(i8vec3) GroupNonUniformQuadSwap 43 250 128
|
||||
252: 160(ptr) AccessChain 34(data) 247 47
|
||||
253: 20(i8vec4) Load 252
|
||||
254: 20(i8vec4) VectorShuffle 253 251 4 5 6 3
|
||||
Store 252 254
|
||||
255: 6(int) Load 8(invocation)
|
||||
256: 160(ptr) AccessChain 34(data) 68 47
|
||||
257: 20(i8vec4) Load 256
|
||||
258: 20(i8vec4) GroupNonUniformQuadSwap 43 257 128
|
||||
259: 160(ptr) AccessChain 34(data) 255 47
|
||||
Store 259 258
|
||||
260: 6(int) Load 8(invocation)
|
||||
262: 261(ptr) AccessChain 34(data) 37 58 38
|
||||
263: 21(int16_t) Load 262
|
||||
264: 21(int16_t) GroupNonUniformQuadBroadcast 43 263 42
|
||||
265: 261(ptr) AccessChain 34(data) 260 58 38
|
||||
Store 265 264
|
||||
266: 6(int) Load 8(invocation)
|
||||
269: 268(ptr) AccessChain 34(data) 47 58
|
||||
270: 22(i16vec4) Load 269
|
||||
271:267(i16vec2) VectorShuffle 270 270 0 1
|
||||
272:267(i16vec2) GroupNonUniformQuadBroadcast 43 271 42
|
||||
273: 268(ptr) AccessChain 34(data) 266 58
|
||||
274: 22(i16vec4) Load 273
|
||||
275: 22(i16vec4) VectorShuffle 274 272 4 5 2 3
|
||||
Store 273 275
|
||||
276: 6(int) Load 8(invocation)
|
||||
278: 268(ptr) AccessChain 34(data) 58 58
|
||||
279: 22(i16vec4) Load 278
|
||||
280:277(i16vec3) VectorShuffle 279 279 0 1 2
|
||||
281:277(i16vec3) GroupNonUniformQuadBroadcast 43 280 42
|
||||
282: 268(ptr) AccessChain 34(data) 276 58
|
||||
283: 22(i16vec4) Load 282
|
||||
284: 22(i16vec4) VectorShuffle 283 281 4 5 6 3
|
||||
Store 282 284
|
||||
285: 6(int) Load 8(invocation)
|
||||
286: 268(ptr) AccessChain 34(data) 68 58
|
||||
287: 22(i16vec4) Load 286
|
||||
288: 22(i16vec4) GroupNonUniformQuadBroadcast 43 287 42
|
||||
289: 268(ptr) AccessChain 34(data) 285 58
|
||||
Store 289 288
|
||||
290: 6(int) Load 8(invocation)
|
||||
291: 261(ptr) AccessChain 34(data) 37 58 38
|
||||
292: 21(int16_t) Load 291
|
||||
293: 21(int16_t) GroupNonUniformQuadSwap 43 292 38
|
||||
294: 261(ptr) AccessChain 34(data) 290 58 38
|
||||
Store 294 293
|
||||
295: 6(int) Load 8(invocation)
|
||||
296: 268(ptr) AccessChain 34(data) 47 58
|
||||
297: 22(i16vec4) Load 296
|
||||
298:267(i16vec2) VectorShuffle 297 297 0 1
|
||||
299:267(i16vec2) GroupNonUniformQuadSwap 43 298 38
|
||||
300: 268(ptr) AccessChain 34(data) 295 58
|
||||
301: 22(i16vec4) Load 300
|
||||
302: 22(i16vec4) VectorShuffle 301 299 4 5 2 3
|
||||
Store 300 302
|
||||
303: 6(int) Load 8(invocation)
|
||||
304: 268(ptr) AccessChain 34(data) 58 58
|
||||
305: 22(i16vec4) Load 304
|
||||
306:277(i16vec3) VectorShuffle 305 305 0 1 2
|
||||
307:277(i16vec3) GroupNonUniformQuadSwap 43 306 38
|
||||
308: 268(ptr) AccessChain 34(data) 303 58
|
||||
309: 22(i16vec4) Load 308
|
||||
310: 22(i16vec4) VectorShuffle 309 307 4 5 6 3
|
||||
Store 308 310
|
||||
311: 6(int) Load 8(invocation)
|
||||
312: 268(ptr) AccessChain 34(data) 68 58
|
||||
313: 22(i16vec4) Load 312
|
||||
314: 22(i16vec4) GroupNonUniformQuadSwap 43 313 38
|
||||
315: 268(ptr) AccessChain 34(data) 311 58
|
||||
Store 315 314
|
||||
316: 6(int) Load 8(invocation)
|
||||
317: 261(ptr) AccessChain 34(data) 37 58 38
|
||||
318: 21(int16_t) Load 317
|
||||
319: 21(int16_t) GroupNonUniformQuadSwap 43 318 42
|
||||
320: 261(ptr) AccessChain 34(data) 316 58 38
|
||||
Store 320 319
|
||||
321: 6(int) Load 8(invocation)
|
||||
322: 268(ptr) AccessChain 34(data) 47 58
|
||||
323: 22(i16vec4) Load 322
|
||||
324:267(i16vec2) VectorShuffle 323 323 0 1
|
||||
325:267(i16vec2) GroupNonUniformQuadSwap 43 324 42
|
||||
326: 268(ptr) AccessChain 34(data) 321 58
|
||||
327: 22(i16vec4) Load 326
|
||||
328: 22(i16vec4) VectorShuffle 327 325 4 5 2 3
|
||||
Store 326 328
|
||||
329: 6(int) Load 8(invocation)
|
||||
330: 268(ptr) AccessChain 34(data) 58 58
|
||||
331: 22(i16vec4) Load 330
|
||||
332:277(i16vec3) VectorShuffle 331 331 0 1 2
|
||||
333:277(i16vec3) GroupNonUniformQuadSwap 43 332 42
|
||||
334: 268(ptr) AccessChain 34(data) 329 58
|
||||
335: 22(i16vec4) Load 334
|
||||
336: 22(i16vec4) VectorShuffle 335 333 4 5 6 3
|
||||
Store 334 336
|
||||
337: 6(int) Load 8(invocation)
|
||||
338: 268(ptr) AccessChain 34(data) 68 58
|
||||
339: 22(i16vec4) Load 338
|
||||
340: 22(i16vec4) GroupNonUniformQuadSwap 43 339 42
|
||||
341: 268(ptr) AccessChain 34(data) 337 58
|
||||
Store 341 340
|
||||
342: 6(int) Load 8(invocation)
|
||||
343: 261(ptr) AccessChain 34(data) 37 58 38
|
||||
344: 21(int16_t) Load 343
|
||||
345: 21(int16_t) GroupNonUniformQuadSwap 43 344 128
|
||||
346: 261(ptr) AccessChain 34(data) 342 58 38
|
||||
Store 346 345
|
||||
347: 6(int) Load 8(invocation)
|
||||
348: 268(ptr) AccessChain 34(data) 47 58
|
||||
349: 22(i16vec4) Load 348
|
||||
350:267(i16vec2) VectorShuffle 349 349 0 1
|
||||
351:267(i16vec2) GroupNonUniformQuadSwap 43 350 128
|
||||
352: 268(ptr) AccessChain 34(data) 347 58
|
||||
353: 22(i16vec4) Load 352
|
||||
354: 22(i16vec4) VectorShuffle 353 351 4 5 2 3
|
||||
Store 352 354
|
||||
355: 6(int) Load 8(invocation)
|
||||
356: 268(ptr) AccessChain 34(data) 58 58
|
||||
357: 22(i16vec4) Load 356
|
||||
358:277(i16vec3) VectorShuffle 357 357 0 1 2
|
||||
359:277(i16vec3) GroupNonUniformQuadSwap 43 358 128
|
||||
360: 268(ptr) AccessChain 34(data) 355 58
|
||||
361: 22(i16vec4) Load 360
|
||||
362: 22(i16vec4) VectorShuffle 361 359 4 5 6 3
|
||||
Store 360 362
|
||||
363: 6(int) Load 8(invocation)
|
||||
364: 268(ptr) AccessChain 34(data) 68 58
|
||||
365: 22(i16vec4) Load 364
|
||||
366: 22(i16vec4) GroupNonUniformQuadSwap 43 365 128
|
||||
367: 268(ptr) AccessChain 34(data) 363 58
|
||||
Store 367 366
|
||||
368: 6(int) Load 8(invocation)
|
||||
370: 369(ptr) AccessChain 34(data) 37 68 38
|
||||
371: 23(int16_t) Load 370
|
||||
372: 23(int16_t) GroupNonUniformQuadBroadcast 43 371 42
|
||||
373: 369(ptr) AccessChain 34(data) 368 68 38
|
||||
Store 373 372
|
||||
374: 6(int) Load 8(invocation)
|
||||
377: 376(ptr) AccessChain 34(data) 47 68
|
||||
378: 24(i16vec4) Load 377
|
||||
379:375(i16vec2) VectorShuffle 378 378 0 1
|
||||
380:375(i16vec2) GroupNonUniformQuadBroadcast 43 379 42
|
||||
381: 376(ptr) AccessChain 34(data) 374 68
|
||||
382: 24(i16vec4) Load 381
|
||||
383: 24(i16vec4) VectorShuffle 382 380 4 5 2 3
|
||||
Store 381 383
|
||||
384: 6(int) Load 8(invocation)
|
||||
386: 376(ptr) AccessChain 34(data) 58 68
|
||||
387: 24(i16vec4) Load 386
|
||||
388:385(i16vec3) VectorShuffle 387 387 0 1 2
|
||||
389:385(i16vec3) GroupNonUniformQuadBroadcast 43 388 42
|
||||
390: 376(ptr) AccessChain 34(data) 384 68
|
||||
391: 24(i16vec4) Load 390
|
||||
392: 24(i16vec4) VectorShuffle 391 389 4 5 6 3
|
||||
Store 390 392
|
||||
393: 6(int) Load 8(invocation)
|
||||
394: 376(ptr) AccessChain 34(data) 68 68
|
||||
395: 24(i16vec4) Load 394
|
||||
396: 24(i16vec4) GroupNonUniformQuadBroadcast 43 395 42
|
||||
397: 376(ptr) AccessChain 34(data) 393 68
|
||||
Store 397 396
|
||||
398: 6(int) Load 8(invocation)
|
||||
399: 369(ptr) AccessChain 34(data) 37 68 38
|
||||
400: 23(int16_t) Load 399
|
||||
401: 23(int16_t) GroupNonUniformQuadSwap 43 400 38
|
||||
402: 369(ptr) AccessChain 34(data) 398 68 38
|
||||
Store 402 401
|
||||
403: 6(int) Load 8(invocation)
|
||||
404: 376(ptr) AccessChain 34(data) 47 68
|
||||
405: 24(i16vec4) Load 404
|
||||
406:375(i16vec2) VectorShuffle 405 405 0 1
|
||||
407:375(i16vec2) GroupNonUniformQuadSwap 43 406 38
|
||||
408: 376(ptr) AccessChain 34(data) 403 68
|
||||
409: 24(i16vec4) Load 408
|
||||
410: 24(i16vec4) VectorShuffle 409 407 4 5 2 3
|
||||
Store 408 410
|
||||
411: 6(int) Load 8(invocation)
|
||||
412: 376(ptr) AccessChain 34(data) 58 68
|
||||
413: 24(i16vec4) Load 412
|
||||
414:385(i16vec3) VectorShuffle 413 413 0 1 2
|
||||
415:385(i16vec3) GroupNonUniformQuadSwap 43 414 38
|
||||
416: 376(ptr) AccessChain 34(data) 411 68
|
||||
417: 24(i16vec4) Load 416
|
||||
418: 24(i16vec4) VectorShuffle 417 415 4 5 6 3
|
||||
Store 416 418
|
||||
419: 6(int) Load 8(invocation)
|
||||
420: 376(ptr) AccessChain 34(data) 68 68
|
||||
421: 24(i16vec4) Load 420
|
||||
422: 24(i16vec4) GroupNonUniformQuadSwap 43 421 38
|
||||
423: 376(ptr) AccessChain 34(data) 419 68
|
||||
Store 423 422
|
||||
424: 6(int) Load 8(invocation)
|
||||
425: 369(ptr) AccessChain 34(data) 37 68 38
|
||||
426: 23(int16_t) Load 425
|
||||
427: 23(int16_t) GroupNonUniformQuadSwap 43 426 42
|
||||
428: 369(ptr) AccessChain 34(data) 424 68 38
|
||||
Store 428 427
|
||||
429: 6(int) Load 8(invocation)
|
||||
430: 376(ptr) AccessChain 34(data) 47 68
|
||||
431: 24(i16vec4) Load 430
|
||||
432:375(i16vec2) VectorShuffle 431 431 0 1
|
||||
433:375(i16vec2) GroupNonUniformQuadSwap 43 432 42
|
||||
434: 376(ptr) AccessChain 34(data) 429 68
|
||||
435: 24(i16vec4) Load 434
|
||||
436: 24(i16vec4) VectorShuffle 435 433 4 5 2 3
|
||||
Store 434 436
|
||||
437: 6(int) Load 8(invocation)
|
||||
438: 376(ptr) AccessChain 34(data) 58 68
|
||||
439: 24(i16vec4) Load 438
|
||||
440:385(i16vec3) VectorShuffle 439 439 0 1 2
|
||||
441:385(i16vec3) GroupNonUniformQuadSwap 43 440 42
|
||||
442: 376(ptr) AccessChain 34(data) 437 68
|
||||
443: 24(i16vec4) Load 442
|
||||
444: 24(i16vec4) VectorShuffle 443 441 4 5 6 3
|
||||
Store 442 444
|
||||
445: 6(int) Load 8(invocation)
|
||||
446: 376(ptr) AccessChain 34(data) 68 68
|
||||
447: 24(i16vec4) Load 446
|
||||
448: 24(i16vec4) GroupNonUniformQuadSwap 43 447 42
|
||||
449: 376(ptr) AccessChain 34(data) 445 68
|
||||
Store 449 448
|
||||
450: 6(int) Load 8(invocation)
|
||||
451: 369(ptr) AccessChain 34(data) 37 68 38
|
||||
452: 23(int16_t) Load 451
|
||||
453: 23(int16_t) GroupNonUniformQuadSwap 43 452 128
|
||||
454: 369(ptr) AccessChain 34(data) 450 68 38
|
||||
Store 454 453
|
||||
455: 6(int) Load 8(invocation)
|
||||
456: 376(ptr) AccessChain 34(data) 47 68
|
||||
457: 24(i16vec4) Load 456
|
||||
458:375(i16vec2) VectorShuffle 457 457 0 1
|
||||
459:375(i16vec2) GroupNonUniformQuadSwap 43 458 128
|
||||
460: 376(ptr) AccessChain 34(data) 455 68
|
||||
461: 24(i16vec4) Load 460
|
||||
462: 24(i16vec4) VectorShuffle 461 459 4 5 2 3
|
||||
Store 460 462
|
||||
463: 6(int) Load 8(invocation)
|
||||
464: 376(ptr) AccessChain 34(data) 58 68
|
||||
465: 24(i16vec4) Load 464
|
||||
466:385(i16vec3) VectorShuffle 465 465 0 1 2
|
||||
467:385(i16vec3) GroupNonUniformQuadSwap 43 466 128
|
||||
468: 376(ptr) AccessChain 34(data) 463 68
|
||||
469: 24(i16vec4) Load 468
|
||||
470: 24(i16vec4) VectorShuffle 469 467 4 5 6 3
|
||||
Store 468 470
|
||||
471: 6(int) Load 8(invocation)
|
||||
472: 376(ptr) AccessChain 34(data) 68 68
|
||||
473: 24(i16vec4) Load 472
|
||||
474: 24(i16vec4) GroupNonUniformQuadSwap 43 473 128
|
||||
475: 376(ptr) AccessChain 34(data) 471 68
|
||||
Store 475 474
|
||||
476: 6(int) Load 8(invocation)
|
||||
479: 478(ptr) AccessChain 34(data) 37 477 38
|
||||
480: 25(int64_t) Load 479
|
||||
481: 25(int64_t) GroupNonUniformQuadBroadcast 43 480 42
|
||||
482: 478(ptr) AccessChain 34(data) 476 477 38
|
||||
Store 482 481
|
||||
483: 6(int) Load 8(invocation)
|
||||
486: 485(ptr) AccessChain 34(data) 47 477
|
||||
487: 26(i64vec4) Load 486
|
||||
488:484(i64vec2) VectorShuffle 487 487 0 1
|
||||
489:484(i64vec2) GroupNonUniformQuadBroadcast 43 488 42
|
||||
490: 485(ptr) AccessChain 34(data) 483 477
|
||||
491: 26(i64vec4) Load 490
|
||||
492: 26(i64vec4) VectorShuffle 491 489 4 5 2 3
|
||||
Store 490 492
|
||||
493: 6(int) Load 8(invocation)
|
||||
495: 485(ptr) AccessChain 34(data) 58 477
|
||||
496: 26(i64vec4) Load 495
|
||||
497:494(i64vec3) VectorShuffle 496 496 0 1 2
|
||||
498:494(i64vec3) GroupNonUniformQuadBroadcast 43 497 42
|
||||
499: 485(ptr) AccessChain 34(data) 493 477
|
||||
500: 26(i64vec4) Load 499
|
||||
501: 26(i64vec4) VectorShuffle 500 498 4 5 6 3
|
||||
Store 499 501
|
||||
502: 6(int) Load 8(invocation)
|
||||
503: 485(ptr) AccessChain 34(data) 68 477
|
||||
504: 26(i64vec4) Load 503
|
||||
505: 26(i64vec4) GroupNonUniformQuadBroadcast 43 504 42
|
||||
506: 485(ptr) AccessChain 34(data) 502 477
|
||||
Store 506 505
|
||||
507: 6(int) Load 8(invocation)
|
||||
508: 478(ptr) AccessChain 34(data) 37 477 38
|
||||
509: 25(int64_t) Load 508
|
||||
510: 25(int64_t) GroupNonUniformQuadSwap 43 509 38
|
||||
511: 478(ptr) AccessChain 34(data) 507 477 38
|
||||
Store 511 510
|
||||
512: 6(int) Load 8(invocation)
|
||||
513: 485(ptr) AccessChain 34(data) 47 477
|
||||
514: 26(i64vec4) Load 513
|
||||
515:484(i64vec2) VectorShuffle 514 514 0 1
|
||||
516:484(i64vec2) GroupNonUniformQuadSwap 43 515 38
|
||||
517: 485(ptr) AccessChain 34(data) 512 477
|
||||
518: 26(i64vec4) Load 517
|
||||
519: 26(i64vec4) VectorShuffle 518 516 4 5 2 3
|
||||
Store 517 519
|
||||
520: 6(int) Load 8(invocation)
|
||||
521: 485(ptr) AccessChain 34(data) 58 477
|
||||
522: 26(i64vec4) Load 521
|
||||
523:494(i64vec3) VectorShuffle 522 522 0 1 2
|
||||
524:494(i64vec3) GroupNonUniformQuadSwap 43 523 38
|
||||
525: 485(ptr) AccessChain 34(data) 520 477
|
||||
526: 26(i64vec4) Load 525
|
||||
527: 26(i64vec4) VectorShuffle 526 524 4 5 6 3
|
||||
Store 525 527
|
||||
528: 6(int) Load 8(invocation)
|
||||
529: 485(ptr) AccessChain 34(data) 68 477
|
||||
530: 26(i64vec4) Load 529
|
||||
531: 26(i64vec4) GroupNonUniformQuadSwap 43 530 38
|
||||
532: 485(ptr) AccessChain 34(data) 528 477
|
||||
Store 532 531
|
||||
533: 6(int) Load 8(invocation)
|
||||
534: 478(ptr) AccessChain 34(data) 37 477 38
|
||||
535: 25(int64_t) Load 534
|
||||
536: 25(int64_t) GroupNonUniformQuadSwap 43 535 42
|
||||
537: 478(ptr) AccessChain 34(data) 533 477 38
|
||||
Store 537 536
|
||||
538: 6(int) Load 8(invocation)
|
||||
539: 485(ptr) AccessChain 34(data) 47 477
|
||||
540: 26(i64vec4) Load 539
|
||||
541:484(i64vec2) VectorShuffle 540 540 0 1
|
||||
542:484(i64vec2) GroupNonUniformQuadSwap 43 541 42
|
||||
543: 485(ptr) AccessChain 34(data) 538 477
|
||||
544: 26(i64vec4) Load 543
|
||||
545: 26(i64vec4) VectorShuffle 544 542 4 5 2 3
|
||||
Store 543 545
|
||||
546: 6(int) Load 8(invocation)
|
||||
547: 485(ptr) AccessChain 34(data) 58 477
|
||||
548: 26(i64vec4) Load 547
|
||||
549:494(i64vec3) VectorShuffle 548 548 0 1 2
|
||||
550:494(i64vec3) GroupNonUniformQuadSwap 43 549 42
|
||||
551: 485(ptr) AccessChain 34(data) 546 477
|
||||
552: 26(i64vec4) Load 551
|
||||
553: 26(i64vec4) VectorShuffle 552 550 4 5 6 3
|
||||
Store 551 553
|
||||
554: 6(int) Load 8(invocation)
|
||||
555: 485(ptr) AccessChain 34(data) 68 477
|
||||
556: 26(i64vec4) Load 555
|
||||
557: 26(i64vec4) GroupNonUniformQuadSwap 43 556 42
|
||||
558: 485(ptr) AccessChain 34(data) 554 477
|
||||
Store 558 557
|
||||
559: 6(int) Load 8(invocation)
|
||||
560: 478(ptr) AccessChain 34(data) 37 477 38
|
||||
561: 25(int64_t) Load 560
|
||||
562: 25(int64_t) GroupNonUniformQuadSwap 43 561 128
|
||||
563: 478(ptr) AccessChain 34(data) 559 477 38
|
||||
Store 563 562
|
||||
564: 6(int) Load 8(invocation)
|
||||
565: 485(ptr) AccessChain 34(data) 47 477
|
||||
566: 26(i64vec4) Load 565
|
||||
567:484(i64vec2) VectorShuffle 566 566 0 1
|
||||
568:484(i64vec2) GroupNonUniformQuadSwap 43 567 128
|
||||
569: 485(ptr) AccessChain 34(data) 564 477
|
||||
570: 26(i64vec4) Load 569
|
||||
571: 26(i64vec4) VectorShuffle 570 568 4 5 2 3
|
||||
Store 569 571
|
||||
572: 6(int) Load 8(invocation)
|
||||
573: 485(ptr) AccessChain 34(data) 58 477
|
||||
574: 26(i64vec4) Load 573
|
||||
575:494(i64vec3) VectorShuffle 574 574 0 1 2
|
||||
576:494(i64vec3) GroupNonUniformQuadSwap 43 575 128
|
||||
577: 485(ptr) AccessChain 34(data) 572 477
|
||||
578: 26(i64vec4) Load 577
|
||||
579: 26(i64vec4) VectorShuffle 578 576 4 5 6 3
|
||||
Store 577 579
|
||||
580: 6(int) Load 8(invocation)
|
||||
581: 485(ptr) AccessChain 34(data) 68 477
|
||||
582: 26(i64vec4) Load 581
|
||||
583: 26(i64vec4) GroupNonUniformQuadSwap 43 582 128
|
||||
584: 485(ptr) AccessChain 34(data) 580 477
|
||||
Store 584 583
|
||||
585: 6(int) Load 8(invocation)
|
||||
588: 587(ptr) AccessChain 34(data) 37 586 38
|
||||
589: 27(int64_t) Load 588
|
||||
590: 27(int64_t) GroupNonUniformQuadBroadcast 43 589 42
|
||||
591: 587(ptr) AccessChain 34(data) 585 586 38
|
||||
Store 591 590
|
||||
592: 6(int) Load 8(invocation)
|
||||
595: 594(ptr) AccessChain 34(data) 47 586
|
||||
596: 28(i64vec4) Load 595
|
||||
597:593(i64vec2) VectorShuffle 596 596 0 1
|
||||
598:593(i64vec2) GroupNonUniformQuadBroadcast 43 597 42
|
||||
599: 594(ptr) AccessChain 34(data) 592 586
|
||||
600: 28(i64vec4) Load 599
|
||||
601: 28(i64vec4) VectorShuffle 600 598 4 5 2 3
|
||||
Store 599 601
|
||||
602: 6(int) Load 8(invocation)
|
||||
604: 594(ptr) AccessChain 34(data) 58 586
|
||||
605: 28(i64vec4) Load 604
|
||||
606:603(i64vec3) VectorShuffle 605 605 0 1 2
|
||||
607:603(i64vec3) GroupNonUniformQuadBroadcast 43 606 42
|
||||
608: 594(ptr) AccessChain 34(data) 602 586
|
||||
609: 28(i64vec4) Load 608
|
||||
610: 28(i64vec4) VectorShuffle 609 607 4 5 6 3
|
||||
Store 608 610
|
||||
611: 6(int) Load 8(invocation)
|
||||
612: 594(ptr) AccessChain 34(data) 68 586
|
||||
613: 28(i64vec4) Load 612
|
||||
614: 28(i64vec4) GroupNonUniformQuadBroadcast 43 613 42
|
||||
615: 594(ptr) AccessChain 34(data) 611 586
|
||||
Store 615 614
|
||||
616: 6(int) Load 8(invocation)
|
||||
617: 587(ptr) AccessChain 34(data) 37 586 38
|
||||
618: 27(int64_t) Load 617
|
||||
619: 27(int64_t) GroupNonUniformQuadSwap 43 618 38
|
||||
620: 587(ptr) AccessChain 34(data) 616 586 38
|
||||
Store 620 619
|
||||
621: 6(int) Load 8(invocation)
|
||||
622: 594(ptr) AccessChain 34(data) 47 586
|
||||
623: 28(i64vec4) Load 622
|
||||
624:593(i64vec2) VectorShuffle 623 623 0 1
|
||||
625:593(i64vec2) GroupNonUniformQuadSwap 43 624 38
|
||||
626: 594(ptr) AccessChain 34(data) 621 586
|
||||
627: 28(i64vec4) Load 626
|
||||
628: 28(i64vec4) VectorShuffle 627 625 4 5 2 3
|
||||
Store 626 628
|
||||
629: 6(int) Load 8(invocation)
|
||||
630: 594(ptr) AccessChain 34(data) 58 586
|
||||
631: 28(i64vec4) Load 630
|
||||
632:603(i64vec3) VectorShuffle 631 631 0 1 2
|
||||
633:603(i64vec3) GroupNonUniformQuadSwap 43 632 38
|
||||
634: 594(ptr) AccessChain 34(data) 629 586
|
||||
635: 28(i64vec4) Load 634
|
||||
636: 28(i64vec4) VectorShuffle 635 633 4 5 6 3
|
||||
Store 634 636
|
||||
637: 6(int) Load 8(invocation)
|
||||
638: 594(ptr) AccessChain 34(data) 68 586
|
||||
639: 28(i64vec4) Load 638
|
||||
640: 28(i64vec4) GroupNonUniformQuadSwap 43 639 38
|
||||
641: 594(ptr) AccessChain 34(data) 637 586
|
||||
Store 641 640
|
||||
642: 6(int) Load 8(invocation)
|
||||
643: 587(ptr) AccessChain 34(data) 37 586 38
|
||||
644: 27(int64_t) Load 643
|
||||
645: 27(int64_t) GroupNonUniformQuadSwap 43 644 42
|
||||
646: 587(ptr) AccessChain 34(data) 642 586 38
|
||||
Store 646 645
|
||||
647: 6(int) Load 8(invocation)
|
||||
648: 594(ptr) AccessChain 34(data) 47 586
|
||||
649: 28(i64vec4) Load 648
|
||||
650:593(i64vec2) VectorShuffle 649 649 0 1
|
||||
651:593(i64vec2) GroupNonUniformQuadSwap 43 650 42
|
||||
652: 594(ptr) AccessChain 34(data) 647 586
|
||||
653: 28(i64vec4) Load 652
|
||||
654: 28(i64vec4) VectorShuffle 653 651 4 5 2 3
|
||||
Store 652 654
|
||||
655: 6(int) Load 8(invocation)
|
||||
656: 594(ptr) AccessChain 34(data) 58 586
|
||||
657: 28(i64vec4) Load 656
|
||||
658:603(i64vec3) VectorShuffle 657 657 0 1 2
|
||||
659:603(i64vec3) GroupNonUniformQuadSwap 43 658 42
|
||||
660: 594(ptr) AccessChain 34(data) 655 586
|
||||
661: 28(i64vec4) Load 660
|
||||
662: 28(i64vec4) VectorShuffle 661 659 4 5 6 3
|
||||
Store 660 662
|
||||
663: 6(int) Load 8(invocation)
|
||||
664: 594(ptr) AccessChain 34(data) 68 586
|
||||
665: 28(i64vec4) Load 664
|
||||
666: 28(i64vec4) GroupNonUniformQuadSwap 43 665 42
|
||||
667: 594(ptr) AccessChain 34(data) 663 586
|
||||
Store 667 666
|
||||
668: 6(int) Load 8(invocation)
|
||||
669: 587(ptr) AccessChain 34(data) 37 586 38
|
||||
670: 27(int64_t) Load 669
|
||||
671: 27(int64_t) GroupNonUniformQuadSwap 43 670 128
|
||||
672: 587(ptr) AccessChain 34(data) 668 586 38
|
||||
Store 672 671
|
||||
673: 6(int) Load 8(invocation)
|
||||
674: 594(ptr) AccessChain 34(data) 47 586
|
||||
675: 28(i64vec4) Load 674
|
||||
676:593(i64vec2) VectorShuffle 675 675 0 1
|
||||
677:593(i64vec2) GroupNonUniformQuadSwap 43 676 128
|
||||
678: 594(ptr) AccessChain 34(data) 673 586
|
||||
679: 28(i64vec4) Load 678
|
||||
680: 28(i64vec4) VectorShuffle 679 677 4 5 2 3
|
||||
Store 678 680
|
||||
681: 6(int) Load 8(invocation)
|
||||
682: 594(ptr) AccessChain 34(data) 58 586
|
||||
683: 28(i64vec4) Load 682
|
||||
684:603(i64vec3) VectorShuffle 683 683 0 1 2
|
||||
685:603(i64vec3) GroupNonUniformQuadSwap 43 684 128
|
||||
686: 594(ptr) AccessChain 34(data) 681 586
|
||||
687: 28(i64vec4) Load 686
|
||||
688: 28(i64vec4) VectorShuffle 687 685 4 5 6 3
|
||||
Store 686 688
|
||||
689: 6(int) Load 8(invocation)
|
||||
690: 594(ptr) AccessChain 34(data) 68 586
|
||||
691: 28(i64vec4) Load 690
|
||||
692: 28(i64vec4) GroupNonUniformQuadSwap 43 691 128
|
||||
693: 594(ptr) AccessChain 34(data) 689 586
|
||||
Store 693 692
|
||||
694: 6(int) Load 8(invocation)
|
||||
697: 696(ptr) AccessChain 34(data) 37 695 38
|
||||
698:29(float16_t) Load 697
|
||||
699:29(float16_t) GroupNonUniformQuadBroadcast 43 698 42
|
||||
700: 696(ptr) AccessChain 34(data) 694 695 38
|
||||
Store 700 699
|
||||
701: 6(int) Load 8(invocation)
|
||||
704: 703(ptr) AccessChain 34(data) 47 695
|
||||
705: 30(f16vec4) Load 704
|
||||
706:702(f16vec2) VectorShuffle 705 705 0 1
|
||||
707:702(f16vec2) GroupNonUniformQuadBroadcast 43 706 42
|
||||
708: 703(ptr) AccessChain 34(data) 701 695
|
||||
709: 30(f16vec4) Load 708
|
||||
710: 30(f16vec4) VectorShuffle 709 707 4 5 2 3
|
||||
Store 708 710
|
||||
711: 6(int) Load 8(invocation)
|
||||
713: 703(ptr) AccessChain 34(data) 58 695
|
||||
714: 30(f16vec4) Load 713
|
||||
715:712(f16vec3) VectorShuffle 714 714 0 1 2
|
||||
716:712(f16vec3) GroupNonUniformQuadBroadcast 43 715 42
|
||||
717: 703(ptr) AccessChain 34(data) 711 695
|
||||
718: 30(f16vec4) Load 717
|
||||
719: 30(f16vec4) VectorShuffle 718 716 4 5 6 3
|
||||
Store 717 719
|
||||
720: 6(int) Load 8(invocation)
|
||||
721: 703(ptr) AccessChain 34(data) 68 695
|
||||
722: 30(f16vec4) Load 721
|
||||
723: 30(f16vec4) GroupNonUniformQuadBroadcast 43 722 42
|
||||
724: 703(ptr) AccessChain 34(data) 720 695
|
||||
Store 724 723
|
||||
725: 6(int) Load 8(invocation)
|
||||
726: 696(ptr) AccessChain 34(data) 37 695 38
|
||||
727:29(float16_t) Load 726
|
||||
728:29(float16_t) GroupNonUniformQuadSwap 43 727 38
|
||||
729: 696(ptr) AccessChain 34(data) 725 695 38
|
||||
Store 729 728
|
||||
730: 6(int) Load 8(invocation)
|
||||
731: 703(ptr) AccessChain 34(data) 47 695
|
||||
732: 30(f16vec4) Load 731
|
||||
733:702(f16vec2) VectorShuffle 732 732 0 1
|
||||
734:702(f16vec2) GroupNonUniformQuadSwap 43 733 38
|
||||
735: 703(ptr) AccessChain 34(data) 730 695
|
||||
736: 30(f16vec4) Load 735
|
||||
737: 30(f16vec4) VectorShuffle 736 734 4 5 2 3
|
||||
Store 735 737
|
||||
738: 6(int) Load 8(invocation)
|
||||
739: 703(ptr) AccessChain 34(data) 58 695
|
||||
740: 30(f16vec4) Load 739
|
||||
741:712(f16vec3) VectorShuffle 740 740 0 1 2
|
||||
742:712(f16vec3) GroupNonUniformQuadSwap 43 741 38
|
||||
743: 703(ptr) AccessChain 34(data) 738 695
|
||||
744: 30(f16vec4) Load 743
|
||||
745: 30(f16vec4) VectorShuffle 744 742 4 5 6 3
|
||||
Store 743 745
|
||||
746: 6(int) Load 8(invocation)
|
||||
747: 703(ptr) AccessChain 34(data) 68 695
|
||||
748: 30(f16vec4) Load 747
|
||||
749: 30(f16vec4) GroupNonUniformQuadSwap 43 748 38
|
||||
750: 703(ptr) AccessChain 34(data) 746 695
|
||||
Store 750 749
|
||||
751: 6(int) Load 8(invocation)
|
||||
752: 696(ptr) AccessChain 34(data) 37 695 38
|
||||
753:29(float16_t) Load 752
|
||||
754:29(float16_t) GroupNonUniformQuadSwap 43 753 42
|
||||
755: 696(ptr) AccessChain 34(data) 751 695 38
|
||||
Store 755 754
|
||||
756: 6(int) Load 8(invocation)
|
||||
757: 703(ptr) AccessChain 34(data) 47 695
|
||||
758: 30(f16vec4) Load 757
|
||||
759:702(f16vec2) VectorShuffle 758 758 0 1
|
||||
760:702(f16vec2) GroupNonUniformQuadSwap 43 759 42
|
||||
761: 703(ptr) AccessChain 34(data) 756 695
|
||||
762: 30(f16vec4) Load 761
|
||||
763: 30(f16vec4) VectorShuffle 762 760 4 5 2 3
|
||||
Store 761 763
|
||||
764: 6(int) Load 8(invocation)
|
||||
765: 703(ptr) AccessChain 34(data) 58 695
|
||||
766: 30(f16vec4) Load 765
|
||||
767:712(f16vec3) VectorShuffle 766 766 0 1 2
|
||||
768:712(f16vec3) GroupNonUniformQuadSwap 43 767 42
|
||||
769: 703(ptr) AccessChain 34(data) 764 695
|
||||
770: 30(f16vec4) Load 769
|
||||
771: 30(f16vec4) VectorShuffle 770 768 4 5 6 3
|
||||
Store 769 771
|
||||
772: 6(int) Load 8(invocation)
|
||||
773: 703(ptr) AccessChain 34(data) 68 695
|
||||
774: 30(f16vec4) Load 773
|
||||
775: 30(f16vec4) GroupNonUniformQuadSwap 43 774 42
|
||||
776: 703(ptr) AccessChain 34(data) 772 695
|
||||
Store 776 775
|
||||
777: 6(int) Load 8(invocation)
|
||||
778: 696(ptr) AccessChain 34(data) 37 695 38
|
||||
779:29(float16_t) Load 778
|
||||
780:29(float16_t) GroupNonUniformQuadSwap 43 779 128
|
||||
781: 696(ptr) AccessChain 34(data) 777 695 38
|
||||
Store 781 780
|
||||
782: 6(int) Load 8(invocation)
|
||||
783: 703(ptr) AccessChain 34(data) 47 695
|
||||
784: 30(f16vec4) Load 783
|
||||
785:702(f16vec2) VectorShuffle 784 784 0 1
|
||||
786:702(f16vec2) GroupNonUniformQuadSwap 43 785 128
|
||||
787: 703(ptr) AccessChain 34(data) 782 695
|
||||
788: 30(f16vec4) Load 787
|
||||
789: 30(f16vec4) VectorShuffle 788 786 4 5 2 3
|
||||
Store 787 789
|
||||
790: 6(int) Load 8(invocation)
|
||||
791: 703(ptr) AccessChain 34(data) 58 695
|
||||
792: 30(f16vec4) Load 791
|
||||
793:712(f16vec3) VectorShuffle 792 792 0 1 2
|
||||
794:712(f16vec3) GroupNonUniformQuadSwap 43 793 128
|
||||
795: 703(ptr) AccessChain 34(data) 790 695
|
||||
796: 30(f16vec4) Load 795
|
||||
797: 30(f16vec4) VectorShuffle 796 794 4 5 6 3
|
||||
Store 795 797
|
||||
798: 6(int) Load 8(invocation)
|
||||
799: 703(ptr) AccessChain 34(data) 68 695
|
||||
800: 30(f16vec4) Load 799
|
||||
801: 30(f16vec4) GroupNonUniformQuadSwap 43 800 128
|
||||
802: 703(ptr) AccessChain 34(data) 798 695
|
||||
Store 802 801
|
||||
Return
|
||||
FunctionEnd
|
117
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesQuadNeg.comp.out
vendored
Normal file
117
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesQuadNeg.comp.out
vendored
Normal file
@ -0,0 +1,117 @@
|
||||
spv.subgroupExtendedTypesQuadNeg.comp
|
||||
ERROR: 0:26: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:27: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:28: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:29: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:31: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:32: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:33: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:34: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:36: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:37: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:38: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:39: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:41: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:42: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:43: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:44: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:46: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:47: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:48: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:49: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:51: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:52: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:53: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:54: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:56: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:57: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:58: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:59: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:61: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:62: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:63: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:64: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:66: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:67: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:68: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:69: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:71: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:72: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:73: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:74: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:76: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:77: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:78: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:79: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:81: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:82: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:83: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:84: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:86: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:87: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:88: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:89: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:91: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:92: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:93: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:94: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:96: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:97: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:98: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:99: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:101: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:102: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:103: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:104: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:106: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:107: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:108: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:109: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:111: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:112: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:113: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:114: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:116: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:117: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:118: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:119: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:121: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:122: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:123: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:124: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:126: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:127: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:128: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:129: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:131: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:132: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:133: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:134: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:136: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:137: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:138: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:139: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:141: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:142: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:143: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:144: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:146: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:147: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:148: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:149: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:151: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:152: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:153: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:154: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:156: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:157: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:158: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:159: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:161: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:162: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:163: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:164: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 112 compilation errors. No code generated.
|
||||
|
||||
|
||||
SPIR-V is not generated for failed compile or link
|
616
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesShuffle.comp.out
vendored
Normal file
616
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesShuffle.comp.out
vendored
Normal file
@ -0,0 +1,616 @@
|
||||
spv.subgroupExtendedTypesShuffle.comp
|
||||
// Module Version 10300
|
||||
// Generated by (magic number): 80007
|
||||
// Id's are bound by 497
|
||||
|
||||
Capability Shader
|
||||
Capability Float16
|
||||
Capability Int64
|
||||
Capability Int16
|
||||
Capability Int8
|
||||
Capability GroupNonUniform
|
||||
Capability GroupNonUniformShuffle
|
||||
Capability StorageUniformBufferBlock16
|
||||
Capability StorageBuffer8BitAccess
|
||||
Extension "SPV_KHR_8bit_storage"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel Logical GLSL450
|
||||
EntryPoint GLCompute 4 "main" 10 12
|
||||
ExecutionMode 4 LocalSize 8 1 1
|
||||
Source GLSL 450
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_float16"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int16"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int64"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int8"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_float16"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int16"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int64"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int8"
|
||||
SourceExtension "GL_KHR_shader_subgroup_basic"
|
||||
SourceExtension "GL_KHR_shader_subgroup_shuffle"
|
||||
Name 4 "main"
|
||||
Name 8 "invocation"
|
||||
Name 10 "gl_SubgroupInvocationID"
|
||||
Name 12 "gl_SubgroupSize"
|
||||
Name 31 "Buffers"
|
||||
MemberName 31(Buffers) 0 "i8"
|
||||
MemberName 31(Buffers) 1 "u8"
|
||||
MemberName 31(Buffers) 2 "i16"
|
||||
MemberName 31(Buffers) 3 "u16"
|
||||
MemberName 31(Buffers) 4 "i64"
|
||||
MemberName 31(Buffers) 5 "u64"
|
||||
MemberName 31(Buffers) 6 "f16"
|
||||
Name 34 "data"
|
||||
Decorate 10(gl_SubgroupInvocationID) RelaxedPrecision
|
||||
Decorate 10(gl_SubgroupInvocationID) BuiltIn SubgroupLocalInvocationId
|
||||
Decorate 11 RelaxedPrecision
|
||||
Decorate 12(gl_SubgroupSize) RelaxedPrecision
|
||||
Decorate 12(gl_SubgroupSize) BuiltIn SubgroupSize
|
||||
Decorate 13 RelaxedPrecision
|
||||
Decorate 14 RelaxedPrecision
|
||||
Decorate 16 RelaxedPrecision
|
||||
MemberDecorate 31(Buffers) 0 Offset 0
|
||||
MemberDecorate 31(Buffers) 1 Offset 4
|
||||
MemberDecorate 31(Buffers) 2 Offset 8
|
||||
MemberDecorate 31(Buffers) 3 Offset 16
|
||||
MemberDecorate 31(Buffers) 4 Offset 32
|
||||
MemberDecorate 31(Buffers) 5 Offset 64
|
||||
MemberDecorate 31(Buffers) 6 Offset 96
|
||||
Decorate 31(Buffers) Block
|
||||
Decorate 34(data) DescriptorSet 0
|
||||
Decorate 34(data) Binding 0
|
||||
Decorate 496 BuiltIn WorkgroupSize
|
||||
2: TypeVoid
|
||||
3: TypeFunction 2
|
||||
6: TypeInt 32 0
|
||||
7: TypePointer Function 6(int)
|
||||
9: TypePointer Input 6(int)
|
||||
10(gl_SubgroupInvocationID): 9(ptr) Variable Input
|
||||
12(gl_SubgroupSize): 9(ptr) Variable Input
|
||||
15: 6(int) Constant 4
|
||||
17: TypeInt 8 1
|
||||
18: TypeVector 17(int8_t) 4
|
||||
19: TypeInt 8 0
|
||||
20: TypeVector 19(int8_t) 4
|
||||
21: TypeInt 16 1
|
||||
22: TypeVector 21(int16_t) 4
|
||||
23: TypeInt 16 0
|
||||
24: TypeVector 23(int16_t) 4
|
||||
25: TypeInt 64 1
|
||||
26: TypeVector 25(int64_t) 4
|
||||
27: TypeInt 64 0
|
||||
28: TypeVector 27(int64_t) 4
|
||||
29: TypeFloat 16
|
||||
30: TypeVector 29(float16_t) 4
|
||||
31(Buffers): TypeStruct 18(i8vec4) 20(i8vec4) 22(i16vec4) 24(i16vec4) 26(i64vec4) 28(i64vec4) 30(f16vec4)
|
||||
32: TypeArray 31(Buffers) 15
|
||||
33: TypePointer StorageBuffer 32
|
||||
34(data): 33(ptr) Variable StorageBuffer
|
||||
36: TypeInt 32 1
|
||||
37: 36(int) Constant 0
|
||||
38: 6(int) Constant 0
|
||||
39: TypePointer StorageBuffer 17(int8_t)
|
||||
43: 6(int) Constant 3
|
||||
47: 36(int) Constant 1
|
||||
48: TypeVector 17(int8_t) 2
|
||||
49: TypePointer StorageBuffer 18(i8vec4)
|
||||
59: 36(int) Constant 2
|
||||
60: TypeVector 17(int8_t) 3
|
||||
70: 36(int) Constant 3
|
||||
107: TypePointer StorageBuffer 19(int8_t)
|
||||
114: TypeVector 19(int8_t) 2
|
||||
115: TypePointer StorageBuffer 20(i8vec4)
|
||||
125: TypeVector 19(int8_t) 3
|
||||
171: TypePointer StorageBuffer 21(int16_t)
|
||||
178: TypeVector 21(int16_t) 2
|
||||
179: TypePointer StorageBuffer 22(i16vec4)
|
||||
189: TypeVector 21(int16_t) 3
|
||||
235: TypePointer StorageBuffer 23(int16_t)
|
||||
242: TypeVector 23(int16_t) 2
|
||||
243: TypePointer StorageBuffer 24(i16vec4)
|
||||
253: TypeVector 23(int16_t) 3
|
||||
299: 36(int) Constant 4
|
||||
300: TypePointer StorageBuffer 25(int64_t)
|
||||
307: TypeVector 25(int64_t) 2
|
||||
308: TypePointer StorageBuffer 26(i64vec4)
|
||||
318: TypeVector 25(int64_t) 3
|
||||
364: 36(int) Constant 5
|
||||
365: TypePointer StorageBuffer 27(int64_t)
|
||||
372: TypeVector 27(int64_t) 2
|
||||
373: TypePointer StorageBuffer 28(i64vec4)
|
||||
383: TypeVector 27(int64_t) 3
|
||||
429: 36(int) Constant 6
|
||||
430: TypePointer StorageBuffer 29(float16_t)
|
||||
437: TypeVector 29(float16_t) 2
|
||||
438: TypePointer StorageBuffer 30(f16vec4)
|
||||
448: TypeVector 29(float16_t) 3
|
||||
493: TypeVector 6(int) 3
|
||||
494: 6(int) Constant 8
|
||||
495: 6(int) Constant 1
|
||||
496: 493(ivec3) ConstantComposite 494 495 495
|
||||
4(main): 2 Function None 3
|
||||
5: Label
|
||||
8(invocation): 7(ptr) Variable Function
|
||||
11: 6(int) Load 10(gl_SubgroupInvocationID)
|
||||
13: 6(int) Load 12(gl_SubgroupSize)
|
||||
14: 6(int) IAdd 11 13
|
||||
16: 6(int) UMod 14 15
|
||||
Store 8(invocation) 16
|
||||
35: 6(int) Load 8(invocation)
|
||||
40: 39(ptr) AccessChain 34(data) 37 37 38
|
||||
41: 17(int8_t) Load 40
|
||||
42: 6(int) Load 8(invocation)
|
||||
44: 17(int8_t) GroupNonUniformShuffle 43 41 42
|
||||
45: 39(ptr) AccessChain 34(data) 35 37 38
|
||||
Store 45 44
|
||||
46: 6(int) Load 8(invocation)
|
||||
50: 49(ptr) AccessChain 34(data) 47 37
|
||||
51: 18(i8vec4) Load 50
|
||||
52: 48(i8vec2) VectorShuffle 51 51 0 1
|
||||
53: 6(int) Load 8(invocation)
|
||||
54: 48(i8vec2) GroupNonUniformShuffle 43 52 53
|
||||
55: 49(ptr) AccessChain 34(data) 46 37
|
||||
56: 18(i8vec4) Load 55
|
||||
57: 18(i8vec4) VectorShuffle 56 54 4 5 2 3
|
||||
Store 55 57
|
||||
58: 6(int) Load 8(invocation)
|
||||
61: 49(ptr) AccessChain 34(data) 59 37
|
||||
62: 18(i8vec4) Load 61
|
||||
63: 60(i8vec3) VectorShuffle 62 62 0 1 2
|
||||
64: 6(int) Load 8(invocation)
|
||||
65: 60(i8vec3) GroupNonUniformShuffle 43 63 64
|
||||
66: 49(ptr) AccessChain 34(data) 58 37
|
||||
67: 18(i8vec4) Load 66
|
||||
68: 18(i8vec4) VectorShuffle 67 65 4 5 6 3
|
||||
Store 66 68
|
||||
69: 6(int) Load 8(invocation)
|
||||
71: 49(ptr) AccessChain 34(data) 70 37
|
||||
72: 18(i8vec4) Load 71
|
||||
73: 6(int) Load 8(invocation)
|
||||
74: 18(i8vec4) GroupNonUniformShuffle 43 72 73
|
||||
75: 49(ptr) AccessChain 34(data) 69 37
|
||||
Store 75 74
|
||||
76: 6(int) Load 8(invocation)
|
||||
77: 39(ptr) AccessChain 34(data) 37 37 38
|
||||
78: 17(int8_t) Load 77
|
||||
79: 6(int) Load 8(invocation)
|
||||
80: 17(int8_t) GroupNonUniformShuffleXor 43 78 79
|
||||
81: 39(ptr) AccessChain 34(data) 76 37 38
|
||||
Store 81 80
|
||||
82: 6(int) Load 8(invocation)
|
||||
83: 49(ptr) AccessChain 34(data) 47 37
|
||||
84: 18(i8vec4) Load 83
|
||||
85: 48(i8vec2) VectorShuffle 84 84 0 1
|
||||
86: 6(int) Load 8(invocation)
|
||||
87: 48(i8vec2) GroupNonUniformShuffleXor 43 85 86
|
||||
88: 49(ptr) AccessChain 34(data) 82 37
|
||||
89: 18(i8vec4) Load 88
|
||||
90: 18(i8vec4) VectorShuffle 89 87 4 5 2 3
|
||||
Store 88 90
|
||||
91: 6(int) Load 8(invocation)
|
||||
92: 49(ptr) AccessChain 34(data) 59 37
|
||||
93: 18(i8vec4) Load 92
|
||||
94: 60(i8vec3) VectorShuffle 93 93 0 1 2
|
||||
95: 6(int) Load 8(invocation)
|
||||
96: 60(i8vec3) GroupNonUniformShuffleXor 43 94 95
|
||||
97: 49(ptr) AccessChain 34(data) 91 37
|
||||
98: 18(i8vec4) Load 97
|
||||
99: 18(i8vec4) VectorShuffle 98 96 4 5 6 3
|
||||
Store 97 99
|
||||
100: 6(int) Load 8(invocation)
|
||||
101: 49(ptr) AccessChain 34(data) 70 37
|
||||
102: 18(i8vec4) Load 101
|
||||
103: 6(int) Load 8(invocation)
|
||||
104: 18(i8vec4) GroupNonUniformShuffleXor 43 102 103
|
||||
105: 49(ptr) AccessChain 34(data) 100 37
|
||||
Store 105 104
|
||||
106: 6(int) Load 8(invocation)
|
||||
108: 107(ptr) AccessChain 34(data) 37 47 38
|
||||
109: 19(int8_t) Load 108
|
||||
110: 6(int) Load 8(invocation)
|
||||
111: 19(int8_t) GroupNonUniformShuffle 43 109 110
|
||||
112: 107(ptr) AccessChain 34(data) 106 47 38
|
||||
Store 112 111
|
||||
113: 6(int) Load 8(invocation)
|
||||
116: 115(ptr) AccessChain 34(data) 47 47
|
||||
117: 20(i8vec4) Load 116
|
||||
118: 114(i8vec2) VectorShuffle 117 117 0 1
|
||||
119: 6(int) Load 8(invocation)
|
||||
120: 114(i8vec2) GroupNonUniformShuffle 43 118 119
|
||||
121: 115(ptr) AccessChain 34(data) 113 47
|
||||
122: 20(i8vec4) Load 121
|
||||
123: 20(i8vec4) VectorShuffle 122 120 4 5 2 3
|
||||
Store 121 123
|
||||
124: 6(int) Load 8(invocation)
|
||||
126: 115(ptr) AccessChain 34(data) 59 47
|
||||
127: 20(i8vec4) Load 126
|
||||
128: 125(i8vec3) VectorShuffle 127 127 0 1 2
|
||||
129: 6(int) Load 8(invocation)
|
||||
130: 125(i8vec3) GroupNonUniformShuffle 43 128 129
|
||||
131: 115(ptr) AccessChain 34(data) 124 47
|
||||
132: 20(i8vec4) Load 131
|
||||
133: 20(i8vec4) VectorShuffle 132 130 4 5 6 3
|
||||
Store 131 133
|
||||
134: 6(int) Load 8(invocation)
|
||||
135: 115(ptr) AccessChain 34(data) 70 47
|
||||
136: 20(i8vec4) Load 135
|
||||
137: 6(int) Load 8(invocation)
|
||||
138: 20(i8vec4) GroupNonUniformShuffle 43 136 137
|
||||
139: 115(ptr) AccessChain 34(data) 134 47
|
||||
Store 139 138
|
||||
140: 6(int) Load 8(invocation)
|
||||
141: 107(ptr) AccessChain 34(data) 37 47 38
|
||||
142: 19(int8_t) Load 141
|
||||
143: 6(int) Load 8(invocation)
|
||||
144: 19(int8_t) GroupNonUniformShuffleXor 43 142 143
|
||||
145: 107(ptr) AccessChain 34(data) 140 47 38
|
||||
Store 145 144
|
||||
146: 6(int) Load 8(invocation)
|
||||
147: 115(ptr) AccessChain 34(data) 47 47
|
||||
148: 20(i8vec4) Load 147
|
||||
149: 114(i8vec2) VectorShuffle 148 148 0 1
|
||||
150: 6(int) Load 8(invocation)
|
||||
151: 114(i8vec2) GroupNonUniformShuffleXor 43 149 150
|
||||
152: 115(ptr) AccessChain 34(data) 146 47
|
||||
153: 20(i8vec4) Load 152
|
||||
154: 20(i8vec4) VectorShuffle 153 151 4 5 2 3
|
||||
Store 152 154
|
||||
155: 6(int) Load 8(invocation)
|
||||
156: 115(ptr) AccessChain 34(data) 59 47
|
||||
157: 20(i8vec4) Load 156
|
||||
158: 125(i8vec3) VectorShuffle 157 157 0 1 2
|
||||
159: 6(int) Load 8(invocation)
|
||||
160: 125(i8vec3) GroupNonUniformShuffleXor 43 158 159
|
||||
161: 115(ptr) AccessChain 34(data) 155 47
|
||||
162: 20(i8vec4) Load 161
|
||||
163: 20(i8vec4) VectorShuffle 162 160 4 5 6 3
|
||||
Store 161 163
|
||||
164: 6(int) Load 8(invocation)
|
||||
165: 115(ptr) AccessChain 34(data) 70 47
|
||||
166: 20(i8vec4) Load 165
|
||||
167: 6(int) Load 8(invocation)
|
||||
168: 20(i8vec4) GroupNonUniformShuffleXor 43 166 167
|
||||
169: 115(ptr) AccessChain 34(data) 164 47
|
||||
Store 169 168
|
||||
170: 6(int) Load 8(invocation)
|
||||
172: 171(ptr) AccessChain 34(data) 37 59 38
|
||||
173: 21(int16_t) Load 172
|
||||
174: 6(int) Load 8(invocation)
|
||||
175: 21(int16_t) GroupNonUniformShuffle 43 173 174
|
||||
176: 171(ptr) AccessChain 34(data) 170 59 38
|
||||
Store 176 175
|
||||
177: 6(int) Load 8(invocation)
|
||||
180: 179(ptr) AccessChain 34(data) 47 59
|
||||
181: 22(i16vec4) Load 180
|
||||
182:178(i16vec2) VectorShuffle 181 181 0 1
|
||||
183: 6(int) Load 8(invocation)
|
||||
184:178(i16vec2) GroupNonUniformShuffle 43 182 183
|
||||
185: 179(ptr) AccessChain 34(data) 177 59
|
||||
186: 22(i16vec4) Load 185
|
||||
187: 22(i16vec4) VectorShuffle 186 184 4 5 2 3
|
||||
Store 185 187
|
||||
188: 6(int) Load 8(invocation)
|
||||
190: 179(ptr) AccessChain 34(data) 59 59
|
||||
191: 22(i16vec4) Load 190
|
||||
192:189(i16vec3) VectorShuffle 191 191 0 1 2
|
||||
193: 6(int) Load 8(invocation)
|
||||
194:189(i16vec3) GroupNonUniformShuffle 43 192 193
|
||||
195: 179(ptr) AccessChain 34(data) 188 59
|
||||
196: 22(i16vec4) Load 195
|
||||
197: 22(i16vec4) VectorShuffle 196 194 4 5 6 3
|
||||
Store 195 197
|
||||
198: 6(int) Load 8(invocation)
|
||||
199: 179(ptr) AccessChain 34(data) 70 59
|
||||
200: 22(i16vec4) Load 199
|
||||
201: 6(int) Load 8(invocation)
|
||||
202: 22(i16vec4) GroupNonUniformShuffle 43 200 201
|
||||
203: 179(ptr) AccessChain 34(data) 198 59
|
||||
Store 203 202
|
||||
204: 6(int) Load 8(invocation)
|
||||
205: 171(ptr) AccessChain 34(data) 37 59 38
|
||||
206: 21(int16_t) Load 205
|
||||
207: 6(int) Load 8(invocation)
|
||||
208: 21(int16_t) GroupNonUniformShuffleXor 43 206 207
|
||||
209: 171(ptr) AccessChain 34(data) 204 59 38
|
||||
Store 209 208
|
||||
210: 6(int) Load 8(invocation)
|
||||
211: 179(ptr) AccessChain 34(data) 47 59
|
||||
212: 22(i16vec4) Load 211
|
||||
213:178(i16vec2) VectorShuffle 212 212 0 1
|
||||
214: 6(int) Load 8(invocation)
|
||||
215:178(i16vec2) GroupNonUniformShuffleXor 43 213 214
|
||||
216: 179(ptr) AccessChain 34(data) 210 59
|
||||
217: 22(i16vec4) Load 216
|
||||
218: 22(i16vec4) VectorShuffle 217 215 4 5 2 3
|
||||
Store 216 218
|
||||
219: 6(int) Load 8(invocation)
|
||||
220: 179(ptr) AccessChain 34(data) 59 59
|
||||
221: 22(i16vec4) Load 220
|
||||
222:189(i16vec3) VectorShuffle 221 221 0 1 2
|
||||
223: 6(int) Load 8(invocation)
|
||||
224:189(i16vec3) GroupNonUniformShuffleXor 43 222 223
|
||||
225: 179(ptr) AccessChain 34(data) 219 59
|
||||
226: 22(i16vec4) Load 225
|
||||
227: 22(i16vec4) VectorShuffle 226 224 4 5 6 3
|
||||
Store 225 227
|
||||
228: 6(int) Load 8(invocation)
|
||||
229: 179(ptr) AccessChain 34(data) 70 59
|
||||
230: 22(i16vec4) Load 229
|
||||
231: 6(int) Load 8(invocation)
|
||||
232: 22(i16vec4) GroupNonUniformShuffleXor 43 230 231
|
||||
233: 179(ptr) AccessChain 34(data) 228 59
|
||||
Store 233 232
|
||||
234: 6(int) Load 8(invocation)
|
||||
236: 235(ptr) AccessChain 34(data) 37 70 38
|
||||
237: 23(int16_t) Load 236
|
||||
238: 6(int) Load 8(invocation)
|
||||
239: 23(int16_t) GroupNonUniformShuffle 43 237 238
|
||||
240: 235(ptr) AccessChain 34(data) 234 70 38
|
||||
Store 240 239
|
||||
241: 6(int) Load 8(invocation)
|
||||
244: 243(ptr) AccessChain 34(data) 47 70
|
||||
245: 24(i16vec4) Load 244
|
||||
246:242(i16vec2) VectorShuffle 245 245 0 1
|
||||
247: 6(int) Load 8(invocation)
|
||||
248:242(i16vec2) GroupNonUniformShuffle 43 246 247
|
||||
249: 243(ptr) AccessChain 34(data) 241 70
|
||||
250: 24(i16vec4) Load 249
|
||||
251: 24(i16vec4) VectorShuffle 250 248 4 5 2 3
|
||||
Store 249 251
|
||||
252: 6(int) Load 8(invocation)
|
||||
254: 243(ptr) AccessChain 34(data) 59 70
|
||||
255: 24(i16vec4) Load 254
|
||||
256:253(i16vec3) VectorShuffle 255 255 0 1 2
|
||||
257: 6(int) Load 8(invocation)
|
||||
258:253(i16vec3) GroupNonUniformShuffle 43 256 257
|
||||
259: 243(ptr) AccessChain 34(data) 252 70
|
||||
260: 24(i16vec4) Load 259
|
||||
261: 24(i16vec4) VectorShuffle 260 258 4 5 6 3
|
||||
Store 259 261
|
||||
262: 6(int) Load 8(invocation)
|
||||
263: 243(ptr) AccessChain 34(data) 70 70
|
||||
264: 24(i16vec4) Load 263
|
||||
265: 6(int) Load 8(invocation)
|
||||
266: 24(i16vec4) GroupNonUniformShuffle 43 264 265
|
||||
267: 243(ptr) AccessChain 34(data) 262 70
|
||||
Store 267 266
|
||||
268: 6(int) Load 8(invocation)
|
||||
269: 235(ptr) AccessChain 34(data) 37 70 38
|
||||
270: 23(int16_t) Load 269
|
||||
271: 6(int) Load 8(invocation)
|
||||
272: 23(int16_t) GroupNonUniformShuffleXor 43 270 271
|
||||
273: 235(ptr) AccessChain 34(data) 268 70 38
|
||||
Store 273 272
|
||||
274: 6(int) Load 8(invocation)
|
||||
275: 243(ptr) AccessChain 34(data) 47 70
|
||||
276: 24(i16vec4) Load 275
|
||||
277:242(i16vec2) VectorShuffle 276 276 0 1
|
||||
278: 6(int) Load 8(invocation)
|
||||
279:242(i16vec2) GroupNonUniformShuffleXor 43 277 278
|
||||
280: 243(ptr) AccessChain 34(data) 274 70
|
||||
281: 24(i16vec4) Load 280
|
||||
282: 24(i16vec4) VectorShuffle 281 279 4 5 2 3
|
||||
Store 280 282
|
||||
283: 6(int) Load 8(invocation)
|
||||
284: 243(ptr) AccessChain 34(data) 59 70
|
||||
285: 24(i16vec4) Load 284
|
||||
286:253(i16vec3) VectorShuffle 285 285 0 1 2
|
||||
287: 6(int) Load 8(invocation)
|
||||
288:253(i16vec3) GroupNonUniformShuffleXor 43 286 287
|
||||
289: 243(ptr) AccessChain 34(data) 283 70
|
||||
290: 24(i16vec4) Load 289
|
||||
291: 24(i16vec4) VectorShuffle 290 288 4 5 6 3
|
||||
Store 289 291
|
||||
292: 6(int) Load 8(invocation)
|
||||
293: 243(ptr) AccessChain 34(data) 70 70
|
||||
294: 24(i16vec4) Load 293
|
||||
295: 6(int) Load 8(invocation)
|
||||
296: 24(i16vec4) GroupNonUniformShuffleXor 43 294 295
|
||||
297: 243(ptr) AccessChain 34(data) 292 70
|
||||
Store 297 296
|
||||
298: 6(int) Load 8(invocation)
|
||||
301: 300(ptr) AccessChain 34(data) 37 299 38
|
||||
302: 25(int64_t) Load 301
|
||||
303: 6(int) Load 8(invocation)
|
||||
304: 25(int64_t) GroupNonUniformShuffle 43 302 303
|
||||
305: 300(ptr) AccessChain 34(data) 298 299 38
|
||||
Store 305 304
|
||||
306: 6(int) Load 8(invocation)
|
||||
309: 308(ptr) AccessChain 34(data) 47 299
|
||||
310: 26(i64vec4) Load 309
|
||||
311:307(i64vec2) VectorShuffle 310 310 0 1
|
||||
312: 6(int) Load 8(invocation)
|
||||
313:307(i64vec2) GroupNonUniformShuffle 43 311 312
|
||||
314: 308(ptr) AccessChain 34(data) 306 299
|
||||
315: 26(i64vec4) Load 314
|
||||
316: 26(i64vec4) VectorShuffle 315 313 4 5 2 3
|
||||
Store 314 316
|
||||
317: 6(int) Load 8(invocation)
|
||||
319: 308(ptr) AccessChain 34(data) 59 299
|
||||
320: 26(i64vec4) Load 319
|
||||
321:318(i64vec3) VectorShuffle 320 320 0 1 2
|
||||
322: 6(int) Load 8(invocation)
|
||||
323:318(i64vec3) GroupNonUniformShuffle 43 321 322
|
||||
324: 308(ptr) AccessChain 34(data) 317 299
|
||||
325: 26(i64vec4) Load 324
|
||||
326: 26(i64vec4) VectorShuffle 325 323 4 5 6 3
|
||||
Store 324 326
|
||||
327: 6(int) Load 8(invocation)
|
||||
328: 308(ptr) AccessChain 34(data) 70 299
|
||||
329: 26(i64vec4) Load 328
|
||||
330: 6(int) Load 8(invocation)
|
||||
331: 26(i64vec4) GroupNonUniformShuffle 43 329 330
|
||||
332: 308(ptr) AccessChain 34(data) 327 299
|
||||
Store 332 331
|
||||
333: 6(int) Load 8(invocation)
|
||||
334: 300(ptr) AccessChain 34(data) 37 299 38
|
||||
335: 25(int64_t) Load 334
|
||||
336: 6(int) Load 8(invocation)
|
||||
337: 25(int64_t) GroupNonUniformShuffleXor 43 335 336
|
||||
338: 300(ptr) AccessChain 34(data) 333 299 38
|
||||
Store 338 337
|
||||
339: 6(int) Load 8(invocation)
|
||||
340: 308(ptr) AccessChain 34(data) 47 299
|
||||
341: 26(i64vec4) Load 340
|
||||
342:307(i64vec2) VectorShuffle 341 341 0 1
|
||||
343: 6(int) Load 8(invocation)
|
||||
344:307(i64vec2) GroupNonUniformShuffleXor 43 342 343
|
||||
345: 308(ptr) AccessChain 34(data) 339 299
|
||||
346: 26(i64vec4) Load 345
|
||||
347: 26(i64vec4) VectorShuffle 346 344 4 5 2 3
|
||||
Store 345 347
|
||||
348: 6(int) Load 8(invocation)
|
||||
349: 308(ptr) AccessChain 34(data) 59 299
|
||||
350: 26(i64vec4) Load 349
|
||||
351:318(i64vec3) VectorShuffle 350 350 0 1 2
|
||||
352: 6(int) Load 8(invocation)
|
||||
353:318(i64vec3) GroupNonUniformShuffleXor 43 351 352
|
||||
354: 308(ptr) AccessChain 34(data) 348 299
|
||||
355: 26(i64vec4) Load 354
|
||||
356: 26(i64vec4) VectorShuffle 355 353 4 5 6 3
|
||||
Store 354 356
|
||||
357: 6(int) Load 8(invocation)
|
||||
358: 308(ptr) AccessChain 34(data) 70 299
|
||||
359: 26(i64vec4) Load 358
|
||||
360: 6(int) Load 8(invocation)
|
||||
361: 26(i64vec4) GroupNonUniformShuffleXor 43 359 360
|
||||
362: 308(ptr) AccessChain 34(data) 357 299
|
||||
Store 362 361
|
||||
363: 6(int) Load 8(invocation)
|
||||
366: 365(ptr) AccessChain 34(data) 37 364 38
|
||||
367: 27(int64_t) Load 366
|
||||
368: 6(int) Load 8(invocation)
|
||||
369: 27(int64_t) GroupNonUniformShuffle 43 367 368
|
||||
370: 365(ptr) AccessChain 34(data) 363 364 38
|
||||
Store 370 369
|
||||
371: 6(int) Load 8(invocation)
|
||||
374: 373(ptr) AccessChain 34(data) 47 364
|
||||
375: 28(i64vec4) Load 374
|
||||
376:372(i64vec2) VectorShuffle 375 375 0 1
|
||||
377: 6(int) Load 8(invocation)
|
||||
378:372(i64vec2) GroupNonUniformShuffle 43 376 377
|
||||
379: 373(ptr) AccessChain 34(data) 371 364
|
||||
380: 28(i64vec4) Load 379
|
||||
381: 28(i64vec4) VectorShuffle 380 378 4 5 2 3
|
||||
Store 379 381
|
||||
382: 6(int) Load 8(invocation)
|
||||
384: 373(ptr) AccessChain 34(data) 59 364
|
||||
385: 28(i64vec4) Load 384
|
||||
386:383(i64vec3) VectorShuffle 385 385 0 1 2
|
||||
387: 6(int) Load 8(invocation)
|
||||
388:383(i64vec3) GroupNonUniformShuffle 43 386 387
|
||||
389: 373(ptr) AccessChain 34(data) 382 364
|
||||
390: 28(i64vec4) Load 389
|
||||
391: 28(i64vec4) VectorShuffle 390 388 4 5 6 3
|
||||
Store 389 391
|
||||
392: 6(int) Load 8(invocation)
|
||||
393: 373(ptr) AccessChain 34(data) 70 364
|
||||
394: 28(i64vec4) Load 393
|
||||
395: 6(int) Load 8(invocation)
|
||||
396: 28(i64vec4) GroupNonUniformShuffle 43 394 395
|
||||
397: 373(ptr) AccessChain 34(data) 392 364
|
||||
Store 397 396
|
||||
398: 6(int) Load 8(invocation)
|
||||
399: 365(ptr) AccessChain 34(data) 37 364 38
|
||||
400: 27(int64_t) Load 399
|
||||
401: 6(int) Load 8(invocation)
|
||||
402: 27(int64_t) GroupNonUniformShuffleXor 43 400 401
|
||||
403: 365(ptr) AccessChain 34(data) 398 364 38
|
||||
Store 403 402
|
||||
404: 6(int) Load 8(invocation)
|
||||
405: 373(ptr) AccessChain 34(data) 47 364
|
||||
406: 28(i64vec4) Load 405
|
||||
407:372(i64vec2) VectorShuffle 406 406 0 1
|
||||
408: 6(int) Load 8(invocation)
|
||||
409:372(i64vec2) GroupNonUniformShuffleXor 43 407 408
|
||||
410: 373(ptr) AccessChain 34(data) 404 364
|
||||
411: 28(i64vec4) Load 410
|
||||
412: 28(i64vec4) VectorShuffle 411 409 4 5 2 3
|
||||
Store 410 412
|
||||
413: 6(int) Load 8(invocation)
|
||||
414: 373(ptr) AccessChain 34(data) 59 364
|
||||
415: 28(i64vec4) Load 414
|
||||
416:383(i64vec3) VectorShuffle 415 415 0 1 2
|
||||
417: 6(int) Load 8(invocation)
|
||||
418:383(i64vec3) GroupNonUniformShuffleXor 43 416 417
|
||||
419: 373(ptr) AccessChain 34(data) 413 364
|
||||
420: 28(i64vec4) Load 419
|
||||
421: 28(i64vec4) VectorShuffle 420 418 4 5 6 3
|
||||
Store 419 421
|
||||
422: 6(int) Load 8(invocation)
|
||||
423: 373(ptr) AccessChain 34(data) 70 364
|
||||
424: 28(i64vec4) Load 423
|
||||
425: 6(int) Load 8(invocation)
|
||||
426: 28(i64vec4) GroupNonUniformShuffleXor 43 424 425
|
||||
427: 373(ptr) AccessChain 34(data) 422 364
|
||||
Store 427 426
|
||||
428: 6(int) Load 8(invocation)
|
||||
431: 430(ptr) AccessChain 34(data) 37 429 38
|
||||
432:29(float16_t) Load 431
|
||||
433: 6(int) Load 8(invocation)
|
||||
434:29(float16_t) GroupNonUniformShuffle 43 432 433
|
||||
435: 430(ptr) AccessChain 34(data) 428 429 38
|
||||
Store 435 434
|
||||
436: 6(int) Load 8(invocation)
|
||||
439: 438(ptr) AccessChain 34(data) 47 429
|
||||
440: 30(f16vec4) Load 439
|
||||
441:437(f16vec2) VectorShuffle 440 440 0 1
|
||||
442: 6(int) Load 8(invocation)
|
||||
443:437(f16vec2) GroupNonUniformShuffle 43 441 442
|
||||
444: 438(ptr) AccessChain 34(data) 436 429
|
||||
445: 30(f16vec4) Load 444
|
||||
446: 30(f16vec4) VectorShuffle 445 443 4 5 2 3
|
||||
Store 444 446
|
||||
447: 6(int) Load 8(invocation)
|
||||
449: 438(ptr) AccessChain 34(data) 59 429
|
||||
450: 30(f16vec4) Load 449
|
||||
451:448(f16vec3) VectorShuffle 450 450 0 1 2
|
||||
452: 6(int) Load 8(invocation)
|
||||
453:448(f16vec3) GroupNonUniformShuffle 43 451 452
|
||||
454: 438(ptr) AccessChain 34(data) 447 429
|
||||
455: 30(f16vec4) Load 454
|
||||
456: 30(f16vec4) VectorShuffle 455 453 4 5 6 3
|
||||
Store 454 456
|
||||
457: 6(int) Load 8(invocation)
|
||||
458: 438(ptr) AccessChain 34(data) 70 429
|
||||
459: 30(f16vec4) Load 458
|
||||
460: 6(int) Load 8(invocation)
|
||||
461: 30(f16vec4) GroupNonUniformShuffle 43 459 460
|
||||
462: 438(ptr) AccessChain 34(data) 457 429
|
||||
Store 462 461
|
||||
463: 6(int) Load 8(invocation)
|
||||
464: 430(ptr) AccessChain 34(data) 37 429 38
|
||||
465:29(float16_t) Load 464
|
||||
466: 6(int) Load 8(invocation)
|
||||
467:29(float16_t) GroupNonUniformShuffleXor 43 465 466
|
||||
468: 430(ptr) AccessChain 34(data) 463 429 38
|
||||
Store 468 467
|
||||
469: 6(int) Load 8(invocation)
|
||||
470: 438(ptr) AccessChain 34(data) 47 429
|
||||
471: 30(f16vec4) Load 470
|
||||
472:437(f16vec2) VectorShuffle 471 471 0 1
|
||||
473: 6(int) Load 8(invocation)
|
||||
474:437(f16vec2) GroupNonUniformShuffleXor 43 472 473
|
||||
475: 438(ptr) AccessChain 34(data) 469 429
|
||||
476: 30(f16vec4) Load 475
|
||||
477: 30(f16vec4) VectorShuffle 476 474 4 5 2 3
|
||||
Store 475 477
|
||||
478: 6(int) Load 8(invocation)
|
||||
479: 438(ptr) AccessChain 34(data) 59 429
|
||||
480: 30(f16vec4) Load 479
|
||||
481:448(f16vec3) VectorShuffle 480 480 0 1 2
|
||||
482: 6(int) Load 8(invocation)
|
||||
483:448(f16vec3) GroupNonUniformShuffleXor 43 481 482
|
||||
484: 438(ptr) AccessChain 34(data) 478 429
|
||||
485: 30(f16vec4) Load 484
|
||||
486: 30(f16vec4) VectorShuffle 485 483 4 5 6 3
|
||||
Store 484 486
|
||||
487: 6(int) Load 8(invocation)
|
||||
488: 438(ptr) AccessChain 34(data) 70 429
|
||||
489: 30(f16vec4) Load 488
|
||||
490: 6(int) Load 8(invocation)
|
||||
491: 30(f16vec4) GroupNonUniformShuffleXor 43 489 490
|
||||
492: 438(ptr) AccessChain 34(data) 487 429
|
||||
Store 492 491
|
||||
Return
|
||||
FunctionEnd
|
61
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesShuffleNeg.comp.out
vendored
Normal file
61
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesShuffleNeg.comp.out
vendored
Normal file
@ -0,0 +1,61 @@
|
||||
spv.subgroupExtendedTypesShuffleNeg.comp
|
||||
ERROR: 0:26: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:27: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:28: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:29: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:31: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:32: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:33: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:34: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:36: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:37: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:38: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:39: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:41: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:42: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:43: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:44: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:46: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:47: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:48: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:49: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:51: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:52: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:53: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:54: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:56: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:57: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:58: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:59: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:61: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:62: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:63: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:64: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:66: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:67: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:68: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:69: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:71: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:72: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:73: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:74: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:76: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:77: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:78: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:79: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:81: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:82: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:83: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:84: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:86: ' temp highp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:87: ' temp highp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:88: ' temp highp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:89: 'layout( column_major std430) buffer highp 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:91: ' temp highp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:92: ' temp highp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:93: ' temp highp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:94: 'layout( column_major std430) buffer highp 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 56 compilation errors. No code generated.
|
||||
|
||||
|
||||
SPIR-V is not generated for failed compile or link
|
616
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesShuffleRelative.comp.out
vendored
Normal file
616
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesShuffleRelative.comp.out
vendored
Normal file
@ -0,0 +1,616 @@
|
||||
spv.subgroupExtendedTypesShuffleRelative.comp
|
||||
// Module Version 10300
|
||||
// Generated by (magic number): 80007
|
||||
// Id's are bound by 497
|
||||
|
||||
Capability Shader
|
||||
Capability Float16
|
||||
Capability Int64
|
||||
Capability Int16
|
||||
Capability Int8
|
||||
Capability GroupNonUniform
|
||||
Capability GroupNonUniformShuffleRelative
|
||||
Capability StorageUniformBufferBlock16
|
||||
Capability StorageBuffer8BitAccess
|
||||
Extension "SPV_KHR_8bit_storage"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel Logical GLSL450
|
||||
EntryPoint GLCompute 4 "main" 10 12
|
||||
ExecutionMode 4 LocalSize 8 1 1
|
||||
Source GLSL 450
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_float16"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int16"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int64"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int8"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_float16"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int16"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int64"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int8"
|
||||
SourceExtension "GL_KHR_shader_subgroup_basic"
|
||||
SourceExtension "GL_KHR_shader_subgroup_shuffle_relative"
|
||||
Name 4 "main"
|
||||
Name 8 "invocation"
|
||||
Name 10 "gl_SubgroupInvocationID"
|
||||
Name 12 "gl_SubgroupSize"
|
||||
Name 31 "Buffers"
|
||||
MemberName 31(Buffers) 0 "i8"
|
||||
MemberName 31(Buffers) 1 "u8"
|
||||
MemberName 31(Buffers) 2 "i16"
|
||||
MemberName 31(Buffers) 3 "u16"
|
||||
MemberName 31(Buffers) 4 "i64"
|
||||
MemberName 31(Buffers) 5 "u64"
|
||||
MemberName 31(Buffers) 6 "f16"
|
||||
Name 34 "data"
|
||||
Decorate 10(gl_SubgroupInvocationID) RelaxedPrecision
|
||||
Decorate 10(gl_SubgroupInvocationID) BuiltIn SubgroupLocalInvocationId
|
||||
Decorate 11 RelaxedPrecision
|
||||
Decorate 12(gl_SubgroupSize) RelaxedPrecision
|
||||
Decorate 12(gl_SubgroupSize) BuiltIn SubgroupSize
|
||||
Decorate 13 RelaxedPrecision
|
||||
Decorate 14 RelaxedPrecision
|
||||
Decorate 16 RelaxedPrecision
|
||||
MemberDecorate 31(Buffers) 0 Offset 0
|
||||
MemberDecorate 31(Buffers) 1 Offset 4
|
||||
MemberDecorate 31(Buffers) 2 Offset 8
|
||||
MemberDecorate 31(Buffers) 3 Offset 16
|
||||
MemberDecorate 31(Buffers) 4 Offset 32
|
||||
MemberDecorate 31(Buffers) 5 Offset 64
|
||||
MemberDecorate 31(Buffers) 6 Offset 96
|
||||
Decorate 31(Buffers) Block
|
||||
Decorate 34(data) DescriptorSet 0
|
||||
Decorate 34(data) Binding 0
|
||||
Decorate 496 BuiltIn WorkgroupSize
|
||||
2: TypeVoid
|
||||
3: TypeFunction 2
|
||||
6: TypeInt 32 0
|
||||
7: TypePointer Function 6(int)
|
||||
9: TypePointer Input 6(int)
|
||||
10(gl_SubgroupInvocationID): 9(ptr) Variable Input
|
||||
12(gl_SubgroupSize): 9(ptr) Variable Input
|
||||
15: 6(int) Constant 4
|
||||
17: TypeInt 8 1
|
||||
18: TypeVector 17(int8_t) 4
|
||||
19: TypeInt 8 0
|
||||
20: TypeVector 19(int8_t) 4
|
||||
21: TypeInt 16 1
|
||||
22: TypeVector 21(int16_t) 4
|
||||
23: TypeInt 16 0
|
||||
24: TypeVector 23(int16_t) 4
|
||||
25: TypeInt 64 1
|
||||
26: TypeVector 25(int64_t) 4
|
||||
27: TypeInt 64 0
|
||||
28: TypeVector 27(int64_t) 4
|
||||
29: TypeFloat 16
|
||||
30: TypeVector 29(float16_t) 4
|
||||
31(Buffers): TypeStruct 18(i8vec4) 20(i8vec4) 22(i16vec4) 24(i16vec4) 26(i64vec4) 28(i64vec4) 30(f16vec4)
|
||||
32: TypeArray 31(Buffers) 15
|
||||
33: TypePointer StorageBuffer 32
|
||||
34(data): 33(ptr) Variable StorageBuffer
|
||||
36: TypeInt 32 1
|
||||
37: 36(int) Constant 0
|
||||
38: 6(int) Constant 0
|
||||
39: TypePointer StorageBuffer 17(int8_t)
|
||||
43: 6(int) Constant 3
|
||||
47: 36(int) Constant 1
|
||||
48: TypeVector 17(int8_t) 2
|
||||
49: TypePointer StorageBuffer 18(i8vec4)
|
||||
59: 36(int) Constant 2
|
||||
60: TypeVector 17(int8_t) 3
|
||||
70: 36(int) Constant 3
|
||||
107: TypePointer StorageBuffer 19(int8_t)
|
||||
114: TypeVector 19(int8_t) 2
|
||||
115: TypePointer StorageBuffer 20(i8vec4)
|
||||
125: TypeVector 19(int8_t) 3
|
||||
171: TypePointer StorageBuffer 21(int16_t)
|
||||
178: TypeVector 21(int16_t) 2
|
||||
179: TypePointer StorageBuffer 22(i16vec4)
|
||||
189: TypeVector 21(int16_t) 3
|
||||
235: TypePointer StorageBuffer 23(int16_t)
|
||||
242: TypeVector 23(int16_t) 2
|
||||
243: TypePointer StorageBuffer 24(i16vec4)
|
||||
253: TypeVector 23(int16_t) 3
|
||||
299: 36(int) Constant 4
|
||||
300: TypePointer StorageBuffer 25(int64_t)
|
||||
307: TypeVector 25(int64_t) 2
|
||||
308: TypePointer StorageBuffer 26(i64vec4)
|
||||
318: TypeVector 25(int64_t) 3
|
||||
364: 36(int) Constant 5
|
||||
365: TypePointer StorageBuffer 27(int64_t)
|
||||
372: TypeVector 27(int64_t) 2
|
||||
373: TypePointer StorageBuffer 28(i64vec4)
|
||||
383: TypeVector 27(int64_t) 3
|
||||
429: 36(int) Constant 6
|
||||
430: TypePointer StorageBuffer 29(float16_t)
|
||||
437: TypeVector 29(float16_t) 2
|
||||
438: TypePointer StorageBuffer 30(f16vec4)
|
||||
448: TypeVector 29(float16_t) 3
|
||||
493: TypeVector 6(int) 3
|
||||
494: 6(int) Constant 8
|
||||
495: 6(int) Constant 1
|
||||
496: 493(ivec3) ConstantComposite 494 495 495
|
||||
4(main): 2 Function None 3
|
||||
5: Label
|
||||
8(invocation): 7(ptr) Variable Function
|
||||
11: 6(int) Load 10(gl_SubgroupInvocationID)
|
||||
13: 6(int) Load 12(gl_SubgroupSize)
|
||||
14: 6(int) IAdd 11 13
|
||||
16: 6(int) UMod 14 15
|
||||
Store 8(invocation) 16
|
||||
35: 6(int) Load 8(invocation)
|
||||
40: 39(ptr) AccessChain 34(data) 37 37 38
|
||||
41: 17(int8_t) Load 40
|
||||
42: 6(int) Load 8(invocation)
|
||||
44: 17(int8_t) GroupNonUniformShuffleUp 43 41 42
|
||||
45: 39(ptr) AccessChain 34(data) 35 37 38
|
||||
Store 45 44
|
||||
46: 6(int) Load 8(invocation)
|
||||
50: 49(ptr) AccessChain 34(data) 47 37
|
||||
51: 18(i8vec4) Load 50
|
||||
52: 48(i8vec2) VectorShuffle 51 51 0 1
|
||||
53: 6(int) Load 8(invocation)
|
||||
54: 48(i8vec2) GroupNonUniformShuffleUp 43 52 53
|
||||
55: 49(ptr) AccessChain 34(data) 46 37
|
||||
56: 18(i8vec4) Load 55
|
||||
57: 18(i8vec4) VectorShuffle 56 54 4 5 2 3
|
||||
Store 55 57
|
||||
58: 6(int) Load 8(invocation)
|
||||
61: 49(ptr) AccessChain 34(data) 59 37
|
||||
62: 18(i8vec4) Load 61
|
||||
63: 60(i8vec3) VectorShuffle 62 62 0 1 2
|
||||
64: 6(int) Load 8(invocation)
|
||||
65: 60(i8vec3) GroupNonUniformShuffleUp 43 63 64
|
||||
66: 49(ptr) AccessChain 34(data) 58 37
|
||||
67: 18(i8vec4) Load 66
|
||||
68: 18(i8vec4) VectorShuffle 67 65 4 5 6 3
|
||||
Store 66 68
|
||||
69: 6(int) Load 8(invocation)
|
||||
71: 49(ptr) AccessChain 34(data) 70 37
|
||||
72: 18(i8vec4) Load 71
|
||||
73: 6(int) Load 8(invocation)
|
||||
74: 18(i8vec4) GroupNonUniformShuffleUp 43 72 73
|
||||
75: 49(ptr) AccessChain 34(data) 69 37
|
||||
Store 75 74
|
||||
76: 6(int) Load 8(invocation)
|
||||
77: 39(ptr) AccessChain 34(data) 37 37 38
|
||||
78: 17(int8_t) Load 77
|
||||
79: 6(int) Load 8(invocation)
|
||||
80: 17(int8_t) GroupNonUniformShuffleDown 43 78 79
|
||||
81: 39(ptr) AccessChain 34(data) 76 37 38
|
||||
Store 81 80
|
||||
82: 6(int) Load 8(invocation)
|
||||
83: 49(ptr) AccessChain 34(data) 47 37
|
||||
84: 18(i8vec4) Load 83
|
||||
85: 48(i8vec2) VectorShuffle 84 84 0 1
|
||||
86: 6(int) Load 8(invocation)
|
||||
87: 48(i8vec2) GroupNonUniformShuffleDown 43 85 86
|
||||
88: 49(ptr) AccessChain 34(data) 82 37
|
||||
89: 18(i8vec4) Load 88
|
||||
90: 18(i8vec4) VectorShuffle 89 87 4 5 2 3
|
||||
Store 88 90
|
||||
91: 6(int) Load 8(invocation)
|
||||
92: 49(ptr) AccessChain 34(data) 59 37
|
||||
93: 18(i8vec4) Load 92
|
||||
94: 60(i8vec3) VectorShuffle 93 93 0 1 2
|
||||
95: 6(int) Load 8(invocation)
|
||||
96: 60(i8vec3) GroupNonUniformShuffleDown 43 94 95
|
||||
97: 49(ptr) AccessChain 34(data) 91 37
|
||||
98: 18(i8vec4) Load 97
|
||||
99: 18(i8vec4) VectorShuffle 98 96 4 5 6 3
|
||||
Store 97 99
|
||||
100: 6(int) Load 8(invocation)
|
||||
101: 49(ptr) AccessChain 34(data) 70 37
|
||||
102: 18(i8vec4) Load 101
|
||||
103: 6(int) Load 8(invocation)
|
||||
104: 18(i8vec4) GroupNonUniformShuffleDown 43 102 103
|
||||
105: 49(ptr) AccessChain 34(data) 100 37
|
||||
Store 105 104
|
||||
106: 6(int) Load 8(invocation)
|
||||
108: 107(ptr) AccessChain 34(data) 37 47 38
|
||||
109: 19(int8_t) Load 108
|
||||
110: 6(int) Load 8(invocation)
|
||||
111: 19(int8_t) GroupNonUniformShuffleUp 43 109 110
|
||||
112: 107(ptr) AccessChain 34(data) 106 47 38
|
||||
Store 112 111
|
||||
113: 6(int) Load 8(invocation)
|
||||
116: 115(ptr) AccessChain 34(data) 47 47
|
||||
117: 20(i8vec4) Load 116
|
||||
118: 114(i8vec2) VectorShuffle 117 117 0 1
|
||||
119: 6(int) Load 8(invocation)
|
||||
120: 114(i8vec2) GroupNonUniformShuffleUp 43 118 119
|
||||
121: 115(ptr) AccessChain 34(data) 113 47
|
||||
122: 20(i8vec4) Load 121
|
||||
123: 20(i8vec4) VectorShuffle 122 120 4 5 2 3
|
||||
Store 121 123
|
||||
124: 6(int) Load 8(invocation)
|
||||
126: 115(ptr) AccessChain 34(data) 59 47
|
||||
127: 20(i8vec4) Load 126
|
||||
128: 125(i8vec3) VectorShuffle 127 127 0 1 2
|
||||
129: 6(int) Load 8(invocation)
|
||||
130: 125(i8vec3) GroupNonUniformShuffleUp 43 128 129
|
||||
131: 115(ptr) AccessChain 34(data) 124 47
|
||||
132: 20(i8vec4) Load 131
|
||||
133: 20(i8vec4) VectorShuffle 132 130 4 5 6 3
|
||||
Store 131 133
|
||||
134: 6(int) Load 8(invocation)
|
||||
135: 115(ptr) AccessChain 34(data) 70 47
|
||||
136: 20(i8vec4) Load 135
|
||||
137: 6(int) Load 8(invocation)
|
||||
138: 20(i8vec4) GroupNonUniformShuffleUp 43 136 137
|
||||
139: 115(ptr) AccessChain 34(data) 134 47
|
||||
Store 139 138
|
||||
140: 6(int) Load 8(invocation)
|
||||
141: 107(ptr) AccessChain 34(data) 37 47 38
|
||||
142: 19(int8_t) Load 141
|
||||
143: 6(int) Load 8(invocation)
|
||||
144: 19(int8_t) GroupNonUniformShuffleDown 43 142 143
|
||||
145: 107(ptr) AccessChain 34(data) 140 47 38
|
||||
Store 145 144
|
||||
146: 6(int) Load 8(invocation)
|
||||
147: 115(ptr) AccessChain 34(data) 47 47
|
||||
148: 20(i8vec4) Load 147
|
||||
149: 114(i8vec2) VectorShuffle 148 148 0 1
|
||||
150: 6(int) Load 8(invocation)
|
||||
151: 114(i8vec2) GroupNonUniformShuffleDown 43 149 150
|
||||
152: 115(ptr) AccessChain 34(data) 146 47
|
||||
153: 20(i8vec4) Load 152
|
||||
154: 20(i8vec4) VectorShuffle 153 151 4 5 2 3
|
||||
Store 152 154
|
||||
155: 6(int) Load 8(invocation)
|
||||
156: 115(ptr) AccessChain 34(data) 59 47
|
||||
157: 20(i8vec4) Load 156
|
||||
158: 125(i8vec3) VectorShuffle 157 157 0 1 2
|
||||
159: 6(int) Load 8(invocation)
|
||||
160: 125(i8vec3) GroupNonUniformShuffleDown 43 158 159
|
||||
161: 115(ptr) AccessChain 34(data) 155 47
|
||||
162: 20(i8vec4) Load 161
|
||||
163: 20(i8vec4) VectorShuffle 162 160 4 5 6 3
|
||||
Store 161 163
|
||||
164: 6(int) Load 8(invocation)
|
||||
165: 115(ptr) AccessChain 34(data) 70 47
|
||||
166: 20(i8vec4) Load 165
|
||||
167: 6(int) Load 8(invocation)
|
||||
168: 20(i8vec4) GroupNonUniformShuffleDown 43 166 167
|
||||
169: 115(ptr) AccessChain 34(data) 164 47
|
||||
Store 169 168
|
||||
170: 6(int) Load 8(invocation)
|
||||
172: 171(ptr) AccessChain 34(data) 37 59 38
|
||||
173: 21(int16_t) Load 172
|
||||
174: 6(int) Load 8(invocation)
|
||||
175: 21(int16_t) GroupNonUniformShuffleUp 43 173 174
|
||||
176: 171(ptr) AccessChain 34(data) 170 59 38
|
||||
Store 176 175
|
||||
177: 6(int) Load 8(invocation)
|
||||
180: 179(ptr) AccessChain 34(data) 47 59
|
||||
181: 22(i16vec4) Load 180
|
||||
182:178(i16vec2) VectorShuffle 181 181 0 1
|
||||
183: 6(int) Load 8(invocation)
|
||||
184:178(i16vec2) GroupNonUniformShuffleUp 43 182 183
|
||||
185: 179(ptr) AccessChain 34(data) 177 59
|
||||
186: 22(i16vec4) Load 185
|
||||
187: 22(i16vec4) VectorShuffle 186 184 4 5 2 3
|
||||
Store 185 187
|
||||
188: 6(int) Load 8(invocation)
|
||||
190: 179(ptr) AccessChain 34(data) 59 59
|
||||
191: 22(i16vec4) Load 190
|
||||
192:189(i16vec3) VectorShuffle 191 191 0 1 2
|
||||
193: 6(int) Load 8(invocation)
|
||||
194:189(i16vec3) GroupNonUniformShuffleUp 43 192 193
|
||||
195: 179(ptr) AccessChain 34(data) 188 59
|
||||
196: 22(i16vec4) Load 195
|
||||
197: 22(i16vec4) VectorShuffle 196 194 4 5 6 3
|
||||
Store 195 197
|
||||
198: 6(int) Load 8(invocation)
|
||||
199: 179(ptr) AccessChain 34(data) 70 59
|
||||
200: 22(i16vec4) Load 199
|
||||
201: 6(int) Load 8(invocation)
|
||||
202: 22(i16vec4) GroupNonUniformShuffleUp 43 200 201
|
||||
203: 179(ptr) AccessChain 34(data) 198 59
|
||||
Store 203 202
|
||||
204: 6(int) Load 8(invocation)
|
||||
205: 171(ptr) AccessChain 34(data) 37 59 38
|
||||
206: 21(int16_t) Load 205
|
||||
207: 6(int) Load 8(invocation)
|
||||
208: 21(int16_t) GroupNonUniformShuffleDown 43 206 207
|
||||
209: 171(ptr) AccessChain 34(data) 204 59 38
|
||||
Store 209 208
|
||||
210: 6(int) Load 8(invocation)
|
||||
211: 179(ptr) AccessChain 34(data) 47 59
|
||||
212: 22(i16vec4) Load 211
|
||||
213:178(i16vec2) VectorShuffle 212 212 0 1
|
||||
214: 6(int) Load 8(invocation)
|
||||
215:178(i16vec2) GroupNonUniformShuffleDown 43 213 214
|
||||
216: 179(ptr) AccessChain 34(data) 210 59
|
||||
217: 22(i16vec4) Load 216
|
||||
218: 22(i16vec4) VectorShuffle 217 215 4 5 2 3
|
||||
Store 216 218
|
||||
219: 6(int) Load 8(invocation)
|
||||
220: 179(ptr) AccessChain 34(data) 59 59
|
||||
221: 22(i16vec4) Load 220
|
||||
222:189(i16vec3) VectorShuffle 221 221 0 1 2
|
||||
223: 6(int) Load 8(invocation)
|
||||
224:189(i16vec3) GroupNonUniformShuffleDown 43 222 223
|
||||
225: 179(ptr) AccessChain 34(data) 219 59
|
||||
226: 22(i16vec4) Load 225
|
||||
227: 22(i16vec4) VectorShuffle 226 224 4 5 6 3
|
||||
Store 225 227
|
||||
228: 6(int) Load 8(invocation)
|
||||
229: 179(ptr) AccessChain 34(data) 70 59
|
||||
230: 22(i16vec4) Load 229
|
||||
231: 6(int) Load 8(invocation)
|
||||
232: 22(i16vec4) GroupNonUniformShuffleDown 43 230 231
|
||||
233: 179(ptr) AccessChain 34(data) 228 59
|
||||
Store 233 232
|
||||
234: 6(int) Load 8(invocation)
|
||||
236: 235(ptr) AccessChain 34(data) 37 70 38
|
||||
237: 23(int16_t) Load 236
|
||||
238: 6(int) Load 8(invocation)
|
||||
239: 23(int16_t) GroupNonUniformShuffleUp 43 237 238
|
||||
240: 235(ptr) AccessChain 34(data) 234 70 38
|
||||
Store 240 239
|
||||
241: 6(int) Load 8(invocation)
|
||||
244: 243(ptr) AccessChain 34(data) 47 70
|
||||
245: 24(i16vec4) Load 244
|
||||
246:242(i16vec2) VectorShuffle 245 245 0 1
|
||||
247: 6(int) Load 8(invocation)
|
||||
248:242(i16vec2) GroupNonUniformShuffleUp 43 246 247
|
||||
249: 243(ptr) AccessChain 34(data) 241 70
|
||||
250: 24(i16vec4) Load 249
|
||||
251: 24(i16vec4) VectorShuffle 250 248 4 5 2 3
|
||||
Store 249 251
|
||||
252: 6(int) Load 8(invocation)
|
||||
254: 243(ptr) AccessChain 34(data) 59 70
|
||||
255: 24(i16vec4) Load 254
|
||||
256:253(i16vec3) VectorShuffle 255 255 0 1 2
|
||||
257: 6(int) Load 8(invocation)
|
||||
258:253(i16vec3) GroupNonUniformShuffleUp 43 256 257
|
||||
259: 243(ptr) AccessChain 34(data) 252 70
|
||||
260: 24(i16vec4) Load 259
|
||||
261: 24(i16vec4) VectorShuffle 260 258 4 5 6 3
|
||||
Store 259 261
|
||||
262: 6(int) Load 8(invocation)
|
||||
263: 243(ptr) AccessChain 34(data) 70 70
|
||||
264: 24(i16vec4) Load 263
|
||||
265: 6(int) Load 8(invocation)
|
||||
266: 24(i16vec4) GroupNonUniformShuffleUp 43 264 265
|
||||
267: 243(ptr) AccessChain 34(data) 262 70
|
||||
Store 267 266
|
||||
268: 6(int) Load 8(invocation)
|
||||
269: 235(ptr) AccessChain 34(data) 37 70 38
|
||||
270: 23(int16_t) Load 269
|
||||
271: 6(int) Load 8(invocation)
|
||||
272: 23(int16_t) GroupNonUniformShuffleDown 43 270 271
|
||||
273: 235(ptr) AccessChain 34(data) 268 70 38
|
||||
Store 273 272
|
||||
274: 6(int) Load 8(invocation)
|
||||
275: 243(ptr) AccessChain 34(data) 47 70
|
||||
276: 24(i16vec4) Load 275
|
||||
277:242(i16vec2) VectorShuffle 276 276 0 1
|
||||
278: 6(int) Load 8(invocation)
|
||||
279:242(i16vec2) GroupNonUniformShuffleDown 43 277 278
|
||||
280: 243(ptr) AccessChain 34(data) 274 70
|
||||
281: 24(i16vec4) Load 280
|
||||
282: 24(i16vec4) VectorShuffle 281 279 4 5 2 3
|
||||
Store 280 282
|
||||
283: 6(int) Load 8(invocation)
|
||||
284: 243(ptr) AccessChain 34(data) 59 70
|
||||
285: 24(i16vec4) Load 284
|
||||
286:253(i16vec3) VectorShuffle 285 285 0 1 2
|
||||
287: 6(int) Load 8(invocation)
|
||||
288:253(i16vec3) GroupNonUniformShuffleDown 43 286 287
|
||||
289: 243(ptr) AccessChain 34(data) 283 70
|
||||
290: 24(i16vec4) Load 289
|
||||
291: 24(i16vec4) VectorShuffle 290 288 4 5 6 3
|
||||
Store 289 291
|
||||
292: 6(int) Load 8(invocation)
|
||||
293: 243(ptr) AccessChain 34(data) 70 70
|
||||
294: 24(i16vec4) Load 293
|
||||
295: 6(int) Load 8(invocation)
|
||||
296: 24(i16vec4) GroupNonUniformShuffleDown 43 294 295
|
||||
297: 243(ptr) AccessChain 34(data) 292 70
|
||||
Store 297 296
|
||||
298: 6(int) Load 8(invocation)
|
||||
301: 300(ptr) AccessChain 34(data) 37 299 38
|
||||
302: 25(int64_t) Load 301
|
||||
303: 6(int) Load 8(invocation)
|
||||
304: 25(int64_t) GroupNonUniformShuffleUp 43 302 303
|
||||
305: 300(ptr) AccessChain 34(data) 298 299 38
|
||||
Store 305 304
|
||||
306: 6(int) Load 8(invocation)
|
||||
309: 308(ptr) AccessChain 34(data) 47 299
|
||||
310: 26(i64vec4) Load 309
|
||||
311:307(i64vec2) VectorShuffle 310 310 0 1
|
||||
312: 6(int) Load 8(invocation)
|
||||
313:307(i64vec2) GroupNonUniformShuffleUp 43 311 312
|
||||
314: 308(ptr) AccessChain 34(data) 306 299
|
||||
315: 26(i64vec4) Load 314
|
||||
316: 26(i64vec4) VectorShuffle 315 313 4 5 2 3
|
||||
Store 314 316
|
||||
317: 6(int) Load 8(invocation)
|
||||
319: 308(ptr) AccessChain 34(data) 59 299
|
||||
320: 26(i64vec4) Load 319
|
||||
321:318(i64vec3) VectorShuffle 320 320 0 1 2
|
||||
322: 6(int) Load 8(invocation)
|
||||
323:318(i64vec3) GroupNonUniformShuffleUp 43 321 322
|
||||
324: 308(ptr) AccessChain 34(data) 317 299
|
||||
325: 26(i64vec4) Load 324
|
||||
326: 26(i64vec4) VectorShuffle 325 323 4 5 6 3
|
||||
Store 324 326
|
||||
327: 6(int) Load 8(invocation)
|
||||
328: 308(ptr) AccessChain 34(data) 70 299
|
||||
329: 26(i64vec4) Load 328
|
||||
330: 6(int) Load 8(invocation)
|
||||
331: 26(i64vec4) GroupNonUniformShuffleUp 43 329 330
|
||||
332: 308(ptr) AccessChain 34(data) 327 299
|
||||
Store 332 331
|
||||
333: 6(int) Load 8(invocation)
|
||||
334: 300(ptr) AccessChain 34(data) 37 299 38
|
||||
335: 25(int64_t) Load 334
|
||||
336: 6(int) Load 8(invocation)
|
||||
337: 25(int64_t) GroupNonUniformShuffleDown 43 335 336
|
||||
338: 300(ptr) AccessChain 34(data) 333 299 38
|
||||
Store 338 337
|
||||
339: 6(int) Load 8(invocation)
|
||||
340: 308(ptr) AccessChain 34(data) 47 299
|
||||
341: 26(i64vec4) Load 340
|
||||
342:307(i64vec2) VectorShuffle 341 341 0 1
|
||||
343: 6(int) Load 8(invocation)
|
||||
344:307(i64vec2) GroupNonUniformShuffleDown 43 342 343
|
||||
345: 308(ptr) AccessChain 34(data) 339 299
|
||||
346: 26(i64vec4) Load 345
|
||||
347: 26(i64vec4) VectorShuffle 346 344 4 5 2 3
|
||||
Store 345 347
|
||||
348: 6(int) Load 8(invocation)
|
||||
349: 308(ptr) AccessChain 34(data) 59 299
|
||||
350: 26(i64vec4) Load 349
|
||||
351:318(i64vec3) VectorShuffle 350 350 0 1 2
|
||||
352: 6(int) Load 8(invocation)
|
||||
353:318(i64vec3) GroupNonUniformShuffleDown 43 351 352
|
||||
354: 308(ptr) AccessChain 34(data) 348 299
|
||||
355: 26(i64vec4) Load 354
|
||||
356: 26(i64vec4) VectorShuffle 355 353 4 5 6 3
|
||||
Store 354 356
|
||||
357: 6(int) Load 8(invocation)
|
||||
358: 308(ptr) AccessChain 34(data) 70 299
|
||||
359: 26(i64vec4) Load 358
|
||||
360: 6(int) Load 8(invocation)
|
||||
361: 26(i64vec4) GroupNonUniformShuffleDown 43 359 360
|
||||
362: 308(ptr) AccessChain 34(data) 357 299
|
||||
Store 362 361
|
||||
363: 6(int) Load 8(invocation)
|
||||
366: 365(ptr) AccessChain 34(data) 37 364 38
|
||||
367: 27(int64_t) Load 366
|
||||
368: 6(int) Load 8(invocation)
|
||||
369: 27(int64_t) GroupNonUniformShuffleUp 43 367 368
|
||||
370: 365(ptr) AccessChain 34(data) 363 364 38
|
||||
Store 370 369
|
||||
371: 6(int) Load 8(invocation)
|
||||
374: 373(ptr) AccessChain 34(data) 47 364
|
||||
375: 28(i64vec4) Load 374
|
||||
376:372(i64vec2) VectorShuffle 375 375 0 1
|
||||
377: 6(int) Load 8(invocation)
|
||||
378:372(i64vec2) GroupNonUniformShuffleUp 43 376 377
|
||||
379: 373(ptr) AccessChain 34(data) 371 364
|
||||
380: 28(i64vec4) Load 379
|
||||
381: 28(i64vec4) VectorShuffle 380 378 4 5 2 3
|
||||
Store 379 381
|
||||
382: 6(int) Load 8(invocation)
|
||||
384: 373(ptr) AccessChain 34(data) 59 364
|
||||
385: 28(i64vec4) Load 384
|
||||
386:383(i64vec3) VectorShuffle 385 385 0 1 2
|
||||
387: 6(int) Load 8(invocation)
|
||||
388:383(i64vec3) GroupNonUniformShuffleUp 43 386 387
|
||||
389: 373(ptr) AccessChain 34(data) 382 364
|
||||
390: 28(i64vec4) Load 389
|
||||
391: 28(i64vec4) VectorShuffle 390 388 4 5 6 3
|
||||
Store 389 391
|
||||
392: 6(int) Load 8(invocation)
|
||||
393: 373(ptr) AccessChain 34(data) 70 364
|
||||
394: 28(i64vec4) Load 393
|
||||
395: 6(int) Load 8(invocation)
|
||||
396: 28(i64vec4) GroupNonUniformShuffleUp 43 394 395
|
||||
397: 373(ptr) AccessChain 34(data) 392 364
|
||||
Store 397 396
|
||||
398: 6(int) Load 8(invocation)
|
||||
399: 365(ptr) AccessChain 34(data) 37 364 38
|
||||
400: 27(int64_t) Load 399
|
||||
401: 6(int) Load 8(invocation)
|
||||
402: 27(int64_t) GroupNonUniformShuffleDown 43 400 401
|
||||
403: 365(ptr) AccessChain 34(data) 398 364 38
|
||||
Store 403 402
|
||||
404: 6(int) Load 8(invocation)
|
||||
405: 373(ptr) AccessChain 34(data) 47 364
|
||||
406: 28(i64vec4) Load 405
|
||||
407:372(i64vec2) VectorShuffle 406 406 0 1
|
||||
408: 6(int) Load 8(invocation)
|
||||
409:372(i64vec2) GroupNonUniformShuffleDown 43 407 408
|
||||
410: 373(ptr) AccessChain 34(data) 404 364
|
||||
411: 28(i64vec4) Load 410
|
||||
412: 28(i64vec4) VectorShuffle 411 409 4 5 2 3
|
||||
Store 410 412
|
||||
413: 6(int) Load 8(invocation)
|
||||
414: 373(ptr) AccessChain 34(data) 59 364
|
||||
415: 28(i64vec4) Load 414
|
||||
416:383(i64vec3) VectorShuffle 415 415 0 1 2
|
||||
417: 6(int) Load 8(invocation)
|
||||
418:383(i64vec3) GroupNonUniformShuffleDown 43 416 417
|
||||
419: 373(ptr) AccessChain 34(data) 413 364
|
||||
420: 28(i64vec4) Load 419
|
||||
421: 28(i64vec4) VectorShuffle 420 418 4 5 6 3
|
||||
Store 419 421
|
||||
422: 6(int) Load 8(invocation)
|
||||
423: 373(ptr) AccessChain 34(data) 70 364
|
||||
424: 28(i64vec4) Load 423
|
||||
425: 6(int) Load 8(invocation)
|
||||
426: 28(i64vec4) GroupNonUniformShuffleDown 43 424 425
|
||||
427: 373(ptr) AccessChain 34(data) 422 364
|
||||
Store 427 426
|
||||
428: 6(int) Load 8(invocation)
|
||||
431: 430(ptr) AccessChain 34(data) 37 429 38
|
||||
432:29(float16_t) Load 431
|
||||
433: 6(int) Load 8(invocation)
|
||||
434:29(float16_t) GroupNonUniformShuffleUp 43 432 433
|
||||
435: 430(ptr) AccessChain 34(data) 428 429 38
|
||||
Store 435 434
|
||||
436: 6(int) Load 8(invocation)
|
||||
439: 438(ptr) AccessChain 34(data) 47 429
|
||||
440: 30(f16vec4) Load 439
|
||||
441:437(f16vec2) VectorShuffle 440 440 0 1
|
||||
442: 6(int) Load 8(invocation)
|
||||
443:437(f16vec2) GroupNonUniformShuffleUp 43 441 442
|
||||
444: 438(ptr) AccessChain 34(data) 436 429
|
||||
445: 30(f16vec4) Load 444
|
||||
446: 30(f16vec4) VectorShuffle 445 443 4 5 2 3
|
||||
Store 444 446
|
||||
447: 6(int) Load 8(invocation)
|
||||
449: 438(ptr) AccessChain 34(data) 59 429
|
||||
450: 30(f16vec4) Load 449
|
||||
451:448(f16vec3) VectorShuffle 450 450 0 1 2
|
||||
452: 6(int) Load 8(invocation)
|
||||
453:448(f16vec3) GroupNonUniformShuffleUp 43 451 452
|
||||
454: 438(ptr) AccessChain 34(data) 447 429
|
||||
455: 30(f16vec4) Load 454
|
||||
456: 30(f16vec4) VectorShuffle 455 453 4 5 6 3
|
||||
Store 454 456
|
||||
457: 6(int) Load 8(invocation)
|
||||
458: 438(ptr) AccessChain 34(data) 70 429
|
||||
459: 30(f16vec4) Load 458
|
||||
460: 6(int) Load 8(invocation)
|
||||
461: 30(f16vec4) GroupNonUniformShuffleUp 43 459 460
|
||||
462: 438(ptr) AccessChain 34(data) 457 429
|
||||
Store 462 461
|
||||
463: 6(int) Load 8(invocation)
|
||||
464: 430(ptr) AccessChain 34(data) 37 429 38
|
||||
465:29(float16_t) Load 464
|
||||
466: 6(int) Load 8(invocation)
|
||||
467:29(float16_t) GroupNonUniformShuffleDown 43 465 466
|
||||
468: 430(ptr) AccessChain 34(data) 463 429 38
|
||||
Store 468 467
|
||||
469: 6(int) Load 8(invocation)
|
||||
470: 438(ptr) AccessChain 34(data) 47 429
|
||||
471: 30(f16vec4) Load 470
|
||||
472:437(f16vec2) VectorShuffle 471 471 0 1
|
||||
473: 6(int) Load 8(invocation)
|
||||
474:437(f16vec2) GroupNonUniformShuffleDown 43 472 473
|
||||
475: 438(ptr) AccessChain 34(data) 469 429
|
||||
476: 30(f16vec4) Load 475
|
||||
477: 30(f16vec4) VectorShuffle 476 474 4 5 2 3
|
||||
Store 475 477
|
||||
478: 6(int) Load 8(invocation)
|
||||
479: 438(ptr) AccessChain 34(data) 59 429
|
||||
480: 30(f16vec4) Load 479
|
||||
481:448(f16vec3) VectorShuffle 480 480 0 1 2
|
||||
482: 6(int) Load 8(invocation)
|
||||
483:448(f16vec3) GroupNonUniformShuffleDown 43 481 482
|
||||
484: 438(ptr) AccessChain 34(data) 478 429
|
||||
485: 30(f16vec4) Load 484
|
||||
486: 30(f16vec4) VectorShuffle 485 483 4 5 6 3
|
||||
Store 484 486
|
||||
487: 6(int) Load 8(invocation)
|
||||
488: 438(ptr) AccessChain 34(data) 70 429
|
||||
489: 30(f16vec4) Load 488
|
||||
490: 6(int) Load 8(invocation)
|
||||
491: 30(f16vec4) GroupNonUniformShuffleDown 43 489 490
|
||||
492: 438(ptr) AccessChain 34(data) 487 429
|
||||
Store 492 491
|
||||
Return
|
||||
FunctionEnd
|
61
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesShuffleRelativeNeg.comp.out
vendored
Normal file
61
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesShuffleRelativeNeg.comp.out
vendored
Normal file
@ -0,0 +1,61 @@
|
||||
spv.subgroupExtendedTypesShuffleRelativeNeg.comp
|
||||
ERROR: 0:26: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:27: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:28: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:29: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:31: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:32: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:33: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:34: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:36: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:37: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:38: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:39: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:41: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:42: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:43: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:44: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:46: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:47: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:48: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:49: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:51: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:52: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:53: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:54: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:56: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:57: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:58: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:59: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:61: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:62: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:63: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:64: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:66: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:67: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:68: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:69: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:71: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:72: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:73: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:74: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:76: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:77: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:78: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:79: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:81: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:82: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:83: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:84: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:86: ' temp highp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:87: ' temp highp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:88: ' temp highp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:89: 'layout( column_major std430) buffer highp 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:91: ' temp highp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:92: ' temp highp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:93: ' temp highp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:94: 'layout( column_major std430) buffer highp 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 56 compilation errors. No code generated.
|
||||
|
||||
|
||||
SPIR-V is not generated for failed compile or link
|
377
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesVote.comp.out
vendored
Normal file
377
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesVote.comp.out
vendored
Normal file
@ -0,0 +1,377 @@
|
||||
spv.subgroupExtendedTypesVote.comp
|
||||
// Module Version 10300
|
||||
// Generated by (magic number): 80007
|
||||
// Id's are bound by 277
|
||||
|
||||
Capability Shader
|
||||
Capability Float16
|
||||
Capability Int64
|
||||
Capability Int16
|
||||
Capability Int8
|
||||
Capability GroupNonUniform
|
||||
Capability GroupNonUniformVote
|
||||
Capability StorageUniformBufferBlock16
|
||||
Capability StorageBuffer8BitAccess
|
||||
Extension "SPV_KHR_8bit_storage"
|
||||
1: ExtInstImport "GLSL.std.450"
|
||||
MemoryModel Logical GLSL450
|
||||
EntryPoint GLCompute 4 "main" 10 12
|
||||
ExecutionMode 4 LocalSize 8 1 1
|
||||
Source GLSL 450
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_float16"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int16"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int64"
|
||||
SourceExtension "GL_EXT_shader_explicit_arithmetic_types_int8"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_float16"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int16"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int64"
|
||||
SourceExtension "GL_EXT_shader_subgroup_extended_types_int8"
|
||||
SourceExtension "GL_KHR_shader_subgroup_basic"
|
||||
SourceExtension "GL_KHR_shader_subgroup_vote"
|
||||
Name 4 "main"
|
||||
Name 8 "invocation"
|
||||
Name 10 "gl_SubgroupInvocationID"
|
||||
Name 12 "gl_SubgroupSize"
|
||||
Name 32 "Buffers"
|
||||
MemberName 32(Buffers) 0 "i8"
|
||||
MemberName 32(Buffers) 1 "u8"
|
||||
MemberName 32(Buffers) 2 "i16"
|
||||
MemberName 32(Buffers) 3 "u16"
|
||||
MemberName 32(Buffers) 4 "i64"
|
||||
MemberName 32(Buffers) 5 "u64"
|
||||
MemberName 32(Buffers) 6 "f16"
|
||||
MemberName 32(Buffers) 7 "r"
|
||||
Name 35 "data"
|
||||
Decorate 10(gl_SubgroupInvocationID) RelaxedPrecision
|
||||
Decorate 10(gl_SubgroupInvocationID) BuiltIn SubgroupLocalInvocationId
|
||||
Decorate 11 RelaxedPrecision
|
||||
Decorate 12(gl_SubgroupSize) RelaxedPrecision
|
||||
Decorate 12(gl_SubgroupSize) BuiltIn SubgroupSize
|
||||
Decorate 13 RelaxedPrecision
|
||||
Decorate 14 RelaxedPrecision
|
||||
Decorate 16 RelaxedPrecision
|
||||
MemberDecorate 32(Buffers) 0 Offset 0
|
||||
MemberDecorate 32(Buffers) 1 Offset 4
|
||||
MemberDecorate 32(Buffers) 2 Offset 8
|
||||
MemberDecorate 32(Buffers) 3 Offset 16
|
||||
MemberDecorate 32(Buffers) 4 Offset 32
|
||||
MemberDecorate 32(Buffers) 5 Offset 64
|
||||
MemberDecorate 32(Buffers) 6 Offset 96
|
||||
MemberDecorate 32(Buffers) 7 Offset 104
|
||||
Decorate 32(Buffers) Block
|
||||
Decorate 35(data) DescriptorSet 0
|
||||
Decorate 35(data) Binding 0
|
||||
Decorate 276 BuiltIn WorkgroupSize
|
||||
2: TypeVoid
|
||||
3: TypeFunction 2
|
||||
6: TypeInt 32 0
|
||||
7: TypePointer Function 6(int)
|
||||
9: TypePointer Input 6(int)
|
||||
10(gl_SubgroupInvocationID): 9(ptr) Variable Input
|
||||
12(gl_SubgroupSize): 9(ptr) Variable Input
|
||||
15: 6(int) Constant 4
|
||||
17: TypeInt 8 1
|
||||
18: TypeVector 17(int8_t) 4
|
||||
19: TypeInt 8 0
|
||||
20: TypeVector 19(int8_t) 4
|
||||
21: TypeInt 16 1
|
||||
22: TypeVector 21(int16_t) 4
|
||||
23: TypeInt 16 0
|
||||
24: TypeVector 23(int16_t) 4
|
||||
25: TypeInt 64 1
|
||||
26: TypeVector 25(int64_t) 4
|
||||
27: TypeInt 64 0
|
||||
28: TypeVector 27(int64_t) 4
|
||||
29: TypeFloat 16
|
||||
30: TypeVector 29(float16_t) 4
|
||||
31: TypeInt 32 1
|
||||
32(Buffers): TypeStruct 18(i8vec4) 20(i8vec4) 22(i16vec4) 24(i16vec4) 26(i64vec4) 28(i64vec4) 30(f16vec4) 31(int)
|
||||
33: TypeArray 32(Buffers) 15
|
||||
34: TypePointer StorageBuffer 33
|
||||
35(data): 34(ptr) Variable StorageBuffer
|
||||
37: 31(int) Constant 7
|
||||
38: TypePointer StorageBuffer 31(int)
|
||||
41: 31(int) Constant 0
|
||||
42: TypeBool
|
||||
44: 6(int) Constant 3
|
||||
49: 6(int) Constant 0
|
||||
50: TypePointer StorageBuffer 17(int8_t)
|
||||
54: 31(int) Constant 1
|
||||
58: TypeVector 17(int8_t) 2
|
||||
59: TypePointer StorageBuffer 18(i8vec4)
|
||||
67: 31(int) Constant 2
|
||||
68: TypeVector 17(int8_t) 3
|
||||
76: 31(int) Constant 3
|
||||
83: TypePointer StorageBuffer 19(int8_t)
|
||||
90: TypeVector 19(int8_t) 2
|
||||
91: TypePointer StorageBuffer 20(i8vec4)
|
||||
99: TypeVector 19(int8_t) 3
|
||||
113: TypePointer StorageBuffer 21(int16_t)
|
||||
120: TypeVector 21(int16_t) 2
|
||||
121: TypePointer StorageBuffer 22(i16vec4)
|
||||
129: TypeVector 21(int16_t) 3
|
||||
143: TypePointer StorageBuffer 23(int16_t)
|
||||
150: TypeVector 23(int16_t) 2
|
||||
151: TypePointer StorageBuffer 24(i16vec4)
|
||||
159: TypeVector 23(int16_t) 3
|
||||
181: 31(int) Constant 4
|
||||
182: TypePointer StorageBuffer 25(int64_t)
|
||||
189: TypeVector 25(int64_t) 2
|
||||
190: TypePointer StorageBuffer 26(i64vec4)
|
||||
198: TypeVector 25(int64_t) 3
|
||||
212: 31(int) Constant 5
|
||||
213: TypePointer StorageBuffer 27(int64_t)
|
||||
220: TypeVector 27(int64_t) 2
|
||||
221: TypePointer StorageBuffer 28(i64vec4)
|
||||
229: TypeVector 27(int64_t) 3
|
||||
243: 31(int) Constant 6
|
||||
244: TypePointer StorageBuffer 29(float16_t)
|
||||
251: TypeVector 29(float16_t) 2
|
||||
252: TypePointer StorageBuffer 30(f16vec4)
|
||||
260: TypeVector 29(float16_t) 3
|
||||
273: TypeVector 6(int) 3
|
||||
274: 6(int) Constant 8
|
||||
275: 6(int) Constant 1
|
||||
276: 273(ivec3) ConstantComposite 274 275 275
|
||||
4(main): 2 Function None 3
|
||||
5: Label
|
||||
8(invocation): 7(ptr) Variable Function
|
||||
11: 6(int) Load 10(gl_SubgroupInvocationID)
|
||||
13: 6(int) Load 12(gl_SubgroupSize)
|
||||
14: 6(int) IAdd 11 13
|
||||
16: 6(int) UMod 14 15
|
||||
Store 8(invocation) 16
|
||||
36: 6(int) Load 8(invocation)
|
||||
39: 38(ptr) AccessChain 35(data) 36 37
|
||||
40: 31(int) Load 39
|
||||
43: 42(bool) SLessThan 40 41
|
||||
45: 42(bool) GroupNonUniformAll 44 43
|
||||
SelectionMerge 47 None
|
||||
BranchConditional 45 46 172
|
||||
46: Label
|
||||
48: 6(int) Load 8(invocation)
|
||||
51: 50(ptr) AccessChain 35(data) 41 41 49
|
||||
52: 17(int8_t) Load 51
|
||||
53: 42(bool) GroupNonUniformAllEqual 44 52
|
||||
55: 31(int) Select 53 54 41
|
||||
56: 38(ptr) AccessChain 35(data) 48 37
|
||||
Store 56 55
|
||||
57: 6(int) Load 8(invocation)
|
||||
60: 59(ptr) AccessChain 35(data) 54 41
|
||||
61: 18(i8vec4) Load 60
|
||||
62: 58(i8vec2) VectorShuffle 61 61 0 1
|
||||
63: 42(bool) GroupNonUniformAllEqual 44 62
|
||||
64: 31(int) Select 63 54 41
|
||||
65: 38(ptr) AccessChain 35(data) 57 37
|
||||
Store 65 64
|
||||
66: 6(int) Load 8(invocation)
|
||||
69: 59(ptr) AccessChain 35(data) 67 41
|
||||
70: 18(i8vec4) Load 69
|
||||
71: 68(i8vec3) VectorShuffle 70 70 0 1 2
|
||||
72: 42(bool) GroupNonUniformAllEqual 44 71
|
||||
73: 31(int) Select 72 54 41
|
||||
74: 38(ptr) AccessChain 35(data) 66 37
|
||||
Store 74 73
|
||||
75: 6(int) Load 8(invocation)
|
||||
77: 59(ptr) AccessChain 35(data) 76 41
|
||||
78: 18(i8vec4) Load 77
|
||||
79: 42(bool) GroupNonUniformAllEqual 44 78
|
||||
80: 31(int) Select 79 54 41
|
||||
81: 38(ptr) AccessChain 35(data) 75 37
|
||||
Store 81 80
|
||||
82: 6(int) Load 8(invocation)
|
||||
84: 83(ptr) AccessChain 35(data) 41 54 49
|
||||
85: 19(int8_t) Load 84
|
||||
86: 42(bool) GroupNonUniformAllEqual 44 85
|
||||
87: 31(int) Select 86 54 41
|
||||
88: 38(ptr) AccessChain 35(data) 82 37
|
||||
Store 88 87
|
||||
89: 6(int) Load 8(invocation)
|
||||
92: 91(ptr) AccessChain 35(data) 54 54
|
||||
93: 20(i8vec4) Load 92
|
||||
94: 90(i8vec2) VectorShuffle 93 93 0 1
|
||||
95: 42(bool) GroupNonUniformAllEqual 44 94
|
||||
96: 31(int) Select 95 54 41
|
||||
97: 38(ptr) AccessChain 35(data) 89 37
|
||||
Store 97 96
|
||||
98: 6(int) Load 8(invocation)
|
||||
100: 91(ptr) AccessChain 35(data) 67 54
|
||||
101: 20(i8vec4) Load 100
|
||||
102: 99(i8vec3) VectorShuffle 101 101 0 1 2
|
||||
103: 42(bool) GroupNonUniformAllEqual 44 102
|
||||
104: 31(int) Select 103 54 41
|
||||
105: 38(ptr) AccessChain 35(data) 98 37
|
||||
Store 105 104
|
||||
106: 6(int) Load 8(invocation)
|
||||
107: 91(ptr) AccessChain 35(data) 76 54
|
||||
108: 20(i8vec4) Load 107
|
||||
109: 42(bool) GroupNonUniformAllEqual 44 108
|
||||
110: 31(int) Select 109 54 41
|
||||
111: 38(ptr) AccessChain 35(data) 106 37
|
||||
Store 111 110
|
||||
112: 6(int) Load 8(invocation)
|
||||
114: 113(ptr) AccessChain 35(data) 41 67 49
|
||||
115: 21(int16_t) Load 114
|
||||
116: 42(bool) GroupNonUniformAllEqual 44 115
|
||||
117: 31(int) Select 116 54 41
|
||||
118: 38(ptr) AccessChain 35(data) 112 37
|
||||
Store 118 117
|
||||
119: 6(int) Load 8(invocation)
|
||||
122: 121(ptr) AccessChain 35(data) 54 67
|
||||
123: 22(i16vec4) Load 122
|
||||
124:120(i16vec2) VectorShuffle 123 123 0 1
|
||||
125: 42(bool) GroupNonUniformAllEqual 44 124
|
||||
126: 31(int) Select 125 54 41
|
||||
127: 38(ptr) AccessChain 35(data) 119 37
|
||||
Store 127 126
|
||||
128: 6(int) Load 8(invocation)
|
||||
130: 121(ptr) AccessChain 35(data) 67 67
|
||||
131: 22(i16vec4) Load 130
|
||||
132:129(i16vec3) VectorShuffle 131 131 0 1 2
|
||||
133: 42(bool) GroupNonUniformAllEqual 44 132
|
||||
134: 31(int) Select 133 54 41
|
||||
135: 38(ptr) AccessChain 35(data) 128 37
|
||||
Store 135 134
|
||||
136: 6(int) Load 8(invocation)
|
||||
137: 121(ptr) AccessChain 35(data) 76 67
|
||||
138: 22(i16vec4) Load 137
|
||||
139: 42(bool) GroupNonUniformAllEqual 44 138
|
||||
140: 31(int) Select 139 54 41
|
||||
141: 38(ptr) AccessChain 35(data) 136 37
|
||||
Store 141 140
|
||||
142: 6(int) Load 8(invocation)
|
||||
144: 143(ptr) AccessChain 35(data) 41 76 49
|
||||
145: 23(int16_t) Load 144
|
||||
146: 42(bool) GroupNonUniformAllEqual 44 145
|
||||
147: 31(int) Select 146 54 41
|
||||
148: 38(ptr) AccessChain 35(data) 142 37
|
||||
Store 148 147
|
||||
149: 6(int) Load 8(invocation)
|
||||
152: 151(ptr) AccessChain 35(data) 54 76
|
||||
153: 24(i16vec4) Load 152
|
||||
154:150(i16vec2) VectorShuffle 153 153 0 1
|
||||
155: 42(bool) GroupNonUniformAllEqual 44 154
|
||||
156: 31(int) Select 155 54 41
|
||||
157: 38(ptr) AccessChain 35(data) 149 37
|
||||
Store 157 156
|
||||
158: 6(int) Load 8(invocation)
|
||||
160: 151(ptr) AccessChain 35(data) 67 76
|
||||
161: 24(i16vec4) Load 160
|
||||
162:159(i16vec3) VectorShuffle 161 161 0 1 2
|
||||
163: 42(bool) GroupNonUniformAllEqual 44 162
|
||||
164: 31(int) Select 163 54 41
|
||||
165: 38(ptr) AccessChain 35(data) 158 37
|
||||
Store 165 164
|
||||
166: 6(int) Load 8(invocation)
|
||||
167: 151(ptr) AccessChain 35(data) 76 76
|
||||
168: 24(i16vec4) Load 167
|
||||
169: 42(bool) GroupNonUniformAllEqual 44 168
|
||||
170: 31(int) Select 169 54 41
|
||||
171: 38(ptr) AccessChain 35(data) 166 37
|
||||
Store 171 170
|
||||
Branch 47
|
||||
172: Label
|
||||
173: 6(int) Load 8(invocation)
|
||||
174: 38(ptr) AccessChain 35(data) 173 37
|
||||
175: 31(int) Load 174
|
||||
176: 42(bool) SLessThan 175 41
|
||||
177: 42(bool) GroupNonUniformAny 44 176
|
||||
SelectionMerge 179 None
|
||||
BranchConditional 177 178 179
|
||||
178: Label
|
||||
180: 6(int) Load 8(invocation)
|
||||
183: 182(ptr) AccessChain 35(data) 41 181 49
|
||||
184: 25(int64_t) Load 183
|
||||
185: 42(bool) GroupNonUniformAllEqual 44 184
|
||||
186: 31(int) Select 185 54 41
|
||||
187: 38(ptr) AccessChain 35(data) 180 37
|
||||
Store 187 186
|
||||
188: 6(int) Load 8(invocation)
|
||||
191: 190(ptr) AccessChain 35(data) 54 181
|
||||
192: 26(i64vec4) Load 191
|
||||
193:189(i64vec2) VectorShuffle 192 192 0 1
|
||||
194: 42(bool) GroupNonUniformAllEqual 44 193
|
||||
195: 31(int) Select 194 54 41
|
||||
196: 38(ptr) AccessChain 35(data) 188 37
|
||||
Store 196 195
|
||||
197: 6(int) Load 8(invocation)
|
||||
199: 190(ptr) AccessChain 35(data) 67 181
|
||||
200: 26(i64vec4) Load 199
|
||||
201:198(i64vec3) VectorShuffle 200 200 0 1 2
|
||||
202: 42(bool) GroupNonUniformAllEqual 44 201
|
||||
203: 31(int) Select 202 54 41
|
||||
204: 38(ptr) AccessChain 35(data) 197 37
|
||||
Store 204 203
|
||||
205: 6(int) Load 8(invocation)
|
||||
206: 190(ptr) AccessChain 35(data) 76 181
|
||||
207: 26(i64vec4) Load 206
|
||||
208: 42(bool) GroupNonUniformAllEqual 44 207
|
||||
209: 31(int) Select 208 54 41
|
||||
210: 38(ptr) AccessChain 35(data) 205 37
|
||||
Store 210 209
|
||||
211: 6(int) Load 8(invocation)
|
||||
214: 213(ptr) AccessChain 35(data) 41 212 49
|
||||
215: 27(int64_t) Load 214
|
||||
216: 42(bool) GroupNonUniformAllEqual 44 215
|
||||
217: 31(int) Select 216 54 41
|
||||
218: 38(ptr) AccessChain 35(data) 211 37
|
||||
Store 218 217
|
||||
219: 6(int) Load 8(invocation)
|
||||
222: 221(ptr) AccessChain 35(data) 54 212
|
||||
223: 28(i64vec4) Load 222
|
||||
224:220(i64vec2) VectorShuffle 223 223 0 1
|
||||
225: 42(bool) GroupNonUniformAllEqual 44 224
|
||||
226: 31(int) Select 225 54 41
|
||||
227: 38(ptr) AccessChain 35(data) 219 37
|
||||
Store 227 226
|
||||
228: 6(int) Load 8(invocation)
|
||||
230: 221(ptr) AccessChain 35(data) 67 212
|
||||
231: 28(i64vec4) Load 230
|
||||
232:229(i64vec3) VectorShuffle 231 231 0 1 2
|
||||
233: 42(bool) GroupNonUniformAllEqual 44 232
|
||||
234: 31(int) Select 233 54 41
|
||||
235: 38(ptr) AccessChain 35(data) 228 37
|
||||
Store 235 234
|
||||
236: 6(int) Load 8(invocation)
|
||||
237: 221(ptr) AccessChain 35(data) 76 212
|
||||
238: 28(i64vec4) Load 237
|
||||
239: 42(bool) GroupNonUniformAllEqual 44 238
|
||||
240: 31(int) Select 239 54 41
|
||||
241: 38(ptr) AccessChain 35(data) 236 37
|
||||
Store 241 240
|
||||
242: 6(int) Load 8(invocation)
|
||||
245: 244(ptr) AccessChain 35(data) 41 243 49
|
||||
246:29(float16_t) Load 245
|
||||
247: 42(bool) GroupNonUniformAllEqual 44 246
|
||||
248: 31(int) Select 247 54 41
|
||||
249: 38(ptr) AccessChain 35(data) 242 37
|
||||
Store 249 248
|
||||
250: 6(int) Load 8(invocation)
|
||||
253: 252(ptr) AccessChain 35(data) 54 243
|
||||
254: 30(f16vec4) Load 253
|
||||
255:251(f16vec2) VectorShuffle 254 254 0 1
|
||||
256: 42(bool) GroupNonUniformAllEqual 44 255
|
||||
257: 31(int) Select 256 54 41
|
||||
258: 38(ptr) AccessChain 35(data) 250 37
|
||||
Store 258 257
|
||||
259: 6(int) Load 8(invocation)
|
||||
261: 252(ptr) AccessChain 35(data) 67 243
|
||||
262: 30(f16vec4) Load 261
|
||||
263:260(f16vec3) VectorShuffle 262 262 0 1 2
|
||||
264: 42(bool) GroupNonUniformAllEqual 44 263
|
||||
265: 31(int) Select 264 54 41
|
||||
266: 38(ptr) AccessChain 35(data) 259 37
|
||||
Store 266 265
|
||||
267: 6(int) Load 8(invocation)
|
||||
268: 252(ptr) AccessChain 35(data) 76 243
|
||||
269: 30(f16vec4) Load 268
|
||||
270: 42(bool) GroupNonUniformAllEqual 44 269
|
||||
271: 31(int) Select 270 54 41
|
||||
272: 38(ptr) AccessChain 35(data) 267 37
|
||||
Store 272 271
|
||||
Branch 179
|
||||
179: Label
|
||||
Branch 47
|
||||
47: Label
|
||||
Return
|
||||
FunctionEnd
|
33
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesVoteNeg.comp.out
vendored
Normal file
33
3rdparty/glslang/Test/baseResults/spv.subgroupExtendedTypesVoteNeg.comp.out
vendored
Normal file
@ -0,0 +1,33 @@
|
||||
spv.subgroupExtendedTypesVoteNeg.comp
|
||||
ERROR: 0:29: ' temp int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:30: ' temp 2-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:31: ' temp 3-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:32: 'layout( column_major std430) buffer 4-component vector of int8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:34: ' temp uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:35: ' temp 2-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:36: ' temp 3-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:37: 'layout( column_major std430) buffer 4-component vector of uint8_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int8
|
||||
ERROR: 0:39: ' temp int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:40: ' temp 2-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:41: ' temp 3-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:42: 'layout( column_major std430) buffer 4-component vector of int16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:44: ' temp uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:45: ' temp 2-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:46: ' temp 3-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:47: 'layout( column_major std430) buffer 4-component vector of uint16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int16
|
||||
ERROR: 0:51: ' temp int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:52: ' temp 2-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:53: ' temp 3-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:54: 'layout( column_major std430) buffer 4-component vector of int64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:56: ' temp uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:57: ' temp 2-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:58: ' temp 3-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:59: 'layout( column_major std430) buffer 4-component vector of uint64_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_int64
|
||||
ERROR: 0:61: ' temp float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:62: ' temp 2-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:63: ' temp 3-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 0:64: 'layout( column_major std430) buffer 4-component vector of float16_t' : required extension not requested: GL_EXT_shader_subgroup_extended_types_float16
|
||||
ERROR: 28 compilation errors. No code generated.
|
||||
|
||||
|
||||
SPIR-V is not generated for failed compile or link
|
4
3rdparty/glslang/Test/nonuniform.frag
vendored
4
3rdparty/glslang/Test/nonuniform.frag
vendored
@ -22,12 +22,12 @@ void main()
|
||||
nonuniformEXT const int nu_ci = 2; // ERROR, const
|
||||
|
||||
foo(nu_li, nu_li);
|
||||
|
||||
int table[5];
|
||||
int a;
|
||||
nu_li = nonuniformEXT(a) + nonuniformEXT(a * 2);
|
||||
nu_li = nonuniformEXT(a, a); // ERROR, too many arguments
|
||||
nu_li = nonuniformEXT(); // ERROR, no arguments
|
||||
nu_li = table[nonuniformEXT(3)];
|
||||
}
|
||||
|
||||
layout(location=1) in struct S { float a; nonuniformEXT float b; } ins; // ERROR, not on member
|
||||
layout(location=3) in inbName { float a; nonuniformEXT float b; } inb; // ERROR, not on member
|
||||
|
32
3rdparty/glslang/Test/spv.bufferhandleUvec2.frag
vendored
Normal file
32
3rdparty/glslang/Test/spv.bufferhandleUvec2.frag
vendored
Normal file
@ -0,0 +1,32 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_EXT_buffer_reference_uvec2 : enable
|
||||
|
||||
layout(buffer_reference, std430) buffer blockType {
|
||||
layout(offset = 0) int a;
|
||||
layout(offset = 4) int b;
|
||||
layout(offset = 8) int c;
|
||||
layout(offset = 12) int d;
|
||||
layout(offset = 16) int e;
|
||||
};
|
||||
|
||||
layout(std430) buffer t2 {
|
||||
blockType f;
|
||||
blockType g;
|
||||
} t;
|
||||
|
||||
flat in uvec2 h, i;
|
||||
|
||||
void main() {
|
||||
|
||||
blockType b1[2] = blockType[2](blockType(h), blockType(i));
|
||||
b1[0].a = b1[1].b;
|
||||
blockType b2 = blockType(h);
|
||||
blockType b3 = blockType(i);
|
||||
b2.a = b3.b;
|
||||
uvec2 j = uvec2(b2);
|
||||
uint carry;
|
||||
j.x = uaddCarry(j.x, 256, carry);
|
||||
j.y += carry;
|
||||
b2 = blockType(j);
|
||||
}
|
715
3rdparty/glslang/Test/spv.subgroupExtendedTypesArithmetic.comp
vendored
Normal file
715
3rdparty/glslang/Test/spv.subgroupExtendedTypesArithmetic.comp
vendored
Normal file
@ -0,0 +1,715 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_arithmetic: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int8: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int16: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int64: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
data[invocation].i8.x = subgroupAdd(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupAdd(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupAdd(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupAdd(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupMul(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupMul(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupMul(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupMul(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupMin(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupMin(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupMin(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupMin(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupMax(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupMax(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupMax(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupMax(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupAnd(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupAnd(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupAnd(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupAnd(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupOr(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupOr(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupOr(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupOr(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupXor(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupXor(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupXor(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupXor(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveAdd(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveAdd(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveAdd(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveAdd(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveMul(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveMul(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveMul(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveMul(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveMin(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveMin(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveMin(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveMin(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveMax(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveMax(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveMax(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveMax(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveAnd(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveAnd(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveAnd(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveAnd(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveOr(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveOr(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveOr(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveOr(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveXor(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveXor(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveXor(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveXor(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveAdd(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveAdd(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveAdd(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveAdd(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveMul(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveMul(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveMul(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveMul(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveMin(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveMin(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveMin(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveMin(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveMax(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveMax(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveMax(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveMax(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveAnd(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveAnd(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveAnd(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveAnd(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveOr(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveOr(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveOr(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveOr(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveXor(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveXor(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveXor(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveXor(data[3].i8);
|
||||
|
||||
data[invocation].u8.x = subgroupAdd(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupAdd(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupAdd(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupAdd(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupMul(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupMul(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupMul(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupMul(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupMin(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupMin(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupMin(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupMin(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupMax(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupMax(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupMax(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupMax(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupAnd(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupAnd(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupAnd(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupAnd(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupOr(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupOr(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupOr(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupOr(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupXor(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupXor(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupXor(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupXor(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveAdd(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveAdd(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveAdd(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveAdd(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveMul(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveMul(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveMul(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveMul(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveMin(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveMin(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveMin(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveMin(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveMax(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveMax(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveMax(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveMax(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveAnd(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveAnd(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveAnd(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveAnd(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveOr(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveOr(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveOr(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveOr(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveXor(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveXor(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveXor(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveXor(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveAdd(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveAdd(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveAdd(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveAdd(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveMul(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveMul(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveMul(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveMul(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveMin(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveMin(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveMin(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveMin(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveMax(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveMax(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveMax(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveMax(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveAnd(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveAnd(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveAnd(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveAnd(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveOr(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveOr(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveOr(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveOr(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveXor(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveXor(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveXor(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveXor(data[3].u8);
|
||||
|
||||
data[invocation].i16.x = subgroupAdd(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupAdd(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupAdd(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupAdd(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupMul(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupMul(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupMul(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupMul(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupMin(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupMin(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupMin(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupMin(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupMax(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupMax(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupMax(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupMax(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupAnd(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupAnd(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupAnd(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupAnd(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupOr(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupOr(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupOr(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupOr(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupXor(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupXor(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupXor(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupXor(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveAdd(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveAdd(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveAdd(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveAdd(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveMul(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveMul(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveMul(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveMul(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveMin(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveMin(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveMin(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveMin(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveMax(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveMax(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveMax(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveMax(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveAnd(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveAnd(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveAnd(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveAnd(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveOr(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveOr(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveOr(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveOr(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveXor(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveXor(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveXor(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveXor(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveAdd(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveAdd(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveAdd(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveAdd(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveMul(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveMul(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveMul(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveMul(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveMin(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveMin(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveMin(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveMin(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveMax(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveMax(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveMax(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveMax(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveAnd(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveAnd(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveAnd(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveAnd(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveOr(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveOr(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveOr(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveOr(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveXor(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveXor(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveXor(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveXor(data[3].i16);
|
||||
|
||||
data[invocation].u16.x = subgroupAdd(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupAdd(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupAdd(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupAdd(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupMul(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupMul(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupMul(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupMul(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupMin(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupMin(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupMin(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupMin(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupMax(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupMax(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupMax(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupMax(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupAnd(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupAnd(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupAnd(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupAnd(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupOr(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupOr(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupOr(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupOr(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupXor(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupXor(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupXor(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupXor(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveAdd(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveAdd(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveAdd(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveAdd(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveMul(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveMul(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveMul(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveMul(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveMin(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveMin(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveMin(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveMin(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveMax(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveMax(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveMax(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveMax(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveAnd(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveAnd(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveAnd(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveAnd(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveOr(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveOr(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveOr(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveOr(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveXor(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveXor(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveXor(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveXor(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveAdd(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveAdd(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveAdd(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveAdd(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveMul(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveMul(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveMul(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveMul(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveMin(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveMin(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveMin(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveMin(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveMax(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveMax(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveMax(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveMax(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveAnd(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveAnd(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveAnd(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveAnd(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveOr(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveOr(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveOr(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveOr(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveXor(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveXor(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveXor(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveXor(data[3].u16);
|
||||
|
||||
data[invocation].i64.x = subgroupAdd(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupAdd(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupAdd(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupAdd(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupMul(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupMul(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupMul(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupMul(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupMin(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupMin(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupMin(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupMin(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupMax(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupMax(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupMax(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupMax(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupAnd(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupAnd(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupAnd(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupAnd(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupOr(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupOr(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupOr(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupOr(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupXor(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupXor(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupXor(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupXor(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveAdd(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveAdd(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveAdd(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveAdd(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveMul(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveMul(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveMul(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveMul(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveMin(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveMin(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveMin(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveMin(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveMax(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveMax(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveMax(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveMax(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveAnd(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveAnd(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveAnd(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveAnd(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveOr(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveOr(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveOr(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveOr(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveXor(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveXor(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveXor(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveXor(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveAdd(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveAdd(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveAdd(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveAdd(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveMul(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveMul(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveMul(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveMul(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveMin(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveMin(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveMin(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveMin(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveMax(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveMax(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveMax(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveMax(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveAnd(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveAnd(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveAnd(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveAnd(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveOr(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveOr(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveOr(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveOr(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveXor(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveXor(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveXor(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveXor(data[3].i64);
|
||||
|
||||
data[invocation].u64.x = subgroupAdd(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupAdd(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupAdd(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupAdd(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupMul(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupMul(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupMul(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupMul(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupMin(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupMin(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupMin(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupMin(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupMax(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupMax(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupMax(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupMax(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupAnd(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupAnd(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupAnd(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupAnd(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupOr(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupOr(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupOr(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupOr(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupXor(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupXor(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupXor(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupXor(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveAdd(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveAdd(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveAdd(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveAdd(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveMul(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveMul(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveMul(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveMul(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveMin(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveMin(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveMin(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveMin(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveMax(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveMax(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveMax(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveMax(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveAnd(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveAnd(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveAnd(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveAnd(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveOr(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveOr(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveOr(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveOr(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveXor(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveXor(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveXor(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveXor(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveAdd(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveAdd(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveAdd(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveAdd(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveMul(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveMul(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveMul(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveMul(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveMin(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveMin(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveMin(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveMin(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveMax(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveMax(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveMax(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveMax(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveAnd(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveAnd(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveAnd(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveAnd(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveOr(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveOr(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveOr(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveOr(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveXor(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveXor(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveXor(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveXor(data[3].u64);
|
||||
|
||||
data[invocation].f16.x = subgroupAdd(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupAdd(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupAdd(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupAdd(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupMul(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupMul(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupMul(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupMul(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupMin(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupMin(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupMin(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupMin(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupMax(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupMax(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupMax(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupMax(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupInclusiveAdd(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupInclusiveAdd(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupInclusiveAdd(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupInclusiveAdd(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupInclusiveMul(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupInclusiveMul(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupInclusiveMul(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupInclusiveMul(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupInclusiveMin(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupInclusiveMin(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupInclusiveMin(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupInclusiveMin(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupInclusiveMax(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupInclusiveMax(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupInclusiveMax(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupInclusiveMax(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupExclusiveAdd(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupExclusiveAdd(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupExclusiveAdd(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupExclusiveAdd(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupExclusiveMul(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupExclusiveMul(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupExclusiveMul(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupExclusiveMul(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupExclusiveMin(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupExclusiveMin(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupExclusiveMin(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupExclusiveMin(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupExclusiveMax(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupExclusiveMax(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupExclusiveMax(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupExclusiveMax(data[3].f16);
|
||||
}
|
715
3rdparty/glslang/Test/spv.subgroupExtendedTypesArithmeticNeg.comp
vendored
Normal file
715
3rdparty/glslang/Test/spv.subgroupExtendedTypesArithmeticNeg.comp
vendored
Normal file
@ -0,0 +1,715 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_arithmetic: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int8: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int16: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int64: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
data[invocation].i8.x = subgroupAdd(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupAdd(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupAdd(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupAdd(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupMul(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupMul(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupMul(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupMul(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupMin(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupMin(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupMin(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupMin(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupMax(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupMax(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupMax(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupMax(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupAnd(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupAnd(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupAnd(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupAnd(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupOr(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupOr(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupOr(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupOr(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupXor(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupXor(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupXor(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupXor(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveAdd(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveAdd(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveAdd(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveAdd(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveMul(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveMul(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveMul(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveMul(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveMin(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveMin(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveMin(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveMin(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveMax(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveMax(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveMax(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveMax(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveAnd(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveAnd(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveAnd(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveAnd(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveOr(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveOr(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveOr(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveOr(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupInclusiveXor(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupInclusiveXor(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupInclusiveXor(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupInclusiveXor(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveAdd(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveAdd(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveAdd(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveAdd(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveMul(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveMul(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveMul(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveMul(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveMin(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveMin(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveMin(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveMin(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveMax(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveMax(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveMax(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveMax(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveAnd(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveAnd(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveAnd(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveAnd(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveOr(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveOr(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveOr(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveOr(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupExclusiveXor(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupExclusiveXor(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupExclusiveXor(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupExclusiveXor(data[3].i8);
|
||||
|
||||
data[invocation].u8.x = subgroupAdd(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupAdd(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupAdd(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupAdd(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupMul(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupMul(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupMul(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupMul(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupMin(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupMin(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupMin(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupMin(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupMax(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupMax(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupMax(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupMax(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupAnd(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupAnd(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupAnd(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupAnd(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupOr(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupOr(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupOr(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupOr(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupXor(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupXor(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupXor(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupXor(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveAdd(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveAdd(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveAdd(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveAdd(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveMul(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveMul(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveMul(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveMul(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveMin(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveMin(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveMin(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveMin(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveMax(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveMax(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveMax(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveMax(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveAnd(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveAnd(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveAnd(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveAnd(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveOr(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveOr(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveOr(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveOr(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupInclusiveXor(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupInclusiveXor(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupInclusiveXor(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupInclusiveXor(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveAdd(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveAdd(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveAdd(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveAdd(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveMul(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveMul(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveMul(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveMul(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveMin(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveMin(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveMin(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveMin(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveMax(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveMax(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveMax(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveMax(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveAnd(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveAnd(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveAnd(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveAnd(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveOr(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveOr(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveOr(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveOr(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupExclusiveXor(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupExclusiveXor(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupExclusiveXor(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupExclusiveXor(data[3].u8);
|
||||
|
||||
data[invocation].i16.x = subgroupAdd(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupAdd(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupAdd(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupAdd(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupMul(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupMul(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupMul(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupMul(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupMin(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupMin(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupMin(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupMin(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupMax(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupMax(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupMax(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupMax(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupAnd(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupAnd(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupAnd(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupAnd(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupOr(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupOr(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupOr(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupOr(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupXor(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupXor(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupXor(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupXor(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveAdd(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveAdd(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveAdd(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveAdd(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveMul(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveMul(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveMul(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveMul(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveMin(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveMin(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveMin(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveMin(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveMax(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveMax(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveMax(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveMax(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveAnd(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveAnd(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveAnd(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveAnd(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveOr(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveOr(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveOr(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveOr(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupInclusiveXor(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupInclusiveXor(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupInclusiveXor(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupInclusiveXor(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveAdd(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveAdd(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveAdd(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveAdd(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveMul(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveMul(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveMul(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveMul(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveMin(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveMin(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveMin(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveMin(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveMax(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveMax(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveMax(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveMax(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveAnd(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveAnd(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveAnd(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveAnd(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveOr(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveOr(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveOr(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveOr(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupExclusiveXor(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupExclusiveXor(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupExclusiveXor(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupExclusiveXor(data[3].i16);
|
||||
|
||||
data[invocation].u16.x = subgroupAdd(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupAdd(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupAdd(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupAdd(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupMul(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupMul(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupMul(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupMul(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupMin(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupMin(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupMin(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupMin(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupMax(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupMax(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupMax(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupMax(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupAnd(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupAnd(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupAnd(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupAnd(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupOr(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupOr(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupOr(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupOr(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupXor(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupXor(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupXor(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupXor(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveAdd(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveAdd(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveAdd(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveAdd(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveMul(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveMul(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveMul(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveMul(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveMin(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveMin(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveMin(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveMin(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveMax(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveMax(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveMax(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveMax(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveAnd(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveAnd(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveAnd(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveAnd(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveOr(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveOr(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveOr(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveOr(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupInclusiveXor(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupInclusiveXor(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupInclusiveXor(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupInclusiveXor(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveAdd(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveAdd(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveAdd(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveAdd(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveMul(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveMul(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveMul(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveMul(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveMin(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveMin(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveMin(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveMin(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveMax(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveMax(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveMax(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveMax(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveAnd(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveAnd(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveAnd(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveAnd(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveOr(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveOr(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveOr(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveOr(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupExclusiveXor(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupExclusiveXor(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupExclusiveXor(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupExclusiveXor(data[3].u16);
|
||||
|
||||
data[invocation].i64.x = subgroupAdd(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupAdd(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupAdd(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupAdd(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupMul(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupMul(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupMul(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupMul(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupMin(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupMin(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupMin(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupMin(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupMax(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupMax(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupMax(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupMax(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupAnd(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupAnd(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupAnd(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupAnd(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupOr(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupOr(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupOr(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupOr(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupXor(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupXor(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupXor(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupXor(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveAdd(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveAdd(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveAdd(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveAdd(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveMul(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveMul(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveMul(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveMul(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveMin(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveMin(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveMin(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveMin(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveMax(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveMax(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveMax(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveMax(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveAnd(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveAnd(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveAnd(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveAnd(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveOr(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveOr(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveOr(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveOr(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupInclusiveXor(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupInclusiveXor(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupInclusiveXor(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupInclusiveXor(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveAdd(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveAdd(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveAdd(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveAdd(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveMul(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveMul(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveMul(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveMul(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveMin(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveMin(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveMin(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveMin(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveMax(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveMax(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveMax(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveMax(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveAnd(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveAnd(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveAnd(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveAnd(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveOr(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveOr(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveOr(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveOr(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupExclusiveXor(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupExclusiveXor(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupExclusiveXor(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupExclusiveXor(data[3].i64);
|
||||
|
||||
data[invocation].u64.x = subgroupAdd(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupAdd(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupAdd(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupAdd(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupMul(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupMul(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupMul(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupMul(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupMin(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupMin(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupMin(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupMin(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupMax(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupMax(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupMax(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupMax(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupAnd(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupAnd(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupAnd(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupAnd(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupOr(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupOr(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupOr(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupOr(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupXor(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupXor(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupXor(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupXor(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveAdd(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveAdd(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveAdd(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveAdd(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveMul(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveMul(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveMul(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveMul(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveMin(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveMin(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveMin(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveMin(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveMax(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveMax(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveMax(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveMax(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveAnd(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveAnd(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveAnd(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveAnd(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveOr(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveOr(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveOr(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveOr(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupInclusiveXor(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupInclusiveXor(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupInclusiveXor(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupInclusiveXor(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveAdd(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveAdd(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveAdd(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveAdd(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveMul(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveMul(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveMul(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveMul(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveMin(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveMin(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveMin(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveMin(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveMax(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveMax(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveMax(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveMax(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveAnd(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveAnd(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveAnd(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveAnd(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveOr(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveOr(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveOr(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveOr(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupExclusiveXor(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupExclusiveXor(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupExclusiveXor(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupExclusiveXor(data[3].u64);
|
||||
|
||||
data[invocation].f16.x = subgroupAdd(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupAdd(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupAdd(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupAdd(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupMul(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupMul(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupMul(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupMul(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupMin(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupMin(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupMin(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupMin(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupMax(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupMax(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupMax(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupMax(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupInclusiveAdd(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupInclusiveAdd(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupInclusiveAdd(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupInclusiveAdd(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupInclusiveMul(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupInclusiveMul(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupInclusiveMul(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupInclusiveMul(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupInclusiveMin(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupInclusiveMin(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupInclusiveMin(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupInclusiveMin(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupInclusiveMax(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupInclusiveMax(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupInclusiveMax(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupInclusiveMax(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupExclusiveAdd(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupExclusiveAdd(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupExclusiveAdd(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupExclusiveAdd(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupExclusiveMul(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupExclusiveMul(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupExclusiveMul(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupExclusiveMul(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupExclusiveMin(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupExclusiveMin(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupExclusiveMin(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupExclusiveMin(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupExclusiveMax(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupExclusiveMax(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupExclusiveMax(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupExclusiveMax(data[3].f16);
|
||||
}
|
88
3rdparty/glslang/Test/spv.subgroupExtendedTypesBallot.comp
vendored
Normal file
88
3rdparty/glslang/Test/spv.subgroupExtendedTypesBallot.comp
vendored
Normal file
@ -0,0 +1,88 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_ballot: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int8: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int16: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int64: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
data[invocation].i8.x = subgroupBroadcast(data[0].i8.x, 3);
|
||||
data[invocation].i8.xy = subgroupBroadcast(data[1].i8.xy, 3);
|
||||
data[invocation].i8.xyz = subgroupBroadcast(data[2].i8.xyz, 3);
|
||||
data[invocation].i8 = subgroupBroadcast(data[3].i8, 3);
|
||||
data[invocation].i8.x = subgroupBroadcastFirst(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupBroadcastFirst(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupBroadcastFirst(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupBroadcastFirst(data[3].i8);
|
||||
|
||||
data[invocation].u8.x = subgroupBroadcast(data[0].u8.x, 3);
|
||||
data[invocation].u8.xy = subgroupBroadcast(data[1].u8.xy, 3);
|
||||
data[invocation].u8.xyz = subgroupBroadcast(data[2].u8.xyz, 3);
|
||||
data[invocation].u8 = subgroupBroadcast(data[3].u8, 3);
|
||||
data[invocation].u8.x = subgroupBroadcastFirst(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupBroadcastFirst(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupBroadcastFirst(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupBroadcastFirst(data[3].u8);
|
||||
|
||||
data[invocation].i16.x = subgroupBroadcast(data[0].i16.x, 3);
|
||||
data[invocation].i16.xy = subgroupBroadcast(data[1].i16.xy, 3);
|
||||
data[invocation].i16.xyz = subgroupBroadcast(data[2].i16.xyz, 3);
|
||||
data[invocation].i16 = subgroupBroadcast(data[3].i16, 3);
|
||||
data[invocation].i16.x = subgroupBroadcastFirst(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupBroadcastFirst(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupBroadcastFirst(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupBroadcastFirst(data[3].i16);
|
||||
|
||||
data[invocation].u16.x = subgroupBroadcast(data[0].u16.x, 3);
|
||||
data[invocation].u16.xy = subgroupBroadcast(data[1].u16.xy, 3);
|
||||
data[invocation].u16.xyz = subgroupBroadcast(data[2].u16.xyz, 3);
|
||||
data[invocation].u16 = subgroupBroadcast(data[3].u16, 3);
|
||||
data[invocation].u16.x = subgroupBroadcastFirst(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupBroadcastFirst(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupBroadcastFirst(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupBroadcastFirst(data[3].u16);
|
||||
|
||||
data[invocation].i64.x = subgroupBroadcast(data[0].i64.x, 3);
|
||||
data[invocation].i64.xy = subgroupBroadcast(data[1].i64.xy, 3);
|
||||
data[invocation].i64.xyz = subgroupBroadcast(data[2].i64.xyz, 3);
|
||||
data[invocation].i64 = subgroupBroadcast(data[3].i64, 3);
|
||||
data[invocation].i64.x = subgroupBroadcastFirst(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupBroadcastFirst(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupBroadcastFirst(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupBroadcastFirst(data[3].i64);
|
||||
|
||||
data[invocation].u64.x = subgroupBroadcast(data[0].u64.x, 3);
|
||||
data[invocation].u64.xy = subgroupBroadcast(data[1].u64.xy, 3);
|
||||
data[invocation].u64.xyz = subgroupBroadcast(data[2].u64.xyz, 3);
|
||||
data[invocation].u64 = subgroupBroadcast(data[3].u64, 3);
|
||||
data[invocation].u64.x = subgroupBroadcastFirst(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupBroadcastFirst(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupBroadcastFirst(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupBroadcastFirst(data[3].u64);
|
||||
|
||||
data[invocation].f16.x = subgroupBroadcast(data[0].f16.x, 3);
|
||||
data[invocation].f16.xy = subgroupBroadcast(data[1].f16.xy, 3);
|
||||
data[invocation].f16.xyz = subgroupBroadcast(data[2].f16.xyz, 3);
|
||||
data[invocation].f16 = subgroupBroadcast(data[3].f16, 3);
|
||||
data[invocation].f16.x = subgroupBroadcastFirst(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupBroadcastFirst(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupBroadcastFirst(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupBroadcastFirst(data[3].f16);
|
||||
}
|
88
3rdparty/glslang/Test/spv.subgroupExtendedTypesBallotNeg.comp
vendored
Normal file
88
3rdparty/glslang/Test/spv.subgroupExtendedTypesBallotNeg.comp
vendored
Normal file
@ -0,0 +1,88 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_ballot: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int8: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int16: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int64: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
data[invocation].i8.x = subgroupBroadcast(data[0].i8.x, 3);
|
||||
data[invocation].i8.xy = subgroupBroadcast(data[1].i8.xy, 3);
|
||||
data[invocation].i8.xyz = subgroupBroadcast(data[2].i8.xyz, 3);
|
||||
data[invocation].i8 = subgroupBroadcast(data[3].i8, 3);
|
||||
data[invocation].i8.x = subgroupBroadcastFirst(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupBroadcastFirst(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupBroadcastFirst(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupBroadcastFirst(data[3].i8);
|
||||
|
||||
data[invocation].u8.x = subgroupBroadcast(data[0].u8.x, 3);
|
||||
data[invocation].u8.xy = subgroupBroadcast(data[1].u8.xy, 3);
|
||||
data[invocation].u8.xyz = subgroupBroadcast(data[2].u8.xyz, 3);
|
||||
data[invocation].u8 = subgroupBroadcast(data[3].u8, 3);
|
||||
data[invocation].u8.x = subgroupBroadcastFirst(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupBroadcastFirst(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupBroadcastFirst(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupBroadcastFirst(data[3].u8);
|
||||
|
||||
data[invocation].i16.x = subgroupBroadcast(data[0].i16.x, 3);
|
||||
data[invocation].i16.xy = subgroupBroadcast(data[1].i16.xy, 3);
|
||||
data[invocation].i16.xyz = subgroupBroadcast(data[2].i16.xyz, 3);
|
||||
data[invocation].i16 = subgroupBroadcast(data[3].i16, 3);
|
||||
data[invocation].i16.x = subgroupBroadcastFirst(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupBroadcastFirst(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupBroadcastFirst(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupBroadcastFirst(data[3].i16);
|
||||
|
||||
data[invocation].u16.x = subgroupBroadcast(data[0].u16.x, 3);
|
||||
data[invocation].u16.xy = subgroupBroadcast(data[1].u16.xy, 3);
|
||||
data[invocation].u16.xyz = subgroupBroadcast(data[2].u16.xyz, 3);
|
||||
data[invocation].u16 = subgroupBroadcast(data[3].u16, 3);
|
||||
data[invocation].u16.x = subgroupBroadcastFirst(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupBroadcastFirst(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupBroadcastFirst(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupBroadcastFirst(data[3].u16);
|
||||
|
||||
data[invocation].i64.x = subgroupBroadcast(data[0].i64.x, 3);
|
||||
data[invocation].i64.xy = subgroupBroadcast(data[1].i64.xy, 3);
|
||||
data[invocation].i64.xyz = subgroupBroadcast(data[2].i64.xyz, 3);
|
||||
data[invocation].i64 = subgroupBroadcast(data[3].i64, 3);
|
||||
data[invocation].i64.x = subgroupBroadcastFirst(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupBroadcastFirst(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupBroadcastFirst(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupBroadcastFirst(data[3].i64);
|
||||
|
||||
data[invocation].u64.x = subgroupBroadcast(data[0].u64.x, 3);
|
||||
data[invocation].u64.xy = subgroupBroadcast(data[1].u64.xy, 3);
|
||||
data[invocation].u64.xyz = subgroupBroadcast(data[2].u64.xyz, 3);
|
||||
data[invocation].u64 = subgroupBroadcast(data[3].u64, 3);
|
||||
data[invocation].u64.x = subgroupBroadcastFirst(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupBroadcastFirst(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupBroadcastFirst(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupBroadcastFirst(data[3].u64);
|
||||
|
||||
data[invocation].f16.x = subgroupBroadcast(data[0].f16.x, 3);
|
||||
data[invocation].f16.xy = subgroupBroadcast(data[1].f16.xy, 3);
|
||||
data[invocation].f16.xyz = subgroupBroadcast(data[2].f16.xyz, 3);
|
||||
data[invocation].f16 = subgroupBroadcast(data[3].f16, 3);
|
||||
data[invocation].f16.x = subgroupBroadcastFirst(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupBroadcastFirst(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupBroadcastFirst(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupBroadcastFirst(data[3].f16);
|
||||
}
|
255
3rdparty/glslang/Test/spv.subgroupExtendedTypesClustered.comp
vendored
Normal file
255
3rdparty/glslang/Test/spv.subgroupExtendedTypesClustered.comp
vendored
Normal file
@ -0,0 +1,255 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_clustered: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int8: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int16: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int64: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredAdd(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredAdd(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredAdd(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredAdd(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredMul(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredMul(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredMul(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredMul(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredMin(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredMin(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredMin(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredMin(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredMax(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredMax(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredMax(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredMax(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredAnd(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredAnd(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredAnd(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredAnd(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredOr(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredOr(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredOr(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredOr(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredXor(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredXor(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredXor(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredXor(data[3].i8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredAdd(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredAdd(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredAdd(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredAdd(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredMul(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredMul(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredMul(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredMul(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredMin(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredMin(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredMin(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredMin(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredMax(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredMax(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredMax(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredMax(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredAnd(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredAnd(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredAnd(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredAnd(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredOr(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredOr(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredOr(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredOr(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredXor(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredXor(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredXor(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredXor(data[3].u8, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredAdd(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredAdd(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredAdd(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredAdd(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredMul(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredMul(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredMul(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredMul(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredMin(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredMin(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredMin(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredMin(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredMax(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredMax(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredMax(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredMax(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredAnd(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredAnd(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredAnd(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredAnd(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredOr(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredOr(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredOr(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredOr(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredXor(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredXor(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredXor(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredXor(data[3].i16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredAdd(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredAdd(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredAdd(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredAdd(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredMul(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredMul(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredMul(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredMul(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredMin(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredMin(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredMin(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredMin(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredMax(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredMax(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredMax(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredMax(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredAnd(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredAnd(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredAnd(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredAnd(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredOr(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredOr(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredOr(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredOr(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredXor(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredXor(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredXor(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredXor(data[3].u16, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredAdd(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredAdd(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredAdd(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredAdd(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredMul(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredMul(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredMul(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredMul(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredMin(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredMin(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredMin(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredMin(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredMax(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredMax(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredMax(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredMax(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredAnd(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredAnd(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredAnd(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredAnd(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredOr(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredOr(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredOr(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredOr(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredXor(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredXor(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredXor(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredXor(data[3].i64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredAdd(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredAdd(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredAdd(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredAdd(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredMul(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredMul(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredMul(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredMul(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredMin(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredMin(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredMin(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredMin(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredMax(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredMax(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredMax(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredMax(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredAnd(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredAnd(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredAnd(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredAnd(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredOr(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredOr(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredOr(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredOr(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredXor(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredXor(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredXor(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredXor(data[3].u64, 1);
|
||||
|
||||
data[invocation].f16.x = subgroupClusteredAdd(data[0].f16.x, 1);
|
||||
data[invocation].f16.xy = subgroupClusteredAdd(data[1].f16.xy, 1);
|
||||
data[invocation].f16.xyz = subgroupClusteredAdd(data[2].f16.xyz, 1);
|
||||
data[invocation].f16 = subgroupClusteredAdd(data[3].f16, 1);
|
||||
|
||||
data[invocation].f16.x = subgroupClusteredMul(data[0].f16.x, 1);
|
||||
data[invocation].f16.xy = subgroupClusteredMul(data[1].f16.xy, 1);
|
||||
data[invocation].f16.xyz = subgroupClusteredMul(data[2].f16.xyz, 1);
|
||||
data[invocation].f16 = subgroupClusteredMul(data[3].f16, 1);
|
||||
|
||||
data[invocation].f16.x = subgroupClusteredMin(data[0].f16.x, 1);
|
||||
data[invocation].f16.xy = subgroupClusteredMin(data[1].f16.xy, 1);
|
||||
data[invocation].f16.xyz = subgroupClusteredMin(data[2].f16.xyz, 1);
|
||||
data[invocation].f16 = subgroupClusteredMin(data[3].f16, 1);
|
||||
|
||||
data[invocation].f16.x = subgroupClusteredMax(data[0].f16.x, 1);
|
||||
data[invocation].f16.xy = subgroupClusteredMax(data[1].f16.xy, 1);
|
||||
data[invocation].f16.xyz = subgroupClusteredMax(data[2].f16.xyz, 1);
|
||||
data[invocation].f16 = subgroupClusteredMax(data[3].f16, 1);
|
||||
}
|
255
3rdparty/glslang/Test/spv.subgroupExtendedTypesClusteredNeg.comp
vendored
Normal file
255
3rdparty/glslang/Test/spv.subgroupExtendedTypesClusteredNeg.comp
vendored
Normal file
@ -0,0 +1,255 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_clustered: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int8: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int16: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int64: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredAdd(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredAdd(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredAdd(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredAdd(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredMul(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredMul(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredMul(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredMul(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredMin(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredMin(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredMin(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredMin(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredMax(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredMax(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredMax(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredMax(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredAnd(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredAnd(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredAnd(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredAnd(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredOr(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredOr(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredOr(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredOr(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupClusteredXor(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupClusteredXor(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupClusteredXor(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupClusteredXor(data[3].i8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredAdd(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredAdd(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredAdd(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredAdd(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredMul(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredMul(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredMul(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredMul(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredMin(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredMin(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredMin(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredMin(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredMax(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredMax(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredMax(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredMax(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredAnd(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredAnd(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredAnd(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredAnd(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredOr(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredOr(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredOr(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredOr(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupClusteredXor(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupClusteredXor(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupClusteredXor(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupClusteredXor(data[3].u8, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredAdd(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredAdd(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredAdd(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredAdd(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredMul(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredMul(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredMul(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredMul(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredMin(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredMin(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredMin(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredMin(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredMax(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredMax(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredMax(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredMax(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredAnd(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredAnd(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredAnd(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredAnd(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredOr(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredOr(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredOr(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredOr(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupClusteredXor(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupClusteredXor(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupClusteredXor(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupClusteredXor(data[3].i16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredAdd(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredAdd(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredAdd(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredAdd(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredMul(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredMul(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredMul(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredMul(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredMin(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredMin(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredMin(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredMin(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredMax(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredMax(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredMax(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredMax(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredAnd(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredAnd(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredAnd(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredAnd(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredOr(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredOr(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredOr(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredOr(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupClusteredXor(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupClusteredXor(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupClusteredXor(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupClusteredXor(data[3].u16, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredAdd(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredAdd(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredAdd(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredAdd(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredMul(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredMul(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredMul(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredMul(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredMin(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredMin(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredMin(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredMin(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredMax(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredMax(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredMax(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredMax(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredAnd(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredAnd(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredAnd(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredAnd(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredOr(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredOr(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredOr(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredOr(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupClusteredXor(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupClusteredXor(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupClusteredXor(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupClusteredXor(data[3].i64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredAdd(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredAdd(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredAdd(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredAdd(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredMul(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredMul(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredMul(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredMul(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredMin(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredMin(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredMin(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredMin(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredMax(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredMax(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredMax(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredMax(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredAnd(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredAnd(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredAnd(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredAnd(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredOr(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredOr(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredOr(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredOr(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupClusteredXor(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupClusteredXor(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupClusteredXor(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupClusteredXor(data[3].u64, 1);
|
||||
|
||||
data[invocation].f16.x = subgroupClusteredAdd(data[0].f16.x, 1);
|
||||
data[invocation].f16.xy = subgroupClusteredAdd(data[1].f16.xy, 1);
|
||||
data[invocation].f16.xyz = subgroupClusteredAdd(data[2].f16.xyz, 1);
|
||||
data[invocation].f16 = subgroupClusteredAdd(data[3].f16, 1);
|
||||
|
||||
data[invocation].f16.x = subgroupClusteredMul(data[0].f16.x, 1);
|
||||
data[invocation].f16.xy = subgroupClusteredMul(data[1].f16.xy, 1);
|
||||
data[invocation].f16.xyz = subgroupClusteredMul(data[2].f16.xyz, 1);
|
||||
data[invocation].f16 = subgroupClusteredMul(data[3].f16, 1);
|
||||
|
||||
data[invocation].f16.x = subgroupClusteredMin(data[0].f16.x, 1);
|
||||
data[invocation].f16.xy = subgroupClusteredMin(data[1].f16.xy, 1);
|
||||
data[invocation].f16.xyz = subgroupClusteredMin(data[2].f16.xyz, 1);
|
||||
data[invocation].f16 = subgroupClusteredMin(data[3].f16, 1);
|
||||
|
||||
data[invocation].f16.x = subgroupClusteredMax(data[0].f16.x, 1);
|
||||
data[invocation].f16.xy = subgroupClusteredMax(data[1].f16.xy, 1);
|
||||
data[invocation].f16.xyz = subgroupClusteredMax(data[2].f16.xyz, 1);
|
||||
data[invocation].f16 = subgroupClusteredMax(data[3].f16, 1);
|
||||
}
|
291
3rdparty/glslang/Test/spv.subgroupExtendedTypesPartitioned.comp
vendored
Normal file
291
3rdparty/glslang/Test/spv.subgroupExtendedTypesPartitioned.comp
vendored
Normal file
@ -0,0 +1,291 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_NV_shader_subgroup_partitioned: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int8: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int16: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int64: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
uvec4 ballot;
|
||||
ballot = subgroupPartitionNV(data[0].i8.x);
|
||||
ballot = subgroupPartitionNV(data[1].i8.xy);
|
||||
ballot = subgroupPartitionNV(data[2].i8.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].i8);
|
||||
|
||||
ballot = subgroupPartitionNV(data[0].u8.x);
|
||||
ballot = subgroupPartitionNV(data[1].u8.xy);
|
||||
ballot = subgroupPartitionNV(data[2].u8.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].u8);
|
||||
|
||||
ballot = subgroupPartitionNV(data[0].i16.x);
|
||||
ballot = subgroupPartitionNV(data[1].i16.xy);
|
||||
ballot = subgroupPartitionNV(data[2].i16.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].i16);
|
||||
|
||||
ballot = subgroupPartitionNV(data[0].u16.x);
|
||||
ballot = subgroupPartitionNV(data[1].u16.xy);
|
||||
ballot = subgroupPartitionNV(data[2].u16.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].u16);
|
||||
|
||||
ballot = subgroupPartitionNV(data[0].i64.x);
|
||||
ballot = subgroupPartitionNV(data[1].i64.xy);
|
||||
ballot = subgroupPartitionNV(data[2].i64.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].i64);
|
||||
|
||||
ballot = subgroupPartitionNV(data[0].u64.x);
|
||||
ballot = subgroupPartitionNV(data[1].u64.xy);
|
||||
ballot = subgroupPartitionNV(data[2].u64.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].u64);
|
||||
|
||||
ballot = subgroupPartitionNV(data[0].f16.x);
|
||||
ballot = subgroupPartitionNV(data[1].f16.xy);
|
||||
ballot = subgroupPartitionNV(data[2].f16.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].f16);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedAddNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedAddNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedAddNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedAddNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedMulNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedMulNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedMulNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedMulNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedMinNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedMinNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedMinNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedMinNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedMaxNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedMaxNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedMaxNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedMaxNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedAndNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedAndNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedAndNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedAndNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedOrNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedOrNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedOrNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedOrNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedXorNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedXorNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedXorNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedXorNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedAddNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedAddNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedAddNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedAddNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedMulNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedMulNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedMulNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedMulNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedMinNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedMinNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedMinNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedMinNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedMaxNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedMaxNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedMaxNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedMaxNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedAndNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedAndNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedAndNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedAndNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedOrNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedOrNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedOrNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedOrNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedXorNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedXorNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedXorNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedXorNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedAddNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedAddNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedAddNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedAddNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedMulNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedMulNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedMulNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedMulNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedMinNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedMinNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedMinNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedMinNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedMaxNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedMaxNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedMaxNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedMaxNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedAndNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedAndNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedAndNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedAndNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedOrNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedOrNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedOrNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedOrNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedXorNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedXorNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedXorNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedXorNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedAddNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedAddNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedAddNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedAddNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedMulNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedMulNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedMulNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedMulNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedMinNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedMinNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedMinNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedMinNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedMaxNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedMaxNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedMaxNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedMaxNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedAndNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedAndNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedAndNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedAndNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedOrNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedOrNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedOrNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedOrNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedXorNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedXorNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedXorNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedXorNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedAddNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedAddNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedAddNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedAddNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedMulNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedMulNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedMulNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedMulNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedMinNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedMinNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedMinNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedMinNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedMaxNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedMaxNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedMaxNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedMaxNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedAndNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedAndNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedAndNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedAndNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedOrNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedOrNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedOrNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedOrNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedXorNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedXorNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedXorNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedXorNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedAddNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedAddNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedAddNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedAddNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedMulNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedMulNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedMulNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedMulNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedMinNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedMinNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedMinNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedMinNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedMaxNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedMaxNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedMaxNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedMaxNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedAndNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedAndNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedAndNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedAndNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedOrNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedOrNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedOrNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedOrNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedXorNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedXorNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedXorNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedXorNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].f16.x = subgroupPartitionedAddNV(data[0].f16.x, ballot);
|
||||
data[invocation].f16.xy = subgroupPartitionedAddNV(data[1].f16.xy, ballot);
|
||||
data[invocation].f16.xyz = subgroupPartitionedAddNV(data[2].f16.xyz, ballot);
|
||||
data[invocation].f16 = subgroupPartitionedAddNV(data[3].f16, ballot);
|
||||
|
||||
data[invocation].f16.x = subgroupPartitionedMulNV(data[0].f16.x, ballot);
|
||||
data[invocation].f16.xy = subgroupPartitionedMulNV(data[1].f16.xy, ballot);
|
||||
data[invocation].f16.xyz = subgroupPartitionedMulNV(data[2].f16.xyz, ballot);
|
||||
data[invocation].f16 = subgroupPartitionedMulNV(data[3].f16, ballot);
|
||||
|
||||
data[invocation].f16.x = subgroupPartitionedMinNV(data[0].f16.x, ballot);
|
||||
data[invocation].f16.xy = subgroupPartitionedMinNV(data[1].f16.xy, ballot);
|
||||
data[invocation].f16.xyz = subgroupPartitionedMinNV(data[2].f16.xyz, ballot);
|
||||
data[invocation].f16 = subgroupPartitionedMinNV(data[3].f16, ballot);
|
||||
|
||||
data[invocation].f16.x = subgroupPartitionedMaxNV(data[0].f16.x, ballot);
|
||||
data[invocation].f16.xy = subgroupPartitionedMaxNV(data[1].f16.xy, ballot);
|
||||
data[invocation].f16.xyz = subgroupPartitionedMaxNV(data[2].f16.xyz, ballot);
|
||||
data[invocation].f16 = subgroupPartitionedMaxNV(data[3].f16, ballot);
|
||||
}
|
291
3rdparty/glslang/Test/spv.subgroupExtendedTypesPartitionedNeg.comp
vendored
Normal file
291
3rdparty/glslang/Test/spv.subgroupExtendedTypesPartitionedNeg.comp
vendored
Normal file
@ -0,0 +1,291 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_NV_shader_subgroup_partitioned: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int8: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int16: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int64: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
uvec4 ballot;
|
||||
ballot = subgroupPartitionNV(data[0].i8.x);
|
||||
ballot = subgroupPartitionNV(data[1].i8.xy);
|
||||
ballot = subgroupPartitionNV(data[2].i8.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].i8);
|
||||
|
||||
ballot = subgroupPartitionNV(data[0].u8.x);
|
||||
ballot = subgroupPartitionNV(data[1].u8.xy);
|
||||
ballot = subgroupPartitionNV(data[2].u8.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].u8);
|
||||
|
||||
ballot = subgroupPartitionNV(data[0].i16.x);
|
||||
ballot = subgroupPartitionNV(data[1].i16.xy);
|
||||
ballot = subgroupPartitionNV(data[2].i16.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].i16);
|
||||
|
||||
ballot = subgroupPartitionNV(data[0].u16.x);
|
||||
ballot = subgroupPartitionNV(data[1].u16.xy);
|
||||
ballot = subgroupPartitionNV(data[2].u16.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].u16);
|
||||
|
||||
ballot = subgroupPartitionNV(data[0].i64.x);
|
||||
ballot = subgroupPartitionNV(data[1].i64.xy);
|
||||
ballot = subgroupPartitionNV(data[2].i64.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].i64);
|
||||
|
||||
ballot = subgroupPartitionNV(data[0].u64.x);
|
||||
ballot = subgroupPartitionNV(data[1].u64.xy);
|
||||
ballot = subgroupPartitionNV(data[2].u64.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].u64);
|
||||
|
||||
ballot = subgroupPartitionNV(data[0].f16.x);
|
||||
ballot = subgroupPartitionNV(data[1].f16.xy);
|
||||
ballot = subgroupPartitionNV(data[2].f16.xyz);
|
||||
ballot = subgroupPartitionNV(data[3].f16);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedAddNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedAddNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedAddNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedAddNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedMulNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedMulNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedMulNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedMulNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedMinNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedMinNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedMinNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedMinNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedMaxNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedMaxNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedMaxNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedMaxNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedAndNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedAndNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedAndNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedAndNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedOrNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedOrNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedOrNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedOrNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].i8.x = subgroupPartitionedXorNV(data[0].i8.x, ballot);
|
||||
data[invocation].i8.xy = subgroupPartitionedXorNV(data[1].i8.xy, ballot);
|
||||
data[invocation].i8.xyz = subgroupPartitionedXorNV(data[2].i8.xyz, ballot);
|
||||
data[invocation].i8 = subgroupPartitionedXorNV(data[3].i8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedAddNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedAddNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedAddNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedAddNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedMulNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedMulNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedMulNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedMulNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedMinNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedMinNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedMinNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedMinNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedMaxNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedMaxNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedMaxNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedMaxNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedAndNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedAndNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedAndNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedAndNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedOrNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedOrNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedOrNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedOrNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].u8.x = subgroupPartitionedXorNV(data[0].u8.x, ballot);
|
||||
data[invocation].u8.xy = subgroupPartitionedXorNV(data[1].u8.xy, ballot);
|
||||
data[invocation].u8.xyz = subgroupPartitionedXorNV(data[2].u8.xyz, ballot);
|
||||
data[invocation].u8 = subgroupPartitionedXorNV(data[3].u8, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedAddNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedAddNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedAddNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedAddNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedMulNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedMulNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedMulNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedMulNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedMinNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedMinNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedMinNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedMinNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedMaxNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedMaxNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedMaxNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedMaxNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedAndNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedAndNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedAndNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedAndNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedOrNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedOrNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedOrNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedOrNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].i16.x = subgroupPartitionedXorNV(data[0].i16.x, ballot);
|
||||
data[invocation].i16.xy = subgroupPartitionedXorNV(data[1].i16.xy, ballot);
|
||||
data[invocation].i16.xyz = subgroupPartitionedXorNV(data[2].i16.xyz, ballot);
|
||||
data[invocation].i16 = subgroupPartitionedXorNV(data[3].i16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedAddNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedAddNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedAddNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedAddNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedMulNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedMulNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedMulNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedMulNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedMinNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedMinNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedMinNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedMinNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedMaxNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedMaxNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedMaxNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedMaxNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedAndNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedAndNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedAndNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedAndNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedOrNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedOrNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedOrNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedOrNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].u16.x = subgroupPartitionedXorNV(data[0].u16.x, ballot);
|
||||
data[invocation].u16.xy = subgroupPartitionedXorNV(data[1].u16.xy, ballot);
|
||||
data[invocation].u16.xyz = subgroupPartitionedXorNV(data[2].u16.xyz, ballot);
|
||||
data[invocation].u16 = subgroupPartitionedXorNV(data[3].u16, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedAddNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedAddNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedAddNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedAddNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedMulNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedMulNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedMulNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedMulNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedMinNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedMinNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedMinNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedMinNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedMaxNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedMaxNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedMaxNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedMaxNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedAndNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedAndNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedAndNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedAndNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedOrNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedOrNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedOrNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedOrNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].i64.x = subgroupPartitionedXorNV(data[0].i64.x, ballot);
|
||||
data[invocation].i64.xy = subgroupPartitionedXorNV(data[1].i64.xy, ballot);
|
||||
data[invocation].i64.xyz = subgroupPartitionedXorNV(data[2].i64.xyz, ballot);
|
||||
data[invocation].i64 = subgroupPartitionedXorNV(data[3].i64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedAddNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedAddNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedAddNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedAddNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedMulNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedMulNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedMulNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedMulNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedMinNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedMinNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedMinNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedMinNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedMaxNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedMaxNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedMaxNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedMaxNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedAndNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedAndNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedAndNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedAndNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedOrNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedOrNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedOrNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedOrNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].u64.x = subgroupPartitionedXorNV(data[0].u64.x, ballot);
|
||||
data[invocation].u64.xy = subgroupPartitionedXorNV(data[1].u64.xy, ballot);
|
||||
data[invocation].u64.xyz = subgroupPartitionedXorNV(data[2].u64.xyz, ballot);
|
||||
data[invocation].u64 = subgroupPartitionedXorNV(data[3].u64, ballot);
|
||||
|
||||
data[invocation].f16.x = subgroupPartitionedAddNV(data[0].f16.x, ballot);
|
||||
data[invocation].f16.xy = subgroupPartitionedAddNV(data[1].f16.xy, ballot);
|
||||
data[invocation].f16.xyz = subgroupPartitionedAddNV(data[2].f16.xyz, ballot);
|
||||
data[invocation].f16 = subgroupPartitionedAddNV(data[3].f16, ballot);
|
||||
|
||||
data[invocation].f16.x = subgroupPartitionedMulNV(data[0].f16.x, ballot);
|
||||
data[invocation].f16.xy = subgroupPartitionedMulNV(data[1].f16.xy, ballot);
|
||||
data[invocation].f16.xyz = subgroupPartitionedMulNV(data[2].f16.xyz, ballot);
|
||||
data[invocation].f16 = subgroupPartitionedMulNV(data[3].f16, ballot);
|
||||
|
||||
data[invocation].f16.x = subgroupPartitionedMinNV(data[0].f16.x, ballot);
|
||||
data[invocation].f16.xy = subgroupPartitionedMinNV(data[1].f16.xy, ballot);
|
||||
data[invocation].f16.xyz = subgroupPartitionedMinNV(data[2].f16.xyz, ballot);
|
||||
data[invocation].f16 = subgroupPartitionedMinNV(data[3].f16, ballot);
|
||||
|
||||
data[invocation].f16.x = subgroupPartitionedMaxNV(data[0].f16.x, ballot);
|
||||
data[invocation].f16.xy = subgroupPartitionedMaxNV(data[1].f16.xy, ballot);
|
||||
data[invocation].f16.xyz = subgroupPartitionedMaxNV(data[2].f16.xyz, ballot);
|
||||
data[invocation].f16 = subgroupPartitionedMaxNV(data[3].f16, ballot);
|
||||
}
|
165
3rdparty/glslang/Test/spv.subgroupExtendedTypesQuad.comp
vendored
Normal file
165
3rdparty/glslang/Test/spv.subgroupExtendedTypesQuad.comp
vendored
Normal file
@ -0,0 +1,165 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_quad: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int8: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int16: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int64: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
data[invocation].i8.x = subgroupQuadBroadcast(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupQuadBroadcast(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupQuadBroadcast(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupQuadBroadcast(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupQuadSwapHorizontal(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupQuadSwapHorizontal(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupQuadSwapHorizontal(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupQuadSwapHorizontal(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupQuadSwapVertical(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupQuadSwapVertical(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupQuadSwapVertical(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupQuadSwapVertical(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupQuadSwapDiagonal(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupQuadSwapDiagonal(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupQuadSwapDiagonal(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupQuadSwapDiagonal(data[3].i8);
|
||||
|
||||
data[invocation].u8.x = subgroupQuadBroadcast(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupQuadBroadcast(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupQuadBroadcast(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupQuadBroadcast(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupQuadSwapHorizontal(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupQuadSwapHorizontal(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupQuadSwapHorizontal(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupQuadSwapHorizontal(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupQuadSwapVertical(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupQuadSwapVertical(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupQuadSwapVertical(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupQuadSwapVertical(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupQuadSwapDiagonal(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupQuadSwapDiagonal(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupQuadSwapDiagonal(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupQuadSwapDiagonal(data[3].u8);
|
||||
|
||||
data[invocation].i16.x = subgroupQuadBroadcast(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupQuadBroadcast(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupQuadBroadcast(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupQuadBroadcast(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupQuadSwapHorizontal(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupQuadSwapHorizontal(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupQuadSwapHorizontal(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupQuadSwapHorizontal(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupQuadSwapVertical(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupQuadSwapVertical(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupQuadSwapVertical(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupQuadSwapVertical(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupQuadSwapDiagonal(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupQuadSwapDiagonal(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupQuadSwapDiagonal(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupQuadSwapDiagonal(data[3].i16);
|
||||
|
||||
data[invocation].u16.x = subgroupQuadBroadcast(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupQuadBroadcast(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupQuadBroadcast(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupQuadBroadcast(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupQuadSwapHorizontal(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupQuadSwapHorizontal(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupQuadSwapHorizontal(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupQuadSwapHorizontal(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupQuadSwapVertical(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupQuadSwapVertical(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupQuadSwapVertical(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupQuadSwapVertical(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupQuadSwapDiagonal(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupQuadSwapDiagonal(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupQuadSwapDiagonal(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupQuadSwapDiagonal(data[3].u16);
|
||||
|
||||
data[invocation].i64.x = subgroupQuadBroadcast(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupQuadBroadcast(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupQuadBroadcast(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupQuadBroadcast(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupQuadSwapHorizontal(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupQuadSwapHorizontal(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupQuadSwapHorizontal(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupQuadSwapHorizontal(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupQuadSwapVertical(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupQuadSwapVertical(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupQuadSwapVertical(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupQuadSwapVertical(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupQuadSwapDiagonal(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupQuadSwapDiagonal(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupQuadSwapDiagonal(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupQuadSwapDiagonal(data[3].i64);
|
||||
|
||||
data[invocation].u64.x = subgroupQuadBroadcast(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupQuadBroadcast(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupQuadBroadcast(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupQuadBroadcast(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupQuadSwapHorizontal(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupQuadSwapHorizontal(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupQuadSwapHorizontal(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupQuadSwapHorizontal(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupQuadSwapVertical(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupQuadSwapVertical(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupQuadSwapVertical(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupQuadSwapVertical(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupQuadSwapDiagonal(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupQuadSwapDiagonal(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupQuadSwapDiagonal(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupQuadSwapDiagonal(data[3].u64);
|
||||
|
||||
data[invocation].f16.x = subgroupQuadBroadcast(data[0].f16.x, 1);
|
||||
data[invocation].f16.xy = subgroupQuadBroadcast(data[1].f16.xy, 1);
|
||||
data[invocation].f16.xyz = subgroupQuadBroadcast(data[2].f16.xyz, 1);
|
||||
data[invocation].f16 = subgroupQuadBroadcast(data[3].f16, 1);
|
||||
|
||||
data[invocation].f16.x = subgroupQuadSwapHorizontal(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupQuadSwapHorizontal(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupQuadSwapHorizontal(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupQuadSwapHorizontal(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupQuadSwapVertical(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupQuadSwapVertical(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupQuadSwapVertical(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupQuadSwapVertical(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupQuadSwapDiagonal(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupQuadSwapDiagonal(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupQuadSwapDiagonal(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupQuadSwapDiagonal(data[3].f16);
|
||||
}
|
165
3rdparty/glslang/Test/spv.subgroupExtendedTypesQuadNeg.comp
vendored
Normal file
165
3rdparty/glslang/Test/spv.subgroupExtendedTypesQuadNeg.comp
vendored
Normal file
@ -0,0 +1,165 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_quad: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int8: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int16: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int64: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
data[invocation].i8.x = subgroupQuadBroadcast(data[0].i8.x, 1);
|
||||
data[invocation].i8.xy = subgroupQuadBroadcast(data[1].i8.xy, 1);
|
||||
data[invocation].i8.xyz = subgroupQuadBroadcast(data[2].i8.xyz, 1);
|
||||
data[invocation].i8 = subgroupQuadBroadcast(data[3].i8, 1);
|
||||
|
||||
data[invocation].i8.x = subgroupQuadSwapHorizontal(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupQuadSwapHorizontal(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupQuadSwapHorizontal(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupQuadSwapHorizontal(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupQuadSwapVertical(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupQuadSwapVertical(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupQuadSwapVertical(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupQuadSwapVertical(data[3].i8);
|
||||
|
||||
data[invocation].i8.x = subgroupQuadSwapDiagonal(data[0].i8.x);
|
||||
data[invocation].i8.xy = subgroupQuadSwapDiagonal(data[1].i8.xy);
|
||||
data[invocation].i8.xyz = subgroupQuadSwapDiagonal(data[2].i8.xyz);
|
||||
data[invocation].i8 = subgroupQuadSwapDiagonal(data[3].i8);
|
||||
|
||||
data[invocation].u8.x = subgroupQuadBroadcast(data[0].u8.x, 1);
|
||||
data[invocation].u8.xy = subgroupQuadBroadcast(data[1].u8.xy, 1);
|
||||
data[invocation].u8.xyz = subgroupQuadBroadcast(data[2].u8.xyz, 1);
|
||||
data[invocation].u8 = subgroupQuadBroadcast(data[3].u8, 1);
|
||||
|
||||
data[invocation].u8.x = subgroupQuadSwapHorizontal(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupQuadSwapHorizontal(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupQuadSwapHorizontal(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupQuadSwapHorizontal(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupQuadSwapVertical(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupQuadSwapVertical(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupQuadSwapVertical(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupQuadSwapVertical(data[3].u8);
|
||||
|
||||
data[invocation].u8.x = subgroupQuadSwapDiagonal(data[0].u8.x);
|
||||
data[invocation].u8.xy = subgroupQuadSwapDiagonal(data[1].u8.xy);
|
||||
data[invocation].u8.xyz = subgroupQuadSwapDiagonal(data[2].u8.xyz);
|
||||
data[invocation].u8 = subgroupQuadSwapDiagonal(data[3].u8);
|
||||
|
||||
data[invocation].i16.x = subgroupQuadBroadcast(data[0].i16.x, 1);
|
||||
data[invocation].i16.xy = subgroupQuadBroadcast(data[1].i16.xy, 1);
|
||||
data[invocation].i16.xyz = subgroupQuadBroadcast(data[2].i16.xyz, 1);
|
||||
data[invocation].i16 = subgroupQuadBroadcast(data[3].i16, 1);
|
||||
|
||||
data[invocation].i16.x = subgroupQuadSwapHorizontal(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupQuadSwapHorizontal(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupQuadSwapHorizontal(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupQuadSwapHorizontal(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupQuadSwapVertical(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupQuadSwapVertical(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupQuadSwapVertical(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupQuadSwapVertical(data[3].i16);
|
||||
|
||||
data[invocation].i16.x = subgroupQuadSwapDiagonal(data[0].i16.x);
|
||||
data[invocation].i16.xy = subgroupQuadSwapDiagonal(data[1].i16.xy);
|
||||
data[invocation].i16.xyz = subgroupQuadSwapDiagonal(data[2].i16.xyz);
|
||||
data[invocation].i16 = subgroupQuadSwapDiagonal(data[3].i16);
|
||||
|
||||
data[invocation].u16.x = subgroupQuadBroadcast(data[0].u16.x, 1);
|
||||
data[invocation].u16.xy = subgroupQuadBroadcast(data[1].u16.xy, 1);
|
||||
data[invocation].u16.xyz = subgroupQuadBroadcast(data[2].u16.xyz, 1);
|
||||
data[invocation].u16 = subgroupQuadBroadcast(data[3].u16, 1);
|
||||
|
||||
data[invocation].u16.x = subgroupQuadSwapHorizontal(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupQuadSwapHorizontal(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupQuadSwapHorizontal(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupQuadSwapHorizontal(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupQuadSwapVertical(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupQuadSwapVertical(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupQuadSwapVertical(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupQuadSwapVertical(data[3].u16);
|
||||
|
||||
data[invocation].u16.x = subgroupQuadSwapDiagonal(data[0].u16.x);
|
||||
data[invocation].u16.xy = subgroupQuadSwapDiagonal(data[1].u16.xy);
|
||||
data[invocation].u16.xyz = subgroupQuadSwapDiagonal(data[2].u16.xyz);
|
||||
data[invocation].u16 = subgroupQuadSwapDiagonal(data[3].u16);
|
||||
|
||||
data[invocation].i64.x = subgroupQuadBroadcast(data[0].i64.x, 1);
|
||||
data[invocation].i64.xy = subgroupQuadBroadcast(data[1].i64.xy, 1);
|
||||
data[invocation].i64.xyz = subgroupQuadBroadcast(data[2].i64.xyz, 1);
|
||||
data[invocation].i64 = subgroupQuadBroadcast(data[3].i64, 1);
|
||||
|
||||
data[invocation].i64.x = subgroupQuadSwapHorizontal(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupQuadSwapHorizontal(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupQuadSwapHorizontal(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupQuadSwapHorizontal(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupQuadSwapVertical(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupQuadSwapVertical(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupQuadSwapVertical(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupQuadSwapVertical(data[3].i64);
|
||||
|
||||
data[invocation].i64.x = subgroupQuadSwapDiagonal(data[0].i64.x);
|
||||
data[invocation].i64.xy = subgroupQuadSwapDiagonal(data[1].i64.xy);
|
||||
data[invocation].i64.xyz = subgroupQuadSwapDiagonal(data[2].i64.xyz);
|
||||
data[invocation].i64 = subgroupQuadSwapDiagonal(data[3].i64);
|
||||
|
||||
data[invocation].u64.x = subgroupQuadBroadcast(data[0].u64.x, 1);
|
||||
data[invocation].u64.xy = subgroupQuadBroadcast(data[1].u64.xy, 1);
|
||||
data[invocation].u64.xyz = subgroupQuadBroadcast(data[2].u64.xyz, 1);
|
||||
data[invocation].u64 = subgroupQuadBroadcast(data[3].u64, 1);
|
||||
|
||||
data[invocation].u64.x = subgroupQuadSwapHorizontal(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupQuadSwapHorizontal(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupQuadSwapHorizontal(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupQuadSwapHorizontal(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupQuadSwapVertical(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupQuadSwapVertical(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupQuadSwapVertical(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupQuadSwapVertical(data[3].u64);
|
||||
|
||||
data[invocation].u64.x = subgroupQuadSwapDiagonal(data[0].u64.x);
|
||||
data[invocation].u64.xy = subgroupQuadSwapDiagonal(data[1].u64.xy);
|
||||
data[invocation].u64.xyz = subgroupQuadSwapDiagonal(data[2].u64.xyz);
|
||||
data[invocation].u64 = subgroupQuadSwapDiagonal(data[3].u64);
|
||||
|
||||
data[invocation].f16.x = subgroupQuadBroadcast(data[0].f16.x, 1);
|
||||
data[invocation].f16.xy = subgroupQuadBroadcast(data[1].f16.xy, 1);
|
||||
data[invocation].f16.xyz = subgroupQuadBroadcast(data[2].f16.xyz, 1);
|
||||
data[invocation].f16 = subgroupQuadBroadcast(data[3].f16, 1);
|
||||
|
||||
data[invocation].f16.x = subgroupQuadSwapHorizontal(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupQuadSwapHorizontal(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupQuadSwapHorizontal(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupQuadSwapHorizontal(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupQuadSwapVertical(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupQuadSwapVertical(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupQuadSwapVertical(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupQuadSwapVertical(data[3].f16);
|
||||
|
||||
data[invocation].f16.x = subgroupQuadSwapDiagonal(data[0].f16.x);
|
||||
data[invocation].f16.xy = subgroupQuadSwapDiagonal(data[1].f16.xy);
|
||||
data[invocation].f16.xyz = subgroupQuadSwapDiagonal(data[2].f16.xyz);
|
||||
data[invocation].f16 = subgroupQuadSwapDiagonal(data[3].f16);
|
||||
}
|
95
3rdparty/glslang/Test/spv.subgroupExtendedTypesShuffle.comp
vendored
Normal file
95
3rdparty/glslang/Test/spv.subgroupExtendedTypesShuffle.comp
vendored
Normal file
@ -0,0 +1,95 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_shuffle: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int8: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int16: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int64: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
data[invocation].i8.x = subgroupShuffle(data[0].i8.x, invocation);
|
||||
data[invocation].i8.xy = subgroupShuffle(data[1].i8.xy, invocation);
|
||||
data[invocation].i8.xyz = subgroupShuffle(data[2].i8.xyz, invocation);
|
||||
data[invocation].i8 = subgroupShuffle(data[3].i8, invocation);
|
||||
|
||||
data[invocation].i8.x = subgroupShuffleXor(data[0].i8.x, invocation);
|
||||
data[invocation].i8.xy = subgroupShuffleXor(data[1].i8.xy, invocation);
|
||||
data[invocation].i8.xyz = subgroupShuffleXor(data[2].i8.xyz, invocation);
|
||||
data[invocation].i8 = subgroupShuffleXor(data[3].i8, invocation);
|
||||
|
||||
data[invocation].u8.x = subgroupShuffle(data[0].u8.x, invocation);
|
||||
data[invocation].u8.xy = subgroupShuffle(data[1].u8.xy, invocation);
|
||||
data[invocation].u8.xyz = subgroupShuffle(data[2].u8.xyz, invocation);
|
||||
data[invocation].u8 = subgroupShuffle(data[3].u8, invocation);
|
||||
|
||||
data[invocation].u8.x = subgroupShuffleXor(data[0].u8.x, invocation);
|
||||
data[invocation].u8.xy = subgroupShuffleXor(data[1].u8.xy, invocation);
|
||||
data[invocation].u8.xyz = subgroupShuffleXor(data[2].u8.xyz, invocation);
|
||||
data[invocation].u8 = subgroupShuffleXor(data[3].u8, invocation);
|
||||
|
||||
data[invocation].i16.x = subgroupShuffle(data[0].i16.x, invocation);
|
||||
data[invocation].i16.xy = subgroupShuffle(data[1].i16.xy, invocation);
|
||||
data[invocation].i16.xyz = subgroupShuffle(data[2].i16.xyz, invocation);
|
||||
data[invocation].i16 = subgroupShuffle(data[3].i16, invocation);
|
||||
|
||||
data[invocation].i16.x = subgroupShuffleXor(data[0].i16.x, invocation);
|
||||
data[invocation].i16.xy = subgroupShuffleXor(data[1].i16.xy, invocation);
|
||||
data[invocation].i16.xyz = subgroupShuffleXor(data[2].i16.xyz, invocation);
|
||||
data[invocation].i16 = subgroupShuffleXor(data[3].i16, invocation);
|
||||
|
||||
data[invocation].u16.x = subgroupShuffle(data[0].u16.x, invocation);
|
||||
data[invocation].u16.xy = subgroupShuffle(data[1].u16.xy, invocation);
|
||||
data[invocation].u16.xyz = subgroupShuffle(data[2].u16.xyz, invocation);
|
||||
data[invocation].u16 = subgroupShuffle(data[3].u16, invocation);
|
||||
|
||||
data[invocation].u16.x = subgroupShuffleXor(data[0].u16.x, invocation);
|
||||
data[invocation].u16.xy = subgroupShuffleXor(data[1].u16.xy, invocation);
|
||||
data[invocation].u16.xyz = subgroupShuffleXor(data[2].u16.xyz, invocation);
|
||||
data[invocation].u16 = subgroupShuffleXor(data[3].u16, invocation);
|
||||
|
||||
data[invocation].i64.x = subgroupShuffle(data[0].i64.x, invocation);
|
||||
data[invocation].i64.xy = subgroupShuffle(data[1].i64.xy, invocation);
|
||||
data[invocation].i64.xyz = subgroupShuffle(data[2].i64.xyz, invocation);
|
||||
data[invocation].i64 = subgroupShuffle(data[3].i64, invocation);
|
||||
|
||||
data[invocation].i64.x = subgroupShuffleXor(data[0].i64.x, invocation);
|
||||
data[invocation].i64.xy = subgroupShuffleXor(data[1].i64.xy, invocation);
|
||||
data[invocation].i64.xyz = subgroupShuffleXor(data[2].i64.xyz, invocation);
|
||||
data[invocation].i64 = subgroupShuffleXor(data[3].i64, invocation);
|
||||
|
||||
data[invocation].u64.x = subgroupShuffle(data[0].u64.x, invocation);
|
||||
data[invocation].u64.xy = subgroupShuffle(data[1].u64.xy, invocation);
|
||||
data[invocation].u64.xyz = subgroupShuffle(data[2].u64.xyz, invocation);
|
||||
data[invocation].u64 = subgroupShuffle(data[3].u64, invocation);
|
||||
|
||||
data[invocation].u64.x = subgroupShuffleXor(data[0].u64.x, invocation);
|
||||
data[invocation].u64.xy = subgroupShuffleXor(data[1].u64.xy, invocation);
|
||||
data[invocation].u64.xyz = subgroupShuffleXor(data[2].u64.xyz, invocation);
|
||||
data[invocation].u64 = subgroupShuffleXor(data[3].u64, invocation);
|
||||
|
||||
data[invocation].f16.x = subgroupShuffle(data[0].f16.x, invocation);
|
||||
data[invocation].f16.xy = subgroupShuffle(data[1].f16.xy, invocation);
|
||||
data[invocation].f16.xyz = subgroupShuffle(data[2].f16.xyz, invocation);
|
||||
data[invocation].f16 = subgroupShuffle(data[3].f16, invocation);
|
||||
|
||||
data[invocation].f16.x = subgroupShuffleXor(data[0].f16.x, invocation);
|
||||
data[invocation].f16.xy = subgroupShuffleXor(data[1].f16.xy, invocation);
|
||||
data[invocation].f16.xyz = subgroupShuffleXor(data[2].f16.xyz, invocation);
|
||||
data[invocation].f16 = subgroupShuffleXor(data[3].f16, invocation);
|
||||
}
|
95
3rdparty/glslang/Test/spv.subgroupExtendedTypesShuffleNeg.comp
vendored
Normal file
95
3rdparty/glslang/Test/spv.subgroupExtendedTypesShuffleNeg.comp
vendored
Normal file
@ -0,0 +1,95 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_shuffle: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int8: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int16: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int64: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
data[invocation].i8.x = subgroupShuffle(data[0].i8.x, invocation);
|
||||
data[invocation].i8.xy = subgroupShuffle(data[1].i8.xy, invocation);
|
||||
data[invocation].i8.xyz = subgroupShuffle(data[2].i8.xyz, invocation);
|
||||
data[invocation].i8 = subgroupShuffle(data[3].i8, invocation);
|
||||
|
||||
data[invocation].i8.x = subgroupShuffleXor(data[0].i8.x, invocation);
|
||||
data[invocation].i8.xy = subgroupShuffleXor(data[1].i8.xy, invocation);
|
||||
data[invocation].i8.xyz = subgroupShuffleXor(data[2].i8.xyz, invocation);
|
||||
data[invocation].i8 = subgroupShuffleXor(data[3].i8, invocation);
|
||||
|
||||
data[invocation].u8.x = subgroupShuffle(data[0].u8.x, invocation);
|
||||
data[invocation].u8.xy = subgroupShuffle(data[1].u8.xy, invocation);
|
||||
data[invocation].u8.xyz = subgroupShuffle(data[2].u8.xyz, invocation);
|
||||
data[invocation].u8 = subgroupShuffle(data[3].u8, invocation);
|
||||
|
||||
data[invocation].u8.x = subgroupShuffleXor(data[0].u8.x, invocation);
|
||||
data[invocation].u8.xy = subgroupShuffleXor(data[1].u8.xy, invocation);
|
||||
data[invocation].u8.xyz = subgroupShuffleXor(data[2].u8.xyz, invocation);
|
||||
data[invocation].u8 = subgroupShuffleXor(data[3].u8, invocation);
|
||||
|
||||
data[invocation].i16.x = subgroupShuffle(data[0].i16.x, invocation);
|
||||
data[invocation].i16.xy = subgroupShuffle(data[1].i16.xy, invocation);
|
||||
data[invocation].i16.xyz = subgroupShuffle(data[2].i16.xyz, invocation);
|
||||
data[invocation].i16 = subgroupShuffle(data[3].i16, invocation);
|
||||
|
||||
data[invocation].i16.x = subgroupShuffleXor(data[0].i16.x, invocation);
|
||||
data[invocation].i16.xy = subgroupShuffleXor(data[1].i16.xy, invocation);
|
||||
data[invocation].i16.xyz = subgroupShuffleXor(data[2].i16.xyz, invocation);
|
||||
data[invocation].i16 = subgroupShuffleXor(data[3].i16, invocation);
|
||||
|
||||
data[invocation].u16.x = subgroupShuffle(data[0].u16.x, invocation);
|
||||
data[invocation].u16.xy = subgroupShuffle(data[1].u16.xy, invocation);
|
||||
data[invocation].u16.xyz = subgroupShuffle(data[2].u16.xyz, invocation);
|
||||
data[invocation].u16 = subgroupShuffle(data[3].u16, invocation);
|
||||
|
||||
data[invocation].u16.x = subgroupShuffleXor(data[0].u16.x, invocation);
|
||||
data[invocation].u16.xy = subgroupShuffleXor(data[1].u16.xy, invocation);
|
||||
data[invocation].u16.xyz = subgroupShuffleXor(data[2].u16.xyz, invocation);
|
||||
data[invocation].u16 = subgroupShuffleXor(data[3].u16, invocation);
|
||||
|
||||
data[invocation].i64.x = subgroupShuffle(data[0].i64.x, invocation);
|
||||
data[invocation].i64.xy = subgroupShuffle(data[1].i64.xy, invocation);
|
||||
data[invocation].i64.xyz = subgroupShuffle(data[2].i64.xyz, invocation);
|
||||
data[invocation].i64 = subgroupShuffle(data[3].i64, invocation);
|
||||
|
||||
data[invocation].i64.x = subgroupShuffleXor(data[0].i64.x, invocation);
|
||||
data[invocation].i64.xy = subgroupShuffleXor(data[1].i64.xy, invocation);
|
||||
data[invocation].i64.xyz = subgroupShuffleXor(data[2].i64.xyz, invocation);
|
||||
data[invocation].i64 = subgroupShuffleXor(data[3].i64, invocation);
|
||||
|
||||
data[invocation].u64.x = subgroupShuffle(data[0].u64.x, invocation);
|
||||
data[invocation].u64.xy = subgroupShuffle(data[1].u64.xy, invocation);
|
||||
data[invocation].u64.xyz = subgroupShuffle(data[2].u64.xyz, invocation);
|
||||
data[invocation].u64 = subgroupShuffle(data[3].u64, invocation);
|
||||
|
||||
data[invocation].u64.x = subgroupShuffleXor(data[0].u64.x, invocation);
|
||||
data[invocation].u64.xy = subgroupShuffleXor(data[1].u64.xy, invocation);
|
||||
data[invocation].u64.xyz = subgroupShuffleXor(data[2].u64.xyz, invocation);
|
||||
data[invocation].u64 = subgroupShuffleXor(data[3].u64, invocation);
|
||||
|
||||
data[invocation].f16.x = subgroupShuffle(data[0].f16.x, invocation);
|
||||
data[invocation].f16.xy = subgroupShuffle(data[1].f16.xy, invocation);
|
||||
data[invocation].f16.xyz = subgroupShuffle(data[2].f16.xyz, invocation);
|
||||
data[invocation].f16 = subgroupShuffle(data[3].f16, invocation);
|
||||
|
||||
data[invocation].f16.x = subgroupShuffleXor(data[0].f16.x, invocation);
|
||||
data[invocation].f16.xy = subgroupShuffleXor(data[1].f16.xy, invocation);
|
||||
data[invocation].f16.xyz = subgroupShuffleXor(data[2].f16.xyz, invocation);
|
||||
data[invocation].f16 = subgroupShuffleXor(data[3].f16, invocation);
|
||||
}
|
95
3rdparty/glslang/Test/spv.subgroupExtendedTypesShuffleRelative.comp
vendored
Normal file
95
3rdparty/glslang/Test/spv.subgroupExtendedTypesShuffleRelative.comp
vendored
Normal file
@ -0,0 +1,95 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_shuffle_relative: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int8: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int16: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int64: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
data[invocation].i8.x = subgroupShuffleUp(data[0].i8.x, invocation);
|
||||
data[invocation].i8.xy = subgroupShuffleUp(data[1].i8.xy, invocation);
|
||||
data[invocation].i8.xyz = subgroupShuffleUp(data[2].i8.xyz, invocation);
|
||||
data[invocation].i8 = subgroupShuffleUp(data[3].i8, invocation);
|
||||
|
||||
data[invocation].i8.x = subgroupShuffleDown(data[0].i8.x, invocation);
|
||||
data[invocation].i8.xy = subgroupShuffleDown(data[1].i8.xy, invocation);
|
||||
data[invocation].i8.xyz = subgroupShuffleDown(data[2].i8.xyz, invocation);
|
||||
data[invocation].i8 = subgroupShuffleDown(data[3].i8, invocation);
|
||||
|
||||
data[invocation].u8.x = subgroupShuffleUp(data[0].u8.x, invocation);
|
||||
data[invocation].u8.xy = subgroupShuffleUp(data[1].u8.xy, invocation);
|
||||
data[invocation].u8.xyz = subgroupShuffleUp(data[2].u8.xyz, invocation);
|
||||
data[invocation].u8 = subgroupShuffleUp(data[3].u8, invocation);
|
||||
|
||||
data[invocation].u8.x = subgroupShuffleDown(data[0].u8.x, invocation);
|
||||
data[invocation].u8.xy = subgroupShuffleDown(data[1].u8.xy, invocation);
|
||||
data[invocation].u8.xyz = subgroupShuffleDown(data[2].u8.xyz, invocation);
|
||||
data[invocation].u8 = subgroupShuffleDown(data[3].u8, invocation);
|
||||
|
||||
data[invocation].i16.x = subgroupShuffleUp(data[0].i16.x, invocation);
|
||||
data[invocation].i16.xy = subgroupShuffleUp(data[1].i16.xy, invocation);
|
||||
data[invocation].i16.xyz = subgroupShuffleUp(data[2].i16.xyz, invocation);
|
||||
data[invocation].i16 = subgroupShuffleUp(data[3].i16, invocation);
|
||||
|
||||
data[invocation].i16.x = subgroupShuffleDown(data[0].i16.x, invocation);
|
||||
data[invocation].i16.xy = subgroupShuffleDown(data[1].i16.xy, invocation);
|
||||
data[invocation].i16.xyz = subgroupShuffleDown(data[2].i16.xyz, invocation);
|
||||
data[invocation].i16 = subgroupShuffleDown(data[3].i16, invocation);
|
||||
|
||||
data[invocation].u16.x = subgroupShuffleUp(data[0].u16.x, invocation);
|
||||
data[invocation].u16.xy = subgroupShuffleUp(data[1].u16.xy, invocation);
|
||||
data[invocation].u16.xyz = subgroupShuffleUp(data[2].u16.xyz, invocation);
|
||||
data[invocation].u16 = subgroupShuffleUp(data[3].u16, invocation);
|
||||
|
||||
data[invocation].u16.x = subgroupShuffleDown(data[0].u16.x, invocation);
|
||||
data[invocation].u16.xy = subgroupShuffleDown(data[1].u16.xy, invocation);
|
||||
data[invocation].u16.xyz = subgroupShuffleDown(data[2].u16.xyz, invocation);
|
||||
data[invocation].u16 = subgroupShuffleDown(data[3].u16, invocation);
|
||||
|
||||
data[invocation].i64.x = subgroupShuffleUp(data[0].i64.x, invocation);
|
||||
data[invocation].i64.xy = subgroupShuffleUp(data[1].i64.xy, invocation);
|
||||
data[invocation].i64.xyz = subgroupShuffleUp(data[2].i64.xyz, invocation);
|
||||
data[invocation].i64 = subgroupShuffleUp(data[3].i64, invocation);
|
||||
|
||||
data[invocation].i64.x = subgroupShuffleDown(data[0].i64.x, invocation);
|
||||
data[invocation].i64.xy = subgroupShuffleDown(data[1].i64.xy, invocation);
|
||||
data[invocation].i64.xyz = subgroupShuffleDown(data[2].i64.xyz, invocation);
|
||||
data[invocation].i64 = subgroupShuffleDown(data[3].i64, invocation);
|
||||
|
||||
data[invocation].u64.x = subgroupShuffleUp(data[0].u64.x, invocation);
|
||||
data[invocation].u64.xy = subgroupShuffleUp(data[1].u64.xy, invocation);
|
||||
data[invocation].u64.xyz = subgroupShuffleUp(data[2].u64.xyz, invocation);
|
||||
data[invocation].u64 = subgroupShuffleUp(data[3].u64, invocation);
|
||||
|
||||
data[invocation].u64.x = subgroupShuffleDown(data[0].u64.x, invocation);
|
||||
data[invocation].u64.xy = subgroupShuffleDown(data[1].u64.xy, invocation);
|
||||
data[invocation].u64.xyz = subgroupShuffleDown(data[2].u64.xyz, invocation);
|
||||
data[invocation].u64 = subgroupShuffleDown(data[3].u64, invocation);
|
||||
|
||||
data[invocation].f16.x = subgroupShuffleUp(data[0].f16.x, invocation);
|
||||
data[invocation].f16.xy = subgroupShuffleUp(data[1].f16.xy, invocation);
|
||||
data[invocation].f16.xyz = subgroupShuffleUp(data[2].f16.xyz, invocation);
|
||||
data[invocation].f16 = subgroupShuffleUp(data[3].f16, invocation);
|
||||
|
||||
data[invocation].f16.x = subgroupShuffleDown(data[0].f16.x, invocation);
|
||||
data[invocation].f16.xy = subgroupShuffleDown(data[1].f16.xy, invocation);
|
||||
data[invocation].f16.xyz = subgroupShuffleDown(data[2].f16.xyz, invocation);
|
||||
data[invocation].f16 = subgroupShuffleDown(data[3].f16, invocation);
|
||||
}
|
95
3rdparty/glslang/Test/spv.subgroupExtendedTypesShuffleRelativeNeg.comp
vendored
Normal file
95
3rdparty/glslang/Test/spv.subgroupExtendedTypesShuffleRelativeNeg.comp
vendored
Normal file
@ -0,0 +1,95 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_shuffle_relative: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int8: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int16: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int64: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
data[invocation].i8.x = subgroupShuffleUp(data[0].i8.x, invocation);
|
||||
data[invocation].i8.xy = subgroupShuffleUp(data[1].i8.xy, invocation);
|
||||
data[invocation].i8.xyz = subgroupShuffleUp(data[2].i8.xyz, invocation);
|
||||
data[invocation].i8 = subgroupShuffleUp(data[3].i8, invocation);
|
||||
|
||||
data[invocation].i8.x = subgroupShuffleDown(data[0].i8.x, invocation);
|
||||
data[invocation].i8.xy = subgroupShuffleDown(data[1].i8.xy, invocation);
|
||||
data[invocation].i8.xyz = subgroupShuffleDown(data[2].i8.xyz, invocation);
|
||||
data[invocation].i8 = subgroupShuffleDown(data[3].i8, invocation);
|
||||
|
||||
data[invocation].u8.x = subgroupShuffleUp(data[0].u8.x, invocation);
|
||||
data[invocation].u8.xy = subgroupShuffleUp(data[1].u8.xy, invocation);
|
||||
data[invocation].u8.xyz = subgroupShuffleUp(data[2].u8.xyz, invocation);
|
||||
data[invocation].u8 = subgroupShuffleUp(data[3].u8, invocation);
|
||||
|
||||
data[invocation].u8.x = subgroupShuffleDown(data[0].u8.x, invocation);
|
||||
data[invocation].u8.xy = subgroupShuffleDown(data[1].u8.xy, invocation);
|
||||
data[invocation].u8.xyz = subgroupShuffleDown(data[2].u8.xyz, invocation);
|
||||
data[invocation].u8 = subgroupShuffleDown(data[3].u8, invocation);
|
||||
|
||||
data[invocation].i16.x = subgroupShuffleUp(data[0].i16.x, invocation);
|
||||
data[invocation].i16.xy = subgroupShuffleUp(data[1].i16.xy, invocation);
|
||||
data[invocation].i16.xyz = subgroupShuffleUp(data[2].i16.xyz, invocation);
|
||||
data[invocation].i16 = subgroupShuffleUp(data[3].i16, invocation);
|
||||
|
||||
data[invocation].i16.x = subgroupShuffleDown(data[0].i16.x, invocation);
|
||||
data[invocation].i16.xy = subgroupShuffleDown(data[1].i16.xy, invocation);
|
||||
data[invocation].i16.xyz = subgroupShuffleDown(data[2].i16.xyz, invocation);
|
||||
data[invocation].i16 = subgroupShuffleDown(data[3].i16, invocation);
|
||||
|
||||
data[invocation].u16.x = subgroupShuffleUp(data[0].u16.x, invocation);
|
||||
data[invocation].u16.xy = subgroupShuffleUp(data[1].u16.xy, invocation);
|
||||
data[invocation].u16.xyz = subgroupShuffleUp(data[2].u16.xyz, invocation);
|
||||
data[invocation].u16 = subgroupShuffleUp(data[3].u16, invocation);
|
||||
|
||||
data[invocation].u16.x = subgroupShuffleDown(data[0].u16.x, invocation);
|
||||
data[invocation].u16.xy = subgroupShuffleDown(data[1].u16.xy, invocation);
|
||||
data[invocation].u16.xyz = subgroupShuffleDown(data[2].u16.xyz, invocation);
|
||||
data[invocation].u16 = subgroupShuffleDown(data[3].u16, invocation);
|
||||
|
||||
data[invocation].i64.x = subgroupShuffleUp(data[0].i64.x, invocation);
|
||||
data[invocation].i64.xy = subgroupShuffleUp(data[1].i64.xy, invocation);
|
||||
data[invocation].i64.xyz = subgroupShuffleUp(data[2].i64.xyz, invocation);
|
||||
data[invocation].i64 = subgroupShuffleUp(data[3].i64, invocation);
|
||||
|
||||
data[invocation].i64.x = subgroupShuffleDown(data[0].i64.x, invocation);
|
||||
data[invocation].i64.xy = subgroupShuffleDown(data[1].i64.xy, invocation);
|
||||
data[invocation].i64.xyz = subgroupShuffleDown(data[2].i64.xyz, invocation);
|
||||
data[invocation].i64 = subgroupShuffleDown(data[3].i64, invocation);
|
||||
|
||||
data[invocation].u64.x = subgroupShuffleUp(data[0].u64.x, invocation);
|
||||
data[invocation].u64.xy = subgroupShuffleUp(data[1].u64.xy, invocation);
|
||||
data[invocation].u64.xyz = subgroupShuffleUp(data[2].u64.xyz, invocation);
|
||||
data[invocation].u64 = subgroupShuffleUp(data[3].u64, invocation);
|
||||
|
||||
data[invocation].u64.x = subgroupShuffleDown(data[0].u64.x, invocation);
|
||||
data[invocation].u64.xy = subgroupShuffleDown(data[1].u64.xy, invocation);
|
||||
data[invocation].u64.xyz = subgroupShuffleDown(data[2].u64.xyz, invocation);
|
||||
data[invocation].u64 = subgroupShuffleDown(data[3].u64, invocation);
|
||||
|
||||
data[invocation].f16.x = subgroupShuffleUp(data[0].f16.x, invocation);
|
||||
data[invocation].f16.xy = subgroupShuffleUp(data[1].f16.xy, invocation);
|
||||
data[invocation].f16.xyz = subgroupShuffleUp(data[2].f16.xyz, invocation);
|
||||
data[invocation].f16 = subgroupShuffleUp(data[3].f16, invocation);
|
||||
|
||||
data[invocation].f16.x = subgroupShuffleDown(data[0].f16.x, invocation);
|
||||
data[invocation].f16.xy = subgroupShuffleDown(data[1].f16.xy, invocation);
|
||||
data[invocation].f16.xyz = subgroupShuffleDown(data[2].f16.xyz, invocation);
|
||||
data[invocation].f16 = subgroupShuffleDown(data[3].f16, invocation);
|
||||
}
|
66
3rdparty/glslang/Test/spv.subgroupExtendedTypesVote.comp
vendored
Normal file
66
3rdparty/glslang/Test/spv.subgroupExtendedTypesVote.comp
vendored
Normal file
@ -0,0 +1,66 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_vote: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int8: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int16: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_int64: enable
|
||||
#extension GL_EXT_shader_subgroup_extended_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
int r;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
if (subgroupAll(data[invocation].r < 0))
|
||||
{
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].i8.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].i8.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].i8.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].i8));
|
||||
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].u8.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].u8.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].u8.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].u8));
|
||||
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].i16.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].i16.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].i16.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].i16));
|
||||
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].u16.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].u16.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].u16.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].u16));
|
||||
}
|
||||
else if (subgroupAny(data[invocation].r < 0))
|
||||
{
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].i64.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].i64.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].i64.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].i64));
|
||||
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].u64.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].u64.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].u64.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].u64));
|
||||
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].f16.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].f16.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].f16.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].f16));
|
||||
}
|
||||
}
|
66
3rdparty/glslang/Test/spv.subgroupExtendedTypesVoteNeg.comp
vendored
Normal file
66
3rdparty/glslang/Test/spv.subgroupExtendedTypesVoteNeg.comp
vendored
Normal file
@ -0,0 +1,66 @@
|
||||
#version 450
|
||||
|
||||
#extension GL_KHR_shader_subgroup_vote: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int8: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int16: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_int64: enable
|
||||
#extension GL_EXT_shader_explicit_arithmetic_types_float16: enable
|
||||
|
||||
layout (local_size_x = 8) in;
|
||||
|
||||
layout(binding = 0) buffer Buffers
|
||||
{
|
||||
i8vec4 i8;
|
||||
u8vec4 u8;
|
||||
i16vec4 i16;
|
||||
u16vec4 u16;
|
||||
i64vec4 i64;
|
||||
u64vec4 u64;
|
||||
f16vec4 f16;
|
||||
int r;
|
||||
} data[4];
|
||||
|
||||
void main()
|
||||
{
|
||||
uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
|
||||
|
||||
if (subgroupAll(data[invocation].r < 0))
|
||||
{
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].i8.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].i8.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].i8.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].i8));
|
||||
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].u8.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].u8.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].u8.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].u8));
|
||||
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].i16.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].i16.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].i16.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].i16));
|
||||
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].u16.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].u16.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].u16.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].u16));
|
||||
}
|
||||
else if (subgroupAny(data[invocation].r < 0))
|
||||
{
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].i64.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].i64.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].i64.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].i64));
|
||||
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].u64.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].u64.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].u64.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].u64));
|
||||
|
||||
data[invocation].r = int(subgroupAllEqual(data[0].f16.x));
|
||||
data[invocation].r = int(subgroupAllEqual(data[1].f16.xy));
|
||||
data[invocation].r = int(subgroupAllEqual(data[2].f16.xyz));
|
||||
data[invocation].r = int(subgroupAllEqual(data[3].f16));
|
||||
}
|
||||
}
|
17
3rdparty/glslang/glslang/CMakeLists.txt
vendored
17
3rdparty/glslang/glslang/CMakeLists.txt
vendored
@ -6,6 +6,10 @@ else(WIN32)
|
||||
message("unknown platform")
|
||||
endif(WIN32)
|
||||
|
||||
if(EMSCRIPTEN OR ENABLE_GLSLANG_WEB)
|
||||
add_subdirectory(OSDependent/Web)
|
||||
endif(EMSCRIPTEN OR ENABLE_GLSLANG_WEB)
|
||||
|
||||
set(SOURCES
|
||||
MachineIndependent/glslang.m4
|
||||
MachineIndependent/glslang.y
|
||||
@ -114,16 +118,3 @@ if(ENABLE_GLSLANG_INSTALL)
|
||||
install(FILES ${file} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/glslang/${dir})
|
||||
endforeach()
|
||||
endif(ENABLE_GLSLANG_INSTALL)
|
||||
|
||||
if(ENABLE_GLSLANG_WEB)
|
||||
add_executable(glslang.js glslang.js.cpp)
|
||||
glslang_set_link_args(glslang.js)
|
||||
target_link_libraries(glslang.js glslang SPIRV)
|
||||
if(EMSCRIPTEN)
|
||||
set_target_properties(glslang.js PROPERTIES
|
||||
OUTPUT_NAME "glslang"
|
||||
SUFFIX ".js"
|
||||
LINK_FLAGS "--bind -s EXPORT_NAME=\"glslangModule\"")
|
||||
em_link_pre_js(glslang.js ${CMAKE_CURRENT_SOURCE_DIR}/glslang.pre.js)
|
||||
endif(EMSCRIPTEN)
|
||||
endif(ENABLE_GLSLANG_WEB)
|
||||
|
7
3rdparty/glslang/glslang/Include/Types.h
vendored
7
3rdparty/glslang/glslang/Include/Types.h
vendored
@ -1195,6 +1195,7 @@ struct TShaderQualifiers {
|
||||
TVertexOrder order;
|
||||
bool pointMode;
|
||||
int localSize[3]; // compute shader
|
||||
bool localSizeNotDefault[3]; // compute shader
|
||||
int localSizeSpecId[3]; // compute shader specialization id for gl_WorkGroupSize
|
||||
#ifndef GLSLANG_WEB
|
||||
bool earlyFragmentTests; // fragment input
|
||||
@ -1225,6 +1226,9 @@ struct TShaderQualifiers {
|
||||
localSize[0] = 1;
|
||||
localSize[1] = 1;
|
||||
localSize[2] = 1;
|
||||
localSizeNotDefault[0] = false;
|
||||
localSizeNotDefault[1] = false;
|
||||
localSizeNotDefault[2] = false;
|
||||
localSizeSpecId[0] = TQualifier::layoutNotSet;
|
||||
localSizeSpecId[1] = TQualifier::layoutNotSet;
|
||||
localSizeSpecId[2] = TQualifier::layoutNotSet;
|
||||
@ -1272,6 +1276,9 @@ struct TShaderQualifiers {
|
||||
if (src.localSize[i] > 1)
|
||||
localSize[i] = src.localSize[i];
|
||||
}
|
||||
for (int i = 0; i < 3; ++i) {
|
||||
localSizeNotDefault[i] = src.localSizeNotDefault[i] || localSizeNotDefault[i];
|
||||
}
|
||||
for (int i = 0; i < 3; ++i) {
|
||||
if (src.localSizeSpecId[i] != TQualifier::layoutNotSet)
|
||||
localSizeSpecId[i] = src.localSizeSpecId[i];
|
||||
|
@ -275,6 +275,10 @@ enum TOperator {
|
||||
EOpConvUint64ToPtr,
|
||||
EOpConvPtrToUint64,
|
||||
|
||||
// uvec2 <-> pointer
|
||||
EOpConvUvec2ToPtr,
|
||||
EOpConvPtrToUvec2,
|
||||
|
||||
//
|
||||
// binary operations
|
||||
//
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -2155,9 +2155,11 @@ void TParseContext::builtInOpCheck(const TSourceLoc& loc, const TFunction& fnCan
|
||||
break;
|
||||
|
||||
case EOpSubgroupBroadcast:
|
||||
// <id> must be an integral constant expression.
|
||||
if ((*argp)[1]->getAsConstantUnion() == nullptr)
|
||||
error(loc, "argument must be compile-time constant", "id", "");
|
||||
if (spvVersion.spv < EShTargetSpv_1_5) {
|
||||
// <id> must be an integral constant expression.
|
||||
if ((*argp)[1]->getAsConstantUnion() == nullptr)
|
||||
error(loc, "argument must be compile-time constant", "id", "");
|
||||
}
|
||||
break;
|
||||
|
||||
case EOpBarrier:
|
||||
@ -2202,6 +2204,30 @@ void TParseContext::builtInOpCheck(const TSourceLoc& loc, const TFunction& fnCan
|
||||
// these require SPIR-V 1.3
|
||||
if (spvVersion.spv > 0 && spvVersion.spv < EShTargetSpv_1_3)
|
||||
error(loc, "requires SPIR-V 1.3", "subgroup op", "");
|
||||
|
||||
// Check that if extended types are being used that the correct extensions are enabled.
|
||||
if (arg0 != nullptr) {
|
||||
const TType& type = arg0->getType();
|
||||
switch (type.getBasicType()) {
|
||||
default:
|
||||
break;
|
||||
case EbtInt8:
|
||||
case EbtUint8:
|
||||
requireExtensions(loc, 1, &E_GL_EXT_shader_subgroup_extended_types_int8, type.getCompleteString().c_str());
|
||||
break;
|
||||
case EbtInt16:
|
||||
case EbtUint16:
|
||||
requireExtensions(loc, 1, &E_GL_EXT_shader_subgroup_extended_types_int16, type.getCompleteString().c_str());
|
||||
break;
|
||||
case EbtInt64:
|
||||
case EbtUint64:
|
||||
requireExtensions(loc, 1, &E_GL_EXT_shader_subgroup_extended_types_int64, type.getCompleteString().c_str());
|
||||
break;
|
||||
case EbtFloat16:
|
||||
requireExtensions(loc, 1, &E_GL_EXT_shader_subgroup_extended_types_float16, type.getCompleteString().c_str());
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -2748,10 +2774,25 @@ bool TParseContext::builtInName(const TString& identifier)
|
||||
//
|
||||
bool TParseContext::constructorError(const TSourceLoc& loc, TIntermNode* node, TFunction& function, TOperator op, TType& type)
|
||||
{
|
||||
type.shallowCopy(function.getType());
|
||||
// See if the constructor does not establish the main type, only requalifies
|
||||
// it, in which case the type comes from the argument instead of from the
|
||||
// constructor function.
|
||||
switch (op) {
|
||||
case EOpConstructNonuniform:
|
||||
if (node != nullptr && node->getAsTyped() != nullptr) {
|
||||
type.shallowCopy(node->getAsTyped()->getType());
|
||||
type.getQualifier().makeTemporary();
|
||||
type.getQualifier().nonUniform = true;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
type.shallowCopy(function.getType());
|
||||
break;
|
||||
}
|
||||
|
||||
// See if it's a matrix
|
||||
bool constructingMatrix = false;
|
||||
switch(op) {
|
||||
switch (op) {
|
||||
#ifndef GLSLANG_WEB
|
||||
case EOpConstructTextureSampler:
|
||||
return constructorTextureSamplerError(loc, function);
|
||||
@ -2845,6 +2886,8 @@ bool TParseContext::constructorError(const TSourceLoc& loc, TIntermNode* node, T
|
||||
}
|
||||
}
|
||||
}
|
||||
if (op == EOpConstructNonuniform)
|
||||
constType = false;
|
||||
|
||||
#ifndef GLSLANG_WEB
|
||||
switch (op) {
|
||||
@ -5360,14 +5403,17 @@ void TParseContext::setLayoutQualifier(const TSourceLoc& loc, TPublicType& publi
|
||||
}
|
||||
if (id == "local_size_x") {
|
||||
publicType.shaderQualifiers.localSize[0] = value;
|
||||
publicType.shaderQualifiers.localSizeNotDefault[0] = true;
|
||||
return;
|
||||
}
|
||||
if (id == "local_size_y") {
|
||||
publicType.shaderQualifiers.localSize[1] = value;
|
||||
publicType.shaderQualifiers.localSizeNotDefault[1] = true;
|
||||
return;
|
||||
}
|
||||
if (id == "local_size_z") {
|
||||
publicType.shaderQualifiers.localSize[2] = value;
|
||||
publicType.shaderQualifiers.localSizeNotDefault[2] = true;
|
||||
return;
|
||||
}
|
||||
if (spvVersion.spv != 0) {
|
||||
@ -6912,6 +6958,12 @@ TIntermTyped* TParseContext::constructBuiltIn(const TType& type, TOperator op, T
|
||||
break;
|
||||
|
||||
case EOpConstructUVec2:
|
||||
if (node->getType().getBasicType() == EbtReference) {
|
||||
requireExtensions(loc, 1, &E_GL_EXT_buffer_reference_uvec2, "reference conversion to uvec2");
|
||||
TIntermTyped* newNode = intermediate.addBuiltInFunctionCall(node->getLoc(), EOpConvPtrToUvec2, true, node,
|
||||
type);
|
||||
return newNode;
|
||||
}
|
||||
case EOpConstructUVec3:
|
||||
case EOpConstructUVec4:
|
||||
case EOpConstructUint:
|
||||
@ -7058,8 +7110,7 @@ TIntermTyped* TParseContext::constructBuiltIn(const TType& type, TOperator op, T
|
||||
|
||||
case EOpConstructNonuniform:
|
||||
// Make a nonuniform copy of node
|
||||
newNode = intermediate.addBuiltInFunctionCall(node->getLoc(), EOpCopyObject, true, node, node->getType());
|
||||
newNode->getWritableType().getQualifier().nonUniform = true;
|
||||
newNode = intermediate.addBuiltInFunctionCall(node->getLoc(), EOpCopyObject, true, node, type);
|
||||
return newNode;
|
||||
|
||||
case EOpConstructReference:
|
||||
@ -7069,7 +7120,15 @@ TIntermTyped* TParseContext::constructBuiltIn(const TType& type, TOperator op, T
|
||||
return newNode;
|
||||
// construct reference from uint64
|
||||
} else if (node->getType().isScalar() && node->getType().getBasicType() == EbtUint64) {
|
||||
TIntermTyped* newNode = intermediate.addBuiltInFunctionCall(node->getLoc(), EOpConvUint64ToPtr, true, node, type);
|
||||
TIntermTyped* newNode = intermediate.addBuiltInFunctionCall(node->getLoc(), EOpConvUint64ToPtr, true, node,
|
||||
type);
|
||||
return newNode;
|
||||
// construct reference from uvec2
|
||||
} else if (node->getType().isVector() && node->getType().getBasicType() == EbtUint &&
|
||||
node->getVectorSize() == 2) {
|
||||
requireExtensions(loc, 1, &E_GL_EXT_buffer_reference_uvec2, "uvec2 conversion to reference");
|
||||
TIntermTyped* newNode = intermediate.addBuiltInFunctionCall(node->getLoc(), EOpConvUvec2ToPtr, true, node,
|
||||
type);
|
||||
return newNode;
|
||||
} else {
|
||||
return nullptr;
|
||||
@ -7945,7 +8004,7 @@ void TParseContext::updateStandaloneQualifierDefaults(const TSourceLoc& loc, con
|
||||
error(loc, "can only apply to 'in'", "point_mode", "");
|
||||
}
|
||||
for (int i = 0; i < 3; ++i) {
|
||||
if (publicType.shaderQualifiers.localSize[i] > 1) {
|
||||
if (publicType.shaderQualifiers.localSizeNotDefault[i]) {
|
||||
if (publicType.qualifier.storage == EvqVaryingIn) {
|
||||
if (! intermediate.setLocalSize(i, publicType.shaderQualifiers.localSize[i]))
|
||||
error(loc, "cannot change previously set size", "local_size", "");
|
||||
|
@ -214,6 +214,7 @@ void TParseVersions::initializeExtensionBehavior()
|
||||
extensionBehavior[E_GL_EXT_fragment_invocation_density] = EBhDisable;
|
||||
extensionBehavior[E_GL_EXT_buffer_reference] = EBhDisable;
|
||||
extensionBehavior[E_GL_EXT_buffer_reference2] = EBhDisable;
|
||||
extensionBehavior[E_GL_EXT_buffer_reference_uvec2] = EBhDisable;
|
||||
extensionBehavior[E_GL_EXT_demote_to_helper_invocation] = EBhDisable;
|
||||
|
||||
extensionBehavior[E_GL_EXT_shader_16bit_storage] = EBhDisable;
|
||||
@ -300,6 +301,12 @@ void TParseVersions::initializeExtensionBehavior()
|
||||
extensionBehavior[E_GL_EXT_shader_explicit_arithmetic_types_float16] = EBhDisable;
|
||||
extensionBehavior[E_GL_EXT_shader_explicit_arithmetic_types_float32] = EBhDisable;
|
||||
extensionBehavior[E_GL_EXT_shader_explicit_arithmetic_types_float64] = EBhDisable;
|
||||
|
||||
// subgroup extended types
|
||||
extensionBehavior[E_GL_EXT_shader_subgroup_extended_types_int8] = EBhDisable;
|
||||
extensionBehavior[E_GL_EXT_shader_subgroup_extended_types_int16] = EBhDisable;
|
||||
extensionBehavior[E_GL_EXT_shader_subgroup_extended_types_int64] = EBhDisable;
|
||||
extensionBehavior[E_GL_EXT_shader_subgroup_extended_types_float16] = EBhDisable;
|
||||
}
|
||||
#endif // GLSLANG_WEB
|
||||
|
||||
@ -398,6 +405,7 @@ void TParseVersions::getPreamble(std::string& preamble)
|
||||
"#define GL_EXT_fragment_invocation_density 1\n"
|
||||
"#define GL_EXT_buffer_reference 1\n"
|
||||
"#define GL_EXT_buffer_reference2 1\n"
|
||||
"#define GL_EXT_buffer_reference_uvec2 1\n"
|
||||
"#define GL_EXT_demote_to_helper_invocation 1\n"
|
||||
|
||||
// GL_KHR_shader_subgroup
|
||||
@ -447,6 +455,11 @@ void TParseVersions::getPreamble(std::string& preamble)
|
||||
"#define GL_EXT_shader_explicit_arithmetic_types_float16 1\n"
|
||||
"#define GL_EXT_shader_explicit_arithmetic_types_float32 1\n"
|
||||
"#define GL_EXT_shader_explicit_arithmetic_types_float64 1\n"
|
||||
|
||||
"#define GL_EXT_shader_subgroup_extended_types_int8 1\n"
|
||||
"#define GL_EXT_shader_subgroup_extended_types_int16 1\n"
|
||||
"#define GL_EXT_shader_subgroup_extended_types_int64 1\n"
|
||||
"#define GL_EXT_shader_subgroup_extended_types_float16 1\n"
|
||||
;
|
||||
|
||||
if (version >= 150) {
|
||||
@ -822,10 +835,20 @@ void TParseVersions::updateExtensionBehavior(int line, const char* extension, co
|
||||
updateExtensionBehavior(line, "GL_KHR_shader_subgroup_basic", behaviorString);
|
||||
else if (strcmp(extension, "GL_NV_shader_subgroup_partitioned") == 0)
|
||||
updateExtensionBehavior(line, "GL_KHR_shader_subgroup_basic", behaviorString);
|
||||
else if (strcmp(extension, "GL_EXT_buffer_reference2") == 0)
|
||||
else if (strcmp(extension, "GL_EXT_buffer_reference2") == 0 ||
|
||||
strcmp(extension, "GL_EXT_buffer_reference_uvec2") == 0)
|
||||
updateExtensionBehavior(line, "GL_EXT_buffer_reference", behaviorString);
|
||||
else if (strcmp(extension, "GL_NV_integer_cooperative_matrix") == 0)
|
||||
updateExtensionBehavior(line, "GL_NV_cooperative_matrix", behaviorString);
|
||||
// subgroup extended types to explicit types
|
||||
else if (strcmp(extension, "GL_EXT_shader_subgroup_extended_types_int8") == 0)
|
||||
updateExtensionBehavior(line, "GL_EXT_shader_explicit_arithmetic_types_int8", behaviorString);
|
||||
else if (strcmp(extension, "GL_EXT_shader_subgroup_extended_types_int16") == 0)
|
||||
updateExtensionBehavior(line, "GL_EXT_shader_explicit_arithmetic_types_int16", behaviorString);
|
||||
else if (strcmp(extension, "GL_EXT_shader_subgroup_extended_types_int64") == 0)
|
||||
updateExtensionBehavior(line, "GL_EXT_shader_explicit_arithmetic_types_int64", behaviorString);
|
||||
else if (strcmp(extension, "GL_EXT_shader_subgroup_extended_types_float16") == 0)
|
||||
updateExtensionBehavior(line, "GL_EXT_shader_explicit_arithmetic_types_float16", behaviorString);
|
||||
}
|
||||
|
||||
void TParseVersions::updateExtensionBehavior(const char* extension, TExtensionBehavior behavior)
|
||||
|
@ -174,6 +174,7 @@ const char* const E_GL_EXT_scalar_block_layout = "GL_EXT_scalar_blo
|
||||
const char* const E_GL_EXT_fragment_invocation_density = "GL_EXT_fragment_invocation_density";
|
||||
const char* const E_GL_EXT_buffer_reference = "GL_EXT_buffer_reference";
|
||||
const char* const E_GL_EXT_buffer_reference2 = "GL_EXT_buffer_reference2";
|
||||
const char* const E_GL_EXT_buffer_reference_uvec2 = "GL_EXT_buffer_reference_uvec2";
|
||||
const char* const E_GL_EXT_demote_to_helper_invocation = "GL_EXT_demote_to_helper_invocation";
|
||||
const char* const E_GL_EXT_shader_realtime_clock = "GL_EXT_shader_realtime_clock";
|
||||
|
||||
@ -257,7 +258,7 @@ const char* const E_GL_OES_tessellation_point_size = "GL_OES_tessel
|
||||
const char* const E_GL_OES_texture_buffer = "GL_OES_texture_buffer";
|
||||
const char* const E_GL_OES_texture_cube_map_array = "GL_OES_texture_cube_map_array";
|
||||
|
||||
// KHX
|
||||
// EXT
|
||||
const char* const E_GL_EXT_shader_explicit_arithmetic_types = "GL_EXT_shader_explicit_arithmetic_types";
|
||||
const char* const E_GL_EXT_shader_explicit_arithmetic_types_int8 = "GL_EXT_shader_explicit_arithmetic_types_int8";
|
||||
const char* const E_GL_EXT_shader_explicit_arithmetic_types_int16 = "GL_EXT_shader_explicit_arithmetic_types_int16";
|
||||
@ -267,6 +268,11 @@ const char* const E_GL_EXT_shader_explicit_arithmetic_types_float16 = "GL_EXT_s
|
||||
const char* const E_GL_EXT_shader_explicit_arithmetic_types_float32 = "GL_EXT_shader_explicit_arithmetic_types_float32";
|
||||
const char* const E_GL_EXT_shader_explicit_arithmetic_types_float64 = "GL_EXT_shader_explicit_arithmetic_types_float64";
|
||||
|
||||
const char* const E_GL_EXT_shader_subgroup_extended_types_int8 = "GL_EXT_shader_subgroup_extended_types_int8";
|
||||
const char* const E_GL_EXT_shader_subgroup_extended_types_int16 = "GL_EXT_shader_subgroup_extended_types_int16";
|
||||
const char* const E_GL_EXT_shader_subgroup_extended_types_int64 = "GL_EXT_shader_subgroup_extended_types_int64";
|
||||
const char* const E_GL_EXT_shader_subgroup_extended_types_float16 = "GL_EXT_shader_subgroup_extended_types_float16";
|
||||
|
||||
// Arrays of extensions for the above AEP duplications
|
||||
|
||||
const char* const AEP_geometry_shader[] = { E_GL_EXT_geometry_shader, E_GL_OES_geometry_shader };
|
||||
|
@ -271,6 +271,9 @@ public:
|
||||
localSize[0] = 1;
|
||||
localSize[1] = 1;
|
||||
localSize[2] = 1;
|
||||
localSizeNotDefault[0] = false;
|
||||
localSizeNotDefault[1] = false;
|
||||
localSizeNotDefault[2] = false;
|
||||
localSizeSpecId[0] = TQualifier::layoutNotSet;
|
||||
localSizeSpecId[1] = TQualifier::layoutNotSet;
|
||||
localSizeSpecId[2] = TQualifier::layoutNotSet;
|
||||
@ -308,6 +311,12 @@ public:
|
||||
case EShTargetSpv_1_3:
|
||||
processes.addProcess("target-env spirv1.3");
|
||||
break;
|
||||
case EShTargetSpv_1_4:
|
||||
processes.addProcess("target-env spirv1.4");
|
||||
break;
|
||||
case EShTargetSpv_1_5:
|
||||
processes.addProcess("target-env spirv1.5");
|
||||
break;
|
||||
default:
|
||||
processes.addProcess("target-env spirvUnknown");
|
||||
break;
|
||||
@ -648,8 +657,9 @@ public:
|
||||
|
||||
bool setLocalSize(int dim, int size)
|
||||
{
|
||||
if (localSize[dim] > 1)
|
||||
if (localSizeNotDefault[dim])
|
||||
return size == localSize[dim];
|
||||
localSizeNotDefault[dim] = true;
|
||||
localSize[dim] = size;
|
||||
return true;
|
||||
}
|
||||
@ -921,6 +931,7 @@ protected:
|
||||
TInterlockOrdering interlockOrdering;
|
||||
bool pointMode;
|
||||
int localSize[3];
|
||||
bool localSizeNotDefault[3];
|
||||
int localSizeSpecId[3];
|
||||
bool earlyFragmentTests;
|
||||
bool postDepthCoverage;
|
||||
|
24
3rdparty/glslang/glslang/OSDependent/Web/CMakeLists.txt
vendored
Normal file
24
3rdparty/glslang/glslang/OSDependent/Web/CMakeLists.txt
vendored
Normal file
@ -0,0 +1,24 @@
|
||||
add_executable(glslang.js "glslang.js.cpp")
|
||||
glslang_set_link_args(glslang.js)
|
||||
target_link_libraries(glslang.js glslang SPIRV)
|
||||
if(EMSCRIPTEN)
|
||||
set_target_properties(glslang.js PROPERTIES
|
||||
OUTPUT_NAME "glslang"
|
||||
SUFFIX ".js")
|
||||
em_link_pre_js(glslang.js "${CMAKE_CURRENT_SOURCE_DIR}/glslang.pre.js")
|
||||
|
||||
target_link_options(glslang.js PRIVATE
|
||||
"SHELL:--bind -s MODULARIZE=1")
|
||||
if(ENABLE_EMSCRIPTEN_ENVIRONMENT_NODE)
|
||||
target_link_options(glslang.js PRIVATE
|
||||
"SHELL:-s ENVIRONMENT=node -s BINARYEN_ASYNC_COMPILATION=0")
|
||||
else()
|
||||
target_link_options(glslang.js PRIVATE
|
||||
"SHELL:-s ENVIRONMENT=web,worker")
|
||||
endif()
|
||||
|
||||
if(NOT ENABLE_EMSCRIPTEN_ENVIRONMENT_NODE)
|
||||
add_custom_command(TARGET glslang.js POST_BUILD
|
||||
COMMAND cat ${CMAKE_CURRENT_SOURCE_DIR}/glslang.after.js >> ${CMAKE_CURRENT_BINARY_DIR}/glslang.js)
|
||||
endif()
|
||||
endif(EMSCRIPTEN)
|
26
3rdparty/glslang/glslang/OSDependent/Web/glslang.after.js
vendored
Normal file
26
3rdparty/glslang/glslang/OSDependent/Web/glslang.after.js
vendored
Normal file
@ -0,0 +1,26 @@
|
||||
export default (() => {
|
||||
const initialize = () => {
|
||||
return new Promise(resolve => {
|
||||
Module({
|
||||
locateFile() {
|
||||
const i = import.meta.url.lastIndexOf('/')
|
||||
return import.meta.url.substring(0, i) + '/glslang.wasm';
|
||||
},
|
||||
onRuntimeInitialized() {
|
||||
resolve({
|
||||
compileGLSLZeroCopy: this.compileGLSLZeroCopy,
|
||||
compileGLSL: this.compileGLSL,
|
||||
});
|
||||
},
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
let instance;
|
||||
return () => {
|
||||
if (!instance) {
|
||||
instance = initialize();
|
||||
}
|
||||
return instance;
|
||||
};
|
||||
})();
|
@ -35,17 +35,16 @@
|
||||
|
||||
#include <cstdio>
|
||||
#include <cstdint>
|
||||
#include <memory>
|
||||
|
||||
#ifdef __EMSCRIPTEN__
|
||||
#include <emscripten.h>
|
||||
#endif // __EMSCRIPTEN__
|
||||
#include <memory>
|
||||
#endif
|
||||
|
||||
#include "../SPIRV/GlslangToSpv.h"
|
||||
#include "../SPIRV/doc.h"
|
||||
#include "./../glslang/Public/ShaderLang.h"
|
||||
#include "../../../SPIRV/GlslangToSpv.h"
|
||||
#include "../../../glslang/Public/ShaderLang.h"
|
||||
|
||||
#ifndef EMSCRIPTEN_KEEPALIVE
|
||||
#ifndef __EMSCRIPTEN__
|
||||
#define EMSCRIPTEN_KEEPALIVE
|
||||
#endif
|
||||
|
1
3rdparty/glslang/glslang/Public/ShaderLang.h
vendored
1
3rdparty/glslang/glslang/Public/ShaderLang.h
vendored
@ -156,6 +156,7 @@ typedef enum {
|
||||
EShTargetSpv_1_2 = (1 << 16) | (2 << 8), // SPIR-V 1.2
|
||||
EShTargetSpv_1_3 = (1 << 16) | (3 << 8), // SPIR-V 1.3
|
||||
EShTargetSpv_1_4 = (1 << 16) | (4 << 8), // SPIR-V 1.4
|
||||
EShTargetSpv_1_5 = (1 << 16) | (5 << 8), // SPIR-V 1.5
|
||||
} EShTargetLanguageVersion;
|
||||
|
||||
struct TInputLanguage {
|
||||
|
2
3rdparty/glslang/glslang/updateGrammar
vendored
2
3rdparty/glslang/glslang/updateGrammar
vendored
@ -1,4 +1,4 @@
|
||||
#!/usr/bin/bash
|
||||
#!/bin/bash
|
||||
|
||||
if [ "$1" = 'web' ]
|
||||
then
|
||||
|
17
3rdparty/glslang/gtests/Spv.FromFile.cpp
vendored
17
3rdparty/glslang/gtests/Spv.FromFile.cpp
vendored
@ -284,6 +284,7 @@ INSTANTIATE_TEST_CASE_P(
|
||||
"spv.bufferhandle7.frag",
|
||||
"spv.bufferhandle8.frag",
|
||||
"spv.bufferhandle9.frag",
|
||||
"spv.bufferhandleUvec2.frag",
|
||||
"spv.bufferhandle_Error.frag",
|
||||
"spv.builtInXFB.vert",
|
||||
"spv.conditionalDemote.frag",
|
||||
@ -459,6 +460,22 @@ INSTANTIATE_TEST_CASE_P(
|
||||
"spv.subgroupShuffleRelative.comp",
|
||||
"spv.subgroupQuad.comp",
|
||||
"spv.subgroupVote.comp",
|
||||
"spv.subgroupExtendedTypesArithmetic.comp",
|
||||
"spv.subgroupExtendedTypesArithmeticNeg.comp",
|
||||
"spv.subgroupExtendedTypesBallot.comp",
|
||||
"spv.subgroupExtendedTypesBallotNeg.comp",
|
||||
"spv.subgroupExtendedTypesClustered.comp",
|
||||
"spv.subgroupExtendedTypesClusteredNeg.comp",
|
||||
"spv.subgroupExtendedTypesPartitioned.comp",
|
||||
"spv.subgroupExtendedTypesPartitionedNeg.comp",
|
||||
"spv.subgroupExtendedTypesShuffle.comp",
|
||||
"spv.subgroupExtendedTypesShuffleNeg.comp",
|
||||
"spv.subgroupExtendedTypesShuffleRelative.comp",
|
||||
"spv.subgroupExtendedTypesShuffleRelativeNeg.comp",
|
||||
"spv.subgroupExtendedTypesQuad.comp",
|
||||
"spv.subgroupExtendedTypesQuadNeg.comp",
|
||||
"spv.subgroupExtendedTypesVote.comp",
|
||||
"spv.subgroupExtendedTypesVoteNeg.comp",
|
||||
"spv.vulkan110.storageBuffer.vert",
|
||||
})),
|
||||
FileNameAsCustomTestSuffix
|
||||
|
5
3rdparty/glslang/hlsl/hlslGrammar.cpp
vendored
5
3rdparty/glslang/hlsl/hlslGrammar.cpp
vendored
@ -3221,6 +3221,11 @@ bool HlslGrammar::acceptConstructor(TIntermTyped*& node)
|
||||
return false;
|
||||
}
|
||||
|
||||
if (arguments == nullptr) {
|
||||
expected("one or more arguments");
|
||||
return false;
|
||||
}
|
||||
|
||||
// hook it up
|
||||
node = parseContext.handleFunctionCall(arguments->getLoc(), constructorFunction, arguments);
|
||||
|
||||
|
4
3rdparty/glslang/known_good.json
vendored
4
3rdparty/glslang/known_good.json
vendored
@ -5,14 +5,14 @@
|
||||
"site" : "github",
|
||||
"subrepo" : "KhronosGroup/SPIRV-Tools",
|
||||
"subdir" : "External/spirv-tools",
|
||||
"commit" : "9b3cc3e05337358d0bd9fec1b7a51e3cbf55312b"
|
||||
"commit" : "bbb29870b510f83f99994358179c9ea6838c3100"
|
||||
},
|
||||
{
|
||||
"name" : "spirv-tools/external/spirv-headers",
|
||||
"site" : "github",
|
||||
"subrepo" : "KhronosGroup/SPIRV-Headers",
|
||||
"subdir" : "External/spirv-tools/external/spirv-headers",
|
||||
"commit" : "38cafab379e5d16137cb97a485b9385191039b92"
|
||||
"commit" : "601d738723ac381741311c6c98c36d6170be14a2"
|
||||
}
|
||||
]
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user