vulkan: Update all components to Vulkan SDK 1.3.231.1
Updates to volk, vulkan headers, `vk_enum_string_helper.h`, glslang, spirv-reflect. No update to VMA which still has 3.0.1 as it's last tagged release.
This commit is contained in:
parent
879aac9db4
commit
0181d005c9
@ -129,6 +129,15 @@ const TBuiltInResource DefaultTBuiltInResource = {
|
|||||||
/* .maxTaskWorkGroupSizeY_NV = */ 1,
|
/* .maxTaskWorkGroupSizeY_NV = */ 1,
|
||||||
/* .maxTaskWorkGroupSizeZ_NV = */ 1,
|
/* .maxTaskWorkGroupSizeZ_NV = */ 1,
|
||||||
/* .maxMeshViewCountNV = */ 4,
|
/* .maxMeshViewCountNV = */ 4,
|
||||||
|
/* .maxMeshOutputVerticesEXT = */ 256,
|
||||||
|
/* .maxMeshOutputPrimitivesEXT = */ 256,
|
||||||
|
/* .maxMeshWorkGroupSizeX_EXT = */ 128,
|
||||||
|
/* .maxMeshWorkGroupSizeY_EXT = */ 128,
|
||||||
|
/* .maxMeshWorkGroupSizeZ_EXT = */ 128,
|
||||||
|
/* .maxTaskWorkGroupSizeX_EXT = */ 128,
|
||||||
|
/* .maxTaskWorkGroupSizeY_EXT = */ 128,
|
||||||
|
/* .maxTaskWorkGroupSizeZ_EXT = */ 128,
|
||||||
|
/* .maxMeshViewCountEXT = */ 4,
|
||||||
/* .maxDualSourceDrawBuffersEXT = */ 1,
|
/* .maxDualSourceDrawBuffersEXT = */ 1,
|
||||||
|
|
||||||
/* .limits = */ {
|
/* .limits = */ {
|
||||||
|
15
thirdparty/README.md
vendored
15
thirdparty/README.md
vendored
@ -176,7 +176,7 @@ commits.
|
|||||||
## glslang
|
## glslang
|
||||||
|
|
||||||
- Upstream: https://github.com/KhronosGroup/glslang
|
- Upstream: https://github.com/KhronosGroup/glslang
|
||||||
- Version: 11.8.0 (c34bb3b6c55f6ab084124ad964be95a699700d34, 2022)
|
- Version: 11.12.0 / sdk-1.3.231.1 (5755de46b07e4374c05fb1081f65f7ae1f8cca81, 2022)
|
||||||
- License: glslang
|
- License: glslang
|
||||||
|
|
||||||
Version should be kept in sync with the one of the used Vulkan SDK (see `vulkan`
|
Version should be kept in sync with the one of the used Vulkan SDK (see `vulkan`
|
||||||
@ -195,7 +195,6 @@ Files extracted from upstream source:
|
|||||||
to `glslang/build_info.h`
|
to `glslang/build_info.h`
|
||||||
- `LICENSE.txt`
|
- `LICENSE.txt`
|
||||||
- Unnecessary files like `CMakeLists.txt`, `*.m4` and `updateGrammar` removed.
|
- Unnecessary files like `CMakeLists.txt`, `*.m4` and `updateGrammar` removed.
|
||||||
- Patch in `patches/unused_cleanup.diff` must be applied.
|
|
||||||
|
|
||||||
|
|
||||||
## graphite
|
## graphite
|
||||||
@ -606,11 +605,10 @@ Godot. See the patch in the `patches` folder for details.
|
|||||||
## spirv-reflect
|
## spirv-reflect
|
||||||
|
|
||||||
- Upstream: https://github.com/KhronosGroup/SPIRV-Reflect
|
- Upstream: https://github.com/KhronosGroup/SPIRV-Reflect
|
||||||
- Version: git (1ef99b09fa7ce5aee2c5cf70c61a4f7458d27e09, 2022)
|
- Version: sdk-1.3.231.1 (b68b5a8a5d8ab5fce79e6596f3a731291046393a, 2022)
|
||||||
- License: Apache 2.0
|
- License: Apache 2.0
|
||||||
|
|
||||||
Does not track Vulkan SDK releases closely, but try to package a commit newer
|
Now tracks Vulkan SDK releases, so keep it in sync with volk / vulkan.
|
||||||
than the matching glslang and Vulkan headers, just in case.
|
|
||||||
|
|
||||||
Files extracted from upstream source:
|
Files extracted from upstream source:
|
||||||
|
|
||||||
@ -620,7 +618,7 @@ Files extracted from upstream source:
|
|||||||
|
|
||||||
Some downstream changes have been made and are identified by
|
Some downstream changes have been made and are identified by
|
||||||
`// -- GODOT begin --` and `// -- GODOT end --` comments.
|
`// -- GODOT begin --` and `// -- GODOT end --` comments.
|
||||||
They can be reapplied using the patch included in the `patches`
|
They can be reapplied using the patches included in the `patches`
|
||||||
folder.
|
folder.
|
||||||
|
|
||||||
|
|
||||||
@ -685,7 +683,7 @@ folder.
|
|||||||
## volk
|
## volk
|
||||||
|
|
||||||
- Upstream: https://github.com/zeux/volk
|
- Upstream: https://github.com/zeux/volk
|
||||||
- Version: 1.3.204 (92ba7c9f112a82cecf452ebf4b7c46f149a5799e, 2022)
|
- Version: sdk-1.3.231.1 (f29df7d2834c434b39169d5b2e4dde8c05a5adc1, 2022)
|
||||||
- License: MIT
|
- License: MIT
|
||||||
|
|
||||||
Unless there is a specific reason to package a more recent version, please stick
|
Unless there is a specific reason to package a more recent version, please stick
|
||||||
@ -695,7 +693,6 @@ to tagged releases. All Vulkan libraries and headers should be kept in sync so:
|
|||||||
- Update glslang (see "glslang").
|
- Update glslang (see "glslang").
|
||||||
- Update spirv-reflect (see "spirv-reflect").
|
- Update spirv-reflect (see "spirv-reflect").
|
||||||
|
|
||||||
|
|
||||||
Files extracted from upstream source:
|
Files extracted from upstream source:
|
||||||
|
|
||||||
- `volk.h`, `volk.c`
|
- `volk.h`, `volk.c`
|
||||||
@ -705,7 +702,7 @@ Files extracted from upstream source:
|
|||||||
## vulkan
|
## vulkan
|
||||||
|
|
||||||
- Upstream: https://github.com/KhronosGroup/Vulkan-Headers
|
- Upstream: https://github.com/KhronosGroup/Vulkan-Headers
|
||||||
- Version: 1.3.204 (1dace16d8044758d32736eb59802d171970e9448, 2022)
|
- Version: sdk-1.3.231.1 (98f440ce6868c94f5ec6e198cc1adda4760e8849, 2022)
|
||||||
- License: Apache 2.0
|
- License: Apache 2.0
|
||||||
|
|
||||||
The vendored version should be kept in sync with volk, see above.
|
The vendored version should be kept in sync with volk, see above.
|
||||||
|
1
thirdparty/glslang/SPIRV/GLSL.ext.EXT.h
vendored
1
thirdparty/glslang/SPIRV/GLSL.ext.EXT.h
vendored
@ -39,5 +39,6 @@ static const char* const E_SPV_EXT_shader_atomic_float_add = "SPV_EXT_shader_ato
|
|||||||
static const char* const E_SPV_EXT_shader_atomic_float16_add = "SPV_EXT_shader_atomic_float16_add";
|
static const char* const E_SPV_EXT_shader_atomic_float16_add = "SPV_EXT_shader_atomic_float16_add";
|
||||||
static const char* const E_SPV_EXT_shader_atomic_float_min_max = "SPV_EXT_shader_atomic_float_min_max";
|
static const char* const E_SPV_EXT_shader_atomic_float_min_max = "SPV_EXT_shader_atomic_float_min_max";
|
||||||
static const char* const E_SPV_EXT_shader_image_int64 = "SPV_EXT_shader_image_int64";
|
static const char* const E_SPV_EXT_shader_image_int64 = "SPV_EXT_shader_image_int64";
|
||||||
|
static const char* const E_SPV_EXT_mesh_shader = "SPV_EXT_mesh_shader";
|
||||||
|
|
||||||
#endif // #ifndef GLSLextEXT_H
|
#endif // #ifndef GLSLextEXT_H
|
||||||
|
4
thirdparty/glslang/SPIRV/GLSL.ext.KHR.h
vendored
4
thirdparty/glslang/SPIRV/GLSL.ext.KHR.h
vendored
@ -29,7 +29,7 @@
|
|||||||
#define GLSLextKHR_H
|
#define GLSLextKHR_H
|
||||||
|
|
||||||
static const int GLSLextKHRVersion = 100;
|
static const int GLSLextKHRVersion = 100;
|
||||||
static const int GLSLextKHRRevision = 2;
|
static const int GLSLextKHRRevision = 3;
|
||||||
|
|
||||||
static const char* const E_SPV_KHR_shader_ballot = "SPV_KHR_shader_ballot";
|
static const char* const E_SPV_KHR_shader_ballot = "SPV_KHR_shader_ballot";
|
||||||
static const char* const E_SPV_KHR_subgroup_vote = "SPV_KHR_subgroup_vote";
|
static const char* const E_SPV_KHR_subgroup_vote = "SPV_KHR_subgroup_vote";
|
||||||
@ -52,5 +52,7 @@ static const char* const E_SPV_KHR_fragment_shading_rate = "SPV_KHR_fragm
|
|||||||
static const char* const E_SPV_KHR_terminate_invocation = "SPV_KHR_terminate_invocation";
|
static const char* const E_SPV_KHR_terminate_invocation = "SPV_KHR_terminate_invocation";
|
||||||
static const char* const E_SPV_KHR_workgroup_memory_explicit_layout = "SPV_KHR_workgroup_memory_explicit_layout";
|
static const char* const E_SPV_KHR_workgroup_memory_explicit_layout = "SPV_KHR_workgroup_memory_explicit_layout";
|
||||||
static const char* const E_SPV_KHR_subgroup_uniform_control_flow = "SPV_KHR_subgroup_uniform_control_flow";
|
static const char* const E_SPV_KHR_subgroup_uniform_control_flow = "SPV_KHR_subgroup_uniform_control_flow";
|
||||||
|
static const char* const E_SPV_KHR_fragment_shader_barycentric = "SPV_KHR_fragment_shader_barycentric";
|
||||||
|
static const char* const E_SPV_AMD_shader_early_and_late_fragment_tests = "SPV_AMD_shader_early_and_late_fragment_tests";
|
||||||
|
|
||||||
#endif // #ifndef GLSLextKHR_H
|
#endif // #ifndef GLSLextKHR_H
|
||||||
|
356
thirdparty/glslang/SPIRV/GlslangToSpv.cpp
vendored
356
thirdparty/glslang/SPIRV/GlslangToSpv.cpp
vendored
@ -260,6 +260,7 @@ protected:
|
|||||||
std::unordered_map<std::string, spv::Id> extBuiltinMap;
|
std::unordered_map<std::string, spv::Id> extBuiltinMap;
|
||||||
|
|
||||||
std::unordered_map<long long, spv::Id> symbolValues;
|
std::unordered_map<long long, spv::Id> symbolValues;
|
||||||
|
std::unordered_map<uint32_t, spv::Id> builtInVariableIds;
|
||||||
std::unordered_set<long long> rValueParameters; // set of formal function parameters passed as rValues,
|
std::unordered_set<long long> rValueParameters; // set of formal function parameters passed as rValues,
|
||||||
// rather than a pointer
|
// rather than a pointer
|
||||||
std::unordered_map<std::string, spv::Function*> functionMap;
|
std::unordered_map<std::string, spv::Function*> functionMap;
|
||||||
@ -279,6 +280,9 @@ protected:
|
|||||||
|
|
||||||
// Used later for generating OpTraceKHR/OpExecuteCallableKHR
|
// Used later for generating OpTraceKHR/OpExecuteCallableKHR
|
||||||
std::unordered_map<unsigned int, glslang::TIntermSymbol *> locationToSymbol[2];
|
std::unordered_map<unsigned int, glslang::TIntermSymbol *> locationToSymbol[2];
|
||||||
|
|
||||||
|
// Used by Task shader while generating opearnds for OpEmitMeshTasksEXT
|
||||||
|
spv::Id taskPayloadID;
|
||||||
};
|
};
|
||||||
|
|
||||||
//
|
//
|
||||||
@ -314,7 +318,7 @@ spv::SourceLanguage TranslateSourceLanguage(glslang::EShSource source, EProfile
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Translate glslang language (stage) to SPIR-V execution model.
|
// Translate glslang language (stage) to SPIR-V execution model.
|
||||||
spv::ExecutionModel TranslateExecutionModel(EShLanguage stage)
|
spv::ExecutionModel TranslateExecutionModel(EShLanguage stage, bool isMeshShaderEXT = false)
|
||||||
{
|
{
|
||||||
switch (stage) {
|
switch (stage) {
|
||||||
case EShLangVertex: return spv::ExecutionModelVertex;
|
case EShLangVertex: return spv::ExecutionModelVertex;
|
||||||
@ -330,8 +334,8 @@ spv::ExecutionModel TranslateExecutionModel(EShLanguage stage)
|
|||||||
case EShLangClosestHit: return spv::ExecutionModelClosestHitKHR;
|
case EShLangClosestHit: return spv::ExecutionModelClosestHitKHR;
|
||||||
case EShLangMiss: return spv::ExecutionModelMissKHR;
|
case EShLangMiss: return spv::ExecutionModelMissKHR;
|
||||||
case EShLangCallable: return spv::ExecutionModelCallableKHR;
|
case EShLangCallable: return spv::ExecutionModelCallableKHR;
|
||||||
case EShLangTaskNV: return spv::ExecutionModelTaskNV;
|
case EShLangTask: return (isMeshShaderEXT)? spv::ExecutionModelTaskEXT : spv::ExecutionModelTaskNV;
|
||||||
case EShLangMeshNV: return spv::ExecutionModelMeshNV;
|
case EShLangMesh: return (isMeshShaderEXT)? spv::ExecutionModelMeshEXT: spv::ExecutionModelMeshNV;
|
||||||
#endif
|
#endif
|
||||||
default:
|
default:
|
||||||
assert(0);
|
assert(0);
|
||||||
@ -762,7 +766,7 @@ spv::BuiltIn TGlslangToSpvTraverser::TranslateBuiltInDecoration(glslang::TBuiltI
|
|||||||
return spv::BuiltInSampleMask;
|
return spv::BuiltInSampleMask;
|
||||||
|
|
||||||
case glslang::EbvLayer:
|
case glslang::EbvLayer:
|
||||||
if (glslangIntermediate->getStage() == EShLangMeshNV) {
|
if (glslangIntermediate->getStage() == EShLangMesh) {
|
||||||
return spv::BuiltInLayer;
|
return spv::BuiltInLayer;
|
||||||
}
|
}
|
||||||
if (glslangIntermediate->getStage() == EShLangGeometry ||
|
if (glslangIntermediate->getStage() == EShLangGeometry ||
|
||||||
@ -1007,6 +1011,8 @@ spv::BuiltIn TGlslangToSpvTraverser::TranslateBuiltInDecoration(glslang::TBuiltI
|
|||||||
return spv::BuiltInRayTminKHR;
|
return spv::BuiltInRayTminKHR;
|
||||||
case glslang::EbvRayTmax:
|
case glslang::EbvRayTmax:
|
||||||
return spv::BuiltInRayTmaxKHR;
|
return spv::BuiltInRayTmaxKHR;
|
||||||
|
case glslang::EbvCullMask:
|
||||||
|
return spv::BuiltInCullMaskKHR;
|
||||||
case glslang::EbvInstanceCustomIndex:
|
case glslang::EbvInstanceCustomIndex:
|
||||||
return spv::BuiltInInstanceCustomIndexKHR;
|
return spv::BuiltInInstanceCustomIndexKHR;
|
||||||
case glslang::EbvHitT:
|
case glslang::EbvHitT:
|
||||||
@ -1048,6 +1054,15 @@ spv::BuiltIn TGlslangToSpvTraverser::TranslateBuiltInDecoration(glslang::TBuiltI
|
|||||||
builder.addCapability(spv::CapabilityFragmentBarycentricNV);
|
builder.addCapability(spv::CapabilityFragmentBarycentricNV);
|
||||||
return spv::BuiltInBaryCoordNoPerspNV;
|
return spv::BuiltInBaryCoordNoPerspNV;
|
||||||
|
|
||||||
|
case glslang::EbvBaryCoordEXT:
|
||||||
|
builder.addExtension(spv::E_SPV_KHR_fragment_shader_barycentric);
|
||||||
|
builder.addCapability(spv::CapabilityFragmentBarycentricKHR);
|
||||||
|
return spv::BuiltInBaryCoordKHR;
|
||||||
|
case glslang::EbvBaryCoordNoPerspEXT:
|
||||||
|
builder.addExtension(spv::E_SPV_KHR_fragment_shader_barycentric);
|
||||||
|
builder.addCapability(spv::CapabilityFragmentBarycentricKHR);
|
||||||
|
return spv::BuiltInBaryCoordNoPerspKHR;
|
||||||
|
|
||||||
// mesh shaders
|
// mesh shaders
|
||||||
case glslang::EbvTaskCountNV:
|
case glslang::EbvTaskCountNV:
|
||||||
return spv::BuiltInTaskCountNV;
|
return spv::BuiltInTaskCountNV;
|
||||||
@ -1066,6 +1081,16 @@ spv::BuiltIn TGlslangToSpvTraverser::TranslateBuiltInDecoration(glslang::TBuiltI
|
|||||||
case glslang::EbvMeshViewIndicesNV:
|
case glslang::EbvMeshViewIndicesNV:
|
||||||
return spv::BuiltInMeshViewIndicesNV;
|
return spv::BuiltInMeshViewIndicesNV;
|
||||||
|
|
||||||
|
// SPV_EXT_mesh_shader
|
||||||
|
case glslang::EbvPrimitivePointIndicesEXT:
|
||||||
|
return spv::BuiltInPrimitivePointIndicesEXT;
|
||||||
|
case glslang::EbvPrimitiveLineIndicesEXT:
|
||||||
|
return spv::BuiltInPrimitiveLineIndicesEXT;
|
||||||
|
case glslang::EbvPrimitiveTriangleIndicesEXT:
|
||||||
|
return spv::BuiltInPrimitiveTriangleIndicesEXT;
|
||||||
|
case glslang::EbvCullPrimitiveEXT:
|
||||||
|
return spv::BuiltInCullPrimitiveEXT;
|
||||||
|
|
||||||
// sm builtins
|
// sm builtins
|
||||||
case glslang::EbvWarpsPerSM:
|
case glslang::EbvWarpsPerSM:
|
||||||
builder.addExtension(spv::E_SPV_NV_shader_sm_builtins);
|
builder.addExtension(spv::E_SPV_NV_shader_sm_builtins);
|
||||||
@ -1309,6 +1334,7 @@ spv::StorageClass TGlslangToSpvTraverser::TranslateStorageClass(const glslang::T
|
|||||||
case glslang::EvqHitAttr: return spv::StorageClassHitAttributeKHR;
|
case glslang::EvqHitAttr: return spv::StorageClassHitAttributeKHR;
|
||||||
case glslang::EvqCallableData: return spv::StorageClassCallableDataKHR;
|
case glslang::EvqCallableData: return spv::StorageClassCallableDataKHR;
|
||||||
case glslang::EvqCallableDataIn: return spv::StorageClassIncomingCallableDataKHR;
|
case glslang::EvqCallableDataIn: return spv::StorageClassIncomingCallableDataKHR;
|
||||||
|
case glslang::EvqtaskPayloadSharedEXT : return spv::StorageClassTaskPayloadWorkgroupEXT;
|
||||||
case glslang::EvqSpirvStorageClass: return static_cast<spv::StorageClass>(type.getQualifier().spirvStorageClass);
|
case glslang::EvqSpirvStorageClass: return static_cast<spv::StorageClass>(type.getQualifier().spirvStorageClass);
|
||||||
#endif
|
#endif
|
||||||
default:
|
default:
|
||||||
@ -1326,7 +1352,9 @@ void TGlslangToSpvTraverser::TranslateLiterals(const glslang::TVector<const glsl
|
|||||||
for (auto constant : constants) {
|
for (auto constant : constants) {
|
||||||
if (constant->getBasicType() == glslang::EbtFloat) {
|
if (constant->getBasicType() == glslang::EbtFloat) {
|
||||||
float floatValue = static_cast<float>(constant->getConstArray()[0].getDConst());
|
float floatValue = static_cast<float>(constant->getConstArray()[0].getDConst());
|
||||||
unsigned literal = *reinterpret_cast<unsigned*>(&floatValue);
|
unsigned literal;
|
||||||
|
static_assert(sizeof(literal) == sizeof(floatValue), "sizeof(unsigned) != sizeof(float)");
|
||||||
|
memcpy(&literal, &floatValue, sizeof(literal));
|
||||||
literals.push_back(literal);
|
literals.push_back(literal);
|
||||||
} else if (constant->getBasicType() == glslang::EbtInt) {
|
} else if (constant->getBasicType() == glslang::EbtInt) {
|
||||||
unsigned literal = constant->getConstArray()[0].getIConst();
|
unsigned literal = constant->getConstArray()[0].getIConst();
|
||||||
@ -1452,6 +1480,8 @@ void InheritQualifiers(glslang::TQualifier& child, const glslang::TQualifier& pa
|
|||||||
child.perViewNV = true;
|
child.perViewNV = true;
|
||||||
if (parent.perTaskNV)
|
if (parent.perTaskNV)
|
||||||
child.perTaskNV = true;
|
child.perTaskNV = true;
|
||||||
|
if (parent.storage == glslang::EvqtaskPayloadSharedEXT)
|
||||||
|
child.storage = glslang::EvqtaskPayloadSharedEXT;
|
||||||
if (parent.patch)
|
if (parent.patch)
|
||||||
child.patch = true;
|
child.patch = true;
|
||||||
if (parent.sample)
|
if (parent.sample)
|
||||||
@ -1511,9 +1541,12 @@ TGlslangToSpvTraverser::TGlslangToSpvTraverser(unsigned int spvVersion,
|
|||||||
inEntryPoint(false), entryPointTerminated(false), linkageOnly(false),
|
inEntryPoint(false), entryPointTerminated(false), linkageOnly(false),
|
||||||
glslangIntermediate(glslangIntermediate),
|
glslangIntermediate(glslangIntermediate),
|
||||||
nanMinMaxClamp(glslangIntermediate->getNanMinMaxClamp()),
|
nanMinMaxClamp(glslangIntermediate->getNanMinMaxClamp()),
|
||||||
nonSemanticDebugPrintf(0)
|
nonSemanticDebugPrintf(0),
|
||||||
|
taskPayloadID(0)
|
||||||
{
|
{
|
||||||
spv::ExecutionModel executionModel = TranslateExecutionModel(glslangIntermediate->getStage());
|
bool isMeshShaderExt = (glslangIntermediate->getRequestedExtensions().find(glslang::E_GL_EXT_mesh_shader) !=
|
||||||
|
glslangIntermediate->getRequestedExtensions().end());
|
||||||
|
spv::ExecutionModel executionModel = TranslateExecutionModel(glslangIntermediate->getStage(), isMeshShaderExt);
|
||||||
|
|
||||||
builder.clearAccessChain();
|
builder.clearAccessChain();
|
||||||
builder.setSource(TranslateSourceLanguage(glslangIntermediate->getSource(), glslangIntermediate->getProfile()),
|
builder.setSource(TranslateSourceLanguage(glslangIntermediate->getSource(), glslangIntermediate->getProfile()),
|
||||||
@ -1545,6 +1578,10 @@ TGlslangToSpvTraverser::TGlslangToSpvTraverser(unsigned int spvVersion,
|
|||||||
for (auto iItr = include_txt.begin(); iItr != include_txt.end(); ++iItr)
|
for (auto iItr = include_txt.begin(); iItr != include_txt.end(); ++iItr)
|
||||||
builder.addInclude(iItr->first, iItr->second);
|
builder.addInclude(iItr->first, iItr->second);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
builder.setEmitNonSemanticShaderDebugInfo(options.emitNonSemanticShaderDebugInfo);
|
||||||
|
builder.setEmitNonSemanticShaderDebugSource(options.emitNonSemanticShaderDebugSource);
|
||||||
|
|
||||||
stdBuiltins = builder.import("GLSL.std.450");
|
stdBuiltins = builder.import("GLSL.std.450");
|
||||||
|
|
||||||
spv::AddressingModel addressingModel = spv::AddressingModelLogical;
|
spv::AddressingModel addressingModel = spv::AddressingModelLogical;
|
||||||
@ -1611,6 +1648,12 @@ TGlslangToSpvTraverser::TGlslangToSpvTraverser(unsigned int spvVersion,
|
|||||||
if (glslangIntermediate->getEarlyFragmentTests())
|
if (glslangIntermediate->getEarlyFragmentTests())
|
||||||
builder.addExecutionMode(shaderEntry, spv::ExecutionModeEarlyFragmentTests);
|
builder.addExecutionMode(shaderEntry, spv::ExecutionModeEarlyFragmentTests);
|
||||||
|
|
||||||
|
if (glslangIntermediate->getEarlyAndLateFragmentTestsAMD())
|
||||||
|
{
|
||||||
|
builder.addExecutionMode(shaderEntry, spv::ExecutionModeEarlyAndLateFragmentTestsAMD);
|
||||||
|
builder.addExtension(spv::E_SPV_AMD_shader_early_and_late_fragment_tests);
|
||||||
|
}
|
||||||
|
|
||||||
if (glslangIntermediate->getPostDepthCoverage()) {
|
if (glslangIntermediate->getPostDepthCoverage()) {
|
||||||
builder.addCapability(spv::CapabilitySampleMaskPostDepthCoverage);
|
builder.addCapability(spv::CapabilitySampleMaskPostDepthCoverage);
|
||||||
builder.addExecutionMode(shaderEntry, spv::ExecutionModePostDepthCoverage);
|
builder.addExecutionMode(shaderEntry, spv::ExecutionModePostDepthCoverage);
|
||||||
@ -1620,6 +1663,9 @@ TGlslangToSpvTraverser::TGlslangToSpvTraverser(unsigned int spvVersion,
|
|||||||
if (glslangIntermediate->isDepthReplacing())
|
if (glslangIntermediate->isDepthReplacing())
|
||||||
builder.addExecutionMode(shaderEntry, spv::ExecutionModeDepthReplacing);
|
builder.addExecutionMode(shaderEntry, spv::ExecutionModeDepthReplacing);
|
||||||
|
|
||||||
|
if (glslangIntermediate->isStencilReplacing())
|
||||||
|
builder.addExecutionMode(shaderEntry, spv::ExecutionModeStencilRefReplacingEXT);
|
||||||
|
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
|
|
||||||
switch(glslangIntermediate->getDepth()) {
|
switch(glslangIntermediate->getDepth()) {
|
||||||
@ -1628,6 +1674,20 @@ TGlslangToSpvTraverser::TGlslangToSpvTraverser(unsigned int spvVersion,
|
|||||||
case glslang::EldUnchanged: mode = spv::ExecutionModeDepthUnchanged; break;
|
case glslang::EldUnchanged: mode = spv::ExecutionModeDepthUnchanged; break;
|
||||||
default: mode = spv::ExecutionModeMax; break;
|
default: mode = spv::ExecutionModeMax; break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (mode != spv::ExecutionModeMax)
|
||||||
|
builder.addExecutionMode(shaderEntry, (spv::ExecutionMode)mode);
|
||||||
|
|
||||||
|
switch (glslangIntermediate->getStencil()) {
|
||||||
|
case glslang::ElsRefUnchangedFrontAMD: mode = spv::ExecutionModeStencilRefUnchangedFrontAMD; break;
|
||||||
|
case glslang::ElsRefGreaterFrontAMD: mode = spv::ExecutionModeStencilRefGreaterFrontAMD; break;
|
||||||
|
case glslang::ElsRefLessFrontAMD: mode = spv::ExecutionModeStencilRefLessFrontAMD; break;
|
||||||
|
case glslang::ElsRefUnchangedBackAMD: mode = spv::ExecutionModeStencilRefUnchangedBackAMD; break;
|
||||||
|
case glslang::ElsRefGreaterBackAMD: mode = spv::ExecutionModeStencilRefGreaterBackAMD; break;
|
||||||
|
case glslang::ElsRefLessBackAMD: mode = spv::ExecutionModeStencilRefLessBackAMD; break;
|
||||||
|
default: mode = spv::ExecutionModeMax; break;
|
||||||
|
}
|
||||||
|
|
||||||
if (mode != spv::ExecutionModeMax)
|
if (mode != spv::ExecutionModeMax)
|
||||||
builder.addExecutionMode(shaderEntry, (spv::ExecutionMode)mode);
|
builder.addExecutionMode(shaderEntry, (spv::ExecutionMode)mode);
|
||||||
switch (glslangIntermediate->getInterlockOrdering()) {
|
switch (glslangIntermediate->getInterlockOrdering()) {
|
||||||
@ -1766,7 +1826,7 @@ TGlslangToSpvTraverser::TGlslangToSpvTraverser(unsigned int spvVersion,
|
|||||||
case EShLangAnyHit:
|
case EShLangAnyHit:
|
||||||
case EShLangClosestHit:
|
case EShLangClosestHit:
|
||||||
case EShLangMiss:
|
case EShLangMiss:
|
||||||
case EShLangCallable:
|
case EShLangCallable:
|
||||||
{
|
{
|
||||||
auto& extensions = glslangIntermediate->getRequestedExtensions();
|
auto& extensions = glslangIntermediate->getRequestedExtensions();
|
||||||
if (extensions.find("GL_NV_ray_tracing") == extensions.end()) {
|
if (extensions.find("GL_NV_ray_tracing") == extensions.end()) {
|
||||||
@ -1777,12 +1837,24 @@ TGlslangToSpvTraverser::TGlslangToSpvTraverser(unsigned int spvVersion,
|
|||||||
builder.addCapability(spv::CapabilityRayTracingNV);
|
builder.addCapability(spv::CapabilityRayTracingNV);
|
||||||
builder.addExtension("SPV_NV_ray_tracing");
|
builder.addExtension("SPV_NV_ray_tracing");
|
||||||
}
|
}
|
||||||
|
if (glslangIntermediate->getStage() != EShLangRayGen && glslangIntermediate->getStage() != EShLangCallable)
|
||||||
|
{
|
||||||
|
if (extensions.find("GL_EXT_ray_cull_mask") != extensions.end()) {
|
||||||
|
builder.addCapability(spv::CapabilityRayCullMaskKHR);
|
||||||
|
builder.addExtension("SPV_KHR_ray_cull_mask");
|
||||||
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case EShLangTaskNV:
|
case EShLangTask:
|
||||||
case EShLangMeshNV:
|
case EShLangMesh:
|
||||||
builder.addCapability(spv::CapabilityMeshShadingNV);
|
if(isMeshShaderExt) {
|
||||||
builder.addExtension(spv::E_SPV_NV_mesh_shader);
|
builder.addCapability(spv::CapabilityMeshShadingEXT);
|
||||||
|
builder.addExtension(spv::E_SPV_EXT_mesh_shader);
|
||||||
|
} else {
|
||||||
|
builder.addCapability(spv::CapabilityMeshShadingNV);
|
||||||
|
builder.addExtension(spv::E_SPV_NV_mesh_shader);
|
||||||
|
}
|
||||||
if (glslangIntermediate->getSpv().spv >= glslang::EShTargetSpv_1_6) {
|
if (glslangIntermediate->getSpv().spv >= glslang::EShTargetSpv_1_6) {
|
||||||
std::vector<spv::Id> dimConstId;
|
std::vector<spv::Id> dimConstId;
|
||||||
for (int dim = 0; dim < 3; ++dim) {
|
for (int dim = 0; dim < 3; ++dim) {
|
||||||
@ -1799,7 +1871,7 @@ TGlslangToSpvTraverser::TGlslangToSpvTraverser(unsigned int spvVersion,
|
|||||||
glslangIntermediate->getLocalSize(1),
|
glslangIntermediate->getLocalSize(1),
|
||||||
glslangIntermediate->getLocalSize(2));
|
glslangIntermediate->getLocalSize(2));
|
||||||
}
|
}
|
||||||
if (glslangIntermediate->getStage() == EShLangMeshNV) {
|
if (glslangIntermediate->getStage() == EShLangMesh) {
|
||||||
builder.addExecutionMode(shaderEntry, spv::ExecutionModeOutputVertices,
|
builder.addExecutionMode(shaderEntry, spv::ExecutionModeOutputVertices,
|
||||||
glslangIntermediate->getVertices());
|
glslangIntermediate->getVertices());
|
||||||
builder.addExecutionMode(shaderEntry, spv::ExecutionModeOutputPrimitivesNV,
|
builder.addExecutionMode(shaderEntry, spv::ExecutionModeOutputPrimitivesNV,
|
||||||
@ -1918,7 +1990,6 @@ void TGlslangToSpvTraverser::visitSymbol(glslang::TIntermSymbol* symbol)
|
|||||||
|
|
||||||
if (symbol->getType().getQualifier().isSpecConstant())
|
if (symbol->getType().getQualifier().isSpecConstant())
|
||||||
spec_constant_op_mode_setter.turnOnSpecConstantOpMode();
|
spec_constant_op_mode_setter.turnOnSpecConstantOpMode();
|
||||||
|
|
||||||
#ifdef ENABLE_HLSL
|
#ifdef ENABLE_HLSL
|
||||||
// Skip symbol handling if it is string-typed
|
// Skip symbol handling if it is string-typed
|
||||||
if (symbol->getBasicType() == glslang::EbtString)
|
if (symbol->getBasicType() == glslang::EbtString)
|
||||||
@ -1929,6 +2000,9 @@ void TGlslangToSpvTraverser::visitSymbol(glslang::TIntermSymbol* symbol)
|
|||||||
// Formal function parameters were mapped during makeFunctions().
|
// Formal function parameters were mapped during makeFunctions().
|
||||||
spv::Id id = getSymbolId(symbol);
|
spv::Id id = getSymbolId(symbol);
|
||||||
|
|
||||||
|
if (symbol->getType().getQualifier().isTaskPayload())
|
||||||
|
taskPayloadID = id; // cache the taskPayloadID to be used it as operand for OpEmitMeshTasksEXT
|
||||||
|
|
||||||
if (builder.isPointer(id)) {
|
if (builder.isPointer(id)) {
|
||||||
if (!symbol->getType().getQualifier().isParamInput() &&
|
if (!symbol->getType().getQualifier().isParamInput() &&
|
||||||
!symbol->getType().getQualifier().isParamOutput()) {
|
!symbol->getType().getQualifier().isParamOutput()) {
|
||||||
@ -2456,6 +2530,14 @@ bool TGlslangToSpvTraverser::visitUnary(glslang::TVisit /* visit */, glslang::TI
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Force variable declaration - Debug Mode Only
|
||||||
|
if (node->getOp() == glslang::EOpDeclare) {
|
||||||
|
builder.clearAccessChain();
|
||||||
|
node->getOperand()->traverse(this);
|
||||||
|
builder.clearAccessChain();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// Start by evaluating the operand
|
// Start by evaluating the operand
|
||||||
|
|
||||||
// Does it need a swizzle inversion? If so, evaluation is inverted;
|
// Does it need a swizzle inversion? If so, evaluation is inverted;
|
||||||
@ -2472,7 +2554,7 @@ bool TGlslangToSpvTraverser::visitUnary(glslang::TVisit /* visit */, glslang::TI
|
|||||||
operandNode = node->getOperand()->getAsBinaryNode()->getLeft();
|
operandNode = node->getOperand()->getAsBinaryNode()->getLeft();
|
||||||
else
|
else
|
||||||
operandNode = node->getOperand();
|
operandNode = node->getOperand();
|
||||||
|
|
||||||
operandNode->traverse(this);
|
operandNode->traverse(this);
|
||||||
|
|
||||||
spv::Id operand = spv::NoResult;
|
spv::Id operand = spv::NoResult;
|
||||||
@ -2716,32 +2798,38 @@ bool TGlslangToSpvTraverser::visitAggregate(glslang::TVisit visit, glslang::TInt
|
|||||||
spv::Decoration precision = TranslatePrecisionDecoration(node->getOperationPrecision());
|
spv::Decoration precision = TranslatePrecisionDecoration(node->getOperationPrecision());
|
||||||
|
|
||||||
switch (node->getOp()) {
|
switch (node->getOp()) {
|
||||||
|
case glslang::EOpScope:
|
||||||
case glslang::EOpSequence:
|
case glslang::EOpSequence:
|
||||||
{
|
{
|
||||||
if (preVisit)
|
if (visit == glslang::EvPreVisit) {
|
||||||
++sequenceDepth;
|
++sequenceDepth;
|
||||||
else
|
if (sequenceDepth == 1) {
|
||||||
|
// If this is the parent node of all the functions, we want to see them
|
||||||
|
// early, so all call points have actual SPIR-V functions to reference.
|
||||||
|
// In all cases, still let the traverser visit the children for us.
|
||||||
|
makeFunctions(node->getAsAggregate()->getSequence());
|
||||||
|
|
||||||
|
// Also, we want all globals initializers to go into the beginning of the entry point, before
|
||||||
|
// anything else gets there, so visit out of order, doing them all now.
|
||||||
|
makeGlobalInitializers(node->getAsAggregate()->getSequence());
|
||||||
|
|
||||||
|
//Pre process linker objects for ray tracing stages
|
||||||
|
if (glslangIntermediate->isRayTracingStage())
|
||||||
|
collectRayTracingLinkerObjects();
|
||||||
|
|
||||||
|
// Initializers are done, don't want to visit again, but functions and link objects need to be processed,
|
||||||
|
// so do them manually.
|
||||||
|
visitFunctions(node->getAsAggregate()->getSequence());
|
||||||
|
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
if (node->getOp() == glslang::EOpScope)
|
||||||
|
builder.enterScope(0);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (sequenceDepth > 1 && node->getOp() == glslang::EOpScope)
|
||||||
|
builder.leaveScope();
|
||||||
--sequenceDepth;
|
--sequenceDepth;
|
||||||
|
|
||||||
if (sequenceDepth == 1) {
|
|
||||||
// If this is the parent node of all the functions, we want to see them
|
|
||||||
// early, so all call points have actual SPIR-V functions to reference.
|
|
||||||
// In all cases, still let the traverser visit the children for us.
|
|
||||||
makeFunctions(node->getAsAggregate()->getSequence());
|
|
||||||
|
|
||||||
// Also, we want all globals initializers to go into the beginning of the entry point, before
|
|
||||||
// anything else gets there, so visit out of order, doing them all now.
|
|
||||||
makeGlobalInitializers(node->getAsAggregate()->getSequence());
|
|
||||||
|
|
||||||
//Pre process linker objects for ray tracing stages
|
|
||||||
if (glslangIntermediate->isRayTracingStage())
|
|
||||||
collectRayTracingLinkerObjects();
|
|
||||||
|
|
||||||
// Initializers are done, don't want to visit again, but functions and link objects need to be processed,
|
|
||||||
// so do them manually.
|
|
||||||
visitFunctions(node->getAsAggregate()->getSequence());
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@ -2770,10 +2858,17 @@ bool TGlslangToSpvTraverser::visitAggregate(glslang::TVisit visit, glslang::TInt
|
|||||||
if (isShaderEntryPoint(node)) {
|
if (isShaderEntryPoint(node)) {
|
||||||
inEntryPoint = true;
|
inEntryPoint = true;
|
||||||
builder.setBuildPoint(shaderEntry->getLastBlock());
|
builder.setBuildPoint(shaderEntry->getLastBlock());
|
||||||
|
builder.enterFunction(shaderEntry);
|
||||||
currentFunction = shaderEntry;
|
currentFunction = shaderEntry;
|
||||||
} else {
|
} else {
|
||||||
handleFunctionEntry(node);
|
handleFunctionEntry(node);
|
||||||
}
|
}
|
||||||
|
if (options.generateDebugInfo) {
|
||||||
|
const auto& loc = node->getLoc();
|
||||||
|
const char* sourceFileName = loc.getFilename();
|
||||||
|
spv::Id sourceFileId = sourceFileName ? builder.getStringId(sourceFileName) : builder.getSourceFile();
|
||||||
|
currentFunction->setDebugLineInfo(sourceFileId, loc.line, loc.column);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (inEntryPoint)
|
if (inEntryPoint)
|
||||||
entryPointTerminated = true;
|
entryPointTerminated = true;
|
||||||
@ -2913,9 +3008,17 @@ bool TGlslangToSpvTraverser::visitAggregate(glslang::TVisit visit, glslang::TInt
|
|||||||
std::vector<spv::Id> arguments;
|
std::vector<spv::Id> arguments;
|
||||||
translateArguments(*node, arguments, lvalueCoherentFlags);
|
translateArguments(*node, arguments, lvalueCoherentFlags);
|
||||||
spv::Id constructed;
|
spv::Id constructed;
|
||||||
if (node->getOp() == glslang::EOpConstructTextureSampler)
|
if (node->getOp() == glslang::EOpConstructTextureSampler) {
|
||||||
constructed = builder.createOp(spv::OpSampledImage, resultType(), arguments);
|
const glslang::TType& texType = node->getSequence()[0]->getAsTyped()->getType();
|
||||||
else if (node->getOp() == glslang::EOpConstructStruct ||
|
if (glslangIntermediate->getSpv().spv >= glslang::EShTargetSpv_1_6 &&
|
||||||
|
texType.getSampler().isBuffer()) {
|
||||||
|
// SamplerBuffer is not supported in spirv1.6 so
|
||||||
|
// `samplerBuffer(textureBuffer, sampler)` is a no-op
|
||||||
|
// and textureBuffer is the result going forward
|
||||||
|
constructed = arguments[0];
|
||||||
|
} else
|
||||||
|
constructed = builder.createOp(spv::OpSampledImage, resultType(), arguments);
|
||||||
|
} else if (node->getOp() == glslang::EOpConstructStruct ||
|
||||||
node->getOp() == glslang::EOpConstructCooperativeMatrix ||
|
node->getOp() == glslang::EOpConstructCooperativeMatrix ||
|
||||||
node->getType().isArray()) {
|
node->getType().isArray()) {
|
||||||
std::vector<spv::Id> constituents;
|
std::vector<spv::Id> constituents;
|
||||||
@ -3055,6 +3158,8 @@ bool TGlslangToSpvTraverser::visitAggregate(glslang::TVisit visit, glslang::TInt
|
|||||||
case glslang::EOpExecuteCallableNV:
|
case glslang::EOpExecuteCallableNV:
|
||||||
case glslang::EOpExecuteCallableKHR:
|
case glslang::EOpExecuteCallableKHR:
|
||||||
case glslang::EOpWritePackedPrimitiveIndices4x8NV:
|
case glslang::EOpWritePackedPrimitiveIndices4x8NV:
|
||||||
|
case glslang::EOpEmitMeshTasksEXT:
|
||||||
|
case glslang::EOpSetMeshOutputsEXT:
|
||||||
noReturnValue = true;
|
noReturnValue = true;
|
||||||
break;
|
break;
|
||||||
case glslang::EOpRayQueryInitialize:
|
case glslang::EOpRayQueryInitialize:
|
||||||
@ -3449,7 +3554,7 @@ bool TGlslangToSpvTraverser::visitAggregate(glslang::TVisit visit, glslang::TInt
|
|||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
{
|
{
|
||||||
OpDecorations decorations = { precision,
|
OpDecorations decorations = { precision,
|
||||||
TranslateNoContractionDecoration(node->getType().getQualifier()),
|
TranslateNoContractionDecoration(node->getType().getQualifier()),
|
||||||
TranslateNonUniformDecoration(node->getType().getQualifier()) };
|
TranslateNonUniformDecoration(node->getType().getQualifier()) };
|
||||||
result = createUnaryOperation(
|
result = createUnaryOperation(
|
||||||
@ -3571,7 +3676,7 @@ bool TGlslangToSpvTraverser::visitSelection(glslang::TVisit /* visit */, glslang
|
|||||||
// smear condition to vector, if necessary (AST is always scalar)
|
// smear condition to vector, if necessary (AST is always scalar)
|
||||||
// Before 1.4, smear like for mix(), starting with 1.4, keep it scalar
|
// Before 1.4, smear like for mix(), starting with 1.4, keep it scalar
|
||||||
if (glslangIntermediate->getSpv().spv < glslang::EShTargetSpv_1_4 && builder.isVector(trueValue)) {
|
if (glslangIntermediate->getSpv().spv < glslang::EShTargetSpv_1_4 && builder.isVector(trueValue)) {
|
||||||
condition = builder.smearScalar(spv::NoPrecision, condition,
|
condition = builder.smearScalar(spv::NoPrecision, condition,
|
||||||
builder.makeVectorType(builder.makeBoolType(),
|
builder.makeVectorType(builder.makeBoolType(),
|
||||||
builder.getNumComponents(trueValue)));
|
builder.getNumComponents(trueValue)));
|
||||||
}
|
}
|
||||||
@ -3742,8 +3847,8 @@ bool TGlslangToSpvTraverser::visitLoop(glslang::TVisit /* visit */, glslang::TIn
|
|||||||
// by a block-ending branch. But we don't want to put any other body/test
|
// by a block-ending branch. But we don't want to put any other body/test
|
||||||
// instructions in it, since the body/test may have arbitrary instructions,
|
// instructions in it, since the body/test may have arbitrary instructions,
|
||||||
// including merges of its own.
|
// including merges of its own.
|
||||||
builder.setLine(node->getLoc().line, node->getLoc().getFilename());
|
|
||||||
builder.setBuildPoint(&blocks.head);
|
builder.setBuildPoint(&blocks.head);
|
||||||
|
builder.setLine(node->getLoc().line, node->getLoc().getFilename());
|
||||||
builder.createLoopMerge(&blocks.merge, &blocks.continue_target, control, operands);
|
builder.createLoopMerge(&blocks.merge, &blocks.continue_target, control, operands);
|
||||||
if (node->testFirst() && node->getTest()) {
|
if (node->testFirst() && node->getTest()) {
|
||||||
spv::Block& test = builder.makeNewBlock();
|
spv::Block& test = builder.makeNewBlock();
|
||||||
@ -3962,7 +4067,7 @@ spv::Id TGlslangToSpvTraverser::createSpvVariable(const glslang::TIntermSymbol*
|
|||||||
initializer = builder.makeNullConstant(spvType);
|
initializer = builder.makeNullConstant(spvType);
|
||||||
}
|
}
|
||||||
|
|
||||||
return builder.createVariable(spv::NoPrecision, storageClass, spvType, name, initializer);
|
return builder.createVariable(spv::NoPrecision, storageClass, spvType, name, initializer, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return type Id of the sampled type.
|
// Return type Id of the sampled type.
|
||||||
@ -4050,7 +4155,7 @@ spv::Id TGlslangToSpvTraverser::convertGlslangToSpvType(const glslang::TType& ty
|
|||||||
if (explicitLayout != glslang::ElpNone)
|
if (explicitLayout != glslang::ElpNone)
|
||||||
spvType = builder.makeUintType(32);
|
spvType = builder.makeUintType(32);
|
||||||
else
|
else
|
||||||
spvType = builder.makeBoolType();
|
spvType = builder.makeBoolType(false);
|
||||||
break;
|
break;
|
||||||
case glslang::EbtInt:
|
case glslang::EbtInt:
|
||||||
spvType = builder.makeIntType(32);
|
spvType = builder.makeIntType(32);
|
||||||
@ -4150,8 +4255,10 @@ spv::Id TGlslangToSpvTraverser::convertGlslangToSpvType(const glslang::TType& ty
|
|||||||
spvType = builder.makeImageType(getSampledType(sampler), TranslateDimensionality(sampler),
|
spvType = builder.makeImageType(getSampledType(sampler), TranslateDimensionality(sampler),
|
||||||
sampler.isShadow(), sampler.isArrayed(), sampler.isMultiSample(),
|
sampler.isShadow(), sampler.isArrayed(), sampler.isMultiSample(),
|
||||||
sampler.isImageClass() ? 2 : 1, TranslateImageFormat(type));
|
sampler.isImageClass() ? 2 : 1, TranslateImageFormat(type));
|
||||||
if (sampler.isCombined()) {
|
if (sampler.isCombined() &&
|
||||||
// already has both image and sampler, make the combined type
|
(!sampler.isBuffer() || glslangIntermediate->getSpv().spv < glslang::EShTargetSpv_1_6)) {
|
||||||
|
// Already has both image and sampler, make the combined type. Only combine sampler to
|
||||||
|
// buffer if before SPIR-V 1.6.
|
||||||
spvType = builder.makeSampledImageType(spvType);
|
spvType = builder.makeSampledImageType(spvType);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -4191,7 +4298,9 @@ spv::Id TGlslangToSpvTraverser::convertGlslangToSpvType(const glslang::TType& ty
|
|||||||
if (typeParam.constant->isLiteral()) {
|
if (typeParam.constant->isLiteral()) {
|
||||||
if (typeParam.constant->getBasicType() == glslang::EbtFloat) {
|
if (typeParam.constant->getBasicType() == glslang::EbtFloat) {
|
||||||
float floatValue = static_cast<float>(typeParam.constant->getConstArray()[0].getDConst());
|
float floatValue = static_cast<float>(typeParam.constant->getConstArray()[0].getDConst());
|
||||||
unsigned literal = *reinterpret_cast<unsigned*>(&floatValue);
|
unsigned literal;
|
||||||
|
static_assert(sizeof(literal) == sizeof(floatValue), "sizeof(unsigned) != sizeof(float)");
|
||||||
|
memcpy(&literal, &floatValue, sizeof(literal));
|
||||||
operands.push_back({false, literal});
|
operands.push_back({false, literal});
|
||||||
} else if (typeParam.constant->getBasicType() == glslang::EbtInt) {
|
} else if (typeParam.constant->getBasicType() == glslang::EbtInt) {
|
||||||
unsigned literal = typeParam.constant->getConstArray()[0].getIConst();
|
unsigned literal = typeParam.constant->getConstArray()[0].getIConst();
|
||||||
@ -4336,7 +4445,7 @@ bool TGlslangToSpvTraverser::filterMember(const glslang::TType& member)
|
|||||||
extensions.find("GL_NV_stereo_view_rendering") == extensions.end())
|
extensions.find("GL_NV_stereo_view_rendering") == extensions.end())
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
if (glslangIntermediate->getStage() != EShLangMeshNV) {
|
if (glslangIntermediate->getStage() != EShLangMesh) {
|
||||||
if (member.getFieldName() == "gl_ViewportMask" &&
|
if (member.getFieldName() == "gl_ViewportMask" &&
|
||||||
extensions.find("GL_NV_viewport_array2") == extensions.end())
|
extensions.find("GL_NV_viewport_array2") == extensions.end())
|
||||||
return true;
|
return true;
|
||||||
@ -4366,14 +4475,14 @@ spv::Id TGlslangToSpvTraverser::convertGlslangStructToSpvType(const glslang::TTy
|
|||||||
// except sometimes for blocks
|
// except sometimes for blocks
|
||||||
std::vector<std::pair<glslang::TType*, glslang::TQualifier> > deferredForwardPointers;
|
std::vector<std::pair<glslang::TType*, glslang::TQualifier> > deferredForwardPointers;
|
||||||
for (int i = 0; i < (int)glslangMembers->size(); i++) {
|
for (int i = 0; i < (int)glslangMembers->size(); i++) {
|
||||||
glslang::TType& glslangMember = *(*glslangMembers)[i].type;
|
auto& glslangMember = (*glslangMembers)[i];
|
||||||
if (glslangMember.hiddenMember()) {
|
if (glslangMember.type->hiddenMember()) {
|
||||||
++memberDelta;
|
++memberDelta;
|
||||||
if (type.getBasicType() == glslang::EbtBlock)
|
if (type.getBasicType() == glslang::EbtBlock)
|
||||||
memberRemapper[glslangTypeToIdMap[glslangMembers]][i] = -1;
|
memberRemapper[glslangTypeToIdMap[glslangMembers]][i] = -1;
|
||||||
} else {
|
} else {
|
||||||
if (type.getBasicType() == glslang::EbtBlock) {
|
if (type.getBasicType() == glslang::EbtBlock) {
|
||||||
if (filterMember(glslangMember)) {
|
if (filterMember(*glslangMember.type)) {
|
||||||
memberDelta++;
|
memberDelta++;
|
||||||
memberRemapper[glslangTypeToIdMap[glslangMembers]][i] = -1;
|
memberRemapper[glslangTypeToIdMap[glslangMembers]][i] = -1;
|
||||||
continue;
|
continue;
|
||||||
@ -4381,7 +4490,7 @@ spv::Id TGlslangToSpvTraverser::convertGlslangStructToSpvType(const glslang::TTy
|
|||||||
memberRemapper[glslangTypeToIdMap[glslangMembers]][i] = i - memberDelta;
|
memberRemapper[glslangTypeToIdMap[glslangMembers]][i] = i - memberDelta;
|
||||||
}
|
}
|
||||||
// modify just this child's view of the qualifier
|
// modify just this child's view of the qualifier
|
||||||
glslang::TQualifier memberQualifier = glslangMember.getQualifier();
|
glslang::TQualifier memberQualifier = glslangMember.type->getQualifier();
|
||||||
InheritQualifiers(memberQualifier, qualifier);
|
InheritQualifiers(memberQualifier, qualifier);
|
||||||
|
|
||||||
// manually inherit location
|
// manually inherit location
|
||||||
@ -4392,25 +4501,38 @@ spv::Id TGlslangToSpvTraverser::convertGlslangStructToSpvType(const glslang::TTy
|
|||||||
bool lastBufferBlockMember = qualifier.storage == glslang::EvqBuffer &&
|
bool lastBufferBlockMember = qualifier.storage == glslang::EvqBuffer &&
|
||||||
i == (int)glslangMembers->size() - 1;
|
i == (int)glslangMembers->size() - 1;
|
||||||
|
|
||||||
// Make forward pointers for any pointer members, and create a list of members to
|
// Make forward pointers for any pointer members.
|
||||||
// convert to spirv types after creating the struct.
|
if (glslangMember.type->isReference() &&
|
||||||
if (glslangMember.isReference()) {
|
forwardPointers.find(glslangMember.type->getReferentType()) == forwardPointers.end()) {
|
||||||
if (forwardPointers.find(glslangMember.getReferentType()) == forwardPointers.end()) {
|
deferredForwardPointers.push_back(std::make_pair(glslangMember.type, memberQualifier));
|
||||||
deferredForwardPointers.push_back(std::make_pair(&glslangMember, memberQualifier));
|
}
|
||||||
}
|
|
||||||
spvMembers.push_back(
|
// Create the member type.
|
||||||
convertGlslangToSpvType(glslangMember, explicitLayout, memberQualifier, lastBufferBlockMember,
|
auto const spvMember = convertGlslangToSpvType(*glslangMember.type, explicitLayout, memberQualifier, lastBufferBlockMember,
|
||||||
true));
|
glslangMember.type->isReference());
|
||||||
} else {
|
spvMembers.push_back(spvMember);
|
||||||
spvMembers.push_back(
|
|
||||||
convertGlslangToSpvType(glslangMember, explicitLayout, memberQualifier, lastBufferBlockMember,
|
// Update the builder with the type's location so that we can create debug types for the structure members.
|
||||||
false));
|
// There doesn't exist a "clean" entry point for this information to be passed along to the builder so, for now,
|
||||||
|
// it is stored in the builder and consumed during the construction of composite debug types.
|
||||||
|
// TODO: This probably warrants further investigation. This approach was decided to be the least ugly of the
|
||||||
|
// quick and dirty approaches that were tried.
|
||||||
|
// Advantages of this approach:
|
||||||
|
// + Relatively clean. No direct calls into debug type system.
|
||||||
|
// + Handles nested recursive structures.
|
||||||
|
// Disadvantages of this approach:
|
||||||
|
// + Not as clean as desired. Traverser queries/sets persistent state. This is fragile.
|
||||||
|
// + Table lookup during creation of composite debug types. This really shouldn't be necessary.
|
||||||
|
if(options.emitNonSemanticShaderDebugInfo) {
|
||||||
|
builder.debugTypeLocs[spvMember].name = glslangMember.type->getFieldName().c_str();
|
||||||
|
builder.debugTypeLocs[spvMember].line = glslangMember.loc.line;
|
||||||
|
builder.debugTypeLocs[spvMember].column = glslangMember.loc.column;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make the SPIR-V type
|
// Make the SPIR-V type
|
||||||
spv::Id spvType = builder.makeStructType(spvMembers, type.getTypeName().c_str());
|
spv::Id spvType = builder.makeStructType(spvMembers, type.getTypeName().c_str(), false);
|
||||||
if (! HasNonLayoutQualifiers(type, qualifier))
|
if (! HasNonLayoutQualifiers(type, qualifier))
|
||||||
structMap[explicitLayout][qualifier.layoutMatrix][glslangMembers] = spvType;
|
structMap[explicitLayout][qualifier.layoutMatrix][glslangMembers] = spvType;
|
||||||
|
|
||||||
@ -5004,6 +5126,7 @@ void TGlslangToSpvTraverser::makeFunctions(const glslang::TIntermSequence& glslF
|
|||||||
// GLSL has copy-in/copy-out semantics. They can be handled though with a pointer to a copy.
|
// GLSL has copy-in/copy-out semantics. They can be handled though with a pointer to a copy.
|
||||||
|
|
||||||
std::vector<spv::Id> paramTypes;
|
std::vector<spv::Id> paramTypes;
|
||||||
|
std::vector<char const*> paramNames;
|
||||||
std::vector<std::vector<spv::Decoration>> paramDecorations; // list of decorations per parameter
|
std::vector<std::vector<spv::Decoration>> paramDecorations; // list of decorations per parameter
|
||||||
glslang::TIntermSequence& parameters = glslFunction->getSequence()[0]->getAsAggregate()->getSequence();
|
glslang::TIntermSequence& parameters = glslFunction->getSequence()[0]->getAsAggregate()->getSequence();
|
||||||
|
|
||||||
@ -5028,10 +5151,14 @@ void TGlslangToSpvTraverser::makeFunctions(const glslang::TIntermSequence& glslF
|
|||||||
paramTypes.push_back(typeId);
|
paramTypes.push_back(typeId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (auto const parameter:parameters) {
|
||||||
|
paramNames.push_back(parameter->getAsSymbolNode()->getName().c_str());
|
||||||
|
}
|
||||||
|
|
||||||
spv::Block* functionBlock;
|
spv::Block* functionBlock;
|
||||||
spv::Function *function = builder.makeFunctionEntry(TranslatePrecisionDecoration(glslFunction->getType()),
|
spv::Function *function = builder.makeFunctionEntry(TranslatePrecisionDecoration(glslFunction->getType()),
|
||||||
convertGlslangToSpvType(glslFunction->getType()),
|
convertGlslangToSpvType(glslFunction->getType()),
|
||||||
glslFunction->getName().c_str(), paramTypes,
|
glslFunction->getName().c_str(), paramTypes, paramNames,
|
||||||
paramDecorations, &functionBlock);
|
paramDecorations, &functionBlock);
|
||||||
if (implicitThis)
|
if (implicitThis)
|
||||||
function->setImplicitThis();
|
function->setImplicitThis();
|
||||||
@ -5121,6 +5248,7 @@ void TGlslangToSpvTraverser::handleFunctionEntry(const glslang::TIntermAggregate
|
|||||||
currentFunction = functionMap[node->getName().c_str()];
|
currentFunction = functionMap[node->getName().c_str()];
|
||||||
spv::Block* functionBlock = currentFunction->getEntryBlock();
|
spv::Block* functionBlock = currentFunction->getEntryBlock();
|
||||||
builder.setBuildPoint(functionBlock);
|
builder.setBuildPoint(functionBlock);
|
||||||
|
builder.enterFunction(currentFunction);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TGlslangToSpvTraverser::translateArguments(const glslang::TIntermAggregate& node, std::vector<spv::Id>& arguments,
|
void TGlslangToSpvTraverser::translateArguments(const glslang::TIntermAggregate& node, std::vector<spv::Id>& arguments,
|
||||||
@ -5548,10 +5676,12 @@ spv::Id TGlslangToSpvTraverser::createImageTextureFunctionCall(glslang::TIntermO
|
|||||||
operands.push_back(sample);
|
operands.push_back(sample);
|
||||||
|
|
||||||
spv::Id resultTypeId;
|
spv::Id resultTypeId;
|
||||||
|
glslang::TBasicType typeProxy = node->getBasicType();
|
||||||
// imageAtomicStore has a void return type so base the pointer type on
|
// imageAtomicStore has a void return type so base the pointer type on
|
||||||
// the type of the value operand.
|
// the type of the value operand.
|
||||||
if (node->getOp() == glslang::EOpImageAtomicStore) {
|
if (node->getOp() == glslang::EOpImageAtomicStore) {
|
||||||
resultTypeId = builder.makePointer(spv::StorageClassImage, builder.getTypeId(*opIt));
|
resultTypeId = builder.makePointer(spv::StorageClassImage, builder.getTypeId(*opIt));
|
||||||
|
typeProxy = node->getAsAggregate()->getSequence()[0]->getAsTyped()->getType().getSampler().type;
|
||||||
} else {
|
} else {
|
||||||
resultTypeId = builder.makePointer(spv::StorageClassImage, resultType());
|
resultTypeId = builder.makePointer(spv::StorageClassImage, resultType());
|
||||||
}
|
}
|
||||||
@ -5565,7 +5695,7 @@ spv::Id TGlslangToSpvTraverser::createImageTextureFunctionCall(glslang::TIntermO
|
|||||||
for (; opIt != arguments.end(); ++opIt)
|
for (; opIt != arguments.end(); ++opIt)
|
||||||
operands.push_back(*opIt);
|
operands.push_back(*opIt);
|
||||||
|
|
||||||
return createAtomicOperation(node->getOp(), precision, resultType(), operands, node->getBasicType(),
|
return createAtomicOperation(node->getOp(), precision, resultType(), operands, typeProxy,
|
||||||
lvalueCoherentFlags);
|
lvalueCoherentFlags);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -5769,10 +5899,10 @@ spv::Id TGlslangToSpvTraverser::createImageTextureFunctionCall(glslang::TIntermO
|
|||||||
assert(builder.isStructType(resultStructType));
|
assert(builder.isStructType(resultStructType));
|
||||||
|
|
||||||
//resType (SPIR-V type) contains 6 elements:
|
//resType (SPIR-V type) contains 6 elements:
|
||||||
//Member 0 must be a Boolean type scalar(LOD),
|
//Member 0 must be a Boolean type scalar(LOD),
|
||||||
//Member 1 must be a vector of integer type, whose Signedness operand is 0(anchor),
|
//Member 1 must be a vector of integer type, whose Signedness operand is 0(anchor),
|
||||||
//Member 2 must be a vector of integer type, whose Signedness operand is 0(offset),
|
//Member 2 must be a vector of integer type, whose Signedness operand is 0(offset),
|
||||||
//Member 3 must be a vector of integer type, whose Signedness operand is 0(mask),
|
//Member 3 must be a vector of integer type, whose Signedness operand is 0(mask),
|
||||||
//Member 4 must be a scalar of integer type, whose Signedness operand is 0(lod),
|
//Member 4 must be a scalar of integer type, whose Signedness operand is 0(lod),
|
||||||
//Member 5 must be a scalar of integer type, whose Signedness operand is 0(granularity).
|
//Member 5 must be a scalar of integer type, whose Signedness operand is 0(granularity).
|
||||||
std::vector<spv::Id> members;
|
std::vector<spv::Id> members;
|
||||||
@ -5785,7 +5915,7 @@ spv::Id TGlslangToSpvTraverser::createImageTextureFunctionCall(glslang::TIntermO
|
|||||||
//call ImageFootprintNV
|
//call ImageFootprintNV
|
||||||
spv::Id res = builder.createTextureCall(precision, resType, sparse, cracked.fetch, cracked.proj,
|
spv::Id res = builder.createTextureCall(precision, resType, sparse, cracked.fetch, cracked.proj,
|
||||||
cracked.gather, noImplicitLod, params, signExtensionMask());
|
cracked.gather, noImplicitLod, params, signExtensionMask());
|
||||||
|
|
||||||
//copy resType (SPIR-V type) to resultStructType(OpenGL type)
|
//copy resType (SPIR-V type) to resultStructType(OpenGL type)
|
||||||
for (int i = 0; i < 5; i++) {
|
for (int i = 0; i < 5; i++) {
|
||||||
builder.clearAccessChain();
|
builder.clearAccessChain();
|
||||||
@ -5838,7 +5968,7 @@ spv::Id TGlslangToSpvTraverser::createImageTextureFunctionCall(glslang::TIntermO
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
std::vector<spv::Id> result( 1,
|
std::vector<spv::Id> result( 1,
|
||||||
builder.createTextureCall(precision, resultType(), sparse, cracked.fetch, cracked.proj, cracked.gather,
|
builder.createTextureCall(precision, resultType(), sparse, cracked.fetch, cracked.proj, cracked.gather,
|
||||||
noImplicitLod, params, signExtensionMask())
|
noImplicitLod, params, signExtensionMask())
|
||||||
);
|
);
|
||||||
@ -7361,7 +7491,7 @@ spv::Id TGlslangToSpvTraverser::createAtomicOperation(glslang::TOperator op, spv
|
|||||||
} else {
|
} else {
|
||||||
scopeId = builder.makeUintConstant(spv::ScopeDevice);
|
scopeId = builder.makeUintConstant(spv::ScopeDevice);
|
||||||
}
|
}
|
||||||
// semantics default to relaxed
|
// semantics default to relaxed
|
||||||
spv::Id semanticsId = builder.makeUintConstant(lvalueCoherentFlags.isVolatile() &&
|
spv::Id semanticsId = builder.makeUintConstant(lvalueCoherentFlags.isVolatile() &&
|
||||||
glslangIntermediate->usingVulkanMemoryModel() ?
|
glslangIntermediate->usingVulkanMemoryModel() ?
|
||||||
spv::MemorySemanticsVolatileMask :
|
spv::MemorySemanticsVolatileMask :
|
||||||
@ -8465,6 +8595,15 @@ spv::Id TGlslangToSpvTraverser::createMiscOperation(glslang::TOperator op, spv::
|
|||||||
case glslang::EOpWritePackedPrimitiveIndices4x8NV:
|
case glslang::EOpWritePackedPrimitiveIndices4x8NV:
|
||||||
builder.createNoResultOp(spv::OpWritePackedPrimitiveIndices4x8NV, operands);
|
builder.createNoResultOp(spv::OpWritePackedPrimitiveIndices4x8NV, operands);
|
||||||
return 0;
|
return 0;
|
||||||
|
case glslang::EOpEmitMeshTasksEXT:
|
||||||
|
if (taskPayloadID)
|
||||||
|
operands.push_back(taskPayloadID);
|
||||||
|
// As per SPV_EXT_mesh_shader make it a terminating instruction in the current block
|
||||||
|
builder.makeStatementTerminator(spv::OpEmitMeshTasksEXT, operands, "post-OpEmitMeshTasksEXT");
|
||||||
|
return 0;
|
||||||
|
case glslang::EOpSetMeshOutputsEXT:
|
||||||
|
builder.createNoResultOp(spv::OpSetMeshOutputsEXT, operands);
|
||||||
|
return 0;
|
||||||
case glslang::EOpCooperativeMatrixMulAdd:
|
case glslang::EOpCooperativeMatrixMulAdd:
|
||||||
opCode = spv::OpCooperativeMatrixMulAddNV;
|
opCode = spv::OpCooperativeMatrixMulAddNV;
|
||||||
break;
|
break;
|
||||||
@ -8728,7 +8867,32 @@ spv::Id TGlslangToSpvTraverser::getSymbolId(const glslang::TIntermSymbol* symbol
|
|||||||
// it was not found, create it
|
// it was not found, create it
|
||||||
spv::BuiltIn builtIn = TranslateBuiltInDecoration(symbol->getQualifier().builtIn, false);
|
spv::BuiltIn builtIn = TranslateBuiltInDecoration(symbol->getQualifier().builtIn, false);
|
||||||
auto forcedType = getForcedType(symbol->getQualifier().builtIn, symbol->getType());
|
auto forcedType = getForcedType(symbol->getQualifier().builtIn, symbol->getType());
|
||||||
|
|
||||||
|
// There are pairs of symbols that map to the same SPIR-V built-in:
|
||||||
|
// gl_ObjectToWorldEXT and gl_ObjectToWorld3x4EXT, and gl_WorldToObjectEXT
|
||||||
|
// and gl_WorldToObject3x4EXT. SPIR-V forbids having two OpVariables
|
||||||
|
// with the same BuiltIn in the same storage class, so we must re-use one.
|
||||||
|
const bool mayNeedToReuseBuiltIn =
|
||||||
|
builtIn == spv::BuiltInObjectToWorldKHR ||
|
||||||
|
builtIn == spv::BuiltInWorldToObjectKHR;
|
||||||
|
|
||||||
|
if (mayNeedToReuseBuiltIn) {
|
||||||
|
auto iter = builtInVariableIds.find(uint32_t(builtIn));
|
||||||
|
if (builtInVariableIds.end() != iter) {
|
||||||
|
id = iter->second;
|
||||||
|
symbolValues[symbol->getId()] = id;
|
||||||
|
if (forcedType.second != spv::NoType)
|
||||||
|
forceType[id] = forcedType.second;
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
id = createSpvVariable(symbol, forcedType.first);
|
id = createSpvVariable(symbol, forcedType.first);
|
||||||
|
|
||||||
|
if (mayNeedToReuseBuiltIn) {
|
||||||
|
builtInVariableIds.insert({uint32_t(builtIn), id});
|
||||||
|
}
|
||||||
|
|
||||||
symbolValues[symbol->getId()] = id;
|
symbolValues[symbol->getId()] = id;
|
||||||
if (forcedType.second != spv::NoType)
|
if (forcedType.second != spv::NoType)
|
||||||
forceType[id] = forcedType.second;
|
forceType[id] = forcedType.second;
|
||||||
@ -8857,6 +9021,12 @@ spv::Id TGlslangToSpvTraverser::getSymbolId(const glslang::TIntermSymbol* symbol
|
|||||||
builder.addExtension(spv::E_SPV_NV_fragment_shader_barycentric);
|
builder.addExtension(spv::E_SPV_NV_fragment_shader_barycentric);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (symbol->getQualifier().pervertexEXT) {
|
||||||
|
builder.addDecoration(id, spv::DecorationPerVertexKHR);
|
||||||
|
builder.addCapability(spv::CapabilityFragmentBarycentricKHR);
|
||||||
|
builder.addExtension(spv::E_SPV_KHR_fragment_shader_barycentric);
|
||||||
|
}
|
||||||
|
|
||||||
if (glslangIntermediate->getHlslFunctionality1() && symbol->getType().getQualifier().semanticName != nullptr) {
|
if (glslangIntermediate->getHlslFunctionality1() && symbol->getType().getQualifier().semanticName != nullptr) {
|
||||||
builder.addExtension("SPV_GOOGLE_hlsl_functionality1");
|
builder.addExtension("SPV_GOOGLE_hlsl_functionality1");
|
||||||
builder.addDecoration(id, (spv::Decoration)spv::DecorationHlslSemanticGOOGLE,
|
builder.addDecoration(id, (spv::Decoration)spv::DecorationHlslSemanticGOOGLE,
|
||||||
@ -8918,13 +9088,21 @@ spv::Id TGlslangToSpvTraverser::getSymbolId(const glslang::TIntermSymbol* symbol
|
|||||||
// add per-primitive, per-view. per-task decorations to a struct member (member >= 0) or an object
|
// add per-primitive, per-view. per-task decorations to a struct member (member >= 0) or an object
|
||||||
void TGlslangToSpvTraverser::addMeshNVDecoration(spv::Id id, int member, const glslang::TQualifier& qualifier)
|
void TGlslangToSpvTraverser::addMeshNVDecoration(spv::Id id, int member, const glslang::TQualifier& qualifier)
|
||||||
{
|
{
|
||||||
|
bool isMeshShaderExt = (glslangIntermediate->getRequestedExtensions().find(glslang::E_GL_EXT_mesh_shader) !=
|
||||||
|
glslangIntermediate->getRequestedExtensions().end());
|
||||||
|
|
||||||
if (member >= 0) {
|
if (member >= 0) {
|
||||||
if (qualifier.perPrimitiveNV) {
|
if (qualifier.perPrimitiveNV) {
|
||||||
// Need to add capability/extension for fragment shader.
|
// Need to add capability/extension for fragment shader.
|
||||||
// Mesh shader already adds this by default.
|
// Mesh shader already adds this by default.
|
||||||
if (glslangIntermediate->getStage() == EShLangFragment) {
|
if (glslangIntermediate->getStage() == EShLangFragment) {
|
||||||
builder.addCapability(spv::CapabilityMeshShadingNV);
|
if(isMeshShaderExt) {
|
||||||
builder.addExtension(spv::E_SPV_NV_mesh_shader);
|
builder.addCapability(spv::CapabilityMeshShadingEXT);
|
||||||
|
builder.addExtension(spv::E_SPV_EXT_mesh_shader);
|
||||||
|
} else {
|
||||||
|
builder.addCapability(spv::CapabilityMeshShadingNV);
|
||||||
|
builder.addExtension(spv::E_SPV_NV_mesh_shader);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
builder.addMemberDecoration(id, (unsigned)member, spv::DecorationPerPrimitiveNV);
|
builder.addMemberDecoration(id, (unsigned)member, spv::DecorationPerPrimitiveNV);
|
||||||
}
|
}
|
||||||
@ -8937,8 +9115,13 @@ void TGlslangToSpvTraverser::addMeshNVDecoration(spv::Id id, int member, const g
|
|||||||
// Need to add capability/extension for fragment shader.
|
// Need to add capability/extension for fragment shader.
|
||||||
// Mesh shader already adds this by default.
|
// Mesh shader already adds this by default.
|
||||||
if (glslangIntermediate->getStage() == EShLangFragment) {
|
if (glslangIntermediate->getStage() == EShLangFragment) {
|
||||||
builder.addCapability(spv::CapabilityMeshShadingNV);
|
if(isMeshShaderExt) {
|
||||||
builder.addExtension(spv::E_SPV_NV_mesh_shader);
|
builder.addCapability(spv::CapabilityMeshShadingEXT);
|
||||||
|
builder.addExtension(spv::E_SPV_EXT_mesh_shader);
|
||||||
|
} else {
|
||||||
|
builder.addCapability(spv::CapabilityMeshShadingNV);
|
||||||
|
builder.addExtension(spv::E_SPV_NV_mesh_shader);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
builder.addDecoration(id, spv::DecorationPerPrimitiveNV);
|
builder.addDecoration(id, spv::DecorationPerPrimitiveNV);
|
||||||
}
|
}
|
||||||
@ -9078,15 +9261,19 @@ spv::Id TGlslangToSpvTraverser::createSpvConstantFromConstUnionArray(const glsla
|
|||||||
break;
|
break;
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
case glslang::EbtInt8:
|
case glslang::EbtInt8:
|
||||||
|
builder.addCapability(spv::CapabilityInt8);
|
||||||
spvConsts.push_back(builder.makeInt8Constant(zero ? 0 : consts[nextConst].getI8Const()));
|
spvConsts.push_back(builder.makeInt8Constant(zero ? 0 : consts[nextConst].getI8Const()));
|
||||||
break;
|
break;
|
||||||
case glslang::EbtUint8:
|
case glslang::EbtUint8:
|
||||||
|
builder.addCapability(spv::CapabilityInt8);
|
||||||
spvConsts.push_back(builder.makeUint8Constant(zero ? 0 : consts[nextConst].getU8Const()));
|
spvConsts.push_back(builder.makeUint8Constant(zero ? 0 : consts[nextConst].getU8Const()));
|
||||||
break;
|
break;
|
||||||
case glslang::EbtInt16:
|
case glslang::EbtInt16:
|
||||||
|
builder.addCapability(spv::CapabilityInt16);
|
||||||
spvConsts.push_back(builder.makeInt16Constant(zero ? 0 : consts[nextConst].getI16Const()));
|
spvConsts.push_back(builder.makeInt16Constant(zero ? 0 : consts[nextConst].getI16Const()));
|
||||||
break;
|
break;
|
||||||
case glslang::EbtUint16:
|
case glslang::EbtUint16:
|
||||||
|
builder.addCapability(spv::CapabilityInt16);
|
||||||
spvConsts.push_back(builder.makeUint16Constant(zero ? 0 : consts[nextConst].getU16Const()));
|
spvConsts.push_back(builder.makeUint16Constant(zero ? 0 : consts[nextConst].getU16Const()));
|
||||||
break;
|
break;
|
||||||
case glslang::EbtInt64:
|
case glslang::EbtInt64:
|
||||||
@ -9099,6 +9286,7 @@ spv::Id TGlslangToSpvTraverser::createSpvConstantFromConstUnionArray(const glsla
|
|||||||
spvConsts.push_back(builder.makeDoubleConstant(zero ? 0.0 : consts[nextConst].getDConst()));
|
spvConsts.push_back(builder.makeDoubleConstant(zero ? 0.0 : consts[nextConst].getDConst()));
|
||||||
break;
|
break;
|
||||||
case glslang::EbtFloat16:
|
case glslang::EbtFloat16:
|
||||||
|
builder.addCapability(spv::CapabilityFloat16);
|
||||||
spvConsts.push_back(builder.makeFloat16Constant(zero ? 0.0F : (float)consts[nextConst].getDConst()));
|
spvConsts.push_back(builder.makeFloat16Constant(zero ? 0.0F : (float)consts[nextConst].getDConst()));
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
@ -9127,15 +9315,19 @@ spv::Id TGlslangToSpvTraverser::createSpvConstantFromConstUnionArray(const glsla
|
|||||||
break;
|
break;
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
case glslang::EbtInt8:
|
case glslang::EbtInt8:
|
||||||
|
builder.addCapability(spv::CapabilityInt8);
|
||||||
scalar = builder.makeInt8Constant(zero ? 0 : consts[nextConst].getI8Const(), specConstant);
|
scalar = builder.makeInt8Constant(zero ? 0 : consts[nextConst].getI8Const(), specConstant);
|
||||||
break;
|
break;
|
||||||
case glslang::EbtUint8:
|
case glslang::EbtUint8:
|
||||||
|
builder.addCapability(spv::CapabilityInt8);
|
||||||
scalar = builder.makeUint8Constant(zero ? 0 : consts[nextConst].getU8Const(), specConstant);
|
scalar = builder.makeUint8Constant(zero ? 0 : consts[nextConst].getU8Const(), specConstant);
|
||||||
break;
|
break;
|
||||||
case glslang::EbtInt16:
|
case glslang::EbtInt16:
|
||||||
|
builder.addCapability(spv::CapabilityInt16);
|
||||||
scalar = builder.makeInt16Constant(zero ? 0 : consts[nextConst].getI16Const(), specConstant);
|
scalar = builder.makeInt16Constant(zero ? 0 : consts[nextConst].getI16Const(), specConstant);
|
||||||
break;
|
break;
|
||||||
case glslang::EbtUint16:
|
case glslang::EbtUint16:
|
||||||
|
builder.addCapability(spv::CapabilityInt16);
|
||||||
scalar = builder.makeUint16Constant(zero ? 0 : consts[nextConst].getU16Const(), specConstant);
|
scalar = builder.makeUint16Constant(zero ? 0 : consts[nextConst].getU16Const(), specConstant);
|
||||||
break;
|
break;
|
||||||
case glslang::EbtInt64:
|
case glslang::EbtInt64:
|
||||||
@ -9148,6 +9340,7 @@ spv::Id TGlslangToSpvTraverser::createSpvConstantFromConstUnionArray(const glsla
|
|||||||
scalar = builder.makeDoubleConstant(zero ? 0.0 : consts[nextConst].getDConst(), specConstant);
|
scalar = builder.makeDoubleConstant(zero ? 0.0 : consts[nextConst].getDConst(), specConstant);
|
||||||
break;
|
break;
|
||||||
case glslang::EbtFloat16:
|
case glslang::EbtFloat16:
|
||||||
|
builder.addCapability(spv::CapabilityFloat16);
|
||||||
scalar = builder.makeFloat16Constant(zero ? 0.0F : (float)consts[nextConst].getDConst(), specConstant);
|
scalar = builder.makeFloat16Constant(zero ? 0.0F : (float)consts[nextConst].getDConst(), specConstant);
|
||||||
break;
|
break;
|
||||||
case glslang::EbtReference:
|
case glslang::EbtReference:
|
||||||
@ -9345,7 +9538,8 @@ int GetSpirvGeneratorVersion()
|
|||||||
// return 7; // GLSL volatile keyword maps to both SPIR-V decorations Volatile and Coherent
|
// return 7; // GLSL volatile keyword maps to both SPIR-V decorations Volatile and Coherent
|
||||||
// return 8; // switch to new dead block eliminator; use OpUnreachable
|
// return 8; // switch to new dead block eliminator; use OpUnreachable
|
||||||
// return 9; // don't include opaque function parameters in OpEntryPoint global's operand list
|
// return 9; // don't include opaque function parameters in OpEntryPoint global's operand list
|
||||||
return 10; // Generate OpFUnordNotEqual for != comparisons
|
// return 10; // Generate OpFUnordNotEqual for != comparisons
|
||||||
|
return 11; // Make OpEmitMeshTasksEXT a terminal instruction
|
||||||
}
|
}
|
||||||
|
|
||||||
// Write SPIR-V out to a binary file
|
// Write SPIR-V out to a binary file
|
||||||
|
171
thirdparty/glslang/SPIRV/NonSemanticShaderDebugInfo100.h
vendored
Normal file
171
thirdparty/glslang/SPIRV/NonSemanticShaderDebugInfo100.h
vendored
Normal file
@ -0,0 +1,171 @@
|
|||||||
|
// Copyright (c) 2018 The Khronos Group Inc.
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
// of this software and/or associated documentation files (the "Materials"),
|
||||||
|
// to deal in the Materials without restriction, including without limitation
|
||||||
|
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
// and/or sell copies of the Materials, and to permit persons to whom the
|
||||||
|
// Materials are furnished to do so, subject to the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be included in
|
||||||
|
// all copies or substantial portions of the Materials.
|
||||||
|
//
|
||||||
|
// MODIFICATIONS TO THIS FILE MAY MEAN IT NO LONGER ACCURATELY REFLECTS KHRONOS
|
||||||
|
// STANDARDS. THE UNMODIFIED, NORMATIVE VERSIONS OF KHRONOS SPECIFICATIONS AND
|
||||||
|
// HEADER INFORMATION ARE LOCATED AT https://www.khronos.org/registry/
|
||||||
|
//
|
||||||
|
// THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||||||
|
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
// FROM,OUT OF OR IN CONNECTION WITH THE MATERIALS OR THE USE OR OTHER DEALINGS
|
||||||
|
// IN THE MATERIALS.
|
||||||
|
|
||||||
|
#ifndef SPIRV_UNIFIED1_NonSemanticShaderDebugInfo100_H_
|
||||||
|
#define SPIRV_UNIFIED1_NonSemanticShaderDebugInfo100_H_
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
enum {
|
||||||
|
NonSemanticShaderDebugInfo100Version = 100,
|
||||||
|
NonSemanticShaderDebugInfo100Version_BitWidthPadding = 0x7fffffff
|
||||||
|
};
|
||||||
|
enum {
|
||||||
|
NonSemanticShaderDebugInfo100Revision = 6,
|
||||||
|
NonSemanticShaderDebugInfo100Revision_BitWidthPadding = 0x7fffffff
|
||||||
|
};
|
||||||
|
|
||||||
|
enum NonSemanticShaderDebugInfo100Instructions {
|
||||||
|
NonSemanticShaderDebugInfo100DebugInfoNone = 0,
|
||||||
|
NonSemanticShaderDebugInfo100DebugCompilationUnit = 1,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeBasic = 2,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypePointer = 3,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeQualifier = 4,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeArray = 5,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeVector = 6,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypedef = 7,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeFunction = 8,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeEnum = 9,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeComposite = 10,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeMember = 11,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeInheritance = 12,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypePtrToMember = 13,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeTemplate = 14,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeTemplateParameter = 15,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeTemplateTemplateParameter = 16,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeTemplateParameterPack = 17,
|
||||||
|
NonSemanticShaderDebugInfo100DebugGlobalVariable = 18,
|
||||||
|
NonSemanticShaderDebugInfo100DebugFunctionDeclaration = 19,
|
||||||
|
NonSemanticShaderDebugInfo100DebugFunction = 20,
|
||||||
|
NonSemanticShaderDebugInfo100DebugLexicalBlock = 21,
|
||||||
|
NonSemanticShaderDebugInfo100DebugLexicalBlockDiscriminator = 22,
|
||||||
|
NonSemanticShaderDebugInfo100DebugScope = 23,
|
||||||
|
NonSemanticShaderDebugInfo100DebugNoScope = 24,
|
||||||
|
NonSemanticShaderDebugInfo100DebugInlinedAt = 25,
|
||||||
|
NonSemanticShaderDebugInfo100DebugLocalVariable = 26,
|
||||||
|
NonSemanticShaderDebugInfo100DebugInlinedVariable = 27,
|
||||||
|
NonSemanticShaderDebugInfo100DebugDeclare = 28,
|
||||||
|
NonSemanticShaderDebugInfo100DebugValue = 29,
|
||||||
|
NonSemanticShaderDebugInfo100DebugOperation = 30,
|
||||||
|
NonSemanticShaderDebugInfo100DebugExpression = 31,
|
||||||
|
NonSemanticShaderDebugInfo100DebugMacroDef = 32,
|
||||||
|
NonSemanticShaderDebugInfo100DebugMacroUndef = 33,
|
||||||
|
NonSemanticShaderDebugInfo100DebugImportedEntity = 34,
|
||||||
|
NonSemanticShaderDebugInfo100DebugSource = 35,
|
||||||
|
NonSemanticShaderDebugInfo100DebugFunctionDefinition = 101,
|
||||||
|
NonSemanticShaderDebugInfo100DebugSourceContinued = 102,
|
||||||
|
NonSemanticShaderDebugInfo100DebugLine = 103,
|
||||||
|
NonSemanticShaderDebugInfo100DebugNoLine = 104,
|
||||||
|
NonSemanticShaderDebugInfo100DebugBuildIdentifier = 105,
|
||||||
|
NonSemanticShaderDebugInfo100DebugStoragePath = 106,
|
||||||
|
NonSemanticShaderDebugInfo100DebugEntryPoint = 107,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeMatrix = 108,
|
||||||
|
NonSemanticShaderDebugInfo100InstructionsMax = 0x7fffffff
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
enum NonSemanticShaderDebugInfo100DebugInfoFlags {
|
||||||
|
NonSemanticShaderDebugInfo100None = 0x0000,
|
||||||
|
NonSemanticShaderDebugInfo100FlagIsProtected = 0x01,
|
||||||
|
NonSemanticShaderDebugInfo100FlagIsPrivate = 0x02,
|
||||||
|
NonSemanticShaderDebugInfo100FlagIsPublic = 0x03,
|
||||||
|
NonSemanticShaderDebugInfo100FlagIsLocal = 0x04,
|
||||||
|
NonSemanticShaderDebugInfo100FlagIsDefinition = 0x08,
|
||||||
|
NonSemanticShaderDebugInfo100FlagFwdDecl = 0x10,
|
||||||
|
NonSemanticShaderDebugInfo100FlagArtificial = 0x20,
|
||||||
|
NonSemanticShaderDebugInfo100FlagExplicit = 0x40,
|
||||||
|
NonSemanticShaderDebugInfo100FlagPrototyped = 0x80,
|
||||||
|
NonSemanticShaderDebugInfo100FlagObjectPointer = 0x100,
|
||||||
|
NonSemanticShaderDebugInfo100FlagStaticMember = 0x200,
|
||||||
|
NonSemanticShaderDebugInfo100FlagIndirectVariable = 0x400,
|
||||||
|
NonSemanticShaderDebugInfo100FlagLValueReference = 0x800,
|
||||||
|
NonSemanticShaderDebugInfo100FlagRValueReference = 0x1000,
|
||||||
|
NonSemanticShaderDebugInfo100FlagIsOptimized = 0x2000,
|
||||||
|
NonSemanticShaderDebugInfo100FlagIsEnumClass = 0x4000,
|
||||||
|
NonSemanticShaderDebugInfo100FlagTypePassByValue = 0x8000,
|
||||||
|
NonSemanticShaderDebugInfo100FlagTypePassByReference = 0x10000,
|
||||||
|
NonSemanticShaderDebugInfo100FlagUnknownPhysicalLayout = 0x20000,
|
||||||
|
NonSemanticShaderDebugInfo100DebugInfoFlagsMax = 0x7fffffff
|
||||||
|
};
|
||||||
|
|
||||||
|
enum NonSemanticShaderDebugInfo100BuildIdentifierFlags {
|
||||||
|
NonSemanticShaderDebugInfo100IdentifierPossibleDuplicates = 0x01,
|
||||||
|
NonSemanticShaderDebugInfo100BuildIdentifierFlagsMax = 0x7fffffff
|
||||||
|
};
|
||||||
|
|
||||||
|
enum NonSemanticShaderDebugInfo100DebugBaseTypeAttributeEncoding {
|
||||||
|
NonSemanticShaderDebugInfo100Unspecified = 0,
|
||||||
|
NonSemanticShaderDebugInfo100Address = 1,
|
||||||
|
NonSemanticShaderDebugInfo100Boolean = 2,
|
||||||
|
NonSemanticShaderDebugInfo100Float = 3,
|
||||||
|
NonSemanticShaderDebugInfo100Signed = 4,
|
||||||
|
NonSemanticShaderDebugInfo100SignedChar = 5,
|
||||||
|
NonSemanticShaderDebugInfo100Unsigned = 6,
|
||||||
|
NonSemanticShaderDebugInfo100UnsignedChar = 7,
|
||||||
|
NonSemanticShaderDebugInfo100DebugBaseTypeAttributeEncodingMax = 0x7fffffff
|
||||||
|
};
|
||||||
|
|
||||||
|
enum NonSemanticShaderDebugInfo100DebugCompositeType {
|
||||||
|
NonSemanticShaderDebugInfo100Class = 0,
|
||||||
|
NonSemanticShaderDebugInfo100Structure = 1,
|
||||||
|
NonSemanticShaderDebugInfo100Union = 2,
|
||||||
|
NonSemanticShaderDebugInfo100DebugCompositeTypeMax = 0x7fffffff
|
||||||
|
};
|
||||||
|
|
||||||
|
enum NonSemanticShaderDebugInfo100DebugTypeQualifier {
|
||||||
|
NonSemanticShaderDebugInfo100ConstType = 0,
|
||||||
|
NonSemanticShaderDebugInfo100VolatileType = 1,
|
||||||
|
NonSemanticShaderDebugInfo100RestrictType = 2,
|
||||||
|
NonSemanticShaderDebugInfo100AtomicType = 3,
|
||||||
|
NonSemanticShaderDebugInfo100DebugTypeQualifierMax = 0x7fffffff
|
||||||
|
};
|
||||||
|
|
||||||
|
enum NonSemanticShaderDebugInfo100DebugOperation {
|
||||||
|
NonSemanticShaderDebugInfo100Deref = 0,
|
||||||
|
NonSemanticShaderDebugInfo100Plus = 1,
|
||||||
|
NonSemanticShaderDebugInfo100Minus = 2,
|
||||||
|
NonSemanticShaderDebugInfo100PlusUconst = 3,
|
||||||
|
NonSemanticShaderDebugInfo100BitPiece = 4,
|
||||||
|
NonSemanticShaderDebugInfo100Swap = 5,
|
||||||
|
NonSemanticShaderDebugInfo100Xderef = 6,
|
||||||
|
NonSemanticShaderDebugInfo100StackValue = 7,
|
||||||
|
NonSemanticShaderDebugInfo100Constu = 8,
|
||||||
|
NonSemanticShaderDebugInfo100Fragment = 9,
|
||||||
|
NonSemanticShaderDebugInfo100DebugOperationMax = 0x7fffffff
|
||||||
|
};
|
||||||
|
|
||||||
|
enum NonSemanticShaderDebugInfo100DebugImportedEntity {
|
||||||
|
NonSemanticShaderDebugInfo100ImportedModule = 0,
|
||||||
|
NonSemanticShaderDebugInfo100ImportedDeclaration = 1,
|
||||||
|
NonSemanticShaderDebugInfo100DebugImportedEntityMax = 0x7fffffff
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // SPIRV_UNIFIED1_NonSemanticShaderDebugInfo100_H_
|
35
thirdparty/glslang/SPIRV/SPVRemapper.cpp
vendored
35
thirdparty/glslang/SPIRV/SPVRemapper.cpp
vendored
@ -160,15 +160,29 @@ namespace spv {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Is this an opcode we should remove when using --strip?
|
// Is this an opcode we should remove when using --strip?
|
||||||
bool spirvbin_t::isStripOp(spv::Op opCode) const
|
bool spirvbin_t::isStripOp(spv::Op opCode, unsigned start) const
|
||||||
{
|
{
|
||||||
switch (opCode) {
|
switch (opCode) {
|
||||||
case spv::OpSource:
|
case spv::OpSource:
|
||||||
case spv::OpSourceExtension:
|
case spv::OpSourceExtension:
|
||||||
case spv::OpName:
|
case spv::OpName:
|
||||||
case spv::OpMemberName:
|
case spv::OpMemberName:
|
||||||
case spv::OpLine: return true;
|
case spv::OpLine :
|
||||||
default: return false;
|
{
|
||||||
|
const std::string name = literalString(start + 2);
|
||||||
|
|
||||||
|
std::vector<std::string>::const_iterator it;
|
||||||
|
for (it = stripWhiteList.begin(); it < stripWhiteList.end(); it++)
|
||||||
|
{
|
||||||
|
if (name.find(*it) != std::string::npos) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
default :
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -372,7 +386,7 @@ namespace spv {
|
|||||||
process(
|
process(
|
||||||
[&](spv::Op opCode, unsigned start) {
|
[&](spv::Op opCode, unsigned start) {
|
||||||
// remember opcodes we want to strip later
|
// remember opcodes we want to strip later
|
||||||
if (isStripOp(opCode))
|
if (isStripOp(opCode, start))
|
||||||
stripInst(start);
|
stripInst(start);
|
||||||
return true;
|
return true;
|
||||||
},
|
},
|
||||||
@ -1494,13 +1508,24 @@ namespace spv {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// remap from a memory image
|
// remap from a memory image
|
||||||
void spirvbin_t::remap(std::vector<std::uint32_t>& in_spv, std::uint32_t opts)
|
void spirvbin_t::remap(std::vector<std::uint32_t>& in_spv, const std::vector<std::string>& whiteListStrings,
|
||||||
|
std::uint32_t opts)
|
||||||
{
|
{
|
||||||
|
stripWhiteList = whiteListStrings;
|
||||||
spv.swap(in_spv);
|
spv.swap(in_spv);
|
||||||
remap(opts);
|
remap(opts);
|
||||||
spv.swap(in_spv);
|
spv.swap(in_spv);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// remap from a memory image - legacy interface without white list
|
||||||
|
void spirvbin_t::remap(std::vector<std::uint32_t>& in_spv, std::uint32_t opts)
|
||||||
|
{
|
||||||
|
stripWhiteList.clear();
|
||||||
|
spv.swap(in_spv);
|
||||||
|
remap(opts);
|
||||||
|
spv.swap(in_spv);
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace SPV
|
} // namespace SPV
|
||||||
|
|
||||||
#endif // defined (use_cpp11)
|
#endif // defined (use_cpp11)
|
||||||
|
8
thirdparty/glslang/SPIRV/SPVRemapper.h
vendored
8
thirdparty/glslang/SPIRV/SPVRemapper.h
vendored
@ -118,6 +118,10 @@ public:
|
|||||||
virtual ~spirvbin_t() { }
|
virtual ~spirvbin_t() { }
|
||||||
|
|
||||||
// remap on an existing binary in memory
|
// remap on an existing binary in memory
|
||||||
|
void remap(std::vector<std::uint32_t>& spv, const std::vector<std::string>& whiteListStrings,
|
||||||
|
std::uint32_t opts = DO_EVERYTHING);
|
||||||
|
|
||||||
|
// remap on an existing binary in memory - legacy interface without white list
|
||||||
void remap(std::vector<std::uint32_t>& spv, std::uint32_t opts = DO_EVERYTHING);
|
void remap(std::vector<std::uint32_t>& spv, std::uint32_t opts = DO_EVERYTHING);
|
||||||
|
|
||||||
// Type for error/log handler functions
|
// Type for error/log handler functions
|
||||||
@ -180,6 +184,8 @@ private:
|
|||||||
unsigned typeSizeInWords(spv::Id id) const;
|
unsigned typeSizeInWords(spv::Id id) const;
|
||||||
unsigned idTypeSizeInWords(spv::Id id) const;
|
unsigned idTypeSizeInWords(spv::Id id) const;
|
||||||
|
|
||||||
|
bool isStripOp(spv::Op opCode, unsigned start) const;
|
||||||
|
|
||||||
spv::Id& asId(unsigned word) { return spv[word]; }
|
spv::Id& asId(unsigned word) { return spv[word]; }
|
||||||
const spv::Id& asId(unsigned word) const { return spv[word]; }
|
const spv::Id& asId(unsigned word) const { return spv[word]; }
|
||||||
spv::Op asOpCode(unsigned word) const { return opOpCode(spv[word]); }
|
spv::Op asOpCode(unsigned word) const { return opOpCode(spv[word]); }
|
||||||
@ -249,6 +255,8 @@ private:
|
|||||||
|
|
||||||
std::vector<spirword_t> spv; // SPIR words
|
std::vector<spirword_t> spv; // SPIR words
|
||||||
|
|
||||||
|
std::vector<std::string> stripWhiteList;
|
||||||
|
|
||||||
namemap_t nameMap; // ID names from OpName
|
namemap_t nameMap; // ID names from OpName
|
||||||
|
|
||||||
// Since we want to also do binary ops, we can't use std::vector<bool>. we could use
|
// Since we want to also do binary ops, we can't use std::vector<bool>. we could use
|
||||||
|
746
thirdparty/glslang/SPIRV/SpvBuilder.cpp
vendored
746
thirdparty/glslang/SPIRV/SpvBuilder.cpp
vendored
@ -59,12 +59,15 @@ namespace spv {
|
|||||||
|
|
||||||
Builder::Builder(unsigned int spvVersion, unsigned int magicNumber, SpvBuildLogger* buildLogger) :
|
Builder::Builder(unsigned int spvVersion, unsigned int magicNumber, SpvBuildLogger* buildLogger) :
|
||||||
spvVersion(spvVersion),
|
spvVersion(spvVersion),
|
||||||
source(SourceLanguageUnknown),
|
sourceLang(SourceLanguageUnknown),
|
||||||
sourceVersion(0),
|
sourceVersion(0),
|
||||||
sourceFileStringId(NoResult),
|
sourceFileStringId(NoResult),
|
||||||
currentLine(0),
|
currentLine(0),
|
||||||
currentFile(nullptr),
|
currentFile(nullptr),
|
||||||
|
currentFileId(NoResult),
|
||||||
|
lastDebugScopeId(NoResult),
|
||||||
emitOpLines(false),
|
emitOpLines(false),
|
||||||
|
emitNonSemanticShaderDebugInfo(false),
|
||||||
addressModel(AddressingModelLogical),
|
addressModel(AddressingModelLogical),
|
||||||
memoryModel(MemoryModelGLSL450),
|
memoryModel(MemoryModelGLSL450),
|
||||||
builderNumber(magicNumber),
|
builderNumber(magicNumber),
|
||||||
@ -98,8 +101,12 @@ void Builder::setLine(int lineNum)
|
|||||||
{
|
{
|
||||||
if (lineNum != 0 && lineNum != currentLine) {
|
if (lineNum != 0 && lineNum != currentLine) {
|
||||||
currentLine = lineNum;
|
currentLine = lineNum;
|
||||||
if (emitOpLines)
|
if (emitOpLines) {
|
||||||
addLine(sourceFileStringId, currentLine, 0);
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
addDebugScopeAndLine(currentFileId, currentLine, 0);
|
||||||
|
else
|
||||||
|
addLine(sourceFileStringId, currentLine, 0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -118,7 +125,10 @@ void Builder::setLine(int lineNum, const char* filename)
|
|||||||
currentFile = filename;
|
currentFile = filename;
|
||||||
if (emitOpLines) {
|
if (emitOpLines) {
|
||||||
spv::Id strId = getStringId(filename);
|
spv::Id strId = getStringId(filename);
|
||||||
addLine(strId, currentLine, 0);
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
addDebugScopeAndLine(strId, currentLine, 0);
|
||||||
|
else
|
||||||
|
addLine(strId, currentLine, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -132,22 +142,49 @@ void Builder::addLine(Id fileName, int lineNum, int column)
|
|||||||
buildPoint->addInstruction(std::unique_ptr<Instruction>(line));
|
buildPoint->addInstruction(std::unique_ptr<Instruction>(line));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Builder::addDebugScopeAndLine(Id fileName, int lineNum, int column)
|
||||||
|
{
|
||||||
|
if (currentDebugScopeId.top() != lastDebugScopeId) {
|
||||||
|
spv::Id resultId = getUniqueId();
|
||||||
|
Instruction* scopeInst = new Instruction(resultId, makeVoidType(), OpExtInst);
|
||||||
|
scopeInst->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
scopeInst->addImmediateOperand(NonSemanticShaderDebugInfo100DebugScope);
|
||||||
|
scopeInst->addIdOperand(currentDebugScopeId.top());
|
||||||
|
buildPoint->addInstruction(std::unique_ptr<Instruction>(scopeInst));
|
||||||
|
lastDebugScopeId = currentDebugScopeId.top();
|
||||||
|
}
|
||||||
|
spv::Id resultId = getUniqueId();
|
||||||
|
Instruction* lineInst = new Instruction(resultId, makeVoidType(), OpExtInst);
|
||||||
|
lineInst->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
lineInst->addImmediateOperand(NonSemanticShaderDebugInfo100DebugLine);
|
||||||
|
lineInst->addIdOperand(makeDebugSource(fileName));
|
||||||
|
lineInst->addIdOperand(makeUintConstant(lineNum));
|
||||||
|
lineInst->addIdOperand(makeUintConstant(lineNum));
|
||||||
|
lineInst->addIdOperand(makeUintConstant(column));
|
||||||
|
lineInst->addIdOperand(makeUintConstant(column));
|
||||||
|
buildPoint->addInstruction(std::unique_ptr<Instruction>(lineInst));
|
||||||
|
}
|
||||||
|
|
||||||
// For creating new groupedTypes (will return old type if the requested one was already made).
|
// For creating new groupedTypes (will return old type if the requested one was already made).
|
||||||
Id Builder::makeVoidType()
|
Id Builder::makeVoidType()
|
||||||
{
|
{
|
||||||
Instruction* type;
|
Instruction* type;
|
||||||
if (groupedTypes[OpTypeVoid].size() == 0) {
|
if (groupedTypes[OpTypeVoid].size() == 0) {
|
||||||
type = new Instruction(getUniqueId(), NoType, OpTypeVoid);
|
Id typeId = getUniqueId();
|
||||||
|
type = new Instruction(typeId, NoType, OpTypeVoid);
|
||||||
groupedTypes[OpTypeVoid].push_back(type);
|
groupedTypes[OpTypeVoid].push_back(type);
|
||||||
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
module.mapInstruction(type);
|
module.mapInstruction(type);
|
||||||
|
// Core OpTypeVoid used for debug void type
|
||||||
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
debugId[typeId] = typeId;
|
||||||
} else
|
} else
|
||||||
type = groupedTypes[OpTypeVoid].back();
|
type = groupedTypes[OpTypeVoid].back();
|
||||||
|
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
}
|
}
|
||||||
|
|
||||||
Id Builder::makeBoolType()
|
Id Builder::makeBoolType(bool const compilerGenerated)
|
||||||
{
|
{
|
||||||
Instruction* type;
|
Instruction* type;
|
||||||
if (groupedTypes[OpTypeBool].size() == 0) {
|
if (groupedTypes[OpTypeBool].size() == 0) {
|
||||||
@ -158,6 +195,12 @@ Id Builder::makeBoolType()
|
|||||||
} else
|
} else
|
||||||
type = groupedTypes[OpTypeBool].back();
|
type = groupedTypes[OpTypeBool].back();
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo && !compilerGenerated)
|
||||||
|
{
|
||||||
|
auto const debugResultId = makeBoolDebugType(32);
|
||||||
|
debugId[type->getResultId()] = debugResultId;
|
||||||
|
}
|
||||||
|
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -172,6 +215,12 @@ Id Builder::makeSamplerType()
|
|||||||
} else
|
} else
|
||||||
type = groupedTypes[OpTypeSampler].back();
|
type = groupedTypes[OpTypeSampler].back();
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
{
|
||||||
|
auto const debugResultId = makeCompositeDebugType({}, "type.sampler", NonSemanticShaderDebugInfo100Structure, true);
|
||||||
|
debugId[type->getResultId()] = debugResultId;
|
||||||
|
}
|
||||||
|
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -268,6 +317,12 @@ Id Builder::makeIntegerType(int width, bool hasSign)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
{
|
||||||
|
auto const debugResultId = makeIntegerDebugType(width, hasSign);
|
||||||
|
debugId[type->getResultId()] = debugResultId;
|
||||||
|
}
|
||||||
|
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -305,6 +360,12 @@ Id Builder::makeFloatType(int width)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
{
|
||||||
|
auto const debugResultId = makeFloatDebugType(width);
|
||||||
|
debugId[type->getResultId()] = debugResultId;
|
||||||
|
}
|
||||||
|
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -312,7 +373,7 @@ Id Builder::makeFloatType(int width)
|
|||||||
// See makeStructResultType() for non-decorated structs
|
// See makeStructResultType() for non-decorated structs
|
||||||
// needed as the result of some instructions, which does
|
// needed as the result of some instructions, which does
|
||||||
// check for duplicates.
|
// check for duplicates.
|
||||||
Id Builder::makeStructType(const std::vector<Id>& members, const char* name)
|
Id Builder::makeStructType(const std::vector<Id>& members, const char* name, bool const compilerGenerated)
|
||||||
{
|
{
|
||||||
// Don't look for previous one, because in the general case,
|
// Don't look for previous one, because in the general case,
|
||||||
// structs can be duplicated except for decorations.
|
// structs can be duplicated except for decorations.
|
||||||
@ -326,6 +387,12 @@ Id Builder::makeStructType(const std::vector<Id>& members, const char* name)
|
|||||||
module.mapInstruction(type);
|
module.mapInstruction(type);
|
||||||
addName(type->getResultId(), name);
|
addName(type->getResultId(), name);
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo && !compilerGenerated)
|
||||||
|
{
|
||||||
|
auto const debugResultId = makeCompositeDebugType(members, name, NonSemanticShaderDebugInfo100Structure);
|
||||||
|
debugId[type->getResultId()] = debugResultId;
|
||||||
|
}
|
||||||
|
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -372,6 +439,12 @@ Id Builder::makeVectorType(Id component, int size)
|
|||||||
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
module.mapInstruction(type);
|
module.mapInstruction(type);
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
{
|
||||||
|
auto const debugResultId = makeVectorDebugType(component, size);
|
||||||
|
debugId[type->getResultId()] = debugResultId;
|
||||||
|
}
|
||||||
|
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -398,6 +471,12 @@ Id Builder::makeMatrixType(Id component, int cols, int rows)
|
|||||||
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
module.mapInstruction(type);
|
module.mapInstruction(type);
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
{
|
||||||
|
auto const debugResultId = makeMatrixDebugType(column, cols);
|
||||||
|
debugId[type->getResultId()] = debugResultId;
|
||||||
|
}
|
||||||
|
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -484,6 +563,12 @@ Id Builder::makeArrayType(Id element, Id sizeId, int stride)
|
|||||||
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
module.mapInstruction(type);
|
module.mapInstruction(type);
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
{
|
||||||
|
auto const debugResultId = makeArrayDebugType(element, sizeId);
|
||||||
|
debugId[type->getResultId()] = debugResultId;
|
||||||
|
}
|
||||||
|
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -494,6 +579,12 @@ Id Builder::makeRuntimeArray(Id element)
|
|||||||
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
module.mapInstruction(type);
|
module.mapInstruction(type);
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
{
|
||||||
|
auto const debugResultId = makeArrayDebugType(element, makeUintConstant(0));
|
||||||
|
debugId[type->getResultId()] = debugResultId;
|
||||||
|
}
|
||||||
|
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -513,11 +604,25 @@ Id Builder::makeFunctionType(Id returnType, const std::vector<Id>& paramTypes)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (! mismatch)
|
if (! mismatch)
|
||||||
|
{
|
||||||
|
// If compiling HLSL, glslang will create a wrapper function around the entrypoint. Accordingly, a void(void)
|
||||||
|
// function type is created for the wrapper function. However, nonsemantic shader debug information is disabled
|
||||||
|
// while creating the HLSL wrapper. Consequently, if we encounter another void(void) function, we need to create
|
||||||
|
// the associated debug function type if it hasn't been created yet.
|
||||||
|
if(emitNonSemanticShaderDebugInfo && debugId[type->getResultId()] == 0) {
|
||||||
|
assert(sourceLang == spv::SourceLanguageHLSL);
|
||||||
|
assert(getTypeClass(returnType) == OpTypeVoid && paramTypes.size() == 0);
|
||||||
|
|
||||||
|
Id debugTypeId = makeDebugFunctionType(returnType, {});
|
||||||
|
debugId[type->getResultId()] = debugTypeId;
|
||||||
|
}
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// not found, make it
|
// not found, make it
|
||||||
type = new Instruction(getUniqueId(), NoType, OpTypeFunction);
|
Id typeId = getUniqueId();
|
||||||
|
type = new Instruction(typeId, NoType, OpTypeFunction);
|
||||||
type->addIdOperand(returnType);
|
type->addIdOperand(returnType);
|
||||||
for (int p = 0; p < (int)paramTypes.size(); ++p)
|
for (int p = 0; p < (int)paramTypes.size(); ++p)
|
||||||
type->addIdOperand(paramTypes[p]);
|
type->addIdOperand(paramTypes[p]);
|
||||||
@ -525,9 +630,34 @@ Id Builder::makeFunctionType(Id returnType, const std::vector<Id>& paramTypes)
|
|||||||
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
module.mapInstruction(type);
|
module.mapInstruction(type);
|
||||||
|
|
||||||
|
// make debug type and map it
|
||||||
|
if (emitNonSemanticShaderDebugInfo) {
|
||||||
|
Id debugTypeId = makeDebugFunctionType(returnType, paramTypes);
|
||||||
|
debugId[typeId] = debugTypeId;
|
||||||
|
}
|
||||||
|
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Id Builder::makeDebugFunctionType(Id returnType, const std::vector<Id>& paramTypes)
|
||||||
|
{
|
||||||
|
assert(debugId[returnType] != 0);
|
||||||
|
|
||||||
|
Id typeId = getUniqueId();
|
||||||
|
auto type = new Instruction(typeId, makeVoidType(), OpExtInst);
|
||||||
|
type->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
type->addImmediateOperand(NonSemanticShaderDebugInfo100DebugTypeFunction);
|
||||||
|
type->addIdOperand(makeUintConstant(NonSemanticShaderDebugInfo100FlagIsPublic));
|
||||||
|
type->addIdOperand(debugId[returnType]);
|
||||||
|
for (auto const paramType : paramTypes) {
|
||||||
|
assert(isPointerType(paramType) || isArrayType(paramType));
|
||||||
|
type->addIdOperand(debugId[getContainedTypeId(paramType)]);
|
||||||
|
}
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
|
module.mapInstruction(type);
|
||||||
|
return typeId;
|
||||||
|
}
|
||||||
|
|
||||||
Id Builder::makeImageType(Id sampledType, Dim dim, bool depth, bool arrayed, bool ms, unsigned sampled,
|
Id Builder::makeImageType(Id sampledType, Dim dim, bool depth, bool arrayed, bool ms, unsigned sampled,
|
||||||
ImageFormat format)
|
ImageFormat format)
|
||||||
{
|
{
|
||||||
@ -609,6 +739,22 @@ Id Builder::makeImageType(Id sampledType, Dim dim, bool depth, bool arrayed, boo
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
{
|
||||||
|
auto TypeName = [&dim]() -> char const* {
|
||||||
|
switch (dim) {
|
||||||
|
case Dim1D: return "type.1d.image";
|
||||||
|
case Dim2D: return "type.2d.image";
|
||||||
|
case Dim3D: return "type.3d.image";
|
||||||
|
case DimCube: return "type.cube.image";
|
||||||
|
default: return "type.image";
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
auto const debugResultId = makeCompositeDebugType({}, TypeName(), NonSemanticShaderDebugInfo100Class, true);
|
||||||
|
debugId[type->getResultId()] = debugResultId;
|
||||||
|
}
|
||||||
|
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -630,9 +776,376 @@ Id Builder::makeSampledImageType(Id imageType)
|
|||||||
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
module.mapInstruction(type);
|
module.mapInstruction(type);
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
{
|
||||||
|
auto const debugResultId = makeCompositeDebugType({}, "type.sampled.image", NonSemanticShaderDebugInfo100Class, true);
|
||||||
|
debugId[type->getResultId()] = debugResultId;
|
||||||
|
}
|
||||||
|
|
||||||
return type->getResultId();
|
return type->getResultId();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Id Builder::makeDebugInfoNone()
|
||||||
|
{
|
||||||
|
if (debugInfoNone != 0)
|
||||||
|
return debugInfoNone;
|
||||||
|
|
||||||
|
Instruction* inst = new Instruction(getUniqueId(), makeVoidType(), OpExtInst);
|
||||||
|
inst->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
inst->addImmediateOperand(NonSemanticShaderDebugInfo100DebugInfoNone);
|
||||||
|
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(inst));
|
||||||
|
module.mapInstruction(inst);
|
||||||
|
|
||||||
|
debugInfoNone = inst->getResultId();
|
||||||
|
|
||||||
|
return debugInfoNone;
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::makeBoolDebugType(int const size)
|
||||||
|
{
|
||||||
|
// try to find it
|
||||||
|
Instruction* type;
|
||||||
|
for (int t = 0; t < (int)groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeBasic].size(); ++t) {
|
||||||
|
type = groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeBasic][t];
|
||||||
|
if (type->getIdOperand(0) == getStringId("bool") &&
|
||||||
|
type->getIdOperand(1) == static_cast<unsigned int>(size) &&
|
||||||
|
type->getIdOperand(2) == NonSemanticShaderDebugInfo100Boolean)
|
||||||
|
return type->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
type = new Instruction(getUniqueId(), makeVoidType(), OpExtInst);
|
||||||
|
type->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
type->addImmediateOperand(NonSemanticShaderDebugInfo100DebugTypeBasic);
|
||||||
|
|
||||||
|
type->addIdOperand(getStringId("bool")); // name id
|
||||||
|
type->addIdOperand(makeUintConstant(size)); // size id
|
||||||
|
type->addIdOperand(makeUintConstant(NonSemanticShaderDebugInfo100Boolean)); // encoding id
|
||||||
|
type->addIdOperand(makeUintConstant(NonSemanticShaderDebugInfo100None)); // flags id
|
||||||
|
|
||||||
|
groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeBasic].push_back(type);
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
|
module.mapInstruction(type);
|
||||||
|
|
||||||
|
return type->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::makeIntegerDebugType(int const width, bool const hasSign)
|
||||||
|
{
|
||||||
|
// try to find it
|
||||||
|
Instruction* type;
|
||||||
|
for (int t = 0; t < (int)groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeBasic].size(); ++t) {
|
||||||
|
type = groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeBasic][t];
|
||||||
|
if (type->getIdOperand(0) == (hasSign ? getStringId("int") : getStringId("uint")) &&
|
||||||
|
type->getIdOperand(1) == static_cast<unsigned int>(width) &&
|
||||||
|
type->getIdOperand(2) == (hasSign ? NonSemanticShaderDebugInfo100Signed : NonSemanticShaderDebugInfo100Unsigned))
|
||||||
|
return type->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
// not found, make it
|
||||||
|
type = new Instruction(getUniqueId(), makeVoidType(), OpExtInst);
|
||||||
|
type->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
type->addImmediateOperand(NonSemanticShaderDebugInfo100DebugTypeBasic);
|
||||||
|
if(hasSign == true) {
|
||||||
|
type->addIdOperand(getStringId("int")); // name id
|
||||||
|
} else {
|
||||||
|
type->addIdOperand(getStringId("uint")); // name id
|
||||||
|
}
|
||||||
|
type->addIdOperand(makeUintConstant(width)); // size id
|
||||||
|
if(hasSign == true) {
|
||||||
|
type->addIdOperand(makeUintConstant(NonSemanticShaderDebugInfo100Signed)); // encoding id
|
||||||
|
} else {
|
||||||
|
type->addIdOperand(makeUintConstant(NonSemanticShaderDebugInfo100Unsigned)); // encoding id
|
||||||
|
}
|
||||||
|
type->addIdOperand(makeUintConstant(NonSemanticShaderDebugInfo100None)); // flags id
|
||||||
|
|
||||||
|
groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeBasic].push_back(type);
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
|
module.mapInstruction(type);
|
||||||
|
|
||||||
|
return type->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::makeFloatDebugType(int const width)
|
||||||
|
{
|
||||||
|
// try to find it
|
||||||
|
Instruction* type;
|
||||||
|
for (int t = 0; t < (int)groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeBasic].size(); ++t) {
|
||||||
|
type = groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeBasic][t];
|
||||||
|
if (type->getIdOperand(0) == getStringId("float") &&
|
||||||
|
type->getIdOperand(1) == static_cast<unsigned int>(width) &&
|
||||||
|
type->getIdOperand(2) == NonSemanticShaderDebugInfo100Float)
|
||||||
|
return type->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
// not found, make it
|
||||||
|
type = new Instruction(getUniqueId(), makeVoidType(), OpExtInst);
|
||||||
|
type->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
type->addImmediateOperand(NonSemanticShaderDebugInfo100DebugTypeBasic);
|
||||||
|
type->addIdOperand(getStringId("float")); // name id
|
||||||
|
type->addIdOperand(makeUintConstant(width)); // size id
|
||||||
|
type->addIdOperand(makeUintConstant(NonSemanticShaderDebugInfo100Float)); // encoding id
|
||||||
|
type->addIdOperand(makeUintConstant(NonSemanticShaderDebugInfo100None)); // flags id
|
||||||
|
|
||||||
|
groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeBasic].push_back(type);
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
|
module.mapInstruction(type);
|
||||||
|
|
||||||
|
return type->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::makeSequentialDebugType(Id const baseType, Id const componentCount, NonSemanticShaderDebugInfo100Instructions const sequenceType)
|
||||||
|
{
|
||||||
|
assert(sequenceType == NonSemanticShaderDebugInfo100DebugTypeArray ||
|
||||||
|
sequenceType == NonSemanticShaderDebugInfo100DebugTypeVector);
|
||||||
|
|
||||||
|
// try to find it
|
||||||
|
Instruction* type;
|
||||||
|
for (int t = 0; t < (int)groupedDebugTypes[sequenceType].size(); ++t) {
|
||||||
|
type = groupedDebugTypes[sequenceType][t];
|
||||||
|
if (type->getIdOperand(0) == baseType &&
|
||||||
|
type->getIdOperand(1) == makeUintConstant(componentCount))
|
||||||
|
return type->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
// not found, make it
|
||||||
|
type = new Instruction(getUniqueId(), makeVoidType(), OpExtInst);
|
||||||
|
type->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
type->addImmediateOperand(sequenceType);
|
||||||
|
type->addIdOperand(debugId[baseType]); // base type
|
||||||
|
type->addIdOperand(componentCount); // component count
|
||||||
|
|
||||||
|
groupedDebugTypes[sequenceType].push_back(type);
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
|
module.mapInstruction(type);
|
||||||
|
|
||||||
|
return type->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::makeArrayDebugType(Id const baseType, Id const componentCount)
|
||||||
|
{
|
||||||
|
return makeSequentialDebugType(baseType, componentCount, NonSemanticShaderDebugInfo100DebugTypeArray);
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::makeVectorDebugType(Id const baseType, int const componentCount)
|
||||||
|
{
|
||||||
|
return makeSequentialDebugType(baseType, makeUintConstant(componentCount), NonSemanticShaderDebugInfo100DebugTypeVector);;
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::makeMatrixDebugType(Id const vectorType, int const vectorCount, bool columnMajor)
|
||||||
|
{
|
||||||
|
// try to find it
|
||||||
|
Instruction* type;
|
||||||
|
for (int t = 0; t < (int)groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeMatrix].size(); ++t) {
|
||||||
|
type = groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeMatrix][t];
|
||||||
|
if (type->getIdOperand(0) == vectorType &&
|
||||||
|
type->getIdOperand(1) == makeUintConstant(vectorCount))
|
||||||
|
return type->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
// not found, make it
|
||||||
|
type = new Instruction(getUniqueId(), makeVoidType(), OpExtInst);
|
||||||
|
type->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
type->addImmediateOperand(NonSemanticShaderDebugInfo100DebugTypeMatrix);
|
||||||
|
type->addIdOperand(debugId[vectorType]); // vector type id
|
||||||
|
type->addIdOperand(makeUintConstant(vectorCount)); // component count id
|
||||||
|
type->addIdOperand(makeBoolConstant(columnMajor)); // column-major id
|
||||||
|
|
||||||
|
groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeMatrix].push_back(type);
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
|
module.mapInstruction(type);
|
||||||
|
|
||||||
|
return type->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::makeMemberDebugType(Id const memberType, DebugTypeLoc const& debugTypeLoc)
|
||||||
|
{
|
||||||
|
assert(debugId[memberType] != 0);
|
||||||
|
|
||||||
|
Instruction* type = new Instruction(getUniqueId(), makeVoidType(), OpExtInst);
|
||||||
|
type->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
type->addImmediateOperand(NonSemanticShaderDebugInfo100DebugTypeMember);
|
||||||
|
type->addIdOperand(getStringId(debugTypeLoc.name)); // name id
|
||||||
|
type->addIdOperand(debugId[memberType]); // type id
|
||||||
|
type->addIdOperand(makeDebugSource(sourceFileStringId)); // source id TODO: verify this works across include directives
|
||||||
|
type->addIdOperand(makeUintConstant(debugTypeLoc.line)); // line id TODO: currentLine is always zero
|
||||||
|
type->addIdOperand(makeUintConstant(debugTypeLoc.column)); // TODO: column id
|
||||||
|
type->addIdOperand(makeUintConstant(0)); // TODO: offset id
|
||||||
|
type->addIdOperand(makeUintConstant(0)); // TODO: size id
|
||||||
|
type->addIdOperand(makeUintConstant(NonSemanticShaderDebugInfo100FlagIsPublic)); // flags id
|
||||||
|
|
||||||
|
groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeMember].push_back(type);
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
|
module.mapInstruction(type);
|
||||||
|
|
||||||
|
return type->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Note: To represent a source language opaque type, this instruction must have no Members operands, Size operand must be
|
||||||
|
// DebugInfoNone, and Name must start with @ to avoid clashes with user defined names.
|
||||||
|
Id Builder::makeCompositeDebugType(std::vector<Id> const& memberTypes, char const*const name,
|
||||||
|
NonSemanticShaderDebugInfo100DebugCompositeType const tag, bool const isOpaqueType)
|
||||||
|
{
|
||||||
|
// Create the debug member types.
|
||||||
|
std::vector<Id> memberDebugTypes;
|
||||||
|
for(auto const memberType : memberTypes) {
|
||||||
|
assert(debugTypeLocs.find(memberType) != debugTypeLocs.end());
|
||||||
|
|
||||||
|
memberDebugTypes.emplace_back(makeMemberDebugType(memberType, debugTypeLocs[memberType]));
|
||||||
|
|
||||||
|
// TODO: Need to rethink this method of passing location information.
|
||||||
|
// debugTypeLocs.erase(memberType);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create The structure debug type.
|
||||||
|
Instruction* type = new Instruction(getUniqueId(), makeVoidType(), OpExtInst);
|
||||||
|
type->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
type->addImmediateOperand(NonSemanticShaderDebugInfo100DebugTypeComposite);
|
||||||
|
type->addIdOperand(getStringId(name)); // name id
|
||||||
|
type->addIdOperand(makeUintConstant(tag)); // tag id
|
||||||
|
type->addIdOperand(makeDebugSource(sourceFileStringId)); // source id TODO: verify this works across include directives
|
||||||
|
type->addIdOperand(makeUintConstant(currentLine)); // line id TODO: currentLine always zero?
|
||||||
|
type->addIdOperand(makeUintConstant(0)); // TODO: column id
|
||||||
|
type->addIdOperand(makeDebugCompilationUnit()); // scope id
|
||||||
|
if(isOpaqueType == true) {
|
||||||
|
// Prepend '@' to opaque types.
|
||||||
|
type->addIdOperand(getStringId('@' + std::string(name))); // linkage name id
|
||||||
|
type->addIdOperand(makeDebugInfoNone()); // size id
|
||||||
|
} else {
|
||||||
|
type->addIdOperand(getStringId(name)); // linkage name id
|
||||||
|
type->addIdOperand(makeUintConstant(0)); // TODO: size id
|
||||||
|
}
|
||||||
|
type->addIdOperand(makeUintConstant(NonSemanticShaderDebugInfo100FlagIsPublic)); // flags id
|
||||||
|
assert(isOpaqueType == false || (isOpaqueType == true && memberDebugTypes.empty()));
|
||||||
|
for(auto const memberDebugType : memberDebugTypes) {
|
||||||
|
type->addIdOperand(memberDebugType);
|
||||||
|
}
|
||||||
|
|
||||||
|
groupedDebugTypes[NonSemanticShaderDebugInfo100DebugTypeComposite].push_back(type);
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
|
module.mapInstruction(type);
|
||||||
|
|
||||||
|
return type->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::makeDebugSource(const Id fileName) {
|
||||||
|
if (debugSourceId.find(fileName) != debugSourceId.end())
|
||||||
|
return debugSourceId[fileName];
|
||||||
|
spv::Id resultId = getUniqueId();
|
||||||
|
Instruction* sourceInst = new Instruction(resultId, makeVoidType(), OpExtInst);
|
||||||
|
sourceInst->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
sourceInst->addImmediateOperand(NonSemanticShaderDebugInfo100DebugSource);
|
||||||
|
sourceInst->addIdOperand(fileName);
|
||||||
|
if (emitNonSemanticShaderDebugSource) {
|
||||||
|
spv::Id sourceId = 0;
|
||||||
|
if (fileName == sourceFileStringId) {
|
||||||
|
sourceId = getStringId(sourceText);
|
||||||
|
} else {
|
||||||
|
auto incItr = includeFiles.find(fileName);
|
||||||
|
assert(incItr != includeFiles.end());
|
||||||
|
sourceId = getStringId(*incItr->second);
|
||||||
|
}
|
||||||
|
sourceInst->addIdOperand(sourceId);
|
||||||
|
}
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(sourceInst));
|
||||||
|
module.mapInstruction(sourceInst);
|
||||||
|
debugSourceId[fileName] = resultId;
|
||||||
|
return resultId;
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::makeDebugCompilationUnit() {
|
||||||
|
if (nonSemanticShaderCompilationUnitId != 0)
|
||||||
|
return nonSemanticShaderCompilationUnitId;
|
||||||
|
spv::Id resultId = getUniqueId();
|
||||||
|
Instruction* sourceInst = new Instruction(resultId, makeVoidType(), OpExtInst);
|
||||||
|
sourceInst->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
sourceInst->addImmediateOperand(NonSemanticShaderDebugInfo100DebugCompilationUnit);
|
||||||
|
sourceInst->addIdOperand(makeUintConstant(1)); // TODO(greg-lunarg): Get rid of magic number
|
||||||
|
sourceInst->addIdOperand(makeUintConstant(4)); // TODO(greg-lunarg): Get rid of magic number
|
||||||
|
sourceInst->addIdOperand(makeDebugSource(sourceFileStringId));
|
||||||
|
sourceInst->addIdOperand(makeUintConstant(sourceLang));
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(sourceInst));
|
||||||
|
module.mapInstruction(sourceInst);
|
||||||
|
nonSemanticShaderCompilationUnitId = resultId;
|
||||||
|
return resultId;
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::createDebugGlobalVariable(Id const type, char const*const name, Id const variable)
|
||||||
|
{
|
||||||
|
assert(type != 0);
|
||||||
|
|
||||||
|
Instruction* inst = new Instruction(getUniqueId(), makeVoidType(), OpExtInst);
|
||||||
|
inst->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
inst->addImmediateOperand(NonSemanticShaderDebugInfo100DebugGlobalVariable);
|
||||||
|
inst->addIdOperand(getStringId(name)); // name id
|
||||||
|
inst->addIdOperand(type); // type id
|
||||||
|
inst->addIdOperand(makeDebugSource(sourceFileStringId)); // source id
|
||||||
|
inst->addIdOperand(makeUintConstant(currentLine)); // line id TODO: currentLine always zero?
|
||||||
|
inst->addIdOperand(makeUintConstant(0)); // TODO: column id
|
||||||
|
inst->addIdOperand(makeDebugCompilationUnit()); // scope id
|
||||||
|
inst->addIdOperand(getStringId(name)); // linkage name id
|
||||||
|
inst->addIdOperand(variable); // variable id
|
||||||
|
inst->addIdOperand(makeUintConstant(NonSemanticShaderDebugInfo100FlagIsDefinition)); // flags id
|
||||||
|
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(inst));
|
||||||
|
module.mapInstruction(inst);
|
||||||
|
|
||||||
|
return inst->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::createDebugLocalVariable(Id type, char const*const name, size_t const argNumber)
|
||||||
|
{
|
||||||
|
assert(name != nullptr);
|
||||||
|
Instruction* inst = new Instruction(getUniqueId(), makeVoidType(), OpExtInst);
|
||||||
|
inst->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
inst->addImmediateOperand(NonSemanticShaderDebugInfo100DebugLocalVariable);
|
||||||
|
inst->addIdOperand(getStringId(name)); // name id
|
||||||
|
inst->addIdOperand(type); // type id
|
||||||
|
inst->addIdOperand(makeDebugSource(sourceFileStringId)); // source id
|
||||||
|
inst->addIdOperand(makeUintConstant(currentLine)); // line id
|
||||||
|
inst->addIdOperand(makeUintConstant(0)); // TODO: column id
|
||||||
|
inst->addIdOperand(currentDebugScopeId.top()); // scope id
|
||||||
|
inst->addIdOperand(makeUintConstant(NonSemanticShaderDebugInfo100FlagIsLocal)); // flags id
|
||||||
|
if(argNumber != 0) {
|
||||||
|
inst->addIdOperand(makeUintConstant(argNumber));
|
||||||
|
}
|
||||||
|
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(inst));
|
||||||
|
module.mapInstruction(inst);
|
||||||
|
|
||||||
|
return inst->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::makeDebugExpression()
|
||||||
|
{
|
||||||
|
if (debugExpression != 0)
|
||||||
|
return debugExpression;
|
||||||
|
|
||||||
|
Instruction* inst = new Instruction(getUniqueId(), makeVoidType(), OpExtInst);
|
||||||
|
inst->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
inst->addImmediateOperand(NonSemanticShaderDebugInfo100DebugExpression);
|
||||||
|
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(inst));
|
||||||
|
module.mapInstruction(inst);
|
||||||
|
|
||||||
|
debugExpression = inst->getResultId();
|
||||||
|
|
||||||
|
return debugExpression;
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::makeDebugDeclare(Id const debugLocalVariable, Id const localVariable)
|
||||||
|
{
|
||||||
|
Instruction* inst = new Instruction(getUniqueId(), makeVoidType(), OpExtInst);
|
||||||
|
inst->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
inst->addImmediateOperand(NonSemanticShaderDebugInfo100DebugDeclare);
|
||||||
|
inst->addIdOperand(debugLocalVariable); // debug local variable id
|
||||||
|
inst->addIdOperand(localVariable); // local variable id
|
||||||
|
inst->addIdOperand(makeDebugExpression()); // expression id
|
||||||
|
buildPoint->addInstruction(std::unique_ptr<Instruction>(inst));
|
||||||
|
|
||||||
|
return inst->getResultId();
|
||||||
|
}
|
||||||
|
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
Id Builder::makeAccelerationStructureType()
|
Id Builder::makeAccelerationStructureType()
|
||||||
{
|
{
|
||||||
@ -920,6 +1433,17 @@ bool Builder::isSpecConstantOpCode(Op opcode) const
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Builder::isRayTracingOpCode(Op opcode) const
|
||||||
|
{
|
||||||
|
switch (opcode) {
|
||||||
|
case OpTypeAccelerationStructureKHR:
|
||||||
|
case OpTypeRayQueryKHR:
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Id Builder::makeNullConstant(Id typeId)
|
Id Builder::makeNullConstant(Id typeId)
|
||||||
{
|
{
|
||||||
Instruction* constant;
|
Instruction* constant;
|
||||||
@ -1136,6 +1660,19 @@ Id Builder::makeFpConstant(Id type, double d, bool specConstant)
|
|||||||
return NoResult;
|
return NoResult;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Id Builder::importNonSemanticShaderDebugInfoInstructions()
|
||||||
|
{
|
||||||
|
assert(emitNonSemanticShaderDebugInfo == true);
|
||||||
|
|
||||||
|
if(nonSemanticShaderDebugInfo == 0)
|
||||||
|
{
|
||||||
|
this->addExtension(spv::E_SPV_KHR_non_semantic_info);
|
||||||
|
nonSemanticShaderDebugInfo = this->import("NonSemantic.Shader.DebugInfo.100");
|
||||||
|
}
|
||||||
|
|
||||||
|
return nonSemanticShaderDebugInfo;
|
||||||
|
}
|
||||||
|
|
||||||
Id Builder::findCompositeConstant(Op typeClass, Id typeId, const std::vector<Id>& comps)
|
Id Builder::findCompositeConstant(Op typeClass, Id typeId, const std::vector<Id>& comps)
|
||||||
{
|
{
|
||||||
Instruction* constant = 0;
|
Instruction* constant = 0;
|
||||||
@ -1447,23 +1984,34 @@ Function* Builder::makeEntryPoint(const char* entryPoint)
|
|||||||
assert(! entryPointFunction);
|
assert(! entryPointFunction);
|
||||||
|
|
||||||
Block* entry;
|
Block* entry;
|
||||||
std::vector<Id> params;
|
std::vector<Id> paramsTypes;
|
||||||
|
std::vector<char const*> paramNames;
|
||||||
std::vector<std::vector<Decoration>> decorations;
|
std::vector<std::vector<Decoration>> decorations;
|
||||||
|
|
||||||
entryPointFunction = makeFunctionEntry(NoPrecision, makeVoidType(), entryPoint, params, decorations, &entry);
|
auto const returnType = makeVoidType();
|
||||||
|
|
||||||
|
restoreNonSemanticShaderDebugInfo = emitNonSemanticShaderDebugInfo;
|
||||||
|
if(sourceLang == spv::SourceLanguageHLSL) {
|
||||||
|
emitNonSemanticShaderDebugInfo = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
entryPointFunction = makeFunctionEntry(NoPrecision, returnType, entryPoint, paramsTypes, paramNames, decorations, &entry);
|
||||||
|
|
||||||
|
emitNonSemanticShaderDebugInfo = restoreNonSemanticShaderDebugInfo;
|
||||||
|
|
||||||
return entryPointFunction;
|
return entryPointFunction;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Comments in header
|
// Comments in header
|
||||||
Function* Builder::makeFunctionEntry(Decoration precision, Id returnType, const char* name,
|
Function* Builder::makeFunctionEntry(Decoration precision, Id returnType, const char* name,
|
||||||
const std::vector<Id>& paramTypes,
|
const std::vector<Id>& paramTypes, const std::vector<char const*>& paramNames,
|
||||||
const std::vector<std::vector<Decoration>>& decorations, Block **entry)
|
const std::vector<std::vector<Decoration>>& decorations, Block **entry)
|
||||||
{
|
{
|
||||||
// Make the function and initial instructions in it
|
// Make the function and initial instructions in it
|
||||||
Id typeId = makeFunctionType(returnType, paramTypes);
|
Id typeId = makeFunctionType(returnType, paramTypes);
|
||||||
Id firstParamId = paramTypes.size() == 0 ? 0 : getUniqueIds((int)paramTypes.size());
|
Id firstParamId = paramTypes.size() == 0 ? 0 : getUniqueIds((int)paramTypes.size());
|
||||||
Function* function = new Function(getUniqueId(), returnType, typeId, firstParamId, module);
|
Id funcId = getUniqueId();
|
||||||
|
Function* function = new Function(funcId, returnType, typeId, firstParamId, module);
|
||||||
|
|
||||||
// Set up the precisions
|
// Set up the precisions
|
||||||
setPrecision(function->getId(), precision);
|
setPrecision(function->getId(), precision);
|
||||||
@ -1475,11 +2023,39 @@ Function* Builder::makeFunctionEntry(Decoration precision, Id returnType, const
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Make the debug function instruction
|
||||||
|
if (emitNonSemanticShaderDebugInfo) {
|
||||||
|
Id nameId = getStringId(unmangleFunctionName(name));
|
||||||
|
Id debugFuncId = makeDebugFunction(function, nameId, typeId);
|
||||||
|
debugId[funcId] = debugFuncId;
|
||||||
|
currentDebugScopeId.push(debugFuncId);
|
||||||
|
lastDebugScopeId = NoResult;
|
||||||
|
}
|
||||||
|
|
||||||
// CFG
|
// CFG
|
||||||
if (entry) {
|
assert(entry != nullptr);
|
||||||
*entry = new Block(getUniqueId(), *function);
|
*entry = new Block(getUniqueId(), *function);
|
||||||
function->addBlock(*entry);
|
function->addBlock(*entry);
|
||||||
setBuildPoint(*entry);
|
setBuildPoint(*entry);
|
||||||
|
|
||||||
|
// DebugScope and DebugLine for parameter DebugDeclares
|
||||||
|
if (emitNonSemanticShaderDebugInfo && (int)paramTypes.size() > 0) {
|
||||||
|
addDebugScopeAndLine(currentFileId, currentLine, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo) {
|
||||||
|
assert(paramTypes.size() == paramNames.size());
|
||||||
|
for(size_t p = 0; p < paramTypes.size(); ++p)
|
||||||
|
{
|
||||||
|
auto const& paramType = paramTypes[p];
|
||||||
|
assert(isPointerType(paramType) || isArrayType(paramType));
|
||||||
|
assert(debugId[getContainedTypeId(paramType)] != 0);
|
||||||
|
auto const& paramName = paramNames[p];
|
||||||
|
auto const debugLocalVariableId = createDebugLocalVariable(debugId[getContainedTypeId(paramType)], paramName, p+1);
|
||||||
|
debugId[firstParamId + p] = debugLocalVariableId;
|
||||||
|
|
||||||
|
makeDebugDeclare(debugLocalVariableId, firstParamId + p);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (name)
|
if (name)
|
||||||
@ -1487,9 +2063,62 @@ Function* Builder::makeFunctionEntry(Decoration precision, Id returnType, const
|
|||||||
|
|
||||||
functions.push_back(std::unique_ptr<Function>(function));
|
functions.push_back(std::unique_ptr<Function>(function));
|
||||||
|
|
||||||
|
// Clear debug scope stack
|
||||||
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
currentDebugScopeId.pop();
|
||||||
|
|
||||||
return function;
|
return function;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Id Builder::makeDebugFunction(Function* function, Id nameId, Id funcTypeId) {
|
||||||
|
assert(function != nullptr);
|
||||||
|
assert(nameId != 0);
|
||||||
|
assert(funcTypeId != 0);
|
||||||
|
assert(debugId[funcTypeId] != 0);
|
||||||
|
|
||||||
|
Id funcId = getUniqueId();
|
||||||
|
auto type = new Instruction(funcId, makeVoidType(), OpExtInst);
|
||||||
|
type->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
type->addImmediateOperand(NonSemanticShaderDebugInfo100DebugFunction);
|
||||||
|
type->addIdOperand(nameId);
|
||||||
|
type->addIdOperand(debugId[funcTypeId]);
|
||||||
|
type->addIdOperand(makeDebugSource(currentFileId)); // Will be fixed later when true filename available
|
||||||
|
type->addIdOperand(makeUintConstant(currentLine)); // Will be fixed later when true line available
|
||||||
|
type->addIdOperand(makeUintConstant(0)); // column
|
||||||
|
type->addIdOperand(makeDebugCompilationUnit()); // scope
|
||||||
|
type->addIdOperand(nameId); // linkage name
|
||||||
|
type->addIdOperand(makeUintConstant(NonSemanticShaderDebugInfo100FlagIsPublic));
|
||||||
|
type->addIdOperand(makeUintConstant(currentLine)); // TODO(greg-lunarg): correct scope line
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(type));
|
||||||
|
module.mapInstruction(type);
|
||||||
|
return funcId;
|
||||||
|
}
|
||||||
|
|
||||||
|
Id Builder::makeDebugLexicalBlock(uint32_t line) {
|
||||||
|
Id lexId = getUniqueId();
|
||||||
|
auto lex = new Instruction(lexId, makeVoidType(), OpExtInst);
|
||||||
|
lex->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
lex->addImmediateOperand(NonSemanticShaderDebugInfo100DebugLexicalBlock);
|
||||||
|
lex->addIdOperand(makeDebugSource(currentFileId));
|
||||||
|
lex->addIdOperand(makeUintConstant(line));
|
||||||
|
lex->addIdOperand(makeUintConstant(0)); // column
|
||||||
|
lex->addIdOperand(currentDebugScopeId.top()); // scope
|
||||||
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(lex));
|
||||||
|
module.mapInstruction(lex);
|
||||||
|
return lexId;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string Builder::unmangleFunctionName(std::string const& name) const
|
||||||
|
{
|
||||||
|
assert(name.length() > 0);
|
||||||
|
|
||||||
|
if(name.rfind('(') != std::string::npos) {
|
||||||
|
return name.substr(0, name.rfind('('));
|
||||||
|
} else {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Comments in header
|
// Comments in header
|
||||||
void Builder::makeReturn(bool implicit, Id retVal)
|
void Builder::makeReturn(bool implicit, Id retVal)
|
||||||
{
|
{
|
||||||
@ -1504,6 +2133,48 @@ void Builder::makeReturn(bool implicit, Id retVal)
|
|||||||
createAndSetNoPredecessorBlock("post-return");
|
createAndSetNoPredecessorBlock("post-return");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Comments in header
|
||||||
|
void Builder::enterScope(uint32_t line)
|
||||||
|
{
|
||||||
|
// Generate new lexical scope debug instruction
|
||||||
|
Id lexId = makeDebugLexicalBlock(line);
|
||||||
|
currentDebugScopeId.push(lexId);
|
||||||
|
lastDebugScopeId = NoResult;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Comments in header
|
||||||
|
void Builder::leaveScope()
|
||||||
|
{
|
||||||
|
// Pop current scope from stack and clear current scope
|
||||||
|
currentDebugScopeId.pop();
|
||||||
|
lastDebugScopeId = NoResult;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Comments in header
|
||||||
|
void Builder::enterFunction(Function const* function)
|
||||||
|
{
|
||||||
|
// Save and disable debugInfo for HLSL entry point function. It is a wrapper
|
||||||
|
// function with no user code in it.
|
||||||
|
restoreNonSemanticShaderDebugInfo = emitNonSemanticShaderDebugInfo;
|
||||||
|
if (sourceLang == spv::SourceLanguageHLSL && function == entryPointFunction) {
|
||||||
|
emitNonSemanticShaderDebugInfo = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo) {
|
||||||
|
// Initialize scope state
|
||||||
|
Id funcId = function->getFuncId();
|
||||||
|
currentDebugScopeId.push(debugId[funcId]);
|
||||||
|
// Create DebugFunctionDefinition
|
||||||
|
spv::Id resultId = getUniqueId();
|
||||||
|
Instruction* defInst = new Instruction(resultId, makeVoidType(), OpExtInst);
|
||||||
|
defInst->addIdOperand(nonSemanticShaderDebugInfo);
|
||||||
|
defInst->addImmediateOperand(NonSemanticShaderDebugInfo100DebugFunctionDefinition);
|
||||||
|
defInst->addIdOperand(debugId[funcId]);
|
||||||
|
defInst->addIdOperand(funcId);
|
||||||
|
buildPoint->addInstruction(std::unique_ptr<Instruction>(defInst));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Comments in header
|
// Comments in header
|
||||||
void Builder::leaveFunction()
|
void Builder::leaveFunction()
|
||||||
{
|
{
|
||||||
@ -1519,6 +2190,12 @@ void Builder::leaveFunction()
|
|||||||
makeReturn(true, createUndefined(function.getReturnType()));
|
makeReturn(true, createUndefined(function.getReturnType()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Clear function scope from debug scope stack
|
||||||
|
if (emitNonSemanticShaderDebugInfo)
|
||||||
|
currentDebugScopeId.pop();
|
||||||
|
|
||||||
|
emitNonSemanticShaderDebugInfo = restoreNonSemanticShaderDebugInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Comments in header
|
// Comments in header
|
||||||
@ -1529,7 +2206,18 @@ void Builder::makeStatementTerminator(spv::Op opcode, const char *name)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Comments in header
|
// Comments in header
|
||||||
Id Builder::createVariable(Decoration precision, StorageClass storageClass, Id type, const char* name, Id initializer)
|
void Builder::makeStatementTerminator(spv::Op opcode, const std::vector<Id>& operands, const char* name)
|
||||||
|
{
|
||||||
|
// It's assumed that the terminator instruction is always of void return type
|
||||||
|
// However in future if there is a need for non void return type, new helper
|
||||||
|
// methods can be created.
|
||||||
|
createNoResultOp(opcode, operands);
|
||||||
|
createAndSetNoPredecessorBlock(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Comments in header
|
||||||
|
Id Builder::createVariable(Decoration precision, StorageClass storageClass, Id type, const char* name, Id initializer,
|
||||||
|
bool const compilerGenerated)
|
||||||
{
|
{
|
||||||
Id pointerType = makePointer(storageClass, type);
|
Id pointerType = makePointer(storageClass, type);
|
||||||
Instruction* inst = new Instruction(getUniqueId(), pointerType, OpVariable);
|
Instruction* inst = new Instruction(getUniqueId(), pointerType, OpVariable);
|
||||||
@ -1541,11 +2229,26 @@ Id Builder::createVariable(Decoration precision, StorageClass storageClass, Id t
|
|||||||
case StorageClassFunction:
|
case StorageClassFunction:
|
||||||
// Validation rules require the declaration in the entry block
|
// Validation rules require the declaration in the entry block
|
||||||
buildPoint->getParent().addLocalVariable(std::unique_ptr<Instruction>(inst));
|
buildPoint->getParent().addLocalVariable(std::unique_ptr<Instruction>(inst));
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo && !compilerGenerated)
|
||||||
|
{
|
||||||
|
auto const debugLocalVariableId = createDebugLocalVariable(debugId[type], name);
|
||||||
|
debugId[inst->getResultId()] = debugLocalVariableId;
|
||||||
|
|
||||||
|
makeDebugDeclare(debugLocalVariableId, inst->getResultId());
|
||||||
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(inst));
|
constantsTypesGlobals.push_back(std::unique_ptr<Instruction>(inst));
|
||||||
module.mapInstruction(inst);
|
module.mapInstruction(inst);
|
||||||
|
|
||||||
|
if (emitNonSemanticShaderDebugInfo && !isRayTracingOpCode(getOpCode(type)))
|
||||||
|
{
|
||||||
|
auto const debugResultId = createDebugGlobalVariable(debugId[type], name, inst->getResultId());
|
||||||
|
debugId[inst->getResultId()] = debugResultId;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1575,7 +2278,7 @@ spv::MemoryAccessMask Builder::sanitizeMemoryAccessForStorageClass(spv::MemoryAc
|
|||||||
case spv::StorageClassPhysicalStorageBufferEXT:
|
case spv::StorageClassPhysicalStorageBufferEXT:
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
memoryAccess = spv::MemoryAccessMask(memoryAccess &
|
memoryAccess = spv::MemoryAccessMask(memoryAccess &
|
||||||
~(spv::MemoryAccessMakePointerAvailableKHRMask |
|
~(spv::MemoryAccessMakePointerAvailableKHRMask |
|
||||||
spv::MemoryAccessMakePointerVisibleKHRMask |
|
spv::MemoryAccessMakePointerVisibleKHRMask |
|
||||||
spv::MemoryAccessNonPrivatePointerKHRMask));
|
spv::MemoryAccessNonPrivatePointerKHRMask));
|
||||||
@ -2051,7 +2754,7 @@ Id Builder::createTextureCall(Decoration precision, Id resultType, bool sparse,
|
|||||||
texArgs[numArgs++] = parameters.granularity;
|
texArgs[numArgs++] = parameters.granularity;
|
||||||
if (parameters.coarse != NoResult)
|
if (parameters.coarse != NoResult)
|
||||||
texArgs[numArgs++] = parameters.coarse;
|
texArgs[numArgs++] = parameters.coarse;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//
|
//
|
||||||
// Set up the optional arguments
|
// Set up the optional arguments
|
||||||
@ -3271,10 +3974,10 @@ void Builder::dumpSourceInstructions(const spv::Id fileId, const std::string& te
|
|||||||
const int opSourceWordCount = 4;
|
const int opSourceWordCount = 4;
|
||||||
const int nonNullBytesPerInstruction = 4 * (maxWordCount - opSourceWordCount) - 1;
|
const int nonNullBytesPerInstruction = 4 * (maxWordCount - opSourceWordCount) - 1;
|
||||||
|
|
||||||
if (source != SourceLanguageUnknown) {
|
if (sourceLang != SourceLanguageUnknown) {
|
||||||
// OpSource Language Version File Source
|
// OpSource Language Version File Source
|
||||||
Instruction sourceInst(NoResult, NoType, OpSource);
|
Instruction sourceInst(NoResult, NoType, OpSource);
|
||||||
sourceInst.addImmediateOperand(source);
|
sourceInst.addImmediateOperand(sourceLang);
|
||||||
sourceInst.addImmediateOperand(sourceVersion);
|
sourceInst.addImmediateOperand(sourceVersion);
|
||||||
// File operand
|
// File operand
|
||||||
if (fileId != NoResult) {
|
if (fileId != NoResult) {
|
||||||
@ -3307,6 +4010,7 @@ void Builder::dumpSourceInstructions(const spv::Id fileId, const std::string& te
|
|||||||
// Dump an OpSource[Continued] sequence for the source and every include file
|
// Dump an OpSource[Continued] sequence for the source and every include file
|
||||||
void Builder::dumpSourceInstructions(std::vector<unsigned int>& out) const
|
void Builder::dumpSourceInstructions(std::vector<unsigned int>& out) const
|
||||||
{
|
{
|
||||||
|
if (emitNonSemanticShaderDebugInfo) return;
|
||||||
dumpSourceInstructions(sourceFileStringId, sourceText, out);
|
dumpSourceInstructions(sourceFileStringId, sourceText, out);
|
||||||
for (auto iItr = includeFiles.begin(); iItr != includeFiles.end(); ++iItr)
|
for (auto iItr = includeFiles.begin(); iItr != includeFiles.end(); ++iItr)
|
||||||
dumpSourceInstructions(iItr->first, *iItr->second, out);
|
dumpSourceInstructions(iItr->first, *iItr->second, out);
|
||||||
|
110
thirdparty/glslang/SPIRV/SpvBuilder.h
vendored
110
thirdparty/glslang/SPIRV/SpvBuilder.h
vendored
@ -50,6 +50,10 @@
|
|||||||
#include "Logger.h"
|
#include "Logger.h"
|
||||||
#include "spirv.hpp"
|
#include "spirv.hpp"
|
||||||
#include "spvIR.h"
|
#include "spvIR.h"
|
||||||
|
namespace spv {
|
||||||
|
#include "GLSL.ext.KHR.h"
|
||||||
|
#include "NonSemanticShaderDebugInfo100.h"
|
||||||
|
}
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <map>
|
#include <map>
|
||||||
@ -82,7 +86,7 @@ public:
|
|||||||
|
|
||||||
void setSource(spv::SourceLanguage lang, int version)
|
void setSource(spv::SourceLanguage lang, int version)
|
||||||
{
|
{
|
||||||
source = lang;
|
sourceLang = lang;
|
||||||
sourceVersion = version;
|
sourceVersion = version;
|
||||||
}
|
}
|
||||||
spv::Id getStringId(const std::string& str)
|
spv::Id getStringId(const std::string& str)
|
||||||
@ -99,14 +103,32 @@ public:
|
|||||||
stringIds[file_c_str] = strId;
|
stringIds[file_c_str] = strId;
|
||||||
return strId;
|
return strId;
|
||||||
}
|
}
|
||||||
|
spv::Id getSourceFile() const
|
||||||
|
{
|
||||||
|
return sourceFileStringId;
|
||||||
|
}
|
||||||
void setSourceFile(const std::string& file)
|
void setSourceFile(const std::string& file)
|
||||||
{
|
{
|
||||||
sourceFileStringId = getStringId(file);
|
sourceFileStringId = getStringId(file);
|
||||||
|
currentFileId = sourceFileStringId;
|
||||||
}
|
}
|
||||||
void setSourceText(const std::string& text) { sourceText = text; }
|
void setSourceText(const std::string& text) { sourceText = text; }
|
||||||
void addSourceExtension(const char* ext) { sourceExtensions.push_back(ext); }
|
void addSourceExtension(const char* ext) { sourceExtensions.push_back(ext); }
|
||||||
void addModuleProcessed(const std::string& p) { moduleProcesses.push_back(p.c_str()); }
|
void addModuleProcessed(const std::string& p) { moduleProcesses.push_back(p.c_str()); }
|
||||||
void setEmitOpLines() { emitOpLines = true; }
|
void setEmitOpLines() { emitOpLines = true; }
|
||||||
|
void setEmitNonSemanticShaderDebugInfo(bool const emit)
|
||||||
|
{
|
||||||
|
emitNonSemanticShaderDebugInfo = emit;
|
||||||
|
|
||||||
|
if(emit)
|
||||||
|
{
|
||||||
|
importNonSemanticShaderDebugInfoInstructions();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void setEmitNonSemanticShaderDebugSource(bool const src)
|
||||||
|
{
|
||||||
|
emitNonSemanticShaderDebugSource = src;
|
||||||
|
}
|
||||||
void addExtension(const char* ext) { extensions.insert(ext); }
|
void addExtension(const char* ext) { extensions.insert(ext); }
|
||||||
void removeExtension(const char* ext)
|
void removeExtension(const char* ext)
|
||||||
{
|
{
|
||||||
@ -159,10 +181,11 @@ public:
|
|||||||
void setLine(int line, const char* filename);
|
void setLine(int line, const char* filename);
|
||||||
// Low-level OpLine. See setLine() for a layered helper.
|
// Low-level OpLine. See setLine() for a layered helper.
|
||||||
void addLine(Id fileName, int line, int column);
|
void addLine(Id fileName, int line, int column);
|
||||||
|
void addDebugScopeAndLine(Id fileName, int line, int column);
|
||||||
|
|
||||||
// For creating new types (will return old type if the requested one was already made).
|
// For creating new types (will return old type if the requested one was already made).
|
||||||
Id makeVoidType();
|
Id makeVoidType();
|
||||||
Id makeBoolType();
|
Id makeBoolType(bool const compilerGenerated = true);
|
||||||
Id makePointer(StorageClass, Id pointee);
|
Id makePointer(StorageClass, Id pointee);
|
||||||
Id makeForwardPointer(StorageClass);
|
Id makeForwardPointer(StorageClass);
|
||||||
Id makePointerFromForwardPointer(StorageClass, Id forwardPointerType, Id pointee);
|
Id makePointerFromForwardPointer(StorageClass, Id forwardPointerType, Id pointee);
|
||||||
@ -170,7 +193,7 @@ public:
|
|||||||
Id makeIntType(int width) { return makeIntegerType(width, true); }
|
Id makeIntType(int width) { return makeIntegerType(width, true); }
|
||||||
Id makeUintType(int width) { return makeIntegerType(width, false); }
|
Id makeUintType(int width) { return makeIntegerType(width, false); }
|
||||||
Id makeFloatType(int width);
|
Id makeFloatType(int width);
|
||||||
Id makeStructType(const std::vector<Id>& members, const char*);
|
Id makeStructType(const std::vector<Id>& members, const char* name, bool const compilerGenerated = true);
|
||||||
Id makeStructResultType(Id type0, Id type1);
|
Id makeStructResultType(Id type0, Id type1);
|
||||||
Id makeVectorType(Id component, int size);
|
Id makeVectorType(Id component, int size);
|
||||||
Id makeMatrixType(Id component, int cols, int rows);
|
Id makeMatrixType(Id component, int cols, int rows);
|
||||||
@ -183,6 +206,36 @@ public:
|
|||||||
Id makeCooperativeMatrixType(Id component, Id scope, Id rows, Id cols);
|
Id makeCooperativeMatrixType(Id component, Id scope, Id rows, Id cols);
|
||||||
Id makeGenericType(spv::Op opcode, std::vector<spv::IdImmediate>& operands);
|
Id makeGenericType(spv::Op opcode, std::vector<spv::IdImmediate>& operands);
|
||||||
|
|
||||||
|
// SPIR-V NonSemantic Shader DebugInfo Instructions
|
||||||
|
struct DebugTypeLoc {
|
||||||
|
std::string name {};
|
||||||
|
int line {0};
|
||||||
|
int column {0};
|
||||||
|
};
|
||||||
|
std::unordered_map<Id, DebugTypeLoc> debugTypeLocs;
|
||||||
|
Id makeDebugInfoNone();
|
||||||
|
Id makeBoolDebugType(int const size);
|
||||||
|
Id makeIntegerDebugType(int const width, bool const hasSign);
|
||||||
|
Id makeFloatDebugType(int const width);
|
||||||
|
Id makeSequentialDebugType(Id const baseType, Id const componentCount, NonSemanticShaderDebugInfo100Instructions const sequenceType);
|
||||||
|
Id makeArrayDebugType(Id const baseType, Id const componentCount);
|
||||||
|
Id makeVectorDebugType(Id const baseType, int const componentCount);
|
||||||
|
Id makeMatrixDebugType(Id const vectorType, int const vectorCount, bool columnMajor = true);
|
||||||
|
Id makeMemberDebugType(Id const memberType, DebugTypeLoc const& debugTypeLoc);
|
||||||
|
Id makeCompositeDebugType(std::vector<Id> const& memberTypes, char const*const name,
|
||||||
|
NonSemanticShaderDebugInfo100DebugCompositeType const tag, bool const isOpaqueType = false);
|
||||||
|
Id makeDebugSource(const Id fileName);
|
||||||
|
Id makeDebugCompilationUnit();
|
||||||
|
Id createDebugGlobalVariable(Id const type, char const*const name, Id const variable);
|
||||||
|
Id createDebugLocalVariable(Id type, char const*const name, size_t const argNumber = 0);
|
||||||
|
Id makeDebugExpression();
|
||||||
|
Id makeDebugDeclare(Id const debugLocalVariable, Id const localVariable);
|
||||||
|
Id makeDebugValue(Id const debugLocalVariable, Id const value);
|
||||||
|
Id makeDebugFunctionType(Id returnType, const std::vector<Id>& paramTypes);
|
||||||
|
Id makeDebugFunction(Function* function, Id nameId, Id funcTypeId);
|
||||||
|
Id makeDebugLexicalBlock(uint32_t line);
|
||||||
|
std::string unmangleFunctionName(std::string const& name) const;
|
||||||
|
|
||||||
// accelerationStructureNV type
|
// accelerationStructureNV type
|
||||||
Id makeAccelerationStructureType();
|
Id makeAccelerationStructureType();
|
||||||
// rayQueryEXT type
|
// rayQueryEXT type
|
||||||
@ -257,6 +310,8 @@ public:
|
|||||||
// See if a resultId is valid for use as an initializer.
|
// See if a resultId is valid for use as an initializer.
|
||||||
bool isValidInitializer(Id resultId) const { return isConstant(resultId) || isGlobalVariable(resultId); }
|
bool isValidInitializer(Id resultId) const { return isConstant(resultId) || isGlobalVariable(resultId); }
|
||||||
|
|
||||||
|
bool isRayTracingOpCode(Op opcode) const;
|
||||||
|
|
||||||
int getScalarTypeWidth(Id typeId) const
|
int getScalarTypeWidth(Id typeId) const
|
||||||
{
|
{
|
||||||
Id scalarTypeId = getScalarTypeId(typeId);
|
Id scalarTypeId = getScalarTypeId(typeId);
|
||||||
@ -318,6 +373,8 @@ public:
|
|||||||
Id makeFloat16Constant(float f16, bool specConstant = false);
|
Id makeFloat16Constant(float f16, bool specConstant = false);
|
||||||
Id makeFpConstant(Id type, double d, bool specConstant = false);
|
Id makeFpConstant(Id type, double d, bool specConstant = false);
|
||||||
|
|
||||||
|
Id importNonSemanticShaderDebugInfoInstructions();
|
||||||
|
|
||||||
// Turn the array of constants into a proper spv constant of the requested type.
|
// Turn the array of constants into a proper spv constant of the requested type.
|
||||||
Id makeCompositeConstant(Id type, const std::vector<Id>& comps, bool specConst = false);
|
Id makeCompositeConstant(Id type, const std::vector<Id>& comps, bool specConst = false);
|
||||||
|
|
||||||
@ -340,7 +397,12 @@ public:
|
|||||||
void addMemberDecoration(Id, unsigned int member, Decoration, const std::vector<const char*>& strings);
|
void addMemberDecoration(Id, unsigned int member, Decoration, const std::vector<const char*>& strings);
|
||||||
|
|
||||||
// At the end of what block do the next create*() instructions go?
|
// At the end of what block do the next create*() instructions go?
|
||||||
void setBuildPoint(Block* bp) { buildPoint = bp; }
|
// Also reset current last DebugScope and current source line to unknown
|
||||||
|
void setBuildPoint(Block* bp) {
|
||||||
|
buildPoint = bp;
|
||||||
|
lastDebugScopeId = NoResult;
|
||||||
|
currentLine = 0;
|
||||||
|
}
|
||||||
Block* getBuildPoint() const { return buildPoint; }
|
Block* getBuildPoint() const { return buildPoint; }
|
||||||
|
|
||||||
// Make the entry-point function. The returned pointer is only valid
|
// Make the entry-point function. The returned pointer is only valid
|
||||||
@ -351,12 +413,22 @@ public:
|
|||||||
// Return the function, pass back the entry.
|
// Return the function, pass back the entry.
|
||||||
// The returned pointer is only valid for the lifetime of this builder.
|
// The returned pointer is only valid for the lifetime of this builder.
|
||||||
Function* makeFunctionEntry(Decoration precision, Id returnType, const char* name,
|
Function* makeFunctionEntry(Decoration precision, Id returnType, const char* name,
|
||||||
const std::vector<Id>& paramTypes, const std::vector<std::vector<Decoration>>& precisions, Block **entry = 0);
|
const std::vector<Id>& paramTypes, const std::vector<char const*>& paramNames,
|
||||||
|
const std::vector<std::vector<Decoration>>& precisions, Block **entry = 0);
|
||||||
|
|
||||||
// Create a return. An 'implicit' return is one not appearing in the source
|
// Create a return. An 'implicit' return is one not appearing in the source
|
||||||
// code. In the case of an implicit return, no post-return block is inserted.
|
// code. In the case of an implicit return, no post-return block is inserted.
|
||||||
void makeReturn(bool implicit, Id retVal = 0);
|
void makeReturn(bool implicit, Id retVal = 0);
|
||||||
|
|
||||||
|
// Initialize state and generate instructions for new lexical scope
|
||||||
|
void enterScope(uint32_t line);
|
||||||
|
|
||||||
|
// Set state and generate instructions to exit current lexical scope
|
||||||
|
void leaveScope();
|
||||||
|
|
||||||
|
// Prepare builder for generation of instructions for a function.
|
||||||
|
void enterFunction(Function const* function);
|
||||||
|
|
||||||
// Generate all the code needed to finish up a function.
|
// Generate all the code needed to finish up a function.
|
||||||
void leaveFunction();
|
void leaveFunction();
|
||||||
|
|
||||||
@ -364,9 +436,13 @@ public:
|
|||||||
// discard, terminate-invocation, terminateRayEXT, or ignoreIntersectionEXT
|
// discard, terminate-invocation, terminateRayEXT, or ignoreIntersectionEXT
|
||||||
void makeStatementTerminator(spv::Op opcode, const char *name);
|
void makeStatementTerminator(spv::Op opcode, const char *name);
|
||||||
|
|
||||||
|
// Create block terminator instruction for statements that have input operands
|
||||||
|
// such as OpEmitMeshTasksEXT
|
||||||
|
void makeStatementTerminator(spv::Op opcode, const std::vector<Id>& operands, const char* name);
|
||||||
|
|
||||||
// Create a global or function local or IO variable.
|
// Create a global or function local or IO variable.
|
||||||
Id createVariable(Decoration precision, StorageClass, Id type, const char* name = nullptr,
|
Id createVariable(Decoration precision, StorageClass storageClass, Id type, const char* name = nullptr,
|
||||||
Id initializer = NoResult);
|
Id initializer = NoResult, bool const compilerGenerated = true);
|
||||||
|
|
||||||
// Create an intermediate with an undefined value.
|
// Create an intermediate with an undefined value.
|
||||||
Id createUndefined(Id type);
|
Id createUndefined(Id type);
|
||||||
@ -801,13 +877,23 @@ public:
|
|||||||
const;
|
const;
|
||||||
|
|
||||||
unsigned int spvVersion; // the version of SPIR-V to emit in the header
|
unsigned int spvVersion; // the version of SPIR-V to emit in the header
|
||||||
SourceLanguage source;
|
SourceLanguage sourceLang;
|
||||||
int sourceVersion;
|
int sourceVersion;
|
||||||
spv::Id sourceFileStringId;
|
spv::Id sourceFileStringId;
|
||||||
|
spv::Id nonSemanticShaderCompilationUnitId {0};
|
||||||
|
spv::Id nonSemanticShaderDebugInfo {0};
|
||||||
|
spv::Id debugInfoNone {0};
|
||||||
|
spv::Id debugExpression {0}; // Debug expression with zero operations.
|
||||||
std::string sourceText;
|
std::string sourceText;
|
||||||
int currentLine;
|
int currentLine;
|
||||||
const char* currentFile;
|
const char* currentFile;
|
||||||
|
spv::Id currentFileId;
|
||||||
|
std::stack<spv::Id> currentDebugScopeId;
|
||||||
|
spv::Id lastDebugScopeId;
|
||||||
bool emitOpLines;
|
bool emitOpLines;
|
||||||
|
bool emitNonSemanticShaderDebugInfo;
|
||||||
|
bool restoreNonSemanticShaderDebugInfo;
|
||||||
|
bool emitNonSemanticShaderDebugSource;
|
||||||
std::set<std::string> extensions;
|
std::set<std::string> extensions;
|
||||||
std::vector<const char*> sourceExtensions;
|
std::vector<const char*> sourceExtensions;
|
||||||
std::vector<const char*> moduleProcesses;
|
std::vector<const char*> moduleProcesses;
|
||||||
@ -841,6 +927,8 @@ public:
|
|||||||
std::unordered_map<unsigned int, std::vector<Instruction*>> groupedStructConstants;
|
std::unordered_map<unsigned int, std::vector<Instruction*>> groupedStructConstants;
|
||||||
// map type opcodes to type instructions
|
// map type opcodes to type instructions
|
||||||
std::unordered_map<unsigned int, std::vector<Instruction*>> groupedTypes;
|
std::unordered_map<unsigned int, std::vector<Instruction*>> groupedTypes;
|
||||||
|
// map type opcodes to debug type instructions
|
||||||
|
std::unordered_map<unsigned int, std::vector<Instruction*>> groupedDebugTypes;
|
||||||
// list of OpConstantNull instructions
|
// list of OpConstantNull instructions
|
||||||
std::vector<Instruction*> nullConstants;
|
std::vector<Instruction*> nullConstants;
|
||||||
|
|
||||||
@ -856,6 +944,12 @@ public:
|
|||||||
// map from include file name ids to their contents
|
// map from include file name ids to their contents
|
||||||
std::map<spv::Id, const std::string*> includeFiles;
|
std::map<spv::Id, const std::string*> includeFiles;
|
||||||
|
|
||||||
|
// map from core id to debug id
|
||||||
|
std::map <spv::Id, spv::Id> debugId;
|
||||||
|
|
||||||
|
// map from file name string id to DebugSource id
|
||||||
|
std::unordered_map<spv::Id, spv::Id> debugSourceId;
|
||||||
|
|
||||||
// The stream for outputting warnings and errors.
|
// The stream for outputting warnings and errors.
|
||||||
SpvBuildLogger* logger;
|
SpvBuildLogger* logger;
|
||||||
}; // end Builder class
|
}; // end Builder class
|
||||||
|
2
thirdparty/glslang/SPIRV/SpvTools.cpp
vendored
2
thirdparty/glslang/SPIRV/SpvTools.cpp
vendored
@ -212,6 +212,8 @@ void SpirvToolsTransform(const glslang::TIntermediate& intermediate, std::vector
|
|||||||
optimizer.RegisterPass(spvtools::CreateInterpolateFixupPass());
|
optimizer.RegisterPass(spvtools::CreateInterpolateFixupPass());
|
||||||
if (options->optimizeSize) {
|
if (options->optimizeSize) {
|
||||||
optimizer.RegisterPass(spvtools::CreateRedundancyEliminationPass());
|
optimizer.RegisterPass(spvtools::CreateRedundancyEliminationPass());
|
||||||
|
if (intermediate.getStage() == EShLanguage::EShLangVertex)
|
||||||
|
optimizer.RegisterPass(spvtools::CreateEliminateDeadInputComponentsPass());
|
||||||
}
|
}
|
||||||
optimizer.RegisterPass(spvtools::CreateAggressiveDCEPass());
|
optimizer.RegisterPass(spvtools::CreateAggressiveDCEPass());
|
||||||
optimizer.RegisterPass(spvtools::CreateCFGCleanupPass());
|
optimizer.RegisterPass(spvtools::CreateCFGCleanupPass());
|
||||||
|
16
thirdparty/glslang/SPIRV/SpvTools.h
vendored
16
thirdparty/glslang/SPIRV/SpvTools.h
vendored
@ -53,14 +53,14 @@
|
|||||||
namespace glslang {
|
namespace glslang {
|
||||||
|
|
||||||
struct SpvOptions {
|
struct SpvOptions {
|
||||||
SpvOptions() : generateDebugInfo(false), stripDebugInfo(false), disableOptimizer(true),
|
bool generateDebugInfo {false};
|
||||||
optimizeSize(false), disassemble(false), validate(false) { }
|
bool stripDebugInfo {false};
|
||||||
bool generateDebugInfo;
|
bool disableOptimizer {true};
|
||||||
bool stripDebugInfo;
|
bool optimizeSize {false};
|
||||||
bool disableOptimizer;
|
bool disassemble {false};
|
||||||
bool optimizeSize;
|
bool validate {false};
|
||||||
bool disassemble;
|
bool emitNonSemanticShaderDebugInfo {false};
|
||||||
bool validate;
|
bool emitNonSemanticShaderDebugSource{ false };
|
||||||
};
|
};
|
||||||
|
|
||||||
#if ENABLE_OPT
|
#if ENABLE_OPT
|
||||||
|
75
thirdparty/glslang/SPIRV/doc.cpp
vendored
75
thirdparty/glslang/SPIRV/doc.cpp
vendored
@ -97,6 +97,8 @@ const char* ExecutionModelString(int model)
|
|||||||
case 6: return "Kernel";
|
case 6: return "Kernel";
|
||||||
case ExecutionModelTaskNV: return "TaskNV";
|
case ExecutionModelTaskNV: return "TaskNV";
|
||||||
case ExecutionModelMeshNV: return "MeshNV";
|
case ExecutionModelMeshNV: return "MeshNV";
|
||||||
|
case ExecutionModelTaskEXT: return "TaskEXT";
|
||||||
|
case ExecutionModelMeshEXT: return "MeshEXT";
|
||||||
|
|
||||||
default: return "Bad";
|
default: return "Bad";
|
||||||
|
|
||||||
@ -173,28 +175,32 @@ const char* ExecutionModeString(int mode)
|
|||||||
case 31: return "ContractionOff";
|
case 31: return "ContractionOff";
|
||||||
case 32: return "Bad";
|
case 32: return "Bad";
|
||||||
|
|
||||||
case ExecutionModeInitializer: return "Initializer";
|
case ExecutionModeInitializer: return "Initializer";
|
||||||
case ExecutionModeFinalizer: return "Finalizer";
|
case ExecutionModeFinalizer: return "Finalizer";
|
||||||
case ExecutionModeSubgroupSize: return "SubgroupSize";
|
case ExecutionModeSubgroupSize: return "SubgroupSize";
|
||||||
case ExecutionModeSubgroupsPerWorkgroup: return "SubgroupsPerWorkgroup";
|
case ExecutionModeSubgroupsPerWorkgroup: return "SubgroupsPerWorkgroup";
|
||||||
case ExecutionModeSubgroupsPerWorkgroupId: return "SubgroupsPerWorkgroupId";
|
case ExecutionModeSubgroupsPerWorkgroupId: return "SubgroupsPerWorkgroupId";
|
||||||
case ExecutionModeLocalSizeId: return "LocalSizeId";
|
case ExecutionModeLocalSizeId: return "LocalSizeId";
|
||||||
case ExecutionModeLocalSizeHintId: return "LocalSizeHintId";
|
case ExecutionModeLocalSizeHintId: return "LocalSizeHintId";
|
||||||
|
|
||||||
case ExecutionModePostDepthCoverage: return "PostDepthCoverage";
|
case ExecutionModePostDepthCoverage: return "PostDepthCoverage";
|
||||||
case ExecutionModeDenormPreserve: return "DenormPreserve";
|
case ExecutionModeDenormPreserve: return "DenormPreserve";
|
||||||
case ExecutionModeDenormFlushToZero: return "DenormFlushToZero";
|
case ExecutionModeDenormFlushToZero: return "DenormFlushToZero";
|
||||||
case ExecutionModeSignedZeroInfNanPreserve: return "SignedZeroInfNanPreserve";
|
case ExecutionModeSignedZeroInfNanPreserve: return "SignedZeroInfNanPreserve";
|
||||||
case ExecutionModeRoundingModeRTE: return "RoundingModeRTE";
|
case ExecutionModeRoundingModeRTE: return "RoundingModeRTE";
|
||||||
case ExecutionModeRoundingModeRTZ: return "RoundingModeRTZ";
|
case ExecutionModeRoundingModeRTZ: return "RoundingModeRTZ";
|
||||||
case ExecutionModeStencilRefReplacingEXT: return "StencilRefReplacingEXT";
|
case ExecutionModeEarlyAndLateFragmentTestsAMD: return "EarlyAndLateFragmentTestsAMD";
|
||||||
|
case ExecutionModeStencilRefUnchangedFrontAMD: return "StencilRefUnchangedFrontAMD";
|
||||||
|
case ExecutionModeStencilRefLessFrontAMD: return "StencilRefLessFrontAMD";
|
||||||
|
case ExecutionModeStencilRefGreaterBackAMD: return "StencilRefGreaterBackAMD";
|
||||||
|
case ExecutionModeStencilRefReplacingEXT: return "StencilRefReplacingEXT";
|
||||||
case ExecutionModeSubgroupUniformControlFlowKHR: return "SubgroupUniformControlFlow";
|
case ExecutionModeSubgroupUniformControlFlowKHR: return "SubgroupUniformControlFlow";
|
||||||
|
|
||||||
case ExecutionModeOutputLinesNV: return "OutputLinesNV";
|
case ExecutionModeOutputLinesNV: return "OutputLinesNV";
|
||||||
case ExecutionModeOutputPrimitivesNV: return "OutputPrimitivesNV";
|
case ExecutionModeOutputPrimitivesNV: return "OutputPrimitivesNV";
|
||||||
case ExecutionModeOutputTrianglesNV: return "OutputTrianglesNV";
|
case ExecutionModeOutputTrianglesNV: return "OutputTrianglesNV";
|
||||||
case ExecutionModeDerivativeGroupQuadsNV: return "DerivativeGroupQuadsNV";
|
case ExecutionModeDerivativeGroupQuadsNV: return "DerivativeGroupQuadsNV";
|
||||||
case ExecutionModeDerivativeGroupLinearNV: return "DerivativeGroupLinearNV";
|
case ExecutionModeDerivativeGroupLinearNV: return "DerivativeGroupLinearNV";
|
||||||
|
|
||||||
case ExecutionModePixelInterlockOrderedEXT: return "PixelInterlockOrderedEXT";
|
case ExecutionModePixelInterlockOrderedEXT: return "PixelInterlockOrderedEXT";
|
||||||
case ExecutionModePixelInterlockUnorderedEXT: return "PixelInterlockUnorderedEXT";
|
case ExecutionModePixelInterlockUnorderedEXT: return "PixelInterlockUnorderedEXT";
|
||||||
@ -238,7 +244,7 @@ const char* StorageClassString(int StorageClass)
|
|||||||
case StorageClassIncomingCallableDataKHR: return "IncomingCallableDataKHR";
|
case StorageClassIncomingCallableDataKHR: return "IncomingCallableDataKHR";
|
||||||
|
|
||||||
case StorageClassPhysicalStorageBufferEXT: return "PhysicalStorageBufferEXT";
|
case StorageClassPhysicalStorageBufferEXT: return "PhysicalStorageBufferEXT";
|
||||||
|
case StorageClassTaskPayloadWorkgroupEXT: return "TaskPayloadWorkgroupEXT";
|
||||||
default: return "Bad";
|
default: return "Bad";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -305,7 +311,8 @@ const char* DecorationString(int decoration)
|
|||||||
case DecorationPerPrimitiveNV: return "PerPrimitiveNV";
|
case DecorationPerPrimitiveNV: return "PerPrimitiveNV";
|
||||||
case DecorationPerViewNV: return "PerViewNV";
|
case DecorationPerViewNV: return "PerViewNV";
|
||||||
case DecorationPerTaskNV: return "PerTaskNV";
|
case DecorationPerTaskNV: return "PerTaskNV";
|
||||||
case DecorationPerVertexNV: return "PerVertexNV";
|
|
||||||
|
case DecorationPerVertexKHR: return "PerVertexKHR";
|
||||||
|
|
||||||
case DecorationNonUniformEXT: return "DecorationNonUniformEXT";
|
case DecorationNonUniformEXT: return "DecorationNonUniformEXT";
|
||||||
case DecorationHlslCounterBufferGOOGLE: return "DecorationHlslCounterBufferGOOGLE";
|
case DecorationHlslCounterBufferGOOGLE: return "DecorationHlslCounterBufferGOOGLE";
|
||||||
@ -392,6 +399,7 @@ const char* BuiltInString(int builtIn)
|
|||||||
case BuiltInObjectRayDirectionKHR: return "ObjectRayDirectionKHR";
|
case BuiltInObjectRayDirectionKHR: return "ObjectRayDirectionKHR";
|
||||||
case BuiltInRayTminKHR: return "RayTminKHR";
|
case BuiltInRayTminKHR: return "RayTminKHR";
|
||||||
case BuiltInRayTmaxKHR: return "RayTmaxKHR";
|
case BuiltInRayTmaxKHR: return "RayTmaxKHR";
|
||||||
|
case BuiltInCullMaskKHR: return "CullMaskKHR";
|
||||||
case BuiltInInstanceCustomIndexKHR: return "InstanceCustomIndexKHR";
|
case BuiltInInstanceCustomIndexKHR: return "InstanceCustomIndexKHR";
|
||||||
case BuiltInRayGeometryIndexKHR: return "RayGeometryIndexKHR";
|
case BuiltInRayGeometryIndexKHR: return "RayGeometryIndexKHR";
|
||||||
case BuiltInObjectToWorldKHR: return "ObjectToWorldKHR";
|
case BuiltInObjectToWorldKHR: return "ObjectToWorldKHR";
|
||||||
@ -406,8 +414,8 @@ const char* BuiltInString(int builtIn)
|
|||||||
case BuiltInViewportMaskPerViewNV: return "ViewportMaskPerViewNV";
|
case BuiltInViewportMaskPerViewNV: return "ViewportMaskPerViewNV";
|
||||||
// case BuiltInFragmentSizeNV: return "FragmentSizeNV"; // superseded by BuiltInFragSizeEXT
|
// case BuiltInFragmentSizeNV: return "FragmentSizeNV"; // superseded by BuiltInFragSizeEXT
|
||||||
// case BuiltInInvocationsPerPixelNV: return "InvocationsPerPixelNV"; // superseded by BuiltInFragInvocationCountEXT
|
// case BuiltInInvocationsPerPixelNV: return "InvocationsPerPixelNV"; // superseded by BuiltInFragInvocationCountEXT
|
||||||
case BuiltInBaryCoordNV: return "BaryCoordNV";
|
case BuiltInBaryCoordKHR: return "BaryCoordKHR";
|
||||||
case BuiltInBaryCoordNoPerspNV: return "BaryCoordNoPerspNV";
|
case BuiltInBaryCoordNoPerspKHR: return "BaryCoordNoPerspKHR";
|
||||||
|
|
||||||
case BuiltInFragSizeEXT: return "FragSizeEXT";
|
case BuiltInFragSizeEXT: return "FragSizeEXT";
|
||||||
case BuiltInFragInvocationCountEXT: return "FragInvocationCountEXT";
|
case BuiltInFragInvocationCountEXT: return "FragInvocationCountEXT";
|
||||||
@ -427,6 +435,10 @@ const char* BuiltInString(int builtIn)
|
|||||||
case BuiltInWarpIDNV: return "WarpIDNV";
|
case BuiltInWarpIDNV: return "WarpIDNV";
|
||||||
case BuiltInSMIDNV: return "SMIDNV";
|
case BuiltInSMIDNV: return "SMIDNV";
|
||||||
case BuiltInCurrentRayTimeNV: return "CurrentRayTimeNV";
|
case BuiltInCurrentRayTimeNV: return "CurrentRayTimeNV";
|
||||||
|
case BuiltInPrimitivePointIndicesEXT: return "PrimitivePointIndicesEXT";
|
||||||
|
case BuiltInPrimitiveLineIndicesEXT: return "PrimitiveLineIndicesEXT";
|
||||||
|
case BuiltInPrimitiveTriangleIndicesEXT: return "PrimitiveTriangleIndicesEXT";
|
||||||
|
case BuiltInCullPrimitiveEXT: return "CullPrimitiveEXT";
|
||||||
|
|
||||||
default: return "Bad";
|
default: return "Bad";
|
||||||
}
|
}
|
||||||
@ -925,14 +937,16 @@ const char* CapabilityString(int info)
|
|||||||
case CapabilityRayTracingNV: return "RayTracingNV";
|
case CapabilityRayTracingNV: return "RayTracingNV";
|
||||||
case CapabilityRayTracingMotionBlurNV: return "RayTracingMotionBlurNV";
|
case CapabilityRayTracingMotionBlurNV: return "RayTracingMotionBlurNV";
|
||||||
case CapabilityRayTracingKHR: return "RayTracingKHR";
|
case CapabilityRayTracingKHR: return "RayTracingKHR";
|
||||||
|
case CapabilityRayCullMaskKHR: return "RayCullMaskKHR";
|
||||||
case CapabilityRayQueryKHR: return "RayQueryKHR";
|
case CapabilityRayQueryKHR: return "RayQueryKHR";
|
||||||
case CapabilityRayTracingProvisionalKHR: return "RayTracingProvisionalKHR";
|
case CapabilityRayTracingProvisionalKHR: return "RayTracingProvisionalKHR";
|
||||||
case CapabilityRayTraversalPrimitiveCullingKHR: return "RayTraversalPrimitiveCullingKHR";
|
case CapabilityRayTraversalPrimitiveCullingKHR: return "RayTraversalPrimitiveCullingKHR";
|
||||||
case CapabilityComputeDerivativeGroupQuadsNV: return "ComputeDerivativeGroupQuadsNV";
|
case CapabilityComputeDerivativeGroupQuadsNV: return "ComputeDerivativeGroupQuadsNV";
|
||||||
case CapabilityComputeDerivativeGroupLinearNV: return "ComputeDerivativeGroupLinearNV";
|
case CapabilityComputeDerivativeGroupLinearNV: return "ComputeDerivativeGroupLinearNV";
|
||||||
case CapabilityFragmentBarycentricNV: return "FragmentBarycentricNV";
|
case CapabilityFragmentBarycentricKHR: return "FragmentBarycentricKHR";
|
||||||
case CapabilityMeshShadingNV: return "MeshShadingNV";
|
case CapabilityMeshShadingNV: return "MeshShadingNV";
|
||||||
case CapabilityImageFootprintNV: return "ImageFootprintNV";
|
case CapabilityImageFootprintNV: return "ImageFootprintNV";
|
||||||
|
case CapabilityMeshShadingEXT: return "MeshShadingEXT";
|
||||||
// case CapabilityShadingRateNV: return "ShadingRateNV"; // superseded by FragmentDensityEXT
|
// case CapabilityShadingRateNV: return "ShadingRateNV"; // superseded by FragmentDensityEXT
|
||||||
case CapabilitySampleMaskOverrideCoverageNV: return "SampleMaskOverrideCoverageNV";
|
case CapabilitySampleMaskOverrideCoverageNV: return "SampleMaskOverrideCoverageNV";
|
||||||
case CapabilityFragmentDensityEXT: return "FragmentDensityEXT";
|
case CapabilityFragmentDensityEXT: return "FragmentDensityEXT";
|
||||||
@ -1400,6 +1414,8 @@ const char* OpcodeString(int op)
|
|||||||
case OpGroupNonUniformPartitionNV: return "OpGroupNonUniformPartitionNV";
|
case OpGroupNonUniformPartitionNV: return "OpGroupNonUniformPartitionNV";
|
||||||
case OpImageSampleFootprintNV: return "OpImageSampleFootprintNV";
|
case OpImageSampleFootprintNV: return "OpImageSampleFootprintNV";
|
||||||
case OpWritePackedPrimitiveIndices4x8NV: return "OpWritePackedPrimitiveIndices4x8NV";
|
case OpWritePackedPrimitiveIndices4x8NV: return "OpWritePackedPrimitiveIndices4x8NV";
|
||||||
|
case OpEmitMeshTasksEXT: return "OpEmitMeshTasksEXT";
|
||||||
|
case OpSetMeshOutputsEXT: return "OpSetMeshOutputsEXT";
|
||||||
|
|
||||||
case OpTypeRayQueryKHR: return "OpTypeRayQueryKHR";
|
case OpTypeRayQueryKHR: return "OpTypeRayQueryKHR";
|
||||||
case OpRayQueryInitializeKHR: return "OpRayQueryInitializeKHR";
|
case OpRayQueryInitializeKHR: return "OpRayQueryInitializeKHR";
|
||||||
@ -2974,6 +2990,17 @@ void Parameterize()
|
|||||||
InstructionDesc[OpWritePackedPrimitiveIndices4x8NV].operands.push(OperandId, "'Index Offset'");
|
InstructionDesc[OpWritePackedPrimitiveIndices4x8NV].operands.push(OperandId, "'Index Offset'");
|
||||||
InstructionDesc[OpWritePackedPrimitiveIndices4x8NV].operands.push(OperandId, "'Packed Indices'");
|
InstructionDesc[OpWritePackedPrimitiveIndices4x8NV].operands.push(OperandId, "'Packed Indices'");
|
||||||
|
|
||||||
|
InstructionDesc[OpEmitMeshTasksEXT].operands.push(OperandId, "'groupCountX'");
|
||||||
|
InstructionDesc[OpEmitMeshTasksEXT].operands.push(OperandId, "'groupCountY'");
|
||||||
|
InstructionDesc[OpEmitMeshTasksEXT].operands.push(OperandId, "'groupCountZ'");
|
||||||
|
InstructionDesc[OpEmitMeshTasksEXT].operands.push(OperandId, "'Payload'");
|
||||||
|
InstructionDesc[OpEmitMeshTasksEXT].setResultAndType(false, false);
|
||||||
|
|
||||||
|
InstructionDesc[OpSetMeshOutputsEXT].operands.push(OperandId, "'vertexCount'");
|
||||||
|
InstructionDesc[OpSetMeshOutputsEXT].operands.push(OperandId, "'primitiveCount'");
|
||||||
|
InstructionDesc[OpSetMeshOutputsEXT].setResultAndType(false, false);
|
||||||
|
|
||||||
|
|
||||||
InstructionDesc[OpTypeCooperativeMatrixNV].operands.push(OperandId, "'Component Type'");
|
InstructionDesc[OpTypeCooperativeMatrixNV].operands.push(OperandId, "'Component Type'");
|
||||||
InstructionDesc[OpTypeCooperativeMatrixNV].operands.push(OperandId, "'Scope'");
|
InstructionDesc[OpTypeCooperativeMatrixNV].operands.push(OperandId, "'Scope'");
|
||||||
InstructionDesc[OpTypeCooperativeMatrixNV].operands.push(OperandId, "'Rows'");
|
InstructionDesc[OpTypeCooperativeMatrixNV].operands.push(OperandId, "'Rows'");
|
||||||
|
42
thirdparty/glslang/SPIRV/spirv.hpp
vendored
42
thirdparty/glslang/SPIRV/spirv.hpp
vendored
@ -1,19 +1,19 @@
|
|||||||
// Copyright (c) 2014-2020 The Khronos Group Inc.
|
// Copyright (c) 2014-2020 The Khronos Group Inc.
|
||||||
//
|
//
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
// of this software and/or associated documentation files (the "Materials"),
|
// of this software and/or associated documentation files (the "Materials"),
|
||||||
// to deal in the Materials without restriction, including without limitation
|
// to deal in the Materials without restriction, including without limitation
|
||||||
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
// and/or sell copies of the Materials, and to permit persons to whom the
|
// and/or sell copies of the Materials, and to permit persons to whom the
|
||||||
// Materials are furnished to do so, subject to the following conditions:
|
// Materials are furnished to do so, subject to the following conditions:
|
||||||
//
|
//
|
||||||
// The above copyright notice and this permission notice shall be included in
|
// The above copyright notice and this permission notice shall be included in
|
||||||
// all copies or substantial portions of the Materials.
|
// all copies or substantial portions of the Materials.
|
||||||
//
|
//
|
||||||
// MODIFICATIONS TO THIS FILE MAY MEAN IT NO LONGER ACCURATELY REFLECTS KHRONOS
|
// MODIFICATIONS TO THIS FILE MAY MEAN IT NO LONGER ACCURATELY REFLECTS KHRONOS
|
||||||
// STANDARDS. THE UNMODIFIED, NORMATIVE VERSIONS OF KHRONOS SPECIFICATIONS AND
|
// STANDARDS. THE UNMODIFIED, NORMATIVE VERSIONS OF KHRONOS SPECIFICATIONS AND
|
||||||
// HEADER INFORMATION ARE LOCATED AT https://www.khronos.org/registry/
|
// HEADER INFORMATION ARE LOCATED AT https://www.khronos.org/registry/
|
||||||
//
|
//
|
||||||
// THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
// THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||||||
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
@ -27,7 +27,7 @@
|
|||||||
|
|
||||||
// Enumeration tokens for SPIR-V, in various styles:
|
// Enumeration tokens for SPIR-V, in various styles:
|
||||||
// C, C++, C++11, JSON, Lua, Python, C#, D
|
// C, C++, C++11, JSON, Lua, Python, C#, D
|
||||||
//
|
//
|
||||||
// - C will have tokens with a "Spv" prefix, e.g.: SpvSourceLanguageGLSL
|
// - C will have tokens with a "Spv" prefix, e.g.: SpvSourceLanguageGLSL
|
||||||
// - C++ will have tokens in the "spv" name space, e.g.: spv::SourceLanguageGLSL
|
// - C++ will have tokens in the "spv" name space, e.g.: spv::SourceLanguageGLSL
|
||||||
// - C++11 will use enum classes in the spv namespace, e.g.: spv::SourceLanguage::GLSL
|
// - C++11 will use enum classes in the spv namespace, e.g.: spv::SourceLanguage::GLSL
|
||||||
@ -36,7 +36,7 @@
|
|||||||
// - C# will use enum classes in the Specification class located in the "Spv" namespace,
|
// - C# will use enum classes in the Specification class located in the "Spv" namespace,
|
||||||
// e.g.: Spv.Specification.SourceLanguage.GLSL
|
// e.g.: Spv.Specification.SourceLanguage.GLSL
|
||||||
// - D will have tokens under the "spv" module, e.g: spv.SourceLanguage.GLSL
|
// - D will have tokens under the "spv" module, e.g: spv.SourceLanguage.GLSL
|
||||||
//
|
//
|
||||||
// Some tokens act like mask values, which can be OR'd together,
|
// Some tokens act like mask values, which can be OR'd together,
|
||||||
// while others are mutually exclusive. The mask-like ones have
|
// while others are mutually exclusive. The mask-like ones have
|
||||||
// "Mask" in their name, and a parallel enum that has the shift
|
// "Mask" in their name, and a parallel enum that has the shift
|
||||||
@ -91,6 +91,8 @@ enum ExecutionModel {
|
|||||||
ExecutionModelMissNV = 5317,
|
ExecutionModelMissNV = 5317,
|
||||||
ExecutionModelCallableKHR = 5318,
|
ExecutionModelCallableKHR = 5318,
|
||||||
ExecutionModelCallableNV = 5318,
|
ExecutionModelCallableNV = 5318,
|
||||||
|
ExecutionModelTaskEXT = 5364,
|
||||||
|
ExecutionModelMeshEXT = 5365,
|
||||||
ExecutionModelMax = 0x7fffffff,
|
ExecutionModelMax = 0x7fffffff,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -158,11 +160,21 @@ enum ExecutionMode {
|
|||||||
ExecutionModeSignedZeroInfNanPreserve = 4461,
|
ExecutionModeSignedZeroInfNanPreserve = 4461,
|
||||||
ExecutionModeRoundingModeRTE = 4462,
|
ExecutionModeRoundingModeRTE = 4462,
|
||||||
ExecutionModeRoundingModeRTZ = 4463,
|
ExecutionModeRoundingModeRTZ = 4463,
|
||||||
|
ExecutionModeEarlyAndLateFragmentTestsAMD = 5017,
|
||||||
ExecutionModeStencilRefReplacingEXT = 5027,
|
ExecutionModeStencilRefReplacingEXT = 5027,
|
||||||
|
ExecutionModeStencilRefUnchangedFrontAMD = 5079,
|
||||||
|
ExecutionModeStencilRefGreaterFrontAMD = 5080,
|
||||||
|
ExecutionModeStencilRefLessFrontAMD = 5081,
|
||||||
|
ExecutionModeStencilRefUnchangedBackAMD = 5082,
|
||||||
|
ExecutionModeStencilRefGreaterBackAMD = 5083,
|
||||||
|
ExecutionModeStencilRefLessBackAMD = 5084,
|
||||||
|
ExecutionModeOutputLinesEXT = 5269,
|
||||||
ExecutionModeOutputLinesNV = 5269,
|
ExecutionModeOutputLinesNV = 5269,
|
||||||
|
ExecutionModeOutputPrimitivesEXT = 5270,
|
||||||
ExecutionModeOutputPrimitivesNV = 5270,
|
ExecutionModeOutputPrimitivesNV = 5270,
|
||||||
ExecutionModeDerivativeGroupQuadsNV = 5289,
|
ExecutionModeDerivativeGroupQuadsNV = 5289,
|
||||||
ExecutionModeDerivativeGroupLinearNV = 5290,
|
ExecutionModeDerivativeGroupLinearNV = 5290,
|
||||||
|
ExecutionModeOutputTrianglesEXT = 5298,
|
||||||
ExecutionModeOutputTrianglesNV = 5298,
|
ExecutionModeOutputTrianglesNV = 5298,
|
||||||
ExecutionModePixelInterlockOrderedEXT = 5366,
|
ExecutionModePixelInterlockOrderedEXT = 5366,
|
||||||
ExecutionModePixelInterlockUnorderedEXT = 5367,
|
ExecutionModePixelInterlockUnorderedEXT = 5367,
|
||||||
@ -211,6 +223,7 @@ enum StorageClass {
|
|||||||
StorageClassShaderRecordBufferNV = 5343,
|
StorageClassShaderRecordBufferNV = 5343,
|
||||||
StorageClassPhysicalStorageBuffer = 5349,
|
StorageClassPhysicalStorageBuffer = 5349,
|
||||||
StorageClassPhysicalStorageBufferEXT = 5349,
|
StorageClassPhysicalStorageBufferEXT = 5349,
|
||||||
|
StorageClassTaskPayloadWorkgroupEXT = 5402,
|
||||||
StorageClassCodeSectionINTEL = 5605,
|
StorageClassCodeSectionINTEL = 5605,
|
||||||
StorageClassDeviceOnlyINTEL = 5936,
|
StorageClassDeviceOnlyINTEL = 5936,
|
||||||
StorageClassHostOnlyINTEL = 5937,
|
StorageClassHostOnlyINTEL = 5937,
|
||||||
@ -493,6 +506,7 @@ enum Decoration {
|
|||||||
DecorationPassthroughNV = 5250,
|
DecorationPassthroughNV = 5250,
|
||||||
DecorationViewportRelativeNV = 5252,
|
DecorationViewportRelativeNV = 5252,
|
||||||
DecorationSecondaryViewportRelativeNV = 5256,
|
DecorationSecondaryViewportRelativeNV = 5256,
|
||||||
|
DecorationPerPrimitiveEXT = 5271,
|
||||||
DecorationPerPrimitiveNV = 5271,
|
DecorationPerPrimitiveNV = 5271,
|
||||||
DecorationPerViewNV = 5272,
|
DecorationPerViewNV = 5272,
|
||||||
DecorationPerTaskNV = 5273,
|
DecorationPerTaskNV = 5273,
|
||||||
@ -640,6 +654,10 @@ enum BuiltIn {
|
|||||||
BuiltInFragmentSizeNV = 5292,
|
BuiltInFragmentSizeNV = 5292,
|
||||||
BuiltInFragInvocationCountEXT = 5293,
|
BuiltInFragInvocationCountEXT = 5293,
|
||||||
BuiltInInvocationsPerPixelNV = 5293,
|
BuiltInInvocationsPerPixelNV = 5293,
|
||||||
|
BuiltInPrimitivePointIndicesEXT = 5294,
|
||||||
|
BuiltInPrimitiveLineIndicesEXT = 5295,
|
||||||
|
BuiltInPrimitiveTriangleIndicesEXT = 5296,
|
||||||
|
BuiltInCullPrimitiveEXT = 5299,
|
||||||
BuiltInLaunchIdKHR = 5319,
|
BuiltInLaunchIdKHR = 5319,
|
||||||
BuiltInLaunchIdNV = 5319,
|
BuiltInLaunchIdNV = 5319,
|
||||||
BuiltInLaunchSizeKHR = 5320,
|
BuiltInLaunchSizeKHR = 5320,
|
||||||
@ -673,6 +691,7 @@ enum BuiltIn {
|
|||||||
BuiltInSMCountNV = 5375,
|
BuiltInSMCountNV = 5375,
|
||||||
BuiltInWarpIDNV = 5376,
|
BuiltInWarpIDNV = 5376,
|
||||||
BuiltInSMIDNV = 5377,
|
BuiltInSMIDNV = 5377,
|
||||||
|
BuiltInCullMaskKHR = 6021,
|
||||||
BuiltInMax = 0x7fffffff,
|
BuiltInMax = 0x7fffffff,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -975,7 +994,8 @@ enum Capability {
|
|||||||
CapabilityFragmentFullyCoveredEXT = 5265,
|
CapabilityFragmentFullyCoveredEXT = 5265,
|
||||||
CapabilityMeshShadingNV = 5266,
|
CapabilityMeshShadingNV = 5266,
|
||||||
CapabilityImageFootprintNV = 5282,
|
CapabilityImageFootprintNV = 5282,
|
||||||
CapabilityFragmentBarycentricKHR = 5284,
|
CapabilityMeshShadingEXT = 5283,
|
||||||
|
CapabilityFragmentBarycentricKHR = 5284,
|
||||||
CapabilityFragmentBarycentricNV = 5284,
|
CapabilityFragmentBarycentricNV = 5284,
|
||||||
CapabilityComputeDerivativeGroupQuadsNV = 5288,
|
CapabilityComputeDerivativeGroupQuadsNV = 5288,
|
||||||
CapabilityFragmentDensityEXT = 5291,
|
CapabilityFragmentDensityEXT = 5291,
|
||||||
@ -1069,6 +1089,7 @@ enum Capability {
|
|||||||
CapabilityDotProductInput4x8BitPackedKHR = 6018,
|
CapabilityDotProductInput4x8BitPackedKHR = 6018,
|
||||||
CapabilityDotProduct = 6019,
|
CapabilityDotProduct = 6019,
|
||||||
CapabilityDotProductKHR = 6019,
|
CapabilityDotProductKHR = 6019,
|
||||||
|
CapabilityRayCullMaskKHR = 6020,
|
||||||
CapabilityBitInstructions = 6025,
|
CapabilityBitInstructions = 6025,
|
||||||
CapabilityAtomicFloat32AddEXT = 6033,
|
CapabilityAtomicFloat32AddEXT = 6033,
|
||||||
CapabilityAtomicFloat64AddEXT = 6034,
|
CapabilityAtomicFloat64AddEXT = 6034,
|
||||||
@ -1568,6 +1589,8 @@ enum Op {
|
|||||||
OpFragmentFetchAMD = 5012,
|
OpFragmentFetchAMD = 5012,
|
||||||
OpReadClockKHR = 5056,
|
OpReadClockKHR = 5056,
|
||||||
OpImageSampleFootprintNV = 5283,
|
OpImageSampleFootprintNV = 5283,
|
||||||
|
OpEmitMeshTasksEXT = 5294,
|
||||||
|
OpSetMeshOutputsEXT = 5295,
|
||||||
OpGroupNonUniformPartitionNV = 5296,
|
OpGroupNonUniformPartitionNV = 5296,
|
||||||
OpWritePackedPrimitiveIndices4x8NV = 5299,
|
OpWritePackedPrimitiveIndices4x8NV = 5299,
|
||||||
OpReportIntersectionKHR = 5334,
|
OpReportIntersectionKHR = 5334,
|
||||||
@ -2225,6 +2248,8 @@ inline void HasResultAndType(Op opcode, bool *hasResult, bool *hasResultType) {
|
|||||||
case OpReadClockKHR: *hasResult = true; *hasResultType = true; break;
|
case OpReadClockKHR: *hasResult = true; *hasResultType = true; break;
|
||||||
case OpImageSampleFootprintNV: *hasResult = true; *hasResultType = true; break;
|
case OpImageSampleFootprintNV: *hasResult = true; *hasResultType = true; break;
|
||||||
case OpGroupNonUniformPartitionNV: *hasResult = true; *hasResultType = true; break;
|
case OpGroupNonUniformPartitionNV: *hasResult = true; *hasResultType = true; break;
|
||||||
|
case OpEmitMeshTasksEXT: *hasResult = false; *hasResultType = false; break;
|
||||||
|
case OpSetMeshOutputsEXT: *hasResult = false; *hasResultType = false; break;
|
||||||
case OpWritePackedPrimitiveIndices4x8NV: *hasResult = false; *hasResultType = false; break;
|
case OpWritePackedPrimitiveIndices4x8NV: *hasResult = false; *hasResultType = false; break;
|
||||||
case OpReportIntersectionNV: *hasResult = true; *hasResultType = true; break;
|
case OpReportIntersectionNV: *hasResult = true; *hasResultType = true; break;
|
||||||
case OpIgnoreIntersectionNV: *hasResult = false; *hasResultType = false; break;
|
case OpIgnoreIntersectionNV: *hasResult = false; *hasResultType = false; break;
|
||||||
@ -2506,4 +2531,3 @@ inline FragmentShadingRateMask operator|(FragmentShadingRateMask a, FragmentShad
|
|||||||
} // end namespace spv
|
} // end namespace spv
|
||||||
|
|
||||||
#endif // #ifndef spirv_HPP
|
#endif // #ifndef spirv_HPP
|
||||||
|
|
||||||
|
18
thirdparty/glslang/SPIRV/spvIR.h
vendored
18
thirdparty/glslang/SPIRV/spvIR.h
vendored
@ -349,6 +349,7 @@ public:
|
|||||||
const std::vector<Block*>& getBlocks() const { return blocks; }
|
const std::vector<Block*>& getBlocks() const { return blocks; }
|
||||||
void addLocalVariable(std::unique_ptr<Instruction> inst);
|
void addLocalVariable(std::unique_ptr<Instruction> inst);
|
||||||
Id getReturnType() const { return functionInstruction.getTypeId(); }
|
Id getReturnType() const { return functionInstruction.getTypeId(); }
|
||||||
|
Id getFuncId() const { return functionInstruction.getResultId(); }
|
||||||
void setReturnPrecision(Decoration precision)
|
void setReturnPrecision(Decoration precision)
|
||||||
{
|
{
|
||||||
if (precision == DecorationRelaxedPrecision)
|
if (precision == DecorationRelaxedPrecision)
|
||||||
@ -357,6 +358,14 @@ public:
|
|||||||
Decoration getReturnPrecision() const
|
Decoration getReturnPrecision() const
|
||||||
{ return reducedPrecisionReturn ? DecorationRelaxedPrecision : NoPrecision; }
|
{ return reducedPrecisionReturn ? DecorationRelaxedPrecision : NoPrecision; }
|
||||||
|
|
||||||
|
void setDebugLineInfo(Id fileName, int line, int column) {
|
||||||
|
lineInstruction = std::unique_ptr<Instruction>{new Instruction(OpLine)};
|
||||||
|
lineInstruction->addIdOperand(fileName);
|
||||||
|
lineInstruction->addImmediateOperand(line);
|
||||||
|
lineInstruction->addImmediateOperand(column);
|
||||||
|
}
|
||||||
|
bool hasDebugLineInfo() const { return lineInstruction != nullptr; }
|
||||||
|
|
||||||
void setImplicitThis() { implicitThis = true; }
|
void setImplicitThis() { implicitThis = true; }
|
||||||
bool hasImplicitThis() const { return implicitThis; }
|
bool hasImplicitThis() const { return implicitThis; }
|
||||||
|
|
||||||
@ -373,6 +382,11 @@ public:
|
|||||||
|
|
||||||
void dump(std::vector<unsigned int>& out) const
|
void dump(std::vector<unsigned int>& out) const
|
||||||
{
|
{
|
||||||
|
// OpLine
|
||||||
|
if (lineInstruction != nullptr) {
|
||||||
|
lineInstruction->dump(out);
|
||||||
|
}
|
||||||
|
|
||||||
// OpFunction
|
// OpFunction
|
||||||
functionInstruction.dump(out);
|
functionInstruction.dump(out);
|
||||||
|
|
||||||
@ -391,6 +405,7 @@ protected:
|
|||||||
Function& operator=(Function&);
|
Function& operator=(Function&);
|
||||||
|
|
||||||
Module& parent;
|
Module& parent;
|
||||||
|
std::unique_ptr<Instruction> lineInstruction;
|
||||||
Instruction functionInstruction;
|
Instruction functionInstruction;
|
||||||
std::vector<Instruction*> parameterInstructions;
|
std::vector<Instruction*> parameterInstructions;
|
||||||
std::vector<Block*> blocks;
|
std::vector<Block*> blocks;
|
||||||
@ -457,7 +472,8 @@ protected:
|
|||||||
// - the OpFunction instruction
|
// - the OpFunction instruction
|
||||||
// - all the OpFunctionParameter instructions
|
// - all the OpFunctionParameter instructions
|
||||||
__inline Function::Function(Id id, Id resultType, Id functionType, Id firstParamId, Module& parent)
|
__inline Function::Function(Id id, Id resultType, Id functionType, Id firstParamId, Module& parent)
|
||||||
: parent(parent), functionInstruction(id, resultType, OpFunction), implicitThis(false),
|
: parent(parent), lineInstruction(nullptr),
|
||||||
|
functionInstruction(id, resultType, OpFunction), implicitThis(false),
|
||||||
reducedPrecisionReturn(false)
|
reducedPrecisionReturn(false)
|
||||||
{
|
{
|
||||||
// OpFunction
|
// OpFunction
|
||||||
|
24
thirdparty/glslang/glslang/Include/BaseTypes.h
vendored
24
thirdparty/glslang/glslang/Include/BaseTypes.h
vendored
@ -105,6 +105,8 @@ enum TStorageQualifier {
|
|||||||
EvqCallableData,
|
EvqCallableData,
|
||||||
EvqCallableDataIn,
|
EvqCallableDataIn,
|
||||||
|
|
||||||
|
EvqtaskPayloadSharedEXT,
|
||||||
|
|
||||||
// parameters
|
// parameters
|
||||||
EvqIn, // also, for 'in' in the grammar before we know if it's a pipeline input or an 'in' parameter
|
EvqIn, // also, for 'in' in the grammar before we know if it's a pipeline input or an 'in' parameter
|
||||||
EvqOut, // also, for 'out' in the grammar before we know if it's a pipeline output or an 'out' parameter
|
EvqOut, // also, for 'out' in the grammar before we know if it's a pipeline output or an 'out' parameter
|
||||||
@ -128,6 +130,7 @@ enum TStorageQualifier {
|
|||||||
// built-ins written by fragment shader
|
// built-ins written by fragment shader
|
||||||
EvqFragColor,
|
EvqFragColor,
|
||||||
EvqFragDepth,
|
EvqFragDepth,
|
||||||
|
EvqFragStencil,
|
||||||
|
|
||||||
// end of list
|
// end of list
|
||||||
EvqLast
|
EvqLast
|
||||||
@ -263,6 +266,7 @@ enum TBuiltInVariable {
|
|||||||
EbvObjectRayDirection,
|
EbvObjectRayDirection,
|
||||||
EbvRayTmin,
|
EbvRayTmin,
|
||||||
EbvRayTmax,
|
EbvRayTmax,
|
||||||
|
EbvCullMask,
|
||||||
EbvHitT,
|
EbvHitT,
|
||||||
EbvHitKind,
|
EbvHitKind,
|
||||||
EbvObjectToWorld,
|
EbvObjectToWorld,
|
||||||
@ -274,6 +278,8 @@ enum TBuiltInVariable {
|
|||||||
// barycentrics
|
// barycentrics
|
||||||
EbvBaryCoordNV,
|
EbvBaryCoordNV,
|
||||||
EbvBaryCoordNoPerspNV,
|
EbvBaryCoordNoPerspNV,
|
||||||
|
EbvBaryCoordEXT,
|
||||||
|
EbvBaryCoordNoPerspEXT,
|
||||||
// mesh shaders
|
// mesh shaders
|
||||||
EbvTaskCountNV,
|
EbvTaskCountNV,
|
||||||
EbvPrimitiveCountNV,
|
EbvPrimitiveCountNV,
|
||||||
@ -283,6 +289,11 @@ enum TBuiltInVariable {
|
|||||||
EbvLayerPerViewNV,
|
EbvLayerPerViewNV,
|
||||||
EbvMeshViewCountNV,
|
EbvMeshViewCountNV,
|
||||||
EbvMeshViewIndicesNV,
|
EbvMeshViewIndicesNV,
|
||||||
|
//GL_EXT_mesh_shader
|
||||||
|
EbvPrimitivePointIndicesEXT,
|
||||||
|
EbvPrimitiveLineIndicesEXT,
|
||||||
|
EbvPrimitiveTriangleIndicesEXT,
|
||||||
|
EbvCullPrimitiveEXT,
|
||||||
|
|
||||||
// sm builtins
|
// sm builtins
|
||||||
EbvWarpsPerSM,
|
EbvWarpsPerSM,
|
||||||
@ -350,11 +361,13 @@ __inline const char* GetStorageQualifierString(TStorageQualifier q)
|
|||||||
case EvqPointCoord: return "gl_PointCoord"; break;
|
case EvqPointCoord: return "gl_PointCoord"; break;
|
||||||
case EvqFragColor: return "fragColor"; break;
|
case EvqFragColor: return "fragColor"; break;
|
||||||
case EvqFragDepth: return "gl_FragDepth"; break;
|
case EvqFragDepth: return "gl_FragDepth"; break;
|
||||||
|
case EvqFragStencil: return "gl_FragStencilRefARB"; break;
|
||||||
case EvqPayload: return "rayPayloadNV"; break;
|
case EvqPayload: return "rayPayloadNV"; break;
|
||||||
case EvqPayloadIn: return "rayPayloadInNV"; break;
|
case EvqPayloadIn: return "rayPayloadInNV"; break;
|
||||||
case EvqHitAttr: return "hitAttributeNV"; break;
|
case EvqHitAttr: return "hitAttributeNV"; break;
|
||||||
case EvqCallableData: return "callableDataNV"; break;
|
case EvqCallableData: return "callableDataNV"; break;
|
||||||
case EvqCallableDataIn: return "callableDataInNV"; break;
|
case EvqCallableDataIn: return "callableDataInNV"; break;
|
||||||
|
case EvqtaskPayloadSharedEXT: return "taskPayloadSharedEXT"; break;
|
||||||
default: return "unknown qualifier";
|
default: return "unknown qualifier";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -478,8 +491,10 @@ __inline const char* GetBuiltInVariableString(TBuiltInVariable v)
|
|||||||
case EbvWorldToObject: return "WorldToObjectNV";
|
case EbvWorldToObject: return "WorldToObjectNV";
|
||||||
case EbvCurrentRayTimeNV: return "CurrentRayTimeNV";
|
case EbvCurrentRayTimeNV: return "CurrentRayTimeNV";
|
||||||
|
|
||||||
case EbvBaryCoordNV: return "BaryCoordNV";
|
case EbvBaryCoordEXT:
|
||||||
case EbvBaryCoordNoPerspNV: return "BaryCoordNoPerspNV";
|
case EbvBaryCoordNV: return "BaryCoordKHR";
|
||||||
|
case EbvBaryCoordNoPerspEXT:
|
||||||
|
case EbvBaryCoordNoPerspNV: return "BaryCoordNoPerspKHR";
|
||||||
|
|
||||||
case EbvTaskCountNV: return "TaskCountNV";
|
case EbvTaskCountNV: return "TaskCountNV";
|
||||||
case EbvPrimitiveCountNV: return "PrimitiveCountNV";
|
case EbvPrimitiveCountNV: return "PrimitiveCountNV";
|
||||||
@ -489,6 +504,11 @@ __inline const char* GetBuiltInVariableString(TBuiltInVariable v)
|
|||||||
case EbvLayerPerViewNV: return "LayerPerViewNV";
|
case EbvLayerPerViewNV: return "LayerPerViewNV";
|
||||||
case EbvMeshViewCountNV: return "MeshViewCountNV";
|
case EbvMeshViewCountNV: return "MeshViewCountNV";
|
||||||
case EbvMeshViewIndicesNV: return "MeshViewIndicesNV";
|
case EbvMeshViewIndicesNV: return "MeshViewIndicesNV";
|
||||||
|
// GL_EXT_mesh_shader
|
||||||
|
case EbvPrimitivePointIndicesEXT: return "PrimitivePointIndicesEXT";
|
||||||
|
case EbvPrimitiveLineIndicesEXT: return "PrimitiveLineIndicesEXT";
|
||||||
|
case EbvPrimitiveTriangleIndicesEXT: return "PrimitiveTriangleIndicesEXT";
|
||||||
|
case EbvCullPrimitiveEXT: return "CullPrimitiveEXT";
|
||||||
|
|
||||||
case EbvWarpsPerSM: return "WarpsPerSMNV";
|
case EbvWarpsPerSM: return "WarpsPerSMNV";
|
||||||
case EbvSMCount: return "SMCountNV";
|
case EbvSMCount: return "SMCountNV";
|
||||||
|
4
thirdparty/glslang/glslang/Include/Common.h
vendored
4
thirdparty/glslang/glslang/Include/Common.h
vendored
@ -66,7 +66,7 @@ std::string to_string(const T& val) {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (defined(_MSC_VER) && _MSC_VER < 1900 /*vs2015*/) || MINGW_HAS_SECURE_API
|
#if (defined(_MSC_VER) && _MSC_VER < 1900 /*vs2015*/) || (defined(MINGW_HAS_SECURE_API) && MINGW_HAS_SECURE_API)
|
||||||
#include <basetsd.h>
|
#include <basetsd.h>
|
||||||
#ifndef snprintf
|
#ifndef snprintf
|
||||||
#define snprintf sprintf_s
|
#define snprintf sprintf_s
|
||||||
@ -218,7 +218,7 @@ template <class T> T Max(const T a, const T b) { return a > b ? a : b; }
|
|||||||
//
|
//
|
||||||
// Create a TString object from an integer.
|
// Create a TString object from an integer.
|
||||||
//
|
//
|
||||||
#if defined _MSC_VER || MINGW_HAS_SECURE_API
|
#if defined(_MSC_VER) || (defined(MINGW_HAS_SECURE_API) && MINGW_HAS_SECURE_API)
|
||||||
inline const TString String(const int i, const int base = 10)
|
inline const TString String(const int i, const int base = 10)
|
||||||
{
|
{
|
||||||
char text[16]; // 32 bit ints are at most 10 digits in base 10
|
char text[16]; // 32 bit ints are at most 10 digits in base 10
|
||||||
|
@ -142,6 +142,15 @@ struct TBuiltInResource {
|
|||||||
int maxTaskWorkGroupSizeY_NV;
|
int maxTaskWorkGroupSizeY_NV;
|
||||||
int maxTaskWorkGroupSizeZ_NV;
|
int maxTaskWorkGroupSizeZ_NV;
|
||||||
int maxMeshViewCountNV;
|
int maxMeshViewCountNV;
|
||||||
|
int maxMeshOutputVerticesEXT;
|
||||||
|
int maxMeshOutputPrimitivesEXT;
|
||||||
|
int maxMeshWorkGroupSizeX_EXT;
|
||||||
|
int maxMeshWorkGroupSizeY_EXT;
|
||||||
|
int maxMeshWorkGroupSizeZ_EXT;
|
||||||
|
int maxTaskWorkGroupSizeX_EXT;
|
||||||
|
int maxTaskWorkGroupSizeY_EXT;
|
||||||
|
int maxTaskWorkGroupSizeZ_EXT;
|
||||||
|
int maxMeshViewCountEXT;
|
||||||
int maxDualSourceDrawBuffersEXT;
|
int maxDualSourceDrawBuffersEXT;
|
||||||
|
|
||||||
TLimits limits;
|
TLimits limits;
|
||||||
|
564
thirdparty/glslang/glslang/Include/Types.h
vendored
564
thirdparty/glslang/glslang/Include/Types.h
vendored
@ -443,6 +443,18 @@ enum TLayoutDepth {
|
|||||||
EldCount
|
EldCount
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum TLayoutStencil {
|
||||||
|
ElsNone,
|
||||||
|
ElsRefUnchangedFrontAMD,
|
||||||
|
ElsRefGreaterFrontAMD,
|
||||||
|
ElsRefLessFrontAMD,
|
||||||
|
ElsRefUnchangedBackAMD,
|
||||||
|
ElsRefGreaterBackAMD,
|
||||||
|
ElsRefLessBackAMD,
|
||||||
|
|
||||||
|
ElsCount
|
||||||
|
};
|
||||||
|
|
||||||
enum TBlendEquationShift {
|
enum TBlendEquationShift {
|
||||||
// No 'EBlendNone':
|
// No 'EBlendNone':
|
||||||
// These are used as bit-shift amounts. A mask of such shifts will have type 'int',
|
// These are used as bit-shift amounts. A mask of such shifts will have type 'int',
|
||||||
@ -552,6 +564,7 @@ public:
|
|||||||
perViewNV = false;
|
perViewNV = false;
|
||||||
perTaskNV = false;
|
perTaskNV = false;
|
||||||
#endif
|
#endif
|
||||||
|
pervertexEXT = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void clearMemory()
|
void clearMemory()
|
||||||
@ -604,7 +617,8 @@ public:
|
|||||||
bool isNoContraction() const { return false; }
|
bool isNoContraction() const { return false; }
|
||||||
void setNoContraction() { }
|
void setNoContraction() { }
|
||||||
bool isPervertexNV() const { return false; }
|
bool isPervertexNV() const { return false; }
|
||||||
void setNullInit() { }
|
bool isPervertexEXT() const { return pervertexEXT; }
|
||||||
|
void setNullInit() {}
|
||||||
bool isNullInit() const { return false; }
|
bool isNullInit() const { return false; }
|
||||||
void setSpirvByReference() { }
|
void setSpirvByReference() { }
|
||||||
bool isSpirvByReference() { return false; }
|
bool isSpirvByReference() { return false; }
|
||||||
@ -615,6 +629,7 @@ public:
|
|||||||
bool nopersp : 1;
|
bool nopersp : 1;
|
||||||
bool explicitInterp : 1;
|
bool explicitInterp : 1;
|
||||||
bool pervertexNV : 1;
|
bool pervertexNV : 1;
|
||||||
|
bool pervertexEXT : 1;
|
||||||
bool perPrimitiveNV : 1;
|
bool perPrimitiveNV : 1;
|
||||||
bool perViewNV : 1;
|
bool perViewNV : 1;
|
||||||
bool perTaskNV : 1;
|
bool perTaskNV : 1;
|
||||||
@ -663,12 +678,13 @@ public:
|
|||||||
}
|
}
|
||||||
bool isAuxiliary() const
|
bool isAuxiliary() const
|
||||||
{
|
{
|
||||||
return centroid || patch || sample || pervertexNV;
|
return centroid || patch || sample || pervertexNV || pervertexEXT;
|
||||||
}
|
}
|
||||||
bool isPatch() const { return patch; }
|
bool isPatch() const { return patch; }
|
||||||
bool isNoContraction() const { return noContraction; }
|
bool isNoContraction() const { return noContraction; }
|
||||||
void setNoContraction() { noContraction = true; }
|
void setNoContraction() { noContraction = true; }
|
||||||
bool isPervertexNV() const { return pervertexNV; }
|
bool isPervertexNV() const { return pervertexNV; }
|
||||||
|
bool isPervertexEXT() const { return pervertexEXT; }
|
||||||
void setNullInit() { nullInit = true; }
|
void setNullInit() { nullInit = true; }
|
||||||
bool isNullInit() const { return nullInit; }
|
bool isNullInit() const { return nullInit; }
|
||||||
void setSpirvByReference() { spirvByReference = true; }
|
void setSpirvByReference() { spirvByReference = true; }
|
||||||
@ -701,6 +717,7 @@ public:
|
|||||||
case EvqVaryingOut:
|
case EvqVaryingOut:
|
||||||
case EvqFragColor:
|
case EvqFragColor:
|
||||||
case EvqFragDepth:
|
case EvqFragDepth:
|
||||||
|
case EvqFragStencil:
|
||||||
return true;
|
return true;
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
@ -768,6 +785,7 @@ public:
|
|||||||
case EvqVaryingOut:
|
case EvqVaryingOut:
|
||||||
case EvqFragColor:
|
case EvqFragColor:
|
||||||
case EvqFragDepth:
|
case EvqFragDepth:
|
||||||
|
case EvqFragStencil:
|
||||||
return true;
|
return true;
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
@ -815,7 +833,7 @@ public:
|
|||||||
}
|
}
|
||||||
storage = EvqUniform;
|
storage = EvqUniform;
|
||||||
break;
|
break;
|
||||||
case EbsStorageBuffer :
|
case EbsStorageBuffer :
|
||||||
storage = EvqBuffer;
|
storage = EvqBuffer;
|
||||||
break;
|
break;
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
@ -838,6 +856,7 @@ public:
|
|||||||
bool isPerPrimitive() const { return perPrimitiveNV; }
|
bool isPerPrimitive() const { return perPrimitiveNV; }
|
||||||
bool isPerView() const { return perViewNV; }
|
bool isPerView() const { return perViewNV; }
|
||||||
bool isTaskMemory() const { return perTaskNV; }
|
bool isTaskMemory() const { return perTaskNV; }
|
||||||
|
bool isTaskPayload() const { return storage == EvqtaskPayloadSharedEXT; }
|
||||||
bool isAnyPayload() const {
|
bool isAnyPayload() const {
|
||||||
return storage == EvqPayload || storage == EvqPayloadIn;
|
return storage == EvqPayload || storage == EvqPayloadIn;
|
||||||
}
|
}
|
||||||
@ -856,8 +875,8 @@ public:
|
|||||||
case EShLangTessEvaluation:
|
case EShLangTessEvaluation:
|
||||||
return ! patch && isPipeInput();
|
return ! patch && isPipeInput();
|
||||||
case EShLangFragment:
|
case EShLangFragment:
|
||||||
return pervertexNV && isPipeInput();
|
return (pervertexNV || pervertexEXT) && isPipeInput();
|
||||||
case EShLangMeshNV:
|
case EShLangMesh:
|
||||||
return ! perTaskNV && isPipeOutput();
|
return ! perTaskNV && isPipeOutput();
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@ -1235,6 +1254,18 @@ public:
|
|||||||
default: return "none";
|
default: return "none";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
static const char* getLayoutStencilString(TLayoutStencil s)
|
||||||
|
{
|
||||||
|
switch (s) {
|
||||||
|
case ElsRefUnchangedFrontAMD: return "stencil_ref_unchanged_front_amd";
|
||||||
|
case ElsRefGreaterFrontAMD: return "stencil_ref_greater_front_amd";
|
||||||
|
case ElsRefLessFrontAMD: return "stencil_ref_less_front_amd";
|
||||||
|
case ElsRefUnchangedBackAMD: return "stencil_ref_unchanged_back_amd";
|
||||||
|
case ElsRefGreaterBackAMD: return "stencil_ref_greater_back_amd";
|
||||||
|
case ElsRefLessBackAMD: return "stencil_ref_less_back_amd";
|
||||||
|
default: return "none";
|
||||||
|
}
|
||||||
|
}
|
||||||
static const char* getBlendEquationString(TBlendEquationShift e)
|
static const char* getBlendEquationString(TBlendEquationShift e)
|
||||||
{
|
{
|
||||||
switch (e) {
|
switch (e) {
|
||||||
@ -1332,7 +1363,9 @@ struct TShaderQualifiers {
|
|||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
bool earlyFragmentTests; // fragment input
|
bool earlyFragmentTests; // fragment input
|
||||||
bool postDepthCoverage; // fragment input
|
bool postDepthCoverage; // fragment input
|
||||||
|
bool earlyAndLateFragmentTestsAMD; //fragment input
|
||||||
TLayoutDepth layoutDepth;
|
TLayoutDepth layoutDepth;
|
||||||
|
TLayoutStencil layoutStencil;
|
||||||
bool blendEquation; // true if any blend equation was specified
|
bool blendEquation; // true if any blend equation was specified
|
||||||
int numViews; // multiview extenstions
|
int numViews; // multiview extenstions
|
||||||
TInterlockOrdering interlockOrdering;
|
TInterlockOrdering interlockOrdering;
|
||||||
@ -1342,6 +1375,7 @@ struct TShaderQualifiers {
|
|||||||
int primitives; // mesh shader "max_primitives"DerivativeGroupLinear; // true if layout derivative_group_linearNV set
|
int primitives; // mesh shader "max_primitives"DerivativeGroupLinear; // true if layout derivative_group_linearNV set
|
||||||
bool layoutPrimitiveCulling; // true if layout primitive_culling set
|
bool layoutPrimitiveCulling; // true if layout primitive_culling set
|
||||||
TLayoutDepth getDepth() const { return layoutDepth; }
|
TLayoutDepth getDepth() const { return layoutDepth; }
|
||||||
|
TLayoutStencil getStencil() const { return layoutStencil; }
|
||||||
#else
|
#else
|
||||||
TLayoutDepth getDepth() const { return EldNone; }
|
TLayoutDepth getDepth() const { return EldNone; }
|
||||||
#endif
|
#endif
|
||||||
@ -1367,8 +1401,10 @@ struct TShaderQualifiers {
|
|||||||
localSizeSpecId[2] = TQualifier::layoutNotSet;
|
localSizeSpecId[2] = TQualifier::layoutNotSet;
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
earlyFragmentTests = false;
|
earlyFragmentTests = false;
|
||||||
|
earlyAndLateFragmentTestsAMD = false;
|
||||||
postDepthCoverage = false;
|
postDepthCoverage = false;
|
||||||
layoutDepth = EldNone;
|
layoutDepth = EldNone;
|
||||||
|
layoutStencil = ElsNone;
|
||||||
blendEquation = false;
|
blendEquation = false;
|
||||||
numViews = TQualifier::layoutNotSet;
|
numViews = TQualifier::layoutNotSet;
|
||||||
layoutOverrideCoverage = false;
|
layoutOverrideCoverage = false;
|
||||||
@ -1420,10 +1456,14 @@ struct TShaderQualifiers {
|
|||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
if (src.earlyFragmentTests)
|
if (src.earlyFragmentTests)
|
||||||
earlyFragmentTests = true;
|
earlyFragmentTests = true;
|
||||||
|
if (src.earlyAndLateFragmentTestsAMD)
|
||||||
|
earlyAndLateFragmentTestsAMD = true;
|
||||||
if (src.postDepthCoverage)
|
if (src.postDepthCoverage)
|
||||||
postDepthCoverage = true;
|
postDepthCoverage = true;
|
||||||
if (src.layoutDepth)
|
if (src.layoutDepth)
|
||||||
layoutDepth = src.layoutDepth;
|
layoutDepth = src.layoutDepth;
|
||||||
|
if (src.layoutStencil)
|
||||||
|
layoutStencil = src.layoutStencil;
|
||||||
if (src.blendEquation)
|
if (src.blendEquation)
|
||||||
blendEquation = src.blendEquation;
|
blendEquation = src.blendEquation;
|
||||||
if (src.numViews != TQualifier::layoutNotSet)
|
if (src.numViews != TQualifier::layoutNotSet)
|
||||||
@ -2142,7 +2182,8 @@ public:
|
|||||||
const char* getPrecisionQualifierString() const { return ""; }
|
const char* getPrecisionQualifierString() const { return ""; }
|
||||||
TString getBasicTypeString() const { return ""; }
|
TString getBasicTypeString() const { return ""; }
|
||||||
#else
|
#else
|
||||||
TString getCompleteString() const
|
TString getCompleteString(bool syntactic = false, bool getQualifiers = true, bool getPrecision = true,
|
||||||
|
bool getType = true, TString name = "", TString structName = "") const
|
||||||
{
|
{
|
||||||
TString typeString;
|
TString typeString;
|
||||||
|
|
||||||
@ -2150,232 +2191,337 @@ public:
|
|||||||
const auto appendUint = [&](unsigned int u) { typeString.append(std::to_string(u).c_str()); };
|
const auto appendUint = [&](unsigned int u) { typeString.append(std::to_string(u).c_str()); };
|
||||||
const auto appendInt = [&](int i) { typeString.append(std::to_string(i).c_str()); };
|
const auto appendInt = [&](int i) { typeString.append(std::to_string(i).c_str()); };
|
||||||
|
|
||||||
if (qualifier.hasSprivDecorate())
|
if (getQualifiers) {
|
||||||
|
if (qualifier.hasSprivDecorate())
|
||||||
appendStr(qualifier.getSpirvDecorateQualifierString().c_str());
|
appendStr(qualifier.getSpirvDecorateQualifierString().c_str());
|
||||||
|
|
||||||
if (qualifier.hasLayout()) {
|
if (qualifier.hasLayout()) {
|
||||||
// To reduce noise, skip this if the only layout is an xfb_buffer
|
// To reduce noise, skip this if the only layout is an xfb_buffer
|
||||||
// with no triggering xfb_offset.
|
// with no triggering xfb_offset.
|
||||||
TQualifier noXfbBuffer = qualifier;
|
TQualifier noXfbBuffer = qualifier;
|
||||||
noXfbBuffer.layoutXfbBuffer = TQualifier::layoutXfbBufferEnd;
|
noXfbBuffer.layoutXfbBuffer = TQualifier::layoutXfbBufferEnd;
|
||||||
if (noXfbBuffer.hasLayout()) {
|
if (noXfbBuffer.hasLayout()) {
|
||||||
appendStr("layout(");
|
appendStr("layout(");
|
||||||
if (qualifier.hasAnyLocation()) {
|
if (qualifier.hasAnyLocation()) {
|
||||||
appendStr(" location=");
|
appendStr(" location=");
|
||||||
appendUint(qualifier.layoutLocation);
|
appendUint(qualifier.layoutLocation);
|
||||||
if (qualifier.hasComponent()) {
|
if (qualifier.hasComponent()) {
|
||||||
appendStr(" component=");
|
appendStr(" component=");
|
||||||
appendUint(qualifier.layoutComponent);
|
appendUint(qualifier.layoutComponent);
|
||||||
}
|
|
||||||
if (qualifier.hasIndex()) {
|
|
||||||
appendStr(" index=");
|
|
||||||
appendUint(qualifier.layoutIndex);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (qualifier.hasSet()) {
|
if (qualifier.hasIndex()) {
|
||||||
appendStr(" set=");
|
appendStr(" index=");
|
||||||
appendUint(qualifier.layoutSet);
|
appendUint(qualifier.layoutIndex);
|
||||||
}
|
|
||||||
if (qualifier.hasBinding()) {
|
|
||||||
appendStr(" binding=");
|
|
||||||
appendUint(qualifier.layoutBinding);
|
|
||||||
}
|
|
||||||
if (qualifier.hasStream()) {
|
|
||||||
appendStr(" stream=");
|
|
||||||
appendUint(qualifier.layoutStream);
|
|
||||||
}
|
|
||||||
if (qualifier.hasMatrix()) {
|
|
||||||
appendStr(" ");
|
|
||||||
appendStr(TQualifier::getLayoutMatrixString(qualifier.layoutMatrix));
|
|
||||||
}
|
|
||||||
if (qualifier.hasPacking()) {
|
|
||||||
appendStr(" ");
|
|
||||||
appendStr(TQualifier::getLayoutPackingString(qualifier.layoutPacking));
|
|
||||||
}
|
|
||||||
if (qualifier.hasOffset()) {
|
|
||||||
appendStr(" offset=");
|
|
||||||
appendInt(qualifier.layoutOffset);
|
|
||||||
}
|
|
||||||
if (qualifier.hasAlign()) {
|
|
||||||
appendStr(" align=");
|
|
||||||
appendInt(qualifier.layoutAlign);
|
|
||||||
}
|
|
||||||
if (qualifier.hasFormat()) {
|
|
||||||
appendStr(" ");
|
|
||||||
appendStr(TQualifier::getLayoutFormatString(qualifier.layoutFormat));
|
|
||||||
}
|
|
||||||
if (qualifier.hasXfbBuffer() && qualifier.hasXfbOffset()) {
|
|
||||||
appendStr(" xfb_buffer=");
|
|
||||||
appendUint(qualifier.layoutXfbBuffer);
|
|
||||||
}
|
|
||||||
if (qualifier.hasXfbOffset()) {
|
|
||||||
appendStr(" xfb_offset=");
|
|
||||||
appendUint(qualifier.layoutXfbOffset);
|
|
||||||
}
|
|
||||||
if (qualifier.hasXfbStride()) {
|
|
||||||
appendStr(" xfb_stride=");
|
|
||||||
appendUint(qualifier.layoutXfbStride);
|
|
||||||
}
|
|
||||||
if (qualifier.hasAttachment()) {
|
|
||||||
appendStr(" input_attachment_index=");
|
|
||||||
appendUint(qualifier.layoutAttachment);
|
|
||||||
}
|
|
||||||
if (qualifier.hasSpecConstantId()) {
|
|
||||||
appendStr(" constant_id=");
|
|
||||||
appendUint(qualifier.layoutSpecConstantId);
|
|
||||||
}
|
|
||||||
if (qualifier.layoutPushConstant)
|
|
||||||
appendStr(" push_constant");
|
|
||||||
if (qualifier.layoutBufferReference)
|
|
||||||
appendStr(" buffer_reference");
|
|
||||||
if (qualifier.hasBufferReferenceAlign()) {
|
|
||||||
appendStr(" buffer_reference_align=");
|
|
||||||
appendUint(1u << qualifier.layoutBufferReferenceAlign);
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
if (qualifier.hasSet()) {
|
||||||
|
appendStr(" set=");
|
||||||
|
appendUint(qualifier.layoutSet);
|
||||||
|
}
|
||||||
|
if (qualifier.hasBinding()) {
|
||||||
|
appendStr(" binding=");
|
||||||
|
appendUint(qualifier.layoutBinding);
|
||||||
|
}
|
||||||
|
if (qualifier.hasStream()) {
|
||||||
|
appendStr(" stream=");
|
||||||
|
appendUint(qualifier.layoutStream);
|
||||||
|
}
|
||||||
|
if (qualifier.hasMatrix()) {
|
||||||
|
appendStr(" ");
|
||||||
|
appendStr(TQualifier::getLayoutMatrixString(qualifier.layoutMatrix));
|
||||||
|
}
|
||||||
|
if (qualifier.hasPacking()) {
|
||||||
|
appendStr(" ");
|
||||||
|
appendStr(TQualifier::getLayoutPackingString(qualifier.layoutPacking));
|
||||||
|
}
|
||||||
|
if (qualifier.hasOffset()) {
|
||||||
|
appendStr(" offset=");
|
||||||
|
appendInt(qualifier.layoutOffset);
|
||||||
|
}
|
||||||
|
if (qualifier.hasAlign()) {
|
||||||
|
appendStr(" align=");
|
||||||
|
appendInt(qualifier.layoutAlign);
|
||||||
|
}
|
||||||
|
if (qualifier.hasFormat()) {
|
||||||
|
appendStr(" ");
|
||||||
|
appendStr(TQualifier::getLayoutFormatString(qualifier.layoutFormat));
|
||||||
|
}
|
||||||
|
if (qualifier.hasXfbBuffer() && qualifier.hasXfbOffset()) {
|
||||||
|
appendStr(" xfb_buffer=");
|
||||||
|
appendUint(qualifier.layoutXfbBuffer);
|
||||||
|
}
|
||||||
|
if (qualifier.hasXfbOffset()) {
|
||||||
|
appendStr(" xfb_offset=");
|
||||||
|
appendUint(qualifier.layoutXfbOffset);
|
||||||
|
}
|
||||||
|
if (qualifier.hasXfbStride()) {
|
||||||
|
appendStr(" xfb_stride=");
|
||||||
|
appendUint(qualifier.layoutXfbStride);
|
||||||
|
}
|
||||||
|
if (qualifier.hasAttachment()) {
|
||||||
|
appendStr(" input_attachment_index=");
|
||||||
|
appendUint(qualifier.layoutAttachment);
|
||||||
|
}
|
||||||
|
if (qualifier.hasSpecConstantId()) {
|
||||||
|
appendStr(" constant_id=");
|
||||||
|
appendUint(qualifier.layoutSpecConstantId);
|
||||||
|
}
|
||||||
|
if (qualifier.layoutPushConstant)
|
||||||
|
appendStr(" push_constant");
|
||||||
|
if (qualifier.layoutBufferReference)
|
||||||
|
appendStr(" buffer_reference");
|
||||||
|
if (qualifier.hasBufferReferenceAlign()) {
|
||||||
|
appendStr(" buffer_reference_align=");
|
||||||
|
appendUint(1u << qualifier.layoutBufferReferenceAlign);
|
||||||
|
}
|
||||||
|
|
||||||
if (qualifier.layoutPassthrough)
|
if (qualifier.layoutPassthrough)
|
||||||
appendStr(" passthrough");
|
appendStr(" passthrough");
|
||||||
if (qualifier.layoutViewportRelative)
|
if (qualifier.layoutViewportRelative)
|
||||||
appendStr(" layoutViewportRelative");
|
appendStr(" layoutViewportRelative");
|
||||||
if (qualifier.layoutSecondaryViewportRelativeOffset != -2048) {
|
if (qualifier.layoutSecondaryViewportRelativeOffset != -2048) {
|
||||||
appendStr(" layoutSecondaryViewportRelativeOffset=");
|
appendStr(" layoutSecondaryViewportRelativeOffset=");
|
||||||
appendInt(qualifier.layoutSecondaryViewportRelativeOffset);
|
appendInt(qualifier.layoutSecondaryViewportRelativeOffset);
|
||||||
}
|
}
|
||||||
if (qualifier.layoutShaderRecord)
|
if (qualifier.layoutShaderRecord)
|
||||||
appendStr(" shaderRecordNV");
|
appendStr(" shaderRecordNV");
|
||||||
|
|
||||||
appendStr(")");
|
appendStr(")");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qualifier.invariant)
|
if (qualifier.invariant)
|
||||||
appendStr(" invariant");
|
appendStr(" invariant");
|
||||||
if (qualifier.noContraction)
|
if (qualifier.noContraction)
|
||||||
appendStr(" noContraction");
|
appendStr(" noContraction");
|
||||||
if (qualifier.centroid)
|
if (qualifier.centroid)
|
||||||
appendStr(" centroid");
|
appendStr(" centroid");
|
||||||
if (qualifier.smooth)
|
if (qualifier.smooth)
|
||||||
appendStr(" smooth");
|
appendStr(" smooth");
|
||||||
if (qualifier.flat)
|
if (qualifier.flat)
|
||||||
appendStr(" flat");
|
appendStr(" flat");
|
||||||
if (qualifier.nopersp)
|
if (qualifier.nopersp)
|
||||||
appendStr(" noperspective");
|
appendStr(" noperspective");
|
||||||
if (qualifier.explicitInterp)
|
if (qualifier.explicitInterp)
|
||||||
appendStr(" __explicitInterpAMD");
|
appendStr(" __explicitInterpAMD");
|
||||||
if (qualifier.pervertexNV)
|
if (qualifier.pervertexNV)
|
||||||
appendStr(" pervertexNV");
|
appendStr(" pervertexNV");
|
||||||
if (qualifier.perPrimitiveNV)
|
if (qualifier.pervertexEXT)
|
||||||
|
appendStr(" pervertexEXT");
|
||||||
|
if (qualifier.perPrimitiveNV)
|
||||||
appendStr(" perprimitiveNV");
|
appendStr(" perprimitiveNV");
|
||||||
if (qualifier.perViewNV)
|
if (qualifier.perViewNV)
|
||||||
appendStr(" perviewNV");
|
appendStr(" perviewNV");
|
||||||
if (qualifier.perTaskNV)
|
if (qualifier.perTaskNV)
|
||||||
appendStr(" taskNV");
|
appendStr(" taskNV");
|
||||||
if (qualifier.patch)
|
if (qualifier.patch)
|
||||||
appendStr(" patch");
|
appendStr(" patch");
|
||||||
if (qualifier.sample)
|
if (qualifier.sample)
|
||||||
appendStr(" sample");
|
appendStr(" sample");
|
||||||
if (qualifier.coherent)
|
if (qualifier.coherent)
|
||||||
appendStr(" coherent");
|
appendStr(" coherent");
|
||||||
if (qualifier.devicecoherent)
|
if (qualifier.devicecoherent)
|
||||||
appendStr(" devicecoherent");
|
appendStr(" devicecoherent");
|
||||||
if (qualifier.queuefamilycoherent)
|
if (qualifier.queuefamilycoherent)
|
||||||
appendStr(" queuefamilycoherent");
|
appendStr(" queuefamilycoherent");
|
||||||
if (qualifier.workgroupcoherent)
|
if (qualifier.workgroupcoherent)
|
||||||
appendStr(" workgroupcoherent");
|
appendStr(" workgroupcoherent");
|
||||||
if (qualifier.subgroupcoherent)
|
if (qualifier.subgroupcoherent)
|
||||||
appendStr(" subgroupcoherent");
|
appendStr(" subgroupcoherent");
|
||||||
if (qualifier.shadercallcoherent)
|
if (qualifier.shadercallcoherent)
|
||||||
appendStr(" shadercallcoherent");
|
appendStr(" shadercallcoherent");
|
||||||
if (qualifier.nonprivate)
|
if (qualifier.nonprivate)
|
||||||
appendStr(" nonprivate");
|
appendStr(" nonprivate");
|
||||||
if (qualifier.volatil)
|
if (qualifier.volatil)
|
||||||
appendStr(" volatile");
|
appendStr(" volatile");
|
||||||
if (qualifier.restrict)
|
if (qualifier.restrict)
|
||||||
appendStr(" restrict");
|
appendStr(" restrict");
|
||||||
if (qualifier.readonly)
|
if (qualifier.readonly)
|
||||||
appendStr(" readonly");
|
appendStr(" readonly");
|
||||||
if (qualifier.writeonly)
|
if (qualifier.writeonly)
|
||||||
appendStr(" writeonly");
|
appendStr(" writeonly");
|
||||||
if (qualifier.specConstant)
|
if (qualifier.specConstant)
|
||||||
appendStr(" specialization-constant");
|
appendStr(" specialization-constant");
|
||||||
if (qualifier.nonUniform)
|
if (qualifier.nonUniform)
|
||||||
appendStr(" nonuniform");
|
appendStr(" nonuniform");
|
||||||
if (qualifier.isNullInit())
|
if (qualifier.isNullInit())
|
||||||
appendStr(" null-init");
|
appendStr(" null-init");
|
||||||
if (qualifier.isSpirvByReference())
|
if (qualifier.isSpirvByReference())
|
||||||
appendStr(" spirv_by_reference");
|
appendStr(" spirv_by_reference");
|
||||||
if (qualifier.isSpirvLiteral())
|
if (qualifier.isSpirvLiteral())
|
||||||
appendStr(" spirv_literal");
|
appendStr(" spirv_literal");
|
||||||
appendStr(" ");
|
appendStr(" ");
|
||||||
appendStr(getStorageQualifierString());
|
appendStr(getStorageQualifierString());
|
||||||
if (isArray()) {
|
}
|
||||||
for(int i = 0; i < (int)arraySizes->getNumDims(); ++i) {
|
if (getType) {
|
||||||
|
if (syntactic) {
|
||||||
|
if (getPrecision && qualifier.precision != EpqNone) {
|
||||||
|
appendStr(" ");
|
||||||
|
appendStr(getPrecisionQualifierString());
|
||||||
|
}
|
||||||
|
if (isVector() || isMatrix()) {
|
||||||
|
appendStr(" ");
|
||||||
|
switch (basicType) {
|
||||||
|
case EbtDouble:
|
||||||
|
appendStr("d");
|
||||||
|
break;
|
||||||
|
case EbtInt:
|
||||||
|
appendStr("i");
|
||||||
|
break;
|
||||||
|
case EbtUint:
|
||||||
|
appendStr("u");
|
||||||
|
break;
|
||||||
|
case EbtBool:
|
||||||
|
appendStr("b");
|
||||||
|
break;
|
||||||
|
case EbtFloat:
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (isVector()) {
|
||||||
|
appendStr("vec");
|
||||||
|
appendInt(vectorSize);
|
||||||
|
} else {
|
||||||
|
appendStr("mat");
|
||||||
|
appendInt(matrixCols);
|
||||||
|
appendStr("x");
|
||||||
|
appendInt(matrixRows);
|
||||||
|
}
|
||||||
|
} else if (isStruct() && structure) {
|
||||||
|
appendStr(" ");
|
||||||
|
appendStr(structName.c_str());
|
||||||
|
appendStr("{");
|
||||||
|
bool hasHiddenMember = true;
|
||||||
|
for (size_t i = 0; i < structure->size(); ++i) {
|
||||||
|
if (!(*structure)[i].type->hiddenMember()) {
|
||||||
|
if (!hasHiddenMember)
|
||||||
|
appendStr(", ");
|
||||||
|
typeString.append((*structure)[i].type->getCompleteString(syntactic, getQualifiers, getPrecision, getType, (*structure)[i].type->getFieldName()));
|
||||||
|
hasHiddenMember = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
appendStr("}");
|
||||||
|
} else {
|
||||||
|
appendStr(" ");
|
||||||
|
switch (basicType) {
|
||||||
|
case EbtDouble:
|
||||||
|
appendStr("double");
|
||||||
|
break;
|
||||||
|
case EbtInt:
|
||||||
|
appendStr("int");
|
||||||
|
break;
|
||||||
|
case EbtUint:
|
||||||
|
appendStr("uint");
|
||||||
|
break;
|
||||||
|
case EbtBool:
|
||||||
|
appendStr("bool");
|
||||||
|
break;
|
||||||
|
case EbtFloat:
|
||||||
|
appendStr("float");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
appendStr("unexpected");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (name.length() > 0) {
|
||||||
|
appendStr(" ");
|
||||||
|
appendStr(name.c_str());
|
||||||
|
}
|
||||||
|
if (isArray()) {
|
||||||
|
for (int i = 0; i < (int)arraySizes->getNumDims(); ++i) {
|
||||||
int size = arraySizes->getDimSize(i);
|
int size = arraySizes->getDimSize(i);
|
||||||
if (size == UnsizedArraySize && i == 0 && arraySizes->isVariablyIndexed())
|
if (size == UnsizedArraySize && i == 0 && arraySizes->isVariablyIndexed())
|
||||||
appendStr(" runtime-sized array of");
|
appendStr("[]");
|
||||||
else {
|
else {
|
||||||
if (size == UnsizedArraySize) {
|
if (size == UnsizedArraySize) {
|
||||||
appendStr(" unsized");
|
appendStr("[");
|
||||||
if (i == 0) {
|
if (i == 0)
|
||||||
appendStr(" ");
|
appendInt(arraySizes->getImplicitSize());
|
||||||
appendInt(arraySizes->getImplicitSize());
|
appendStr("]");
|
||||||
}
|
}
|
||||||
} else {
|
else {
|
||||||
appendStr(" ");
|
appendStr("[");
|
||||||
appendInt(arraySizes->getDimSize(i));
|
appendInt(arraySizes->getDimSize(i));
|
||||||
}
|
appendStr("]");
|
||||||
appendStr("-element array of");
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (isParameterized()) {
|
else {
|
||||||
appendStr("<");
|
if (isArray()) {
|
||||||
for(int i = 0; i < (int)typeParameters->getNumDims(); ++i) {
|
for (int i = 0; i < (int)arraySizes->getNumDims(); ++i) {
|
||||||
|
int size = arraySizes->getDimSize(i);
|
||||||
|
if (size == UnsizedArraySize && i == 0 && arraySizes->isVariablyIndexed())
|
||||||
|
appendStr(" runtime-sized array of");
|
||||||
|
else {
|
||||||
|
if (size == UnsizedArraySize) {
|
||||||
|
appendStr(" unsized");
|
||||||
|
if (i == 0) {
|
||||||
|
appendStr(" ");
|
||||||
|
appendInt(arraySizes->getImplicitSize());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
appendStr(" ");
|
||||||
|
appendInt(arraySizes->getDimSize(i));
|
||||||
|
}
|
||||||
|
appendStr("-element array of");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (isParameterized()) {
|
||||||
|
appendStr("<");
|
||||||
|
for (int i = 0; i < (int)typeParameters->getNumDims(); ++i) {
|
||||||
appendInt(typeParameters->getDimSize(i));
|
appendInt(typeParameters->getDimSize(i));
|
||||||
if (i != (int)typeParameters->getNumDims() - 1)
|
if (i != (int)typeParameters->getNumDims() - 1)
|
||||||
|
appendStr(", ");
|
||||||
|
}
|
||||||
|
appendStr(">");
|
||||||
|
}
|
||||||
|
if (getPrecision && qualifier.precision != EpqNone) {
|
||||||
|
appendStr(" ");
|
||||||
|
appendStr(getPrecisionQualifierString());
|
||||||
|
}
|
||||||
|
if (isMatrix()) {
|
||||||
|
appendStr(" ");
|
||||||
|
appendInt(matrixCols);
|
||||||
|
appendStr("X");
|
||||||
|
appendInt(matrixRows);
|
||||||
|
appendStr(" matrix of");
|
||||||
|
}
|
||||||
|
else if (isVector()) {
|
||||||
|
appendStr(" ");
|
||||||
|
appendInt(vectorSize);
|
||||||
|
appendStr("-component vector of");
|
||||||
|
}
|
||||||
|
|
||||||
|
appendStr(" ");
|
||||||
|
typeString.append(getBasicTypeString());
|
||||||
|
|
||||||
|
if (qualifier.builtIn != EbvNone) {
|
||||||
|
appendStr(" ");
|
||||||
|
appendStr(getBuiltInVariableString());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add struct/block members
|
||||||
|
if (isStruct() && structure) {
|
||||||
|
appendStr("{");
|
||||||
|
bool hasHiddenMember = true;
|
||||||
|
for (size_t i = 0; i < structure->size(); ++i) {
|
||||||
|
if (!(*structure)[i].type->hiddenMember()) {
|
||||||
|
if (!hasHiddenMember)
|
||||||
appendStr(", ");
|
appendStr(", ");
|
||||||
}
|
typeString.append((*structure)[i].type->getCompleteString());
|
||||||
appendStr(">");
|
typeString.append(" ");
|
||||||
}
|
typeString.append((*structure)[i].type->getFieldName());
|
||||||
if (qualifier.precision != EpqNone) {
|
hasHiddenMember = false;
|
||||||
appendStr(" ");
|
|
||||||
appendStr(getPrecisionQualifierString());
|
|
||||||
}
|
|
||||||
if (isMatrix()) {
|
|
||||||
appendStr(" ");
|
|
||||||
appendInt(matrixCols);
|
|
||||||
appendStr("X");
|
|
||||||
appendInt(matrixRows);
|
|
||||||
appendStr(" matrix of");
|
|
||||||
} else if (isVector()) {
|
|
||||||
appendStr(" ");
|
|
||||||
appendInt(vectorSize);
|
|
||||||
appendStr("-component vector of");
|
|
||||||
}
|
|
||||||
|
|
||||||
appendStr(" ");
|
|
||||||
typeString.append(getBasicTypeString());
|
|
||||||
|
|
||||||
if (qualifier.builtIn != EbvNone) {
|
|
||||||
appendStr(" ");
|
|
||||||
appendStr(getBuiltInVariableString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add struct/block members
|
|
||||||
if (isStruct() && structure) {
|
|
||||||
appendStr("{");
|
|
||||||
bool hasHiddenMember = true;
|
|
||||||
for (size_t i = 0; i < structure->size(); ++i) {
|
|
||||||
if (! (*structure)[i].type->hiddenMember()) {
|
|
||||||
if (!hasHiddenMember)
|
|
||||||
appendStr(", ");
|
|
||||||
typeString.append((*structure)[i].type->getCompleteString());
|
|
||||||
typeString.append(" ");
|
|
||||||
typeString.append((*structure)[i].type->getFieldName());
|
|
||||||
hasHiddenMember = false;
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
appendStr("}");
|
||||||
}
|
}
|
||||||
appendStr("}");
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return typeString;
|
return typeString;
|
||||||
@ -2398,7 +2544,7 @@ public:
|
|||||||
void setStruct(TTypeList* s) { assert(isStruct()); structure = s; }
|
void setStruct(TTypeList* s) { assert(isStruct()); structure = s; }
|
||||||
TTypeList* getWritableStruct() const { assert(isStruct()); return structure; } // This should only be used when known to not be sharing with other threads
|
TTypeList* getWritableStruct() const { assert(isStruct()); return structure; } // This should only be used when known to not be sharing with other threads
|
||||||
void setBasicType(const TBasicType& t) { basicType = t; }
|
void setBasicType(const TBasicType& t) { basicType = t; }
|
||||||
|
|
||||||
int computeNumComponents() const
|
int computeNumComponents() const
|
||||||
{
|
{
|
||||||
int components = 0;
|
int components = 0;
|
||||||
@ -2444,10 +2590,20 @@ public:
|
|||||||
// type definitions, and member names to be considered the same type.
|
// type definitions, and member names to be considered the same type.
|
||||||
// This rule applies recursively for nested or embedded types."
|
// This rule applies recursively for nested or embedded types."
|
||||||
//
|
//
|
||||||
bool sameStructType(const TType& right) const
|
// If type mismatch in structure, return member indices through lpidx and rpidx.
|
||||||
|
// If matching members for either block are exhausted, return -1 for exhausted
|
||||||
|
// block and the index of the unmatched member. Otherwise return {-1,-1}.
|
||||||
|
//
|
||||||
|
bool sameStructType(const TType& right, int* lpidx = nullptr, int* rpidx = nullptr) const
|
||||||
{
|
{
|
||||||
// TODO: Why return true when neither types are structures?
|
// Initialize error to general type mismatch.
|
||||||
|
if (lpidx != nullptr) {
|
||||||
|
*lpidx = -1;
|
||||||
|
*rpidx = -1;
|
||||||
|
}
|
||||||
|
|
||||||
// Most commonly, they are both nullptr, or the same pointer to the same actual structure
|
// Most commonly, they are both nullptr, or the same pointer to the same actual structure
|
||||||
|
// TODO: Why return true when neither types are structures?
|
||||||
if ((!isStruct() && !right.isStruct()) ||
|
if ((!isStruct() && !right.isStruct()) ||
|
||||||
(isStruct() && right.isStruct() && structure == right.structure))
|
(isStruct() && right.isStruct() && structure == right.structure))
|
||||||
return true;
|
return true;
|
||||||
@ -2464,11 +2620,17 @@ public:
|
|||||||
bool isGLPerVertex = *typeName == "gl_PerVertex";
|
bool isGLPerVertex = *typeName == "gl_PerVertex";
|
||||||
|
|
||||||
// Both being nullptr was caught above, now they both have to be structures of the same number of elements
|
// Both being nullptr was caught above, now they both have to be structures of the same number of elements
|
||||||
if (structure->size() != right.structure->size() && !isGLPerVertex)
|
if (lpidx == nullptr &&
|
||||||
|
(structure->size() != right.structure->size() && !isGLPerVertex)) {
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// Compare the names and types of all the members, which have to match
|
// Compare the names and types of all the members, which have to match
|
||||||
for (size_t li = 0, ri = 0; li < structure->size() || ri < right.structure->size(); ++li, ++ri) {
|
for (size_t li = 0, ri = 0; li < structure->size() || ri < right.structure->size(); ++li, ++ri) {
|
||||||
|
if (lpidx != nullptr) {
|
||||||
|
*lpidx = static_cast<int>(li);
|
||||||
|
*rpidx = static_cast<int>(ri);
|
||||||
|
}
|
||||||
if (li < structure->size() && ri < right.structure->size()) {
|
if (li < structure->size() && ri < right.structure->size()) {
|
||||||
if ((*structure)[li].type->getFieldName() == (*right.structure)[ri].type->getFieldName()) {
|
if ((*structure)[li].type->getFieldName() == (*right.structure)[ri].type->getFieldName()) {
|
||||||
if (*(*structure)[li].type != *(*right.structure)[ri].type)
|
if (*(*structure)[li].type != *(*right.structure)[ri].type)
|
||||||
@ -2498,11 +2660,19 @@ public:
|
|||||||
}
|
}
|
||||||
// If we get here, then there should only be inconsistently declared members left
|
// If we get here, then there should only be inconsistently declared members left
|
||||||
} else if (li < structure->size()) {
|
} else if (li < structure->size()) {
|
||||||
if (!(*structure)[li].type->hiddenMember() && !isInconsistentGLPerVertexMember((*structure)[li].type->getFieldName()))
|
if (!(*structure)[li].type->hiddenMember() && !isInconsistentGLPerVertexMember((*structure)[li].type->getFieldName())) {
|
||||||
|
if (lpidx != nullptr) {
|
||||||
|
*rpidx = -1;
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (!(*right.structure)[ri].type->hiddenMember() && !isInconsistentGLPerVertexMember((*right.structure)[ri].type->getFieldName()))
|
if (!(*right.structure)[ri].type->hiddenMember() && !isInconsistentGLPerVertexMember((*right.structure)[ri].type->getFieldName())) {
|
||||||
|
if (lpidx != nullptr) {
|
||||||
|
*lpidx = -1;
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2526,10 +2696,15 @@ public:
|
|||||||
return *referentType == *right.referentType;
|
return *referentType == *right.referentType;
|
||||||
}
|
}
|
||||||
|
|
||||||
// See if two types match, in all aspects except arrayness
|
// See if two types match, in all aspects except arrayness
|
||||||
bool sameElementType(const TType& right) const
|
// If mismatch in structure members, return member indices in lpidx and rpidx.
|
||||||
|
bool sameElementType(const TType& right, int* lpidx = nullptr, int* rpidx = nullptr) const
|
||||||
{
|
{
|
||||||
return basicType == right.basicType && sameElementShape(right);
|
if (lpidx != nullptr) {
|
||||||
|
*lpidx = -1;
|
||||||
|
*rpidx = -1;
|
||||||
|
}
|
||||||
|
return basicType == right.basicType && sameElementShape(right, lpidx, rpidx);
|
||||||
}
|
}
|
||||||
|
|
||||||
// See if two type's arrayness match
|
// See if two type's arrayness match
|
||||||
@ -2563,15 +2738,20 @@ public:
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// See if two type's elements match in all ways except basic type
|
// See if two type's elements match in all ways except basic type
|
||||||
bool sameElementShape(const TType& right) const
|
// If mismatch in structure members, return member indices in lpidx and rpidx.
|
||||||
|
bool sameElementShape(const TType& right, int* lpidx = nullptr, int* rpidx = nullptr) const
|
||||||
{
|
{
|
||||||
return sampler == right.sampler &&
|
if (lpidx != nullptr) {
|
||||||
|
*lpidx = -1;
|
||||||
|
*rpidx = -1;
|
||||||
|
}
|
||||||
|
return ((basicType != EbtSampler && right.basicType != EbtSampler) || sampler == right.sampler) &&
|
||||||
vectorSize == right.vectorSize &&
|
vectorSize == right.vectorSize &&
|
||||||
matrixCols == right.matrixCols &&
|
matrixCols == right.matrixCols &&
|
||||||
matrixRows == right.matrixRows &&
|
matrixRows == right.matrixRows &&
|
||||||
vector1 == right.vector1 &&
|
vector1 == right.vector1 &&
|
||||||
isCoopMat() == right.isCoopMat() &&
|
isCoopMat() == right.isCoopMat() &&
|
||||||
sameStructType(right) &&
|
sameStructType(right, lpidx, rpidx) &&
|
||||||
sameReferenceType(right);
|
sameReferenceType(right);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -148,6 +148,15 @@ typedef struct glslang_resource_s {
|
|||||||
int max_task_work_group_size_y_nv;
|
int max_task_work_group_size_y_nv;
|
||||||
int max_task_work_group_size_z_nv;
|
int max_task_work_group_size_z_nv;
|
||||||
int max_mesh_view_count_nv;
|
int max_mesh_view_count_nv;
|
||||||
|
int max_mesh_output_vertices_ext;
|
||||||
|
int max_mesh_output_primitives_ext;
|
||||||
|
int max_mesh_work_group_size_x_ext;
|
||||||
|
int max_mesh_work_group_size_y_ext;
|
||||||
|
int max_mesh_work_group_size_z_ext;
|
||||||
|
int max_task_work_group_size_x_ext;
|
||||||
|
int max_task_work_group_size_y_ext;
|
||||||
|
int max_task_work_group_size_z_ext;
|
||||||
|
int max_mesh_view_count_ext;
|
||||||
int maxDualSourceDrawBuffersEXT;
|
int maxDualSourceDrawBuffersEXT;
|
||||||
|
|
||||||
glslang_limits_t limits;
|
glslang_limits_t limits;
|
||||||
@ -199,6 +208,18 @@ typedef struct glsl_include_callbacks_s {
|
|||||||
glsl_free_include_result_func free_include_result;
|
glsl_free_include_result_func free_include_result;
|
||||||
} glsl_include_callbacks_t;
|
} glsl_include_callbacks_t;
|
||||||
|
|
||||||
|
/* SpvOptions counterpart */
|
||||||
|
typedef struct glslang_spv_options_s {
|
||||||
|
bool generate_debug_info;
|
||||||
|
bool strip_debug_info;
|
||||||
|
bool disable_optimizer;
|
||||||
|
bool optimize_size;
|
||||||
|
bool disassemble;
|
||||||
|
bool validate;
|
||||||
|
bool emit_nonsemantic_shader_debug_info;
|
||||||
|
bool emit_nonsemantic_shader_debug_source;
|
||||||
|
} glslang_spv_options_t;
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
@ -224,9 +245,11 @@ GLSLANG_EXPORT void glslang_finalize_process();
|
|||||||
|
|
||||||
GLSLANG_EXPORT glslang_shader_t* glslang_shader_create(const glslang_input_t* input);
|
GLSLANG_EXPORT glslang_shader_t* glslang_shader_create(const glslang_input_t* input);
|
||||||
GLSLANG_EXPORT void glslang_shader_delete(glslang_shader_t* shader);
|
GLSLANG_EXPORT void glslang_shader_delete(glslang_shader_t* shader);
|
||||||
|
GLSLANG_EXPORT void glslang_shader_set_preamble(glslang_shader_t* shader, const char* s);
|
||||||
GLSLANG_EXPORT void glslang_shader_shift_binding(glslang_shader_t* shader, glslang_resource_type_t res, unsigned int base);
|
GLSLANG_EXPORT void glslang_shader_shift_binding(glslang_shader_t* shader, glslang_resource_type_t res, unsigned int base);
|
||||||
GLSLANG_EXPORT void glslang_shader_shift_binding_for_set(glslang_shader_t* shader, glslang_resource_type_t res, unsigned int base, unsigned int set);
|
GLSLANG_EXPORT void glslang_shader_shift_binding_for_set(glslang_shader_t* shader, glslang_resource_type_t res, unsigned int base, unsigned int set);
|
||||||
GLSLANG_EXPORT void glslang_shader_set_options(glslang_shader_t* shader, int options); // glslang_shader_options_t
|
GLSLANG_EXPORT void glslang_shader_set_options(glslang_shader_t* shader, int options); // glslang_shader_options_t
|
||||||
|
GLSLANG_EXPORT void glslang_shader_set_glsl_version(glslang_shader_t* shader, int version);
|
||||||
GLSLANG_EXPORT int glslang_shader_preprocess(glslang_shader_t* shader, const glslang_input_t* input);
|
GLSLANG_EXPORT int glslang_shader_preprocess(glslang_shader_t* shader, const glslang_input_t* input);
|
||||||
GLSLANG_EXPORT int glslang_shader_parse(glslang_shader_t* shader, const glslang_input_t* input);
|
GLSLANG_EXPORT int glslang_shader_parse(glslang_shader_t* shader, const glslang_input_t* input);
|
||||||
GLSLANG_EXPORT const char* glslang_shader_get_preprocessed_code(glslang_shader_t* shader);
|
GLSLANG_EXPORT const char* glslang_shader_get_preprocessed_code(glslang_shader_t* shader);
|
||||||
@ -237,8 +260,11 @@ GLSLANG_EXPORT glslang_program_t* glslang_program_create();
|
|||||||
GLSLANG_EXPORT void glslang_program_delete(glslang_program_t* program);
|
GLSLANG_EXPORT void glslang_program_delete(glslang_program_t* program);
|
||||||
GLSLANG_EXPORT void glslang_program_add_shader(glslang_program_t* program, glslang_shader_t* shader);
|
GLSLANG_EXPORT void glslang_program_add_shader(glslang_program_t* program, glslang_shader_t* shader);
|
||||||
GLSLANG_EXPORT int glslang_program_link(glslang_program_t* program, int messages); // glslang_messages_t
|
GLSLANG_EXPORT int glslang_program_link(glslang_program_t* program, int messages); // glslang_messages_t
|
||||||
|
GLSLANG_EXPORT void glslang_program_add_source_text(glslang_program_t* program, glslang_stage_t stage, const char* text, size_t len);
|
||||||
|
GLSLANG_EXPORT void glslang_program_set_source_file(glslang_program_t* program, glslang_stage_t stage, const char* file);
|
||||||
GLSLANG_EXPORT int glslang_program_map_io(glslang_program_t* program);
|
GLSLANG_EXPORT int glslang_program_map_io(glslang_program_t* program);
|
||||||
GLSLANG_EXPORT void glslang_program_SPIRV_generate(glslang_program_t* program, glslang_stage_t stage);
|
GLSLANG_EXPORT void glslang_program_SPIRV_generate(glslang_program_t* program, glslang_stage_t stage);
|
||||||
|
GLSLANG_EXPORT void glslang_program_SPIRV_generate_with_options(glslang_program_t* program, glslang_stage_t stage, glslang_spv_options_t* spv_options);
|
||||||
GLSLANG_EXPORT size_t glslang_program_SPIRV_get_size(glslang_program_t* program);
|
GLSLANG_EXPORT size_t glslang_program_SPIRV_get_size(glslang_program_t* program);
|
||||||
GLSLANG_EXPORT void glslang_program_SPIRV_get(glslang_program_t* program, unsigned int*);
|
GLSLANG_EXPORT void glslang_program_SPIRV_get(glslang_program_t* program, unsigned int*);
|
||||||
GLSLANG_EXPORT unsigned int* glslang_program_SPIRV_get_ptr(glslang_program_t* program);
|
GLSLANG_EXPORT unsigned int* glslang_program_SPIRV_get_ptr(glslang_program_t* program);
|
||||||
|
@ -43,14 +43,22 @@ typedef enum {
|
|||||||
GLSLANG_STAGE_GEOMETRY,
|
GLSLANG_STAGE_GEOMETRY,
|
||||||
GLSLANG_STAGE_FRAGMENT,
|
GLSLANG_STAGE_FRAGMENT,
|
||||||
GLSLANG_STAGE_COMPUTE,
|
GLSLANG_STAGE_COMPUTE,
|
||||||
GLSLANG_STAGE_RAYGEN_NV,
|
GLSLANG_STAGE_RAYGEN,
|
||||||
GLSLANG_STAGE_INTERSECT_NV,
|
GLSLANG_STAGE_RAYGEN_NV = GLSLANG_STAGE_RAYGEN,
|
||||||
GLSLANG_STAGE_ANYHIT_NV,
|
GLSLANG_STAGE_INTERSECT,
|
||||||
GLSLANG_STAGE_CLOSESTHIT_NV,
|
GLSLANG_STAGE_INTERSECT_NV = GLSLANG_STAGE_INTERSECT,
|
||||||
GLSLANG_STAGE_MISS_NV,
|
GLSLANG_STAGE_ANYHIT,
|
||||||
GLSLANG_STAGE_CALLABLE_NV,
|
GLSLANG_STAGE_ANYHIT_NV = GLSLANG_STAGE_ANYHIT,
|
||||||
GLSLANG_STAGE_TASK_NV,
|
GLSLANG_STAGE_CLOSESTHIT,
|
||||||
GLSLANG_STAGE_MESH_NV,
|
GLSLANG_STAGE_CLOSESTHIT_NV = GLSLANG_STAGE_CLOSESTHIT,
|
||||||
|
GLSLANG_STAGE_MISS,
|
||||||
|
GLSLANG_STAGE_MISS_NV = GLSLANG_STAGE_MISS,
|
||||||
|
GLSLANG_STAGE_CALLABLE,
|
||||||
|
GLSLANG_STAGE_CALLABLE_NV = GLSLANG_STAGE_CALLABLE,
|
||||||
|
GLSLANG_STAGE_TASK,
|
||||||
|
GLSLANG_STAGE_TASK_NV = GLSLANG_STAGE_TASK,
|
||||||
|
GLSLANG_STAGE_MESH,
|
||||||
|
GLSLANG_STAGE_MESH_NV = GLSLANG_STAGE_MESH,
|
||||||
LAST_ELEMENT_MARKER(GLSLANG_STAGE_COUNT),
|
LAST_ELEMENT_MARKER(GLSLANG_STAGE_COUNT),
|
||||||
} glslang_stage_t; // would be better as stage, but this is ancient now
|
} glslang_stage_t; // would be better as stage, but this is ancient now
|
||||||
|
|
||||||
@ -62,14 +70,22 @@ typedef enum {
|
|||||||
GLSLANG_STAGE_GEOMETRY_MASK = (1 << GLSLANG_STAGE_GEOMETRY),
|
GLSLANG_STAGE_GEOMETRY_MASK = (1 << GLSLANG_STAGE_GEOMETRY),
|
||||||
GLSLANG_STAGE_FRAGMENT_MASK = (1 << GLSLANG_STAGE_FRAGMENT),
|
GLSLANG_STAGE_FRAGMENT_MASK = (1 << GLSLANG_STAGE_FRAGMENT),
|
||||||
GLSLANG_STAGE_COMPUTE_MASK = (1 << GLSLANG_STAGE_COMPUTE),
|
GLSLANG_STAGE_COMPUTE_MASK = (1 << GLSLANG_STAGE_COMPUTE),
|
||||||
GLSLANG_STAGE_RAYGEN_NV_MASK = (1 << GLSLANG_STAGE_RAYGEN_NV),
|
GLSLANG_STAGE_RAYGEN_MASK = (1 << GLSLANG_STAGE_RAYGEN),
|
||||||
GLSLANG_STAGE_INTERSECT_NV_MASK = (1 << GLSLANG_STAGE_INTERSECT_NV),
|
GLSLANG_STAGE_RAYGEN_NV_MASK = GLSLANG_STAGE_RAYGEN_MASK,
|
||||||
GLSLANG_STAGE_ANYHIT_NV_MASK = (1 << GLSLANG_STAGE_ANYHIT_NV),
|
GLSLANG_STAGE_INTERSECT_MASK = (1 << GLSLANG_STAGE_INTERSECT),
|
||||||
GLSLANG_STAGE_CLOSESTHIT_NV_MASK = (1 << GLSLANG_STAGE_CLOSESTHIT_NV),
|
GLSLANG_STAGE_INTERSECT_NV_MASK = GLSLANG_STAGE_INTERSECT_MASK,
|
||||||
GLSLANG_STAGE_MISS_NV_MASK = (1 << GLSLANG_STAGE_MISS_NV),
|
GLSLANG_STAGE_ANYHIT_MASK = (1 << GLSLANG_STAGE_ANYHIT),
|
||||||
GLSLANG_STAGE_CALLABLE_NV_MASK = (1 << GLSLANG_STAGE_CALLABLE_NV),
|
GLSLANG_STAGE_ANYHIT_NV_MASK = GLSLANG_STAGE_ANYHIT_MASK,
|
||||||
GLSLANG_STAGE_TASK_NV_MASK = (1 << GLSLANG_STAGE_TASK_NV),
|
GLSLANG_STAGE_CLOSESTHIT_MASK = (1 << GLSLANG_STAGE_CLOSESTHIT),
|
||||||
GLSLANG_STAGE_MESH_NV_MASK = (1 << GLSLANG_STAGE_MESH_NV),
|
GLSLANG_STAGE_CLOSESTHIT_NV_MASK = GLSLANG_STAGE_CLOSESTHIT_MASK,
|
||||||
|
GLSLANG_STAGE_MISS_MASK = (1 << GLSLANG_STAGE_MISS),
|
||||||
|
GLSLANG_STAGE_MISS_NV_MASK = GLSLANG_STAGE_MISS_MASK,
|
||||||
|
GLSLANG_STAGE_CALLABLE_MASK = (1 << GLSLANG_STAGE_CALLABLE),
|
||||||
|
GLSLANG_STAGE_CALLABLE_NV_MASK = GLSLANG_STAGE_CALLABLE_MASK,
|
||||||
|
GLSLANG_STAGE_TASK_MASK = (1 << GLSLANG_STAGE_TASK),
|
||||||
|
GLSLANG_STAGE_TASK_NV_MASK = GLSLANG_STAGE_TASK_MASK,
|
||||||
|
GLSLANG_STAGE_MESH_MASK = (1 << GLSLANG_STAGE_MESH),
|
||||||
|
GLSLANG_STAGE_MESH_NV_MASK = GLSLANG_STAGE_MESH_MASK,
|
||||||
LAST_ELEMENT_MARKER(GLSLANG_STAGE_MASK_COUNT),
|
LAST_ELEMENT_MARKER(GLSLANG_STAGE_MASK_COUNT),
|
||||||
} glslang_stage_mask_t;
|
} glslang_stage_mask_t;
|
||||||
|
|
||||||
@ -121,7 +137,9 @@ typedef enum {
|
|||||||
/* EShExecutable counterpart */
|
/* EShExecutable counterpart */
|
||||||
typedef enum { GLSLANG_EX_VERTEX_FRAGMENT, GLSLANG_EX_FRAGMENT } glslang_executable_t;
|
typedef enum { GLSLANG_EX_VERTEX_FRAGMENT, GLSLANG_EX_FRAGMENT } glslang_executable_t;
|
||||||
|
|
||||||
/* EShOptimizationLevel counterpart */
|
// EShOptimizationLevel counterpart
|
||||||
|
// This enum is not used in the current C interface, but could be added at a later date.
|
||||||
|
// GLSLANG_OPT_NONE is the current default.
|
||||||
typedef enum {
|
typedef enum {
|
||||||
GLSLANG_OPT_NO_GENERATION,
|
GLSLANG_OPT_NO_GENERATION,
|
||||||
GLSLANG_OPT_NONE,
|
GLSLANG_OPT_NONE,
|
||||||
@ -155,6 +173,7 @@ typedef enum {
|
|||||||
GLSLANG_MSG_HLSL_LEGALIZATION_BIT = (1 << 12),
|
GLSLANG_MSG_HLSL_LEGALIZATION_BIT = (1 << 12),
|
||||||
GLSLANG_MSG_HLSL_DX9_COMPATIBLE_BIT = (1 << 13),
|
GLSLANG_MSG_HLSL_DX9_COMPATIBLE_BIT = (1 << 13),
|
||||||
GLSLANG_MSG_BUILTIN_SYMBOL_TABLE_BIT = (1 << 14),
|
GLSLANG_MSG_BUILTIN_SYMBOL_TABLE_BIT = (1 << 14),
|
||||||
|
GLSLANG_MSG_ENHANCED = (1 << 15),
|
||||||
LAST_ELEMENT_MARKER(GLSLANG_MSG_COUNT),
|
LAST_ELEMENT_MARKER(GLSLANG_MSG_COUNT),
|
||||||
} glslang_messages_t;
|
} glslang_messages_t;
|
||||||
|
|
||||||
|
@ -67,6 +67,7 @@ class TIntermediate;
|
|||||||
enum TOperator {
|
enum TOperator {
|
||||||
EOpNull, // if in a node, should only mean a node is still being built
|
EOpNull, // if in a node, should only mean a node is still being built
|
||||||
EOpSequence, // denotes a list of statements, or parameters, etc.
|
EOpSequence, // denotes a list of statements, or parameters, etc.
|
||||||
|
EOpScope, // Used by debugging to denote a scoped list of statements
|
||||||
EOpLinkerObjects, // for aggregate node of objects the linker may need, if not reference by the rest of the AST
|
EOpLinkerObjects, // for aggregate node of objects the linker may need, if not reference by the rest of the AST
|
||||||
EOpFunctionCall,
|
EOpFunctionCall,
|
||||||
EOpFunction, // For function definition
|
EOpFunction, // For function definition
|
||||||
@ -91,6 +92,8 @@ enum TOperator {
|
|||||||
|
|
||||||
EOpCopyObject,
|
EOpCopyObject,
|
||||||
|
|
||||||
|
EOpDeclare, // Used by debugging to force declaration of variable in correct scope
|
||||||
|
|
||||||
// (u)int* -> bool
|
// (u)int* -> bool
|
||||||
EOpConvInt8ToBool,
|
EOpConvInt8ToBool,
|
||||||
EOpConvUint8ToBool,
|
EOpConvUint8ToBool,
|
||||||
@ -934,6 +937,8 @@ enum TOperator {
|
|||||||
EOpExecuteCallableNV,
|
EOpExecuteCallableNV,
|
||||||
EOpExecuteCallableKHR,
|
EOpExecuteCallableKHR,
|
||||||
EOpWritePackedPrimitiveIndices4x8NV,
|
EOpWritePackedPrimitiveIndices4x8NV,
|
||||||
|
EOpEmitMeshTasksEXT,
|
||||||
|
EOpSetMeshOutputsEXT,
|
||||||
|
|
||||||
//
|
//
|
||||||
// GL_EXT_ray_query operations
|
// GL_EXT_ray_query operations
|
||||||
@ -1155,7 +1160,7 @@ public:
|
|||||||
virtual bool isIntegerDomain() const { return type.isIntegerDomain(); }
|
virtual bool isIntegerDomain() const { return type.isIntegerDomain(); }
|
||||||
bool isAtomic() const { return type.isAtomic(); }
|
bool isAtomic() const { return type.isAtomic(); }
|
||||||
bool isReference() const { return type.isReference(); }
|
bool isReference() const { return type.isReference(); }
|
||||||
TString getCompleteString() const { return type.getCompleteString(); }
|
TString getCompleteString(bool enhanced = false) const { return type.getCompleteString(enhanced); }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
TIntermTyped& operator=(const TIntermTyped&);
|
TIntermTyped& operator=(const TIntermTyped&);
|
||||||
|
@ -2268,11 +2268,11 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
|
|
||||||
"\n"
|
"\n"
|
||||||
);
|
);
|
||||||
stageBuiltins[EShLangMeshNV].append(
|
stageBuiltins[EShLangMesh].append(
|
||||||
"void subgroupMemoryBarrierShared();"
|
"void subgroupMemoryBarrierShared();"
|
||||||
"\n"
|
"\n"
|
||||||
);
|
);
|
||||||
stageBuiltins[EShLangTaskNV].append(
|
stageBuiltins[EShLangTask].append(
|
||||||
"void subgroupMemoryBarrierShared();"
|
"void subgroupMemoryBarrierShared();"
|
||||||
"\n"
|
"\n"
|
||||||
);
|
);
|
||||||
@ -4298,10 +4298,10 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
"void barrier();"
|
"void barrier();"
|
||||||
);
|
);
|
||||||
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
||||||
stageBuiltins[EShLangMeshNV].append(
|
stageBuiltins[EShLangMesh].append(
|
||||||
"void barrier();"
|
"void barrier();"
|
||||||
);
|
);
|
||||||
stageBuiltins[EShLangTaskNV].append(
|
stageBuiltins[EShLangTask].append(
|
||||||
"void barrier();"
|
"void barrier();"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ -4326,11 +4326,11 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
commonBuiltins.append("void memoryBarrierImage();");
|
commonBuiltins.append("void memoryBarrierImage();");
|
||||||
}
|
}
|
||||||
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
||||||
stageBuiltins[EShLangMeshNV].append(
|
stageBuiltins[EShLangMesh].append(
|
||||||
"void memoryBarrierShared();"
|
"void memoryBarrierShared();"
|
||||||
"void groupMemoryBarrier();"
|
"void groupMemoryBarrier();"
|
||||||
);
|
);
|
||||||
stageBuiltins[EShLangTaskNV].append(
|
stageBuiltins[EShLangTask].append(
|
||||||
"void memoryBarrierShared();"
|
"void memoryBarrierShared();"
|
||||||
"void groupMemoryBarrier();"
|
"void groupMemoryBarrier();"
|
||||||
);
|
);
|
||||||
@ -4655,10 +4655,21 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
|
|
||||||
// Builtins for GL_NV_mesh_shader
|
// Builtins for GL_NV_mesh_shader
|
||||||
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
||||||
stageBuiltins[EShLangMeshNV].append(
|
stageBuiltins[EShLangMesh].append(
|
||||||
"void writePackedPrimitiveIndices4x8NV(uint, uint);"
|
"void writePackedPrimitiveIndices4x8NV(uint, uint);"
|
||||||
"\n");
|
"\n");
|
||||||
}
|
}
|
||||||
|
// Builtins for GL_EXT_mesh_shader
|
||||||
|
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
||||||
|
// Builtins for GL_EXT_mesh_shader
|
||||||
|
stageBuiltins[EShLangTask].append(
|
||||||
|
"void EmitMeshTasksEXT(uint, uint, uint);"
|
||||||
|
"\n");
|
||||||
|
|
||||||
|
stageBuiltins[EShLangMesh].append(
|
||||||
|
"void SetMeshOutputsEXT(uint, uint);"
|
||||||
|
"\n");
|
||||||
|
}
|
||||||
#endif // !GLSLANG_ANGLE
|
#endif // !GLSLANG_ANGLE
|
||||||
#endif // !GLSLANG_WEB
|
#endif // !GLSLANG_WEB
|
||||||
|
|
||||||
@ -4855,7 +4866,7 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
|
|
||||||
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
||||||
// per-vertex attributes
|
// per-vertex attributes
|
||||||
stageBuiltins[EShLangMeshNV].append(
|
stageBuiltins[EShLangMesh].append(
|
||||||
"out gl_MeshPerVertexNV {"
|
"out gl_MeshPerVertexNV {"
|
||||||
"vec4 gl_Position;"
|
"vec4 gl_Position;"
|
||||||
"float gl_PointSize;"
|
"float gl_PointSize;"
|
||||||
@ -4868,7 +4879,7 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
);
|
);
|
||||||
|
|
||||||
// per-primitive attributes
|
// per-primitive attributes
|
||||||
stageBuiltins[EShLangMeshNV].append(
|
stageBuiltins[EShLangMesh].append(
|
||||||
"perprimitiveNV out gl_MeshPerPrimitiveNV {"
|
"perprimitiveNV out gl_MeshPerPrimitiveNV {"
|
||||||
"int gl_PrimitiveID;"
|
"int gl_PrimitiveID;"
|
||||||
"int gl_Layer;"
|
"int gl_Layer;"
|
||||||
@ -4879,7 +4890,7 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
"} gl_MeshPrimitivesNV[];"
|
"} gl_MeshPrimitivesNV[];"
|
||||||
);
|
);
|
||||||
|
|
||||||
stageBuiltins[EShLangMeshNV].append(
|
stageBuiltins[EShLangMesh].append(
|
||||||
"out uint gl_PrimitiveCountNV;"
|
"out uint gl_PrimitiveCountNV;"
|
||||||
"out uint gl_PrimitiveIndicesNV[];"
|
"out uint gl_PrimitiveIndicesNV[];"
|
||||||
|
|
||||||
@ -4893,10 +4904,38 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
|
|
||||||
"in highp uvec3 gl_GlobalInvocationID;"
|
"in highp uvec3 gl_GlobalInvocationID;"
|
||||||
"in highp uint gl_LocalInvocationIndex;"
|
"in highp uint gl_LocalInvocationIndex;"
|
||||||
|
|
||||||
"\n");
|
"\n");
|
||||||
|
|
||||||
stageBuiltins[EShLangTaskNV].append(
|
// GL_EXT_mesh_shader
|
||||||
|
stageBuiltins[EShLangMesh].append(
|
||||||
|
"out uint gl_PrimitivePointIndicesEXT[];"
|
||||||
|
"out uvec2 gl_PrimitiveLineIndicesEXT[];"
|
||||||
|
"out uvec3 gl_PrimitiveTriangleIndicesEXT[];"
|
||||||
|
"in highp uvec3 gl_NumWorkGroups;"
|
||||||
|
"\n");
|
||||||
|
|
||||||
|
// per-vertex attributes
|
||||||
|
stageBuiltins[EShLangMesh].append(
|
||||||
|
"out gl_MeshPerVertexEXT {"
|
||||||
|
"vec4 gl_Position;"
|
||||||
|
"float gl_PointSize;"
|
||||||
|
"float gl_ClipDistance[];"
|
||||||
|
"float gl_CullDistance[];"
|
||||||
|
"} gl_MeshVerticesEXT[];"
|
||||||
|
);
|
||||||
|
|
||||||
|
// per-primitive attributes
|
||||||
|
stageBuiltins[EShLangMesh].append(
|
||||||
|
"perprimitiveEXT out gl_MeshPerPrimitiveEXT {"
|
||||||
|
"int gl_PrimitiveID;"
|
||||||
|
"int gl_Layer;"
|
||||||
|
"int gl_ViewportIndex;"
|
||||||
|
"bool gl_CullPrimitiveEXT;"
|
||||||
|
"int gl_PrimitiveShadingRateEXT;"
|
||||||
|
"} gl_MeshPrimitivesEXT[];"
|
||||||
|
);
|
||||||
|
|
||||||
|
stageBuiltins[EShLangTask].append(
|
||||||
"out uint gl_TaskCountNV;"
|
"out uint gl_TaskCountNV;"
|
||||||
|
|
||||||
"const highp uvec3 gl_WorkGroupSize = uvec3(1,1,1);"
|
"const highp uvec3 gl_WorkGroupSize = uvec3(1,1,1);"
|
||||||
@ -4909,27 +4948,28 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
|
|
||||||
"in uint gl_MeshViewCountNV;"
|
"in uint gl_MeshViewCountNV;"
|
||||||
"in uint gl_MeshViewIndicesNV[4];"
|
"in uint gl_MeshViewIndicesNV[4];"
|
||||||
|
"in highp uvec3 gl_NumWorkGroups;"
|
||||||
"\n");
|
"\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (profile != EEsProfile && version >= 450) {
|
if (profile != EEsProfile && version >= 450) {
|
||||||
stageBuiltins[EShLangMeshNV].append(
|
stageBuiltins[EShLangMesh].append(
|
||||||
"in highp int gl_DeviceIndex;" // GL_EXT_device_group
|
"in highp int gl_DeviceIndex;" // GL_EXT_device_group
|
||||||
"in int gl_DrawIDARB;" // GL_ARB_shader_draw_parameters
|
"in int gl_DrawIDARB;" // GL_ARB_shader_draw_parameters
|
||||||
|
"in int gl_ViewIndex;" // GL_EXT_multiview
|
||||||
"\n");
|
"\n");
|
||||||
|
|
||||||
stageBuiltins[EShLangTaskNV].append(
|
stageBuiltins[EShLangTask].append(
|
||||||
"in highp int gl_DeviceIndex;" // GL_EXT_device_group
|
"in highp int gl_DeviceIndex;" // GL_EXT_device_group
|
||||||
"in int gl_DrawIDARB;" // GL_ARB_shader_draw_parameters
|
"in int gl_DrawIDARB;" // GL_ARB_shader_draw_parameters
|
||||||
"\n");
|
"\n");
|
||||||
|
|
||||||
if (version >= 460) {
|
if (version >= 460) {
|
||||||
stageBuiltins[EShLangMeshNV].append(
|
stageBuiltins[EShLangMesh].append(
|
||||||
"in int gl_DrawID;"
|
"in int gl_DrawID;"
|
||||||
"\n");
|
"\n");
|
||||||
|
|
||||||
stageBuiltins[EShLangTaskNV].append(
|
stageBuiltins[EShLangTask].append(
|
||||||
"in int gl_DrawID;"
|
"in int gl_DrawID;"
|
||||||
"\n");
|
"\n");
|
||||||
}
|
}
|
||||||
@ -5571,6 +5611,8 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
"flat in int gl_InvocationsPerPixelNV;"
|
"flat in int gl_InvocationsPerPixelNV;"
|
||||||
"in vec3 gl_BaryCoordNV;" // GL_NV_fragment_shader_barycentric
|
"in vec3 gl_BaryCoordNV;" // GL_NV_fragment_shader_barycentric
|
||||||
"in vec3 gl_BaryCoordNoPerspNV;"
|
"in vec3 gl_BaryCoordNoPerspNV;"
|
||||||
|
"in vec3 gl_BaryCoordEXT;" // GL_EXT_fragment_shader_barycentric
|
||||||
|
"in vec3 gl_BaryCoordNoPerspEXT;"
|
||||||
);
|
);
|
||||||
|
|
||||||
if (version >= 450)
|
if (version >= 450)
|
||||||
@ -5635,7 +5677,9 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
stageBuiltins[EShLangFragment].append(
|
stageBuiltins[EShLangFragment].append(
|
||||||
"in vec3 gl_BaryCoordNV;"
|
"in vec3 gl_BaryCoordNV;"
|
||||||
"in vec3 gl_BaryCoordNoPerspNV;"
|
"in vec3 gl_BaryCoordNoPerspNV;"
|
||||||
);
|
"in vec3 gl_BaryCoordEXT;"
|
||||||
|
"in vec3 gl_BaryCoordNoPerspEXT;"
|
||||||
|
);
|
||||||
if (version >= 310)
|
if (version >= 310)
|
||||||
stageBuiltins[EShLangFragment].append(
|
stageBuiltins[EShLangFragment].append(
|
||||||
"flat in highp int gl_ShadingRateEXT;" // GL_EXT_fragment_shading_rate
|
"flat in highp int gl_ShadingRateEXT;" // GL_EXT_fragment_shading_rate
|
||||||
@ -5700,8 +5744,8 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
stageBuiltins[EShLangGeometry] .append(ballotDecls);
|
stageBuiltins[EShLangGeometry] .append(ballotDecls);
|
||||||
stageBuiltins[EShLangCompute] .append(ballotDecls);
|
stageBuiltins[EShLangCompute] .append(ballotDecls);
|
||||||
stageBuiltins[EShLangFragment] .append(fragmentBallotDecls);
|
stageBuiltins[EShLangFragment] .append(fragmentBallotDecls);
|
||||||
stageBuiltins[EShLangMeshNV] .append(ballotDecls);
|
stageBuiltins[EShLangMesh] .append(ballotDecls);
|
||||||
stageBuiltins[EShLangTaskNV] .append(ballotDecls);
|
stageBuiltins[EShLangTask] .append(ballotDecls);
|
||||||
stageBuiltins[EShLangRayGen] .append(rtBallotDecls);
|
stageBuiltins[EShLangRayGen] .append(rtBallotDecls);
|
||||||
stageBuiltins[EShLangIntersect] .append(rtBallotDecls);
|
stageBuiltins[EShLangIntersect] .append(rtBallotDecls);
|
||||||
// No volatile qualifier on these builtins in any-hit
|
// No volatile qualifier on these builtins in any-hit
|
||||||
@ -5769,10 +5813,10 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
stageBuiltins[EShLangCompute] .append(subgroupDecls);
|
stageBuiltins[EShLangCompute] .append(subgroupDecls);
|
||||||
stageBuiltins[EShLangCompute] .append(computeSubgroupDecls);
|
stageBuiltins[EShLangCompute] .append(computeSubgroupDecls);
|
||||||
stageBuiltins[EShLangFragment] .append(fragmentSubgroupDecls);
|
stageBuiltins[EShLangFragment] .append(fragmentSubgroupDecls);
|
||||||
stageBuiltins[EShLangMeshNV] .append(subgroupDecls);
|
stageBuiltins[EShLangMesh] .append(subgroupDecls);
|
||||||
stageBuiltins[EShLangMeshNV] .append(computeSubgroupDecls);
|
stageBuiltins[EShLangMesh] .append(computeSubgroupDecls);
|
||||||
stageBuiltins[EShLangTaskNV] .append(subgroupDecls);
|
stageBuiltins[EShLangTask] .append(subgroupDecls);
|
||||||
stageBuiltins[EShLangTaskNV] .append(computeSubgroupDecls);
|
stageBuiltins[EShLangTask] .append(computeSubgroupDecls);
|
||||||
stageBuiltins[EShLangRayGen] .append(rtSubgroupDecls);
|
stageBuiltins[EShLangRayGen] .append(rtSubgroupDecls);
|
||||||
stageBuiltins[EShLangIntersect] .append(rtSubgroupDecls);
|
stageBuiltins[EShLangIntersect] .append(rtSubgroupDecls);
|
||||||
// No volatile qualifier on these builtins in any-hit
|
// No volatile qualifier on these builtins in any-hit
|
||||||
@ -5806,6 +5850,7 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
"const uint gl_RayFlagsCullNoOpaqueEXT = 128U;"
|
"const uint gl_RayFlagsCullNoOpaqueEXT = 128U;"
|
||||||
"const uint gl_RayFlagsSkipTrianglesEXT = 256U;"
|
"const uint gl_RayFlagsSkipTrianglesEXT = 256U;"
|
||||||
"const uint gl_RayFlagsSkipAABBEXT = 512U;"
|
"const uint gl_RayFlagsSkipAABBEXT = 512U;"
|
||||||
|
"const uint gl_RayFlagsForceOpacityMicromap2StateEXT = 1024U;"
|
||||||
"const uint gl_HitKindFrontFacingTriangleEXT = 254U;"
|
"const uint gl_HitKindFrontFacingTriangleEXT = 254U;"
|
||||||
"const uint gl_HitKindBackFacingTriangleEXT = 255U;"
|
"const uint gl_HitKindBackFacingTriangleEXT = 255U;"
|
||||||
"\n";
|
"\n";
|
||||||
@ -5857,6 +5902,7 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
"in uint gl_IncomingRayFlagsNV;"
|
"in uint gl_IncomingRayFlagsNV;"
|
||||||
"in uint gl_IncomingRayFlagsEXT;"
|
"in uint gl_IncomingRayFlagsEXT;"
|
||||||
"in float gl_CurrentRayTimeNV;"
|
"in float gl_CurrentRayTimeNV;"
|
||||||
|
"in uint gl_CullMaskEXT;"
|
||||||
"\n";
|
"\n";
|
||||||
const char *hitDecls =
|
const char *hitDecls =
|
||||||
"in uvec3 gl_LaunchIDNV;"
|
"in uvec3 gl_LaunchIDNV;"
|
||||||
@ -5893,6 +5939,7 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
"in uint gl_IncomingRayFlagsNV;"
|
"in uint gl_IncomingRayFlagsNV;"
|
||||||
"in uint gl_IncomingRayFlagsEXT;"
|
"in uint gl_IncomingRayFlagsEXT;"
|
||||||
"in float gl_CurrentRayTimeNV;"
|
"in float gl_CurrentRayTimeNV;"
|
||||||
|
"in uint gl_CullMaskEXT;"
|
||||||
"\n";
|
"\n";
|
||||||
const char *missDecls =
|
const char *missDecls =
|
||||||
"in uvec3 gl_LaunchIDNV;"
|
"in uvec3 gl_LaunchIDNV;"
|
||||||
@ -5912,6 +5959,7 @@ void TBuiltIns::initialize(int version, EProfile profile, const SpvVersion& spvV
|
|||||||
"in uint gl_IncomingRayFlagsNV;"
|
"in uint gl_IncomingRayFlagsNV;"
|
||||||
"in uint gl_IncomingRayFlagsEXT;"
|
"in uint gl_IncomingRayFlagsEXT;"
|
||||||
"in float gl_CurrentRayTimeNV;"
|
"in float gl_CurrentRayTimeNV;"
|
||||||
|
"in uint gl_CullMaskEXT;"
|
||||||
"\n";
|
"\n";
|
||||||
|
|
||||||
const char *callableDecls =
|
const char *callableDecls =
|
||||||
@ -7606,6 +7654,23 @@ static void SpecialQualifier(const char* name, TStorageQualifier qualifier, TBui
|
|||||||
symQualifier.builtIn = builtIn;
|
symQualifier.builtIn = builtIn;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// Modify the symbol's flat decoration.
|
||||||
|
//
|
||||||
|
// Safe to call even if name is not present.
|
||||||
|
//
|
||||||
|
// Originally written to transform gl_SubGroupSizeARB from uniform to fragment input in Vulkan.
|
||||||
|
//
|
||||||
|
static void ModifyFlatDecoration(const char* name, bool flat, TSymbolTable& symbolTable)
|
||||||
|
{
|
||||||
|
TSymbol* symbol = symbolTable.find(name);
|
||||||
|
if (symbol == nullptr)
|
||||||
|
return;
|
||||||
|
|
||||||
|
TQualifier& symQualifier = symbol->getWritableType().getQualifier();
|
||||||
|
symQualifier.flat = flat;
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// To tag built-in variables with their TBuiltInVariable enum. Use this when the
|
// To tag built-in variables with their TBuiltInVariable enum. Use this when the
|
||||||
// normal declaration text already gets the qualifier right, and all that's needed
|
// normal declaration text already gets the qualifier right, and all that's needed
|
||||||
@ -7989,9 +8054,12 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
BuiltInVariable("gl_SubGroupLeMaskARB", EbvSubGroupLeMask, symbolTable);
|
BuiltInVariable("gl_SubGroupLeMaskARB", EbvSubGroupLeMask, symbolTable);
|
||||||
BuiltInVariable("gl_SubGroupLtMaskARB", EbvSubGroupLtMask, symbolTable);
|
BuiltInVariable("gl_SubGroupLtMaskARB", EbvSubGroupLtMask, symbolTable);
|
||||||
|
|
||||||
if (spvVersion.vulkan > 0)
|
if (spvVersion.vulkan > 0) {
|
||||||
// Treat "gl_SubGroupSizeARB" as shader input instead of uniform for Vulkan
|
// Treat "gl_SubGroupSizeARB" as shader input instead of uniform for Vulkan
|
||||||
SpecialQualifier("gl_SubGroupSizeARB", EvqVaryingIn, EbvSubGroupSize, symbolTable);
|
SpecialQualifier("gl_SubGroupSizeARB", EvqVaryingIn, EbvSubGroupSize, symbolTable);
|
||||||
|
if (language == EShLangFragment)
|
||||||
|
ModifyFlatDecoration("gl_SubGroupSizeARB", true, symbolTable);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
BuiltInVariable("gl_SubGroupSizeARB", EbvSubGroupSize, symbolTable);
|
BuiltInVariable("gl_SubGroupSizeARB", EbvSubGroupSize, symbolTable);
|
||||||
}
|
}
|
||||||
@ -8058,6 +8126,7 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
SpecialQualifier("gl_FragDepth", EvqFragDepth, EbvFragDepth, symbolTable);
|
SpecialQualifier("gl_FragDepth", EvqFragDepth, EbvFragDepth, symbolTable);
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
SpecialQualifier("gl_FragDepthEXT", EvqFragDepth, EbvFragDepth, symbolTable);
|
SpecialQualifier("gl_FragDepthEXT", EvqFragDepth, EbvFragDepth, symbolTable);
|
||||||
|
SpecialQualifier("gl_FragStencilRefARB", EvqFragStencil, EbvFragStencilRef, symbolTable);
|
||||||
SpecialQualifier("gl_HelperInvocation", EvqVaryingIn, EbvHelperInvocation, symbolTable);
|
SpecialQualifier("gl_HelperInvocation", EvqVaryingIn, EbvHelperInvocation, symbolTable);
|
||||||
|
|
||||||
BuiltInVariable("gl_ClipDistance", EbvClipDistance, symbolTable);
|
BuiltInVariable("gl_ClipDistance", EbvClipDistance, symbolTable);
|
||||||
@ -8099,6 +8168,7 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
symbolTable.setFunctionExtensions("rayQueryGetWorldRayDirectionEXT", 1, &E_GL_EXT_ray_query);
|
symbolTable.setFunctionExtensions("rayQueryGetWorldRayDirectionEXT", 1, &E_GL_EXT_ray_query);
|
||||||
symbolTable.setVariableExtensions("gl_RayFlagsSkipAABBEXT", 1, &E_GL_EXT_ray_flags_primitive_culling);
|
symbolTable.setVariableExtensions("gl_RayFlagsSkipAABBEXT", 1, &E_GL_EXT_ray_flags_primitive_culling);
|
||||||
symbolTable.setVariableExtensions("gl_RayFlagsSkipTrianglesEXT", 1, &E_GL_EXT_ray_flags_primitive_culling);
|
symbolTable.setVariableExtensions("gl_RayFlagsSkipTrianglesEXT", 1, &E_GL_EXT_ray_flags_primitive_culling);
|
||||||
|
symbolTable.setVariableExtensions("gl_RayFlagsForceOpacityMicromap2StateEXT", 1, &E_GL_EXT_opacity_micromap);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((profile != EEsProfile && version >= 130) ||
|
if ((profile != EEsProfile && version >= 130) ||
|
||||||
@ -8318,6 +8388,10 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
symbolTable.setVariableExtensions("gl_BaryCoordNoPerspNV", 1, &E_GL_NV_fragment_shader_barycentric);
|
symbolTable.setVariableExtensions("gl_BaryCoordNoPerspNV", 1, &E_GL_NV_fragment_shader_barycentric);
|
||||||
BuiltInVariable("gl_BaryCoordNV", EbvBaryCoordNV, symbolTable);
|
BuiltInVariable("gl_BaryCoordNV", EbvBaryCoordNV, symbolTable);
|
||||||
BuiltInVariable("gl_BaryCoordNoPerspNV", EbvBaryCoordNoPerspNV, symbolTable);
|
BuiltInVariable("gl_BaryCoordNoPerspNV", EbvBaryCoordNoPerspNV, symbolTable);
|
||||||
|
symbolTable.setVariableExtensions("gl_BaryCoordEXT", 1, &E_GL_EXT_fragment_shader_barycentric);
|
||||||
|
symbolTable.setVariableExtensions("gl_BaryCoordNoPerspEXT", 1, &E_GL_EXT_fragment_shader_barycentric);
|
||||||
|
BuiltInVariable("gl_BaryCoordEXT", EbvBaryCoordEXT, symbolTable);
|
||||||
|
BuiltInVariable("gl_BaryCoordNoPerspEXT", EbvBaryCoordNoPerspEXT, symbolTable);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((profile != EEsProfile && version >= 450) ||
|
if ((profile != EEsProfile && version >= 450) ||
|
||||||
@ -8418,9 +8492,12 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
BuiltInVariable("gl_SubGroupLeMaskARB", EbvSubGroupLeMask, symbolTable);
|
BuiltInVariable("gl_SubGroupLeMaskARB", EbvSubGroupLeMask, symbolTable);
|
||||||
BuiltInVariable("gl_SubGroupLtMaskARB", EbvSubGroupLtMask, symbolTable);
|
BuiltInVariable("gl_SubGroupLtMaskARB", EbvSubGroupLtMask, symbolTable);
|
||||||
|
|
||||||
if (spvVersion.vulkan > 0)
|
if (spvVersion.vulkan > 0) {
|
||||||
// Treat "gl_SubGroupSizeARB" as shader input instead of uniform for Vulkan
|
// Treat "gl_SubGroupSizeARB" as shader input instead of uniform for Vulkan
|
||||||
SpecialQualifier("gl_SubGroupSizeARB", EvqVaryingIn, EbvSubGroupSize, symbolTable);
|
SpecialQualifier("gl_SubGroupSizeARB", EvqVaryingIn, EbvSubGroupSize, symbolTable);
|
||||||
|
if (language == EShLangFragment)
|
||||||
|
ModifyFlatDecoration("gl_SubGroupSizeARB", true, symbolTable);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
BuiltInVariable("gl_SubGroupSizeARB", EbvSubGroupSize, symbolTable);
|
BuiltInVariable("gl_SubGroupSizeARB", EbvSubGroupSize, symbolTable);
|
||||||
}
|
}
|
||||||
@ -8635,9 +8712,12 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
BuiltInVariable("gl_SubGroupLeMaskARB", EbvSubGroupLeMask, symbolTable);
|
BuiltInVariable("gl_SubGroupLeMaskARB", EbvSubGroupLeMask, symbolTable);
|
||||||
BuiltInVariable("gl_SubGroupLtMaskARB", EbvSubGroupLtMask, symbolTable);
|
BuiltInVariable("gl_SubGroupLtMaskARB", EbvSubGroupLtMask, symbolTable);
|
||||||
|
|
||||||
if (spvVersion.vulkan > 0)
|
if (spvVersion.vulkan > 0) {
|
||||||
// Treat "gl_SubGroupSizeARB" as shader input instead of uniform for Vulkan
|
// Treat "gl_SubGroupSizeARB" as shader input instead of uniform for Vulkan
|
||||||
SpecialQualifier("gl_SubGroupSizeARB", EvqVaryingIn, EbvSubGroupSize, symbolTable);
|
SpecialQualifier("gl_SubGroupSizeARB", EvqVaryingIn, EbvSubGroupSize, symbolTable);
|
||||||
|
if (language == EShLangFragment)
|
||||||
|
ModifyFlatDecoration("gl_SubGroupSizeARB", true, symbolTable);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
BuiltInVariable("gl_SubGroupSizeARB", EbvSubGroupSize, symbolTable);
|
BuiltInVariable("gl_SubGroupSizeARB", EbvSubGroupSize, symbolTable);
|
||||||
}
|
}
|
||||||
@ -8743,6 +8823,7 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
symbolTable.setVariableExtensions("gl_RayTminEXT", 1, &E_GL_EXT_ray_tracing);
|
symbolTable.setVariableExtensions("gl_RayTminEXT", 1, &E_GL_EXT_ray_tracing);
|
||||||
symbolTable.setVariableExtensions("gl_RayTmaxNV", 1, &E_GL_NV_ray_tracing);
|
symbolTable.setVariableExtensions("gl_RayTmaxNV", 1, &E_GL_NV_ray_tracing);
|
||||||
symbolTable.setVariableExtensions("gl_RayTmaxEXT", 1, &E_GL_EXT_ray_tracing);
|
symbolTable.setVariableExtensions("gl_RayTmaxEXT", 1, &E_GL_EXT_ray_tracing);
|
||||||
|
symbolTable.setVariableExtensions("gl_CullMaskEXT", 1, &E_GL_EXT_ray_cull_mask);
|
||||||
symbolTable.setVariableExtensions("gl_HitTNV", 1, &E_GL_NV_ray_tracing);
|
symbolTable.setVariableExtensions("gl_HitTNV", 1, &E_GL_NV_ray_tracing);
|
||||||
symbolTable.setVariableExtensions("gl_HitTEXT", 1, &E_GL_EXT_ray_tracing);
|
symbolTable.setVariableExtensions("gl_HitTEXT", 1, &E_GL_EXT_ray_tracing);
|
||||||
symbolTable.setVariableExtensions("gl_HitKindNV", 1, &E_GL_NV_ray_tracing);
|
symbolTable.setVariableExtensions("gl_HitKindNV", 1, &E_GL_NV_ray_tracing);
|
||||||
@ -8792,6 +8873,7 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
BuiltInVariable("gl_RayTminEXT", EbvRayTmin, symbolTable);
|
BuiltInVariable("gl_RayTminEXT", EbvRayTmin, symbolTable);
|
||||||
BuiltInVariable("gl_RayTmaxNV", EbvRayTmax, symbolTable);
|
BuiltInVariable("gl_RayTmaxNV", EbvRayTmax, symbolTable);
|
||||||
BuiltInVariable("gl_RayTmaxEXT", EbvRayTmax, symbolTable);
|
BuiltInVariable("gl_RayTmaxEXT", EbvRayTmax, symbolTable);
|
||||||
|
BuiltInVariable("gl_CullMaskEXT", EbvCullMask, symbolTable);
|
||||||
BuiltInVariable("gl_HitTNV", EbvHitT, symbolTable);
|
BuiltInVariable("gl_HitTNV", EbvHitT, symbolTable);
|
||||||
BuiltInVariable("gl_HitTEXT", EbvHitT, symbolTable);
|
BuiltInVariable("gl_HitTEXT", EbvHitT, symbolTable);
|
||||||
BuiltInVariable("gl_HitKindNV", EbvHitKind, symbolTable);
|
BuiltInVariable("gl_HitKindNV", EbvHitKind, symbolTable);
|
||||||
@ -8823,9 +8905,12 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
BuiltInVariable("gl_SubGroupLeMaskARB", EbvSubGroupLeMask, symbolTable);
|
BuiltInVariable("gl_SubGroupLeMaskARB", EbvSubGroupLeMask, symbolTable);
|
||||||
BuiltInVariable("gl_SubGroupLtMaskARB", EbvSubGroupLtMask, symbolTable);
|
BuiltInVariable("gl_SubGroupLtMaskARB", EbvSubGroupLtMask, symbolTable);
|
||||||
|
|
||||||
if (spvVersion.vulkan > 0)
|
if (spvVersion.vulkan > 0) {
|
||||||
// Treat "gl_SubGroupSizeARB" as shader input instead of uniform for Vulkan
|
// Treat "gl_SubGroupSizeARB" as shader input instead of uniform for Vulkan
|
||||||
SpecialQualifier("gl_SubGroupSizeARB", EvqVaryingIn, EbvSubGroupSize, symbolTable);
|
SpecialQualifier("gl_SubGroupSizeARB", EvqVaryingIn, EbvSubGroupSize, symbolTable);
|
||||||
|
if (language == EShLangFragment)
|
||||||
|
ModifyFlatDecoration("gl_SubGroupSizeARB", true, symbolTable);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
BuiltInVariable("gl_SubGroupSizeARB", EbvSubGroupSize, symbolTable);
|
BuiltInVariable("gl_SubGroupSizeARB", EbvSubGroupSize, symbolTable);
|
||||||
|
|
||||||
@ -8869,7 +8954,7 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case EShLangMeshNV:
|
case EShLangMesh:
|
||||||
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
||||||
// per-vertex builtins
|
// per-vertex builtins
|
||||||
symbolTable.setVariableExtensions("gl_MeshVerticesNV", "gl_Position", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_MeshVerticesNV", "gl_Position", 1, &E_GL_NV_mesh_shader);
|
||||||
@ -8913,12 +8998,19 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
symbolTable.setVariableExtensions("gl_PrimitiveIndicesNV", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_PrimitiveIndicesNV", 1, &E_GL_NV_mesh_shader);
|
||||||
symbolTable.setVariableExtensions("gl_MeshViewCountNV", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_MeshViewCountNV", 1, &E_GL_NV_mesh_shader);
|
||||||
symbolTable.setVariableExtensions("gl_MeshViewIndicesNV", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_MeshViewIndicesNV", 1, &E_GL_NV_mesh_shader);
|
||||||
symbolTable.setVariableExtensions("gl_WorkGroupSize", 1, &E_GL_NV_mesh_shader);
|
if (profile != EEsProfile) {
|
||||||
symbolTable.setVariableExtensions("gl_WorkGroupID", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_WorkGroupSize", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
symbolTable.setVariableExtensions("gl_LocalInvocationID", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_WorkGroupID", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
symbolTable.setVariableExtensions("gl_GlobalInvocationID", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_LocalInvocationID", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
symbolTable.setVariableExtensions("gl_LocalInvocationIndex", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_GlobalInvocationID", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_LocalInvocationIndex", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
|
} else {
|
||||||
|
symbolTable.setVariableExtensions("gl_WorkGroupSize", 1, &E_GL_NV_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_WorkGroupID", 1, &E_GL_NV_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_LocalInvocationID", 1, &E_GL_NV_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_GlobalInvocationID", 1, &E_GL_NV_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_LocalInvocationIndex", 1, &E_GL_NV_mesh_shader);
|
||||||
|
}
|
||||||
BuiltInVariable("gl_PrimitiveCountNV", EbvPrimitiveCountNV, symbolTable);
|
BuiltInVariable("gl_PrimitiveCountNV", EbvPrimitiveCountNV, symbolTable);
|
||||||
BuiltInVariable("gl_PrimitiveIndicesNV", EbvPrimitiveIndicesNV, symbolTable);
|
BuiltInVariable("gl_PrimitiveIndicesNV", EbvPrimitiveIndicesNV, symbolTable);
|
||||||
BuiltInVariable("gl_MeshViewCountNV", EbvMeshViewCountNV, symbolTable);
|
BuiltInVariable("gl_MeshViewCountNV", EbvMeshViewCountNV, symbolTable);
|
||||||
@ -8936,12 +9028,54 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
symbolTable.setVariableExtensions("gl_MaxMeshViewCountNV", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_MaxMeshViewCountNV", 1, &E_GL_NV_mesh_shader);
|
||||||
|
|
||||||
// builtin functions
|
// builtin functions
|
||||||
symbolTable.setFunctionExtensions("barrier", 1, &E_GL_NV_mesh_shader);
|
if (profile != EEsProfile) {
|
||||||
symbolTable.setFunctionExtensions("memoryBarrierShared", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setFunctionExtensions("barrier", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
symbolTable.setFunctionExtensions("groupMemoryBarrier", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setFunctionExtensions("memoryBarrierShared", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
|
symbolTable.setFunctionExtensions("groupMemoryBarrier", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
|
} else {
|
||||||
|
symbolTable.setFunctionExtensions("barrier", 1, &E_GL_NV_mesh_shader);
|
||||||
|
symbolTable.setFunctionExtensions("memoryBarrierShared", 1, &E_GL_NV_mesh_shader);
|
||||||
|
symbolTable.setFunctionExtensions("groupMemoryBarrier", 1, &E_GL_NV_mesh_shader);
|
||||||
|
}
|
||||||
|
symbolTable.setFunctionExtensions("writePackedPrimitiveIndices4x8NV", 1, &E_GL_NV_mesh_shader);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (profile != EEsProfile && version >= 450) {
|
if (profile != EEsProfile && version >= 450) {
|
||||||
|
// GL_EXT_Mesh_shader
|
||||||
|
symbolTable.setVariableExtensions("gl_PrimitivePointIndicesEXT", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_PrimitiveLineIndicesEXT", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_PrimitiveTriangleIndicesEXT", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_NumWorkGroups", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
|
||||||
|
BuiltInVariable("gl_PrimitivePointIndicesEXT", EbvPrimitivePointIndicesEXT, symbolTable);
|
||||||
|
BuiltInVariable("gl_PrimitiveLineIndicesEXT", EbvPrimitiveLineIndicesEXT, symbolTable);
|
||||||
|
BuiltInVariable("gl_PrimitiveTriangleIndicesEXT", EbvPrimitiveTriangleIndicesEXT, symbolTable);
|
||||||
|
BuiltInVariable("gl_NumWorkGroups", EbvNumWorkGroups, symbolTable);
|
||||||
|
|
||||||
|
symbolTable.setVariableExtensions("gl_MeshVerticesEXT", "gl_Position", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_MeshVerticesEXT", "gl_PointSize", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_MeshVerticesEXT", "gl_ClipDistance", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_MeshVerticesEXT", "gl_CullDistance", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
|
||||||
|
BuiltInVariable("gl_MeshVerticesEXT", "gl_Position", EbvPosition, symbolTable);
|
||||||
|
BuiltInVariable("gl_MeshVerticesEXT", "gl_PointSize", EbvPointSize, symbolTable);
|
||||||
|
BuiltInVariable("gl_MeshVerticesEXT", "gl_ClipDistance", EbvClipDistance, symbolTable);
|
||||||
|
BuiltInVariable("gl_MeshVerticesEXT", "gl_CullDistance", EbvCullDistance, symbolTable);
|
||||||
|
|
||||||
|
symbolTable.setVariableExtensions("gl_MeshPrimitivesEXT", "gl_PrimitiveID", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_MeshPrimitivesEXT", "gl_Layer", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_MeshPrimitivesEXT", "gl_ViewportIndex", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_MeshPrimitivesEXT", "gl_CullPrimitiveEXT", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_MeshPrimitivesEXT", "gl_PrimitiveShadingRateEXT", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
|
||||||
|
BuiltInVariable("gl_MeshPrimitivesEXT", "gl_PrimitiveID", EbvPrimitiveId, symbolTable);
|
||||||
|
BuiltInVariable("gl_MeshPrimitivesEXT", "gl_Layer", EbvLayer, symbolTable);
|
||||||
|
BuiltInVariable("gl_MeshPrimitivesEXT", "gl_ViewportIndex", EbvViewportIndex, symbolTable);
|
||||||
|
BuiltInVariable("gl_MeshPrimitivesEXT", "gl_CullPrimitiveEXT", EbvCullPrimitiveEXT, symbolTable);
|
||||||
|
BuiltInVariable("gl_MeshPrimitivesEXT", "gl_PrimitiveShadingRateEXT", EbvPrimitiveShadingRateKHR, symbolTable);
|
||||||
|
|
||||||
|
symbolTable.setFunctionExtensions("SetMeshOutputsEXT", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
|
||||||
// GL_EXT_device_group
|
// GL_EXT_device_group
|
||||||
symbolTable.setVariableExtensions("gl_DeviceIndex", 1, &E_GL_EXT_device_group);
|
symbolTable.setVariableExtensions("gl_DeviceIndex", 1, &E_GL_EXT_device_group);
|
||||||
BuiltInVariable("gl_DeviceIndex", EbvDeviceIndex, symbolTable);
|
BuiltInVariable("gl_DeviceIndex", EbvDeviceIndex, symbolTable);
|
||||||
@ -8952,6 +9086,9 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
if (version >= 460) {
|
if (version >= 460) {
|
||||||
BuiltInVariable("gl_DrawID", EbvDrawId, symbolTable);
|
BuiltInVariable("gl_DrawID", EbvDrawId, symbolTable);
|
||||||
}
|
}
|
||||||
|
// GL_EXT_multiview
|
||||||
|
BuiltInVariable("gl_ViewIndex", EbvViewIndex, symbolTable);
|
||||||
|
symbolTable.setVariableExtensions("gl_ViewIndex", 1, &E_GL_EXT_multiview);
|
||||||
|
|
||||||
// GL_ARB_shader_ballot
|
// GL_ARB_shader_ballot
|
||||||
symbolTable.setVariableExtensions("gl_SubGroupSizeARB", 1, &E_GL_ARB_shader_ballot);
|
symbolTable.setVariableExtensions("gl_SubGroupSizeARB", 1, &E_GL_ARB_shader_ballot);
|
||||||
@ -8969,9 +9106,12 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
BuiltInVariable("gl_SubGroupLeMaskARB", EbvSubGroupLeMask, symbolTable);
|
BuiltInVariable("gl_SubGroupLeMaskARB", EbvSubGroupLeMask, symbolTable);
|
||||||
BuiltInVariable("gl_SubGroupLtMaskARB", EbvSubGroupLtMask, symbolTable);
|
BuiltInVariable("gl_SubGroupLtMaskARB", EbvSubGroupLtMask, symbolTable);
|
||||||
|
|
||||||
if (spvVersion.vulkan > 0)
|
if (spvVersion.vulkan > 0) {
|
||||||
// Treat "gl_SubGroupSizeARB" as shader input instead of uniform for Vulkan
|
// Treat "gl_SubGroupSizeARB" as shader input instead of uniform for Vulkan
|
||||||
SpecialQualifier("gl_SubGroupSizeARB", EvqVaryingIn, EbvSubGroupSize, symbolTable);
|
SpecialQualifier("gl_SubGroupSizeARB", EvqVaryingIn, EbvSubGroupSize, symbolTable);
|
||||||
|
if (language == EShLangFragment)
|
||||||
|
ModifyFlatDecoration("gl_SubGroupSizeARB", true, symbolTable);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
BuiltInVariable("gl_SubGroupSizeARB", EbvSubGroupSize, symbolTable);
|
BuiltInVariable("gl_SubGroupSizeARB", EbvSubGroupSize, symbolTable);
|
||||||
}
|
}
|
||||||
@ -9021,16 +9161,24 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case EShLangTaskNV:
|
case EShLangTask:
|
||||||
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
||||||
symbolTable.setVariableExtensions("gl_TaskCountNV", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_TaskCountNV", 1, &E_GL_NV_mesh_shader);
|
||||||
symbolTable.setVariableExtensions("gl_WorkGroupSize", 1, &E_GL_NV_mesh_shader);
|
|
||||||
symbolTable.setVariableExtensions("gl_WorkGroupID", 1, &E_GL_NV_mesh_shader);
|
|
||||||
symbolTable.setVariableExtensions("gl_LocalInvocationID", 1, &E_GL_NV_mesh_shader);
|
|
||||||
symbolTable.setVariableExtensions("gl_GlobalInvocationID", 1, &E_GL_NV_mesh_shader);
|
|
||||||
symbolTable.setVariableExtensions("gl_LocalInvocationIndex", 1, &E_GL_NV_mesh_shader);
|
|
||||||
symbolTable.setVariableExtensions("gl_MeshViewCountNV", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_MeshViewCountNV", 1, &E_GL_NV_mesh_shader);
|
||||||
symbolTable.setVariableExtensions("gl_MeshViewIndicesNV", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_MeshViewIndicesNV", 1, &E_GL_NV_mesh_shader);
|
||||||
|
if (profile != EEsProfile) {
|
||||||
|
symbolTable.setVariableExtensions("gl_WorkGroupSize", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_WorkGroupID", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_LocalInvocationID", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_GlobalInvocationID", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_LocalInvocationIndex", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
|
} else {
|
||||||
|
symbolTable.setVariableExtensions("gl_WorkGroupSize", 1, &E_GL_NV_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_WorkGroupID", 1, &E_GL_NV_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_LocalInvocationID", 1, &E_GL_NV_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_GlobalInvocationID", 1, &E_GL_NV_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_LocalInvocationIndex", 1, &E_GL_NV_mesh_shader);
|
||||||
|
}
|
||||||
|
|
||||||
BuiltInVariable("gl_TaskCountNV", EbvTaskCountNV, symbolTable);
|
BuiltInVariable("gl_TaskCountNV", EbvTaskCountNV, symbolTable);
|
||||||
BuiltInVariable("gl_WorkGroupSize", EbvWorkGroupSize, symbolTable);
|
BuiltInVariable("gl_WorkGroupSize", EbvWorkGroupSize, symbolTable);
|
||||||
@ -9044,12 +9192,23 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
symbolTable.setVariableExtensions("gl_MaxTaskWorkGroupSizeNV", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_MaxTaskWorkGroupSizeNV", 1, &E_GL_NV_mesh_shader);
|
||||||
symbolTable.setVariableExtensions("gl_MaxMeshViewCountNV", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setVariableExtensions("gl_MaxMeshViewCountNV", 1, &E_GL_NV_mesh_shader);
|
||||||
|
|
||||||
symbolTable.setFunctionExtensions("barrier", 1, &E_GL_NV_mesh_shader);
|
if (profile != EEsProfile) {
|
||||||
symbolTable.setFunctionExtensions("memoryBarrierShared", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setFunctionExtensions("barrier", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
symbolTable.setFunctionExtensions("groupMemoryBarrier", 1, &E_GL_NV_mesh_shader);
|
symbolTable.setFunctionExtensions("memoryBarrierShared", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
|
symbolTable.setFunctionExtensions("groupMemoryBarrier", Num_AEP_mesh_shader, AEP_mesh_shader);
|
||||||
|
} else {
|
||||||
|
symbolTable.setFunctionExtensions("barrier", 1, &E_GL_NV_mesh_shader);
|
||||||
|
symbolTable.setFunctionExtensions("memoryBarrierShared", 1, &E_GL_NV_mesh_shader);
|
||||||
|
symbolTable.setFunctionExtensions("groupMemoryBarrier", 1, &E_GL_NV_mesh_shader);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (profile != EEsProfile && version >= 450) {
|
if (profile != EEsProfile && version >= 450) {
|
||||||
|
// GL_EXT_mesh_shader
|
||||||
|
symbolTable.setFunctionExtensions("EmitMeshTasksEXT", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
symbolTable.setVariableExtensions("gl_NumWorkGroups", 1, &E_GL_EXT_mesh_shader);
|
||||||
|
BuiltInVariable("gl_NumWorkGroups", EbvNumWorkGroups, symbolTable);
|
||||||
|
|
||||||
// GL_EXT_device_group
|
// GL_EXT_device_group
|
||||||
symbolTable.setVariableExtensions("gl_DeviceIndex", 1, &E_GL_EXT_device_group);
|
symbolTable.setVariableExtensions("gl_DeviceIndex", 1, &E_GL_EXT_device_group);
|
||||||
BuiltInVariable("gl_DeviceIndex", EbvDeviceIndex, symbolTable);
|
BuiltInVariable("gl_DeviceIndex", EbvDeviceIndex, symbolTable);
|
||||||
@ -9077,9 +9236,12 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
BuiltInVariable("gl_SubGroupLeMaskARB", EbvSubGroupLeMask, symbolTable);
|
BuiltInVariable("gl_SubGroupLeMaskARB", EbvSubGroupLeMask, symbolTable);
|
||||||
BuiltInVariable("gl_SubGroupLtMaskARB", EbvSubGroupLtMask, symbolTable);
|
BuiltInVariable("gl_SubGroupLtMaskARB", EbvSubGroupLtMask, symbolTable);
|
||||||
|
|
||||||
if (spvVersion.vulkan > 0)
|
if (spvVersion.vulkan > 0) {
|
||||||
// Treat "gl_SubGroupSizeARB" as shader input instead of uniform for Vulkan
|
// Treat "gl_SubGroupSizeARB" as shader input instead of uniform for Vulkan
|
||||||
SpecialQualifier("gl_SubGroupSizeARB", EvqVaryingIn, EbvSubGroupSize, symbolTable);
|
SpecialQualifier("gl_SubGroupSizeARB", EvqVaryingIn, EbvSubGroupSize, symbolTable);
|
||||||
|
if (language == EShLangFragment)
|
||||||
|
ModifyFlatDecoration("gl_SubGroupSizeARB", true, symbolTable);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
BuiltInVariable("gl_SubGroupSizeARB", EbvSubGroupSize, symbolTable);
|
BuiltInVariable("gl_SubGroupSizeARB", EbvSubGroupSize, symbolTable);
|
||||||
}
|
}
|
||||||
@ -9673,17 +9835,27 @@ void TBuiltIns::identifyBuiltIns(int version, EProfile profile, const SpvVersion
|
|||||||
symbolTable.relateToOperator("executeCallableEXT", EOpExecuteCallableKHR);
|
symbolTable.relateToOperator("executeCallableEXT", EOpExecuteCallableKHR);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case EShLangMeshNV:
|
case EShLangMesh:
|
||||||
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
||||||
symbolTable.relateToOperator("writePackedPrimitiveIndices4x8NV", EOpWritePackedPrimitiveIndices4x8NV);
|
symbolTable.relateToOperator("writePackedPrimitiveIndices4x8NV", EOpWritePackedPrimitiveIndices4x8NV);
|
||||||
|
symbolTable.relateToOperator("memoryBarrierShared", EOpMemoryBarrierShared);
|
||||||
|
symbolTable.relateToOperator("groupMemoryBarrier", EOpGroupMemoryBarrier);
|
||||||
|
symbolTable.relateToOperator("subgroupMemoryBarrierShared", EOpSubgroupMemoryBarrierShared);
|
||||||
}
|
}
|
||||||
// fall through
|
|
||||||
case EShLangTaskNV:
|
if (profile != EEsProfile && version >= 450) {
|
||||||
|
symbolTable.relateToOperator("SetMeshOutputsEXT", EOpSetMeshOutputsEXT);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case EShLangTask:
|
||||||
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
if ((profile != EEsProfile && version >= 450) || (profile == EEsProfile && version >= 320)) {
|
||||||
symbolTable.relateToOperator("memoryBarrierShared", EOpMemoryBarrierShared);
|
symbolTable.relateToOperator("memoryBarrierShared", EOpMemoryBarrierShared);
|
||||||
symbolTable.relateToOperator("groupMemoryBarrier", EOpGroupMemoryBarrier);
|
symbolTable.relateToOperator("groupMemoryBarrier", EOpGroupMemoryBarrier);
|
||||||
symbolTable.relateToOperator("subgroupMemoryBarrierShared", EOpSubgroupMemoryBarrierShared);
|
symbolTable.relateToOperator("subgroupMemoryBarrierShared", EOpSubgroupMemoryBarrierShared);
|
||||||
}
|
}
|
||||||
|
if (profile != EEsProfile && version >= 450) {
|
||||||
|
symbolTable.relateToOperator("EmitMeshTasksEXT", EOpEmitMeshTasksEXT);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -2733,10 +2733,10 @@ TIntermAggregate* TIntermediate::addForLoop(TIntermNode* body, TIntermNode* init
|
|||||||
TIntermAggregate* loopSequence = (initializer == nullptr ||
|
TIntermAggregate* loopSequence = (initializer == nullptr ||
|
||||||
initializer->getAsAggregate() == nullptr) ? makeAggregate(initializer, loc)
|
initializer->getAsAggregate() == nullptr) ? makeAggregate(initializer, loc)
|
||||||
: initializer->getAsAggregate();
|
: initializer->getAsAggregate();
|
||||||
if (loopSequence != nullptr && loopSequence->getOp() == EOpSequence)
|
if (loopSequence != nullptr && (loopSequence->getOp() == EOpSequence || loopSequence->getOp() == EOpScope))
|
||||||
loopSequence->setOp(EOpNull);
|
loopSequence->setOp(EOpNull);
|
||||||
loopSequence = growAggregate(loopSequence, node);
|
loopSequence = growAggregate(loopSequence, node);
|
||||||
loopSequence->setOperator(EOpSequence);
|
loopSequence->setOperator(getDebugInfo() ? EOpScope : EOpSequence);
|
||||||
|
|
||||||
return loopSequence;
|
return loopSequence;
|
||||||
}
|
}
|
||||||
@ -2766,7 +2766,7 @@ void TIntermBranch::updatePrecision(TPrecisionQualifier parentPrecision)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
if (exp->getBasicType() == EbtInt || exp->getBasicType() == EbtUint ||
|
if (exp->getBasicType() == EbtInt || exp->getBasicType() == EbtUint ||
|
||||||
exp->getBasicType() == EbtFloat || exp->getBasicType() == EbtFloat16) {
|
exp->getBasicType() == EbtFloat) {
|
||||||
if (parentPrecision != EpqNone && exp->getQualifier().precision == EpqNone) {
|
if (parentPrecision != EpqNone && exp->getQualifier().precision == EpqNone) {
|
||||||
exp->propagatePrecision(parentPrecision);
|
exp->propagatePrecision(parentPrecision);
|
||||||
}
|
}
|
||||||
@ -3284,7 +3284,7 @@ bool TIntermediate::promoteUnary(TIntermUnary& node)
|
|||||||
void TIntermUnary::updatePrecision()
|
void TIntermUnary::updatePrecision()
|
||||||
{
|
{
|
||||||
if (getBasicType() == EbtInt || getBasicType() == EbtUint ||
|
if (getBasicType() == EbtInt || getBasicType() == EbtUint ||
|
||||||
getBasicType() == EbtFloat || getBasicType() == EbtFloat16) {
|
getBasicType() == EbtFloat) {
|
||||||
if (operand->getQualifier().precision > getQualifier().precision)
|
if (operand->getQualifier().precision > getQualifier().precision)
|
||||||
getQualifier().precision = operand->getQualifier().precision;
|
getQualifier().precision = operand->getQualifier().precision;
|
||||||
}
|
}
|
||||||
@ -3785,7 +3785,7 @@ bool TIntermediate::promoteAggregate(TIntermAggregate& node)
|
|||||||
void TIntermAggregate::updatePrecision()
|
void TIntermAggregate::updatePrecision()
|
||||||
{
|
{
|
||||||
if (getBasicType() == EbtInt || getBasicType() == EbtUint ||
|
if (getBasicType() == EbtInt || getBasicType() == EbtUint ||
|
||||||
getBasicType() == EbtFloat || getBasicType() == EbtFloat16) {
|
getBasicType() == EbtFloat) {
|
||||||
TPrecisionQualifier maxPrecision = EpqNone;
|
TPrecisionQualifier maxPrecision = EpqNone;
|
||||||
TIntermSequence operands = getSequence();
|
TIntermSequence operands = getSequence();
|
||||||
for (unsigned int i = 0; i < operands.size(); ++i) {
|
for (unsigned int i = 0; i < operands.size(); ++i) {
|
||||||
@ -3807,7 +3807,7 @@ void TIntermAggregate::updatePrecision()
|
|||||||
void TIntermBinary::updatePrecision()
|
void TIntermBinary::updatePrecision()
|
||||||
{
|
{
|
||||||
if (getBasicType() == EbtInt || getBasicType() == EbtUint ||
|
if (getBasicType() == EbtInt || getBasicType() == EbtUint ||
|
||||||
getBasicType() == EbtFloat || getBasicType() == EbtFloat16) {
|
getBasicType() == EbtFloat) {
|
||||||
if (op == EOpRightShift || op == EOpLeftShift) {
|
if (op == EOpRightShift || op == EOpLeftShift) {
|
||||||
// For shifts get precision from left side only and thus no need to propagate
|
// For shifts get precision from left side only and thus no need to propagate
|
||||||
getQualifier().precision = left->getQualifier().precision;
|
getQualifier().precision = left->getQualifier().precision;
|
||||||
|
@ -74,6 +74,9 @@ void C_DECL TParseContextBase::error(const TSourceLoc& loc, const char* szReason
|
|||||||
{
|
{
|
||||||
if (messages & EShMsgOnlyPreprocessor)
|
if (messages & EShMsgOnlyPreprocessor)
|
||||||
return;
|
return;
|
||||||
|
// If enhanced msg readability, only print one error
|
||||||
|
if (messages & EShMsgEnhanced && numErrors > 0)
|
||||||
|
return;
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start(args, szExtraInfoFormat);
|
va_start(args, szExtraInfoFormat);
|
||||||
outputMessage(loc, szReason, szToken, szExtraInfoFormat, EPrefixError, args);
|
outputMessage(loc, szReason, szToken, szExtraInfoFormat, EPrefixError, args);
|
||||||
|
@ -502,6 +502,16 @@ TIntermTyped* TParseContext::handleVariable(const TSourceLoc& loc, TSymbol* symb
|
|||||||
error(loc, "cannot be used (maybe an instance name is needed)", string->c_str(), "");
|
error(loc, "cannot be used (maybe an instance name is needed)", string->c_str(), "");
|
||||||
variable = nullptr;
|
variable = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (language == EShLangMesh && variable) {
|
||||||
|
TLayoutGeometry primitiveType = intermediate.getOutputPrimitive();
|
||||||
|
if ((variable->getMangledName() == "gl_PrimitiveTriangleIndicesEXT" && primitiveType != ElgTriangles) ||
|
||||||
|
(variable->getMangledName() == "gl_PrimitiveLineIndicesEXT" && primitiveType != ElgLines) ||
|
||||||
|
(variable->getMangledName() == "gl_PrimitivePointIndicesEXT" && primitiveType != ElgPoints)) {
|
||||||
|
error(loc, "cannot be used (ouput primitive type mismatch)", string->c_str(), "");
|
||||||
|
variable = nullptr;
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (symbol)
|
if (symbol)
|
||||||
error(loc, "variable name expected", string->c_str(), "");
|
error(loc, "variable name expected", string->c_str(), "");
|
||||||
@ -716,8 +726,8 @@ bool TParseContext::isIoResizeArray(const TType& type) const
|
|||||||
(language == EShLangTessControl && type.getQualifier().storage == EvqVaryingOut &&
|
(language == EShLangTessControl && type.getQualifier().storage == EvqVaryingOut &&
|
||||||
! type.getQualifier().patch) ||
|
! type.getQualifier().patch) ||
|
||||||
(language == EShLangFragment && type.getQualifier().storage == EvqVaryingIn &&
|
(language == EShLangFragment && type.getQualifier().storage == EvqVaryingIn &&
|
||||||
type.getQualifier().pervertexNV) ||
|
(type.getQualifier().pervertexNV || type.getQualifier().pervertexEXT)) ||
|
||||||
(language == EShLangMeshNV && type.getQualifier().storage == EvqVaryingOut &&
|
(language == EShLangMesh && type.getQualifier().storage == EvqVaryingOut &&
|
||||||
!type.getQualifier().perTaskNV));
|
!type.getQualifier().perTaskNV));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -794,7 +804,7 @@ void TParseContext::checkIoArraysConsistency(const TSourceLoc &loc, bool tailOnl
|
|||||||
|
|
||||||
// As I/O array sizes don't change, fetch requiredSize only once,
|
// As I/O array sizes don't change, fetch requiredSize only once,
|
||||||
// except for mesh shaders which could have different I/O array sizes based on type qualifiers.
|
// except for mesh shaders which could have different I/O array sizes based on type qualifiers.
|
||||||
if (firstIteration || (language == EShLangMeshNV)) {
|
if (firstIteration || (language == EShLangMesh)) {
|
||||||
requiredSize = getIoArrayImplicitSize(type.getQualifier(), &featureString);
|
requiredSize = getIoArrayImplicitSize(type.getQualifier(), &featureString);
|
||||||
if (requiredSize == 0)
|
if (requiredSize == 0)
|
||||||
break;
|
break;
|
||||||
@ -823,10 +833,11 @@ int TParseContext::getIoArrayImplicitSize(const TQualifier &qualifier, TString *
|
|||||||
// Number of vertices for Fragment shader is always three.
|
// Number of vertices for Fragment shader is always three.
|
||||||
expectedSize = 3;
|
expectedSize = 3;
|
||||||
str = "vertices";
|
str = "vertices";
|
||||||
} else if (language == EShLangMeshNV) {
|
} else if (language == EShLangMesh) {
|
||||||
unsigned int maxPrimitives =
|
unsigned int maxPrimitives =
|
||||||
intermediate.getPrimitives() != TQualifier::layoutNotSet ? intermediate.getPrimitives() : 0;
|
intermediate.getPrimitives() != TQualifier::layoutNotSet ? intermediate.getPrimitives() : 0;
|
||||||
if (qualifier.builtIn == EbvPrimitiveIndicesNV) {
|
if (qualifier.builtIn == EbvPrimitiveIndicesNV || qualifier.builtIn == EbvPrimitiveTriangleIndicesEXT ||
|
||||||
|
qualifier.builtIn == EbvPrimitiveLineIndicesEXT || qualifier.builtIn == EbvPrimitivePointIndicesEXT) {
|
||||||
expectedSize = maxPrimitives * TQualifier::mapGeometryToSize(intermediate.getOutputPrimitive());
|
expectedSize = maxPrimitives * TQualifier::mapGeometryToSize(intermediate.getOutputPrimitive());
|
||||||
str = "max_primitives*";
|
str = "max_primitives*";
|
||||||
str += TQualifier::getGeometryString(intermediate.getOutputPrimitive());
|
str += TQualifier::getGeometryString(intermediate.getOutputPrimitive());
|
||||||
@ -856,9 +867,9 @@ void TParseContext::checkIoArrayConsistency(const TSourceLoc& loc, int requiredS
|
|||||||
error(loc, "inconsistent output number of vertices for array size of", feature, name.c_str());
|
error(loc, "inconsistent output number of vertices for array size of", feature, name.c_str());
|
||||||
else if (language == EShLangFragment) {
|
else if (language == EShLangFragment) {
|
||||||
if (type.getOuterArraySize() > requiredSize)
|
if (type.getOuterArraySize() > requiredSize)
|
||||||
error(loc, " cannot be greater than 3 for pervertexNV", feature, name.c_str());
|
error(loc, " cannot be greater than 3 for pervertexEXT", feature, name.c_str());
|
||||||
}
|
}
|
||||||
else if (language == EShLangMeshNV)
|
else if (language == EShLangMesh)
|
||||||
error(loc, "inconsistent output array size of", feature, name.c_str());
|
error(loc, "inconsistent output array size of", feature, name.c_str());
|
||||||
else
|
else
|
||||||
assert(0);
|
assert(0);
|
||||||
@ -902,8 +913,10 @@ TIntermTyped* TParseContext::handleBinaryMath(const TSourceLoc& loc, const char*
|
|||||||
result = intermediate.addBinaryMath(op, left, right, loc);
|
result = intermediate.addBinaryMath(op, left, right, loc);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (result == nullptr)
|
if (result == nullptr) {
|
||||||
binaryOpError(loc, str, left->getCompleteString(), right->getCompleteString());
|
bool enhanced = intermediate.getEnhancedMsgs();
|
||||||
|
binaryOpError(loc, str, left->getCompleteString(enhanced), right->getCompleteString(enhanced));
|
||||||
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -926,8 +939,10 @@ TIntermTyped* TParseContext::handleUnaryMath(const TSourceLoc& loc, const char*
|
|||||||
|
|
||||||
if (result)
|
if (result)
|
||||||
return result;
|
return result;
|
||||||
else
|
else {
|
||||||
unaryOpError(loc, str, childNode->getCompleteString());
|
bool enhanced = intermediate.getEnhancedMsgs();
|
||||||
|
unaryOpError(loc, str, childNode->getCompleteString(enhanced));
|
||||||
|
}
|
||||||
|
|
||||||
return childNode;
|
return childNode;
|
||||||
}
|
}
|
||||||
@ -953,8 +968,8 @@ TIntermTyped* TParseContext::handleDotDereference(const TSourceLoc& loc, TInterm
|
|||||||
requireProfile(loc, ~EEsProfile, feature);
|
requireProfile(loc, ~EEsProfile, feature);
|
||||||
profileRequires(loc, ~EEsProfile, 420, E_GL_ARB_shading_language_420pack, feature);
|
profileRequires(loc, ~EEsProfile, 420, E_GL_ARB_shading_language_420pack, feature);
|
||||||
} else if (!base->getType().isCoopMat()) {
|
} else if (!base->getType().isCoopMat()) {
|
||||||
error(loc, "does not operate on this type:", field.c_str(), base->getType().getCompleteString().c_str());
|
bool enhanced = intermediate.getEnhancedMsgs();
|
||||||
|
error(loc, "does not operate on this type:", field.c_str(), base->getType().getCompleteString(enhanced).c_str());
|
||||||
return base;
|
return base;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1005,10 +1020,16 @@ TIntermTyped* TParseContext::handleDotDereference(const TSourceLoc& loc, TInterm
|
|||||||
intermediate.addIoAccessed(field);
|
intermediate.addIoAccessed(field);
|
||||||
}
|
}
|
||||||
inheritMemoryQualifiers(base->getQualifier(), result->getWritableType().getQualifier());
|
inheritMemoryQualifiers(base->getQualifier(), result->getWritableType().getQualifier());
|
||||||
} else
|
} else {
|
||||||
error(loc, "no such field in structure", field.c_str(), "");
|
auto baseSymbol = base;
|
||||||
|
while (baseSymbol->getAsSymbolNode() == nullptr)
|
||||||
|
baseSymbol = baseSymbol->getAsBinaryNode()->getLeft();
|
||||||
|
TString structName;
|
||||||
|
structName.append("\'").append(baseSymbol->getAsSymbolNode()->getName().c_str()).append( "\'");
|
||||||
|
error(loc, "no such field in structure", field.c_str(), structName.c_str());
|
||||||
|
}
|
||||||
} else
|
} else
|
||||||
error(loc, "does not apply to this type:", field.c_str(), base->getType().getCompleteString().c_str());
|
error(loc, "does not apply to this type:", field.c_str(), base->getType().getCompleteString(intermediate.getEnhancedMsgs()).c_str());
|
||||||
|
|
||||||
// Propagate noContraction up the dereference chain
|
// Propagate noContraction up the dereference chain
|
||||||
if (base->getQualifier().isNoContraction())
|
if (base->getQualifier().isNoContraction())
|
||||||
@ -1314,7 +1335,7 @@ TIntermTyped* TParseContext::handleFunctionCall(const TSourceLoc& loc, TFunction
|
|||||||
//
|
//
|
||||||
result = addConstructor(loc, arguments, type);
|
result = addConstructor(loc, arguments, type);
|
||||||
if (result == nullptr)
|
if (result == nullptr)
|
||||||
error(loc, "cannot construct with these arguments", type.getCompleteString().c_str(), "");
|
error(loc, "cannot construct with these arguments", type.getCompleteString(intermediate.getEnhancedMsgs()).c_str(), "");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
//
|
//
|
||||||
@ -1494,7 +1515,7 @@ TIntermTyped* TParseContext::handleBuiltInFunctionCall(TSourceLoc loc, TIntermNo
|
|||||||
else
|
else
|
||||||
error(arguments->getLoc(), " wrong operand type", "Internal Error",
|
error(arguments->getLoc(), " wrong operand type", "Internal Error",
|
||||||
"built in unary operator function. Type: %s",
|
"built in unary operator function. Type: %s",
|
||||||
static_cast<TIntermTyped*>(arguments)->getCompleteString().c_str());
|
static_cast<TIntermTyped*>(arguments)->getCompleteString(intermediate.getEnhancedMsgs()).c_str());
|
||||||
} else if (result->getAsOperator())
|
} else if (result->getAsOperator())
|
||||||
builtInOpCheck(loc, function, *result->getAsOperator());
|
builtInOpCheck(loc, function, *result->getAsOperator());
|
||||||
|
|
||||||
@ -1990,18 +2011,18 @@ void TParseContext::memorySemanticsCheck(const TSourceLoc& loc, const TFunction&
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((semantics & gl_SemanticsAcquire) &&
|
if ((semantics & gl_SemanticsAcquire) &&
|
||||||
(callNode.getOp() == EOpAtomicStore || callNode.getOp() == EOpImageAtomicStore)) {
|
(callNode.getOp() == EOpAtomicStore || callNode.getOp() == EOpImageAtomicStore)) {
|
||||||
error(loc, "gl_SemanticsAcquire must not be used with (image) atomic store",
|
error(loc, "gl_SemanticsAcquire must not be used with (image) atomic store",
|
||||||
fnCandidate.getName().c_str(), "");
|
fnCandidate.getName().c_str(), "");
|
||||||
}
|
}
|
||||||
if ((semantics & gl_SemanticsRelease) &&
|
if ((semantics & gl_SemanticsRelease) &&
|
||||||
(callNode.getOp() == EOpAtomicLoad || callNode.getOp() == EOpImageAtomicLoad)) {
|
(callNode.getOp() == EOpAtomicLoad || callNode.getOp() == EOpImageAtomicLoad)) {
|
||||||
error(loc, "gl_SemanticsRelease must not be used with (image) atomic load",
|
error(loc, "gl_SemanticsRelease must not be used with (image) atomic load",
|
||||||
fnCandidate.getName().c_str(), "");
|
fnCandidate.getName().c_str(), "");
|
||||||
}
|
}
|
||||||
if ((semantics & gl_SemanticsAcquireRelease) &&
|
if ((semantics & gl_SemanticsAcquireRelease) &&
|
||||||
(callNode.getOp() == EOpAtomicStore || callNode.getOp() == EOpImageAtomicStore ||
|
(callNode.getOp() == EOpAtomicStore || callNode.getOp() == EOpImageAtomicStore ||
|
||||||
callNode.getOp() == EOpAtomicLoad || callNode.getOp() == EOpImageAtomicLoad)) {
|
callNode.getOp() == EOpAtomicLoad || callNode.getOp() == EOpImageAtomicLoad)) {
|
||||||
error(loc, "gl_SemanticsAcquireRelease must not be used with (image) atomic load/store",
|
error(loc, "gl_SemanticsAcquireRelease must not be used with (image) atomic load/store",
|
||||||
fnCandidate.getName().c_str(), "");
|
fnCandidate.getName().c_str(), "");
|
||||||
@ -2317,7 +2338,7 @@ void TParseContext::builtInOpCheck(const TSourceLoc& loc, const TFunction& fnCan
|
|||||||
error(loc, "argument must be compile-time constant", "payload number", "a");
|
error(loc, "argument must be compile-time constant", "payload number", "a");
|
||||||
else {
|
else {
|
||||||
unsigned int location = (*argp)[10]->getAsConstantUnion()->getAsConstantUnion()->getConstArray()[0].getUConst();
|
unsigned int location = (*argp)[10]->getAsConstantUnion()->getAsConstantUnion()->getConstArray()[0].getUConst();
|
||||||
if (intermediate.checkLocationRT(0, location) < 0)
|
if (!extensionTurnedOn(E_GL_EXT_spirv_intrinsics) && intermediate.checkLocationRT(0, location) < 0)
|
||||||
error(loc, "with layout(location =", "no rayPayloadEXT/rayPayloadInEXT declared", "%d)", location);
|
error(loc, "with layout(location =", "no rayPayloadEXT/rayPayloadInEXT declared", "%d)", location);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -2330,7 +2351,7 @@ void TParseContext::builtInOpCheck(const TSourceLoc& loc, const TFunction& fnCan
|
|||||||
error(loc, "argument must be compile-time constant", "callable data number", "");
|
error(loc, "argument must be compile-time constant", "callable data number", "");
|
||||||
else {
|
else {
|
||||||
unsigned int location = (*argp)[1]->getAsConstantUnion()->getAsConstantUnion()->getConstArray()[0].getUConst();
|
unsigned int location = (*argp)[1]->getAsConstantUnion()->getAsConstantUnion()->getConstArray()[0].getUConst();
|
||||||
if (intermediate.checkLocationRT(1, location) < 0)
|
if (!extensionTurnedOn(E_GL_EXT_spirv_intrinsics) && intermediate.checkLocationRT(1, location) < 0)
|
||||||
error(loc, "with layout(location =", "no callableDataEXT/callableDataInEXT declared", "%d)", location);
|
error(loc, "with layout(location =", "no callableDataEXT/callableDataInEXT declared", "%d)", location);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -2452,7 +2473,7 @@ void TParseContext::builtInOpCheck(const TSourceLoc& loc, const TFunction& fnCan
|
|||||||
const TIntermTyped* base = TIntermediate::findLValueBase(arg0, true , true);
|
const TIntermTyped* base = TIntermediate::findLValueBase(arg0, true , true);
|
||||||
const TType* refType = (base->getType().isReference()) ? base->getType().getReferentType() : nullptr;
|
const TType* refType = (base->getType().isReference()) ? base->getType().getReferentType() : nullptr;
|
||||||
const TQualifier& qualifier = (refType != nullptr) ? refType->getQualifier() : base->getType().getQualifier();
|
const TQualifier& qualifier = (refType != nullptr) ? refType->getQualifier() : base->getType().getQualifier();
|
||||||
if (qualifier.storage != EvqShared && qualifier.storage != EvqBuffer)
|
if (qualifier.storage != EvqShared && qualifier.storage != EvqBuffer && qualifier.storage != EvqtaskPayloadSharedEXT)
|
||||||
error(loc,"Atomic memory function can only be used for shader storage block member or shared variable.",
|
error(loc,"Atomic memory function can only be used for shader storage block member or shared variable.",
|
||||||
fnCandidate.getName().c_str(), "");
|
fnCandidate.getName().c_str(), "");
|
||||||
|
|
||||||
@ -2550,7 +2571,7 @@ void TParseContext::builtInOpCheck(const TSourceLoc& loc, const TFunction& fnCan
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (profile != EEsProfile && version < 450) {
|
if (profile != EEsProfile && version < 450) {
|
||||||
if ((*argp)[0]->getAsTyped()->getBasicType() != EbtFloat &&
|
if ((*argp)[0]->getAsTyped()->getBasicType() != EbtFloat &&
|
||||||
(*argp)[0]->getAsTyped()->getBasicType() != EbtDouble &&
|
(*argp)[0]->getAsTyped()->getBasicType() != EbtDouble &&
|
||||||
(*argp)[1]->getAsTyped()->getBasicType() != EbtFloat &&
|
(*argp)[1]->getAsTyped()->getBasicType() != EbtFloat &&
|
||||||
(*argp)[1]->getAsTyped()->getBasicType() != EbtDouble &&
|
(*argp)[1]->getAsTyped()->getBasicType() != EbtDouble &&
|
||||||
@ -2599,23 +2620,24 @@ void TParseContext::builtInOpCheck(const TSourceLoc& loc, const TFunction& fnCan
|
|||||||
// Check that if extended types are being used that the correct extensions are enabled.
|
// Check that if extended types are being used that the correct extensions are enabled.
|
||||||
if (arg0 != nullptr) {
|
if (arg0 != nullptr) {
|
||||||
const TType& type = arg0->getType();
|
const TType& type = arg0->getType();
|
||||||
|
bool enhanced = intermediate.getEnhancedMsgs();
|
||||||
switch (type.getBasicType()) {
|
switch (type.getBasicType()) {
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
case EbtInt8:
|
case EbtInt8:
|
||||||
case EbtUint8:
|
case EbtUint8:
|
||||||
requireExtensions(loc, 1, &E_GL_EXT_shader_subgroup_extended_types_int8, type.getCompleteString().c_str());
|
requireExtensions(loc, 1, &E_GL_EXT_shader_subgroup_extended_types_int8, type.getCompleteString(enhanced).c_str());
|
||||||
break;
|
break;
|
||||||
case EbtInt16:
|
case EbtInt16:
|
||||||
case EbtUint16:
|
case EbtUint16:
|
||||||
requireExtensions(loc, 1, &E_GL_EXT_shader_subgroup_extended_types_int16, type.getCompleteString().c_str());
|
requireExtensions(loc, 1, &E_GL_EXT_shader_subgroup_extended_types_int16, type.getCompleteString(enhanced).c_str());
|
||||||
break;
|
break;
|
||||||
case EbtInt64:
|
case EbtInt64:
|
||||||
case EbtUint64:
|
case EbtUint64:
|
||||||
requireExtensions(loc, 1, &E_GL_EXT_shader_subgroup_extended_types_int64, type.getCompleteString().c_str());
|
requireExtensions(loc, 1, &E_GL_EXT_shader_subgroup_extended_types_int64, type.getCompleteString(enhanced).c_str());
|
||||||
break;
|
break;
|
||||||
case EbtFloat16:
|
case EbtFloat16:
|
||||||
requireExtensions(loc, 1, &E_GL_EXT_shader_subgroup_extended_types_float16, type.getCompleteString().c_str());
|
requireExtensions(loc, 1, &E_GL_EXT_shader_subgroup_extended_types_float16, type.getCompleteString(enhanced).c_str());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2788,7 +2810,10 @@ TFunction* TParseContext::handleConstructorCall(const TSourceLoc& loc, const TPu
|
|||||||
TOperator op = intermediate.mapTypeToConstructorOp(type);
|
TOperator op = intermediate.mapTypeToConstructorOp(type);
|
||||||
|
|
||||||
if (op == EOpNull) {
|
if (op == EOpNull) {
|
||||||
error(loc, "cannot construct this type", type.getBasicString(), "");
|
if (intermediate.getEnhancedMsgs() && type.getBasicType() == EbtSampler)
|
||||||
|
error(loc, "function not supported in this version; use texture() instead", "texture*D*", "");
|
||||||
|
else
|
||||||
|
error(loc, "cannot construct this type", type.getBasicString(), "");
|
||||||
op = EOpConstructFloat;
|
op = EOpConstructFloat;
|
||||||
TType errorType(EbtFloat);
|
TType errorType(EbtFloat);
|
||||||
type.shallowCopy(errorType);
|
type.shallowCopy(errorType);
|
||||||
@ -2974,7 +2999,17 @@ bool TParseContext::lValueErrorCheck(const TSourceLoc& loc, const char* op, TInt
|
|||||||
if (isEsProfile() && intermediate.getEarlyFragmentTests())
|
if (isEsProfile() && intermediate.getEarlyFragmentTests())
|
||||||
message = "can't modify gl_FragDepth if using early_fragment_tests";
|
message = "can't modify gl_FragDepth if using early_fragment_tests";
|
||||||
break;
|
break;
|
||||||
|
case EvqFragStencil:
|
||||||
|
intermediate.setStencilReplacing();
|
||||||
|
// "In addition, it is an error to statically write to gl_FragDepth in the fragment shader."
|
||||||
|
if (isEsProfile() && intermediate.getEarlyFragmentTests())
|
||||||
|
message = "can't modify EvqFragStencil if using early_fragment_tests";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case EvqtaskPayloadSharedEXT:
|
||||||
|
if (language == EShLangMesh)
|
||||||
|
message = "can't modify variable with storage qualifier taskPayloadSharedEXT in mesh shaders";
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -3013,7 +3048,7 @@ void TParseContext::rValueErrorCheck(const TSourceLoc& loc, const char* op, TInt
|
|||||||
if (symNode && symNode->getQualifier().isExplicitInterpolation())
|
if (symNode && symNode->getQualifier().isExplicitInterpolation())
|
||||||
error(loc, "can't read from explicitly-interpolated object: ", op, symNode->getName().c_str());
|
error(loc, "can't read from explicitly-interpolated object: ", op, symNode->getName().c_str());
|
||||||
|
|
||||||
// local_size_{xyz} must be assigned or specialized before gl_WorkGroupSize can be assigned.
|
// local_size_{xyz} must be assigned or specialized before gl_WorkGroupSize can be assigned.
|
||||||
if(node->getQualifier().builtIn == EbvWorkGroupSize &&
|
if(node->getQualifier().builtIn == EbvWorkGroupSize &&
|
||||||
!(intermediate.isLocalSizeSet() || intermediate.isLocalSizeSpecialized()))
|
!(intermediate.isLocalSizeSet() || intermediate.isLocalSizeSpecialized()))
|
||||||
error(loc, "can't read from gl_WorkGroupSize before a fixed workgroup size has been declared", op, "");
|
error(loc, "can't read from gl_WorkGroupSize before a fixed workgroup size has been declared", op, "");
|
||||||
@ -3198,6 +3233,12 @@ bool TParseContext::constructorError(const TSourceLoc& loc, TIntermNode* node, T
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TString constructorString;
|
||||||
|
if (intermediate.getEnhancedMsgs())
|
||||||
|
constructorString.append(type.getCompleteString(true, false, false, true)).append(" constructor");
|
||||||
|
else
|
||||||
|
constructorString.append("constructor");
|
||||||
|
|
||||||
// See if it's a matrix
|
// See if it's a matrix
|
||||||
bool constructingMatrix = false;
|
bool constructingMatrix = false;
|
||||||
switch (op) {
|
switch (op) {
|
||||||
@ -3255,7 +3296,7 @@ bool TParseContext::constructorError(const TSourceLoc& loc, TIntermNode* node, T
|
|||||||
if (function[arg].type->isArray()) {
|
if (function[arg].type->isArray()) {
|
||||||
if (function[arg].type->isUnsizedArray()) {
|
if (function[arg].type->isUnsizedArray()) {
|
||||||
// Can't construct from an unsized array.
|
// Can't construct from an unsized array.
|
||||||
error(loc, "array argument must be sized", "constructor", "");
|
error(loc, "array argument must be sized", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
arrayArg = true;
|
arrayArg = true;
|
||||||
@ -3285,13 +3326,13 @@ bool TParseContext::constructorError(const TSourceLoc& loc, TIntermNode* node, T
|
|||||||
intArgument = true;
|
intArgument = true;
|
||||||
if (type.isStruct()) {
|
if (type.isStruct()) {
|
||||||
if (function[arg].type->contains16BitFloat()) {
|
if (function[arg].type->contains16BitFloat()) {
|
||||||
requireFloat16Arithmetic(loc, "constructor", "can't construct structure containing 16-bit type");
|
requireFloat16Arithmetic(loc, constructorString.c_str(), "can't construct structure containing 16-bit type");
|
||||||
}
|
}
|
||||||
if (function[arg].type->contains16BitInt()) {
|
if (function[arg].type->contains16BitInt()) {
|
||||||
requireInt16Arithmetic(loc, "constructor", "can't construct structure containing 16-bit type");
|
requireInt16Arithmetic(loc, constructorString.c_str(), "can't construct structure containing 16-bit type");
|
||||||
}
|
}
|
||||||
if (function[arg].type->contains8BitInt()) {
|
if (function[arg].type->contains8BitInt()) {
|
||||||
requireInt8Arithmetic(loc, "constructor", "can't construct structure containing 8-bit type");
|
requireInt8Arithmetic(loc, constructorString.c_str(), "can't construct structure containing 8-bit type");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3305,9 +3346,9 @@ bool TParseContext::constructorError(const TSourceLoc& loc, TIntermNode* node, T
|
|||||||
case EOpConstructF16Vec3:
|
case EOpConstructF16Vec3:
|
||||||
case EOpConstructF16Vec4:
|
case EOpConstructF16Vec4:
|
||||||
if (type.isArray())
|
if (type.isArray())
|
||||||
requireFloat16Arithmetic(loc, "constructor", "16-bit arrays not supported");
|
requireFloat16Arithmetic(loc, constructorString.c_str(), "16-bit arrays not supported");
|
||||||
if (type.isVector() && function.getParamCount() != 1)
|
if (type.isVector() && function.getParamCount() != 1)
|
||||||
requireFloat16Arithmetic(loc, "constructor", "16-bit vectors only take vector types");
|
requireFloat16Arithmetic(loc, constructorString.c_str(), "16-bit vectors only take vector types");
|
||||||
break;
|
break;
|
||||||
case EOpConstructUint16:
|
case EOpConstructUint16:
|
||||||
case EOpConstructU16Vec2:
|
case EOpConstructU16Vec2:
|
||||||
@ -3318,9 +3359,9 @@ bool TParseContext::constructorError(const TSourceLoc& loc, TIntermNode* node, T
|
|||||||
case EOpConstructI16Vec3:
|
case EOpConstructI16Vec3:
|
||||||
case EOpConstructI16Vec4:
|
case EOpConstructI16Vec4:
|
||||||
if (type.isArray())
|
if (type.isArray())
|
||||||
requireInt16Arithmetic(loc, "constructor", "16-bit arrays not supported");
|
requireInt16Arithmetic(loc, constructorString.c_str(), "16-bit arrays not supported");
|
||||||
if (type.isVector() && function.getParamCount() != 1)
|
if (type.isVector() && function.getParamCount() != 1)
|
||||||
requireInt16Arithmetic(loc, "constructor", "16-bit vectors only take vector types");
|
requireInt16Arithmetic(loc, constructorString.c_str(), "16-bit vectors only take vector types");
|
||||||
break;
|
break;
|
||||||
case EOpConstructUint8:
|
case EOpConstructUint8:
|
||||||
case EOpConstructU8Vec2:
|
case EOpConstructU8Vec2:
|
||||||
@ -3331,9 +3372,9 @@ bool TParseContext::constructorError(const TSourceLoc& loc, TIntermNode* node, T
|
|||||||
case EOpConstructI8Vec3:
|
case EOpConstructI8Vec3:
|
||||||
case EOpConstructI8Vec4:
|
case EOpConstructI8Vec4:
|
||||||
if (type.isArray())
|
if (type.isArray())
|
||||||
requireInt8Arithmetic(loc, "constructor", "8-bit arrays not supported");
|
requireInt8Arithmetic(loc, constructorString.c_str(), "8-bit arrays not supported");
|
||||||
if (type.isVector() && function.getParamCount() != 1)
|
if (type.isVector() && function.getParamCount() != 1)
|
||||||
requireInt8Arithmetic(loc, "constructor", "8-bit vectors only take vector types");
|
requireInt8Arithmetic(loc, constructorString.c_str(), "8-bit vectors only take vector types");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
@ -3415,7 +3456,7 @@ bool TParseContext::constructorError(const TSourceLoc& loc, TIntermNode* node, T
|
|||||||
|
|
||||||
if (type.isArray()) {
|
if (type.isArray()) {
|
||||||
if (function.getParamCount() == 0) {
|
if (function.getParamCount() == 0) {
|
||||||
error(loc, "array constructor must have at least one argument", "constructor", "");
|
error(loc, "array constructor must have at least one argument", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3423,7 +3464,7 @@ bool TParseContext::constructorError(const TSourceLoc& loc, TIntermNode* node, T
|
|||||||
// auto adapt the constructor type to the number of arguments
|
// auto adapt the constructor type to the number of arguments
|
||||||
type.changeOuterArraySize(function.getParamCount());
|
type.changeOuterArraySize(function.getParamCount());
|
||||||
} else if (type.getOuterArraySize() != function.getParamCount()) {
|
} else if (type.getOuterArraySize() != function.getParamCount()) {
|
||||||
error(loc, "array constructor needs one argument per array element", "constructor", "");
|
error(loc, "array constructor needs one argument per array element", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3436,7 +3477,7 @@ bool TParseContext::constructorError(const TSourceLoc& loc, TIntermNode* node, T
|
|||||||
// At least the dimensionalities have to match.
|
// At least the dimensionalities have to match.
|
||||||
if (! function[0].type->isArray() ||
|
if (! function[0].type->isArray() ||
|
||||||
arraySizes.getNumDims() != function[0].type->getArraySizes()->getNumDims() + 1) {
|
arraySizes.getNumDims() != function[0].type->getArraySizes()->getNumDims() + 1) {
|
||||||
error(loc, "array constructor argument not correct type to construct array element", "constructor", "");
|
error(loc, "array constructor argument not correct type to construct array element", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3453,7 +3494,7 @@ bool TParseContext::constructorError(const TSourceLoc& loc, TIntermNode* node, T
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (arrayArg && op != EOpConstructStruct && ! type.isArrayOfArrays()) {
|
if (arrayArg && op != EOpConstructStruct && ! type.isArrayOfArrays()) {
|
||||||
error(loc, "constructing non-array constituent from array argument", "constructor", "");
|
error(loc, "constructing non-array constituent from array argument", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3463,51 +3504,51 @@ bool TParseContext::constructorError(const TSourceLoc& loc, TIntermNode* node, T
|
|||||||
// "If a matrix argument is given to a matrix constructor,
|
// "If a matrix argument is given to a matrix constructor,
|
||||||
// it is a compile-time error to have any other arguments."
|
// it is a compile-time error to have any other arguments."
|
||||||
if (function.getParamCount() != 1)
|
if (function.getParamCount() != 1)
|
||||||
error(loc, "matrix constructed from matrix can only have one argument", "constructor", "");
|
error(loc, "matrix constructed from matrix can only have one argument", constructorString.c_str(), "");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (overFull) {
|
if (overFull) {
|
||||||
error(loc, "too many arguments", "constructor", "");
|
error(loc, "too many arguments", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (op == EOpConstructStruct && ! type.isArray() && (int)type.getStruct()->size() != function.getParamCount()) {
|
if (op == EOpConstructStruct && ! type.isArray() && (int)type.getStruct()->size() != function.getParamCount()) {
|
||||||
error(loc, "Number of constructor parameters does not match the number of structure fields", "constructor", "");
|
error(loc, "Number of constructor parameters does not match the number of structure fields", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((op != EOpConstructStruct && size != 1 && size < type.computeNumComponents()) ||
|
if ((op != EOpConstructStruct && size != 1 && size < type.computeNumComponents()) ||
|
||||||
(op == EOpConstructStruct && size < type.computeNumComponents())) {
|
(op == EOpConstructStruct && size < type.computeNumComponents())) {
|
||||||
error(loc, "not enough data provided for construction", "constructor", "");
|
error(loc, "not enough data provided for construction", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (type.isCoopMat() && function.getParamCount() != 1) {
|
if (type.isCoopMat() && function.getParamCount() != 1) {
|
||||||
error(loc, "wrong number of arguments", "constructor", "");
|
error(loc, "wrong number of arguments", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (type.isCoopMat() &&
|
if (type.isCoopMat() &&
|
||||||
!(function[0].type->isScalar() || function[0].type->isCoopMat())) {
|
!(function[0].type->isScalar() || function[0].type->isCoopMat())) {
|
||||||
error(loc, "Cooperative matrix constructor argument must be scalar or cooperative matrix", "constructor", "");
|
error(loc, "Cooperative matrix constructor argument must be scalar or cooperative matrix", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
TIntermTyped* typed = node->getAsTyped();
|
TIntermTyped* typed = node->getAsTyped();
|
||||||
if (typed == nullptr) {
|
if (typed == nullptr) {
|
||||||
error(loc, "constructor argument does not have a type", "constructor", "");
|
error(loc, "constructor argument does not have a type", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (op != EOpConstructStruct && op != EOpConstructNonuniform && typed->getBasicType() == EbtSampler) {
|
if (op != EOpConstructStruct && op != EOpConstructNonuniform && typed->getBasicType() == EbtSampler) {
|
||||||
error(loc, "cannot convert a sampler", "constructor", "");
|
error(loc, "cannot convert a sampler", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (op != EOpConstructStruct && typed->isAtomic()) {
|
if (op != EOpConstructStruct && typed->isAtomic()) {
|
||||||
error(loc, "cannot convert an atomic_uint", "constructor", "");
|
error(loc, "cannot convert an atomic_uint", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (typed->getBasicType() == EbtVoid) {
|
if (typed->getBasicType() == EbtVoid) {
|
||||||
error(loc, "cannot convert a void", "constructor", "");
|
error(loc, "cannot convert a void", constructorString.c_str(), "");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3786,7 +3827,7 @@ void TParseContext::globalQualifierTypeCheck(const TSourceLoc& loc, const TQuali
|
|||||||
if (isTypeInt(publicType.basicType) || publicType.basicType == EbtDouble)
|
if (isTypeInt(publicType.basicType) || publicType.basicType == EbtDouble)
|
||||||
profileRequires(loc, EEsProfile, 300, nullptr, "shader input/output");
|
profileRequires(loc, EEsProfile, 300, nullptr, "shader input/output");
|
||||||
|
|
||||||
if (!qualifier.flat && !qualifier.isExplicitInterpolation() && !qualifier.isPervertexNV()) {
|
if (!qualifier.flat && !qualifier.isExplicitInterpolation() && !qualifier.isPervertexNV() && !qualifier.isPervertexEXT()) {
|
||||||
if (isTypeInt(publicType.basicType) ||
|
if (isTypeInt(publicType.basicType) ||
|
||||||
publicType.basicType == EbtDouble ||
|
publicType.basicType == EbtDouble ||
|
||||||
(publicType.userDef && ( publicType.userDef->containsBasicType(EbtInt)
|
(publicType.userDef && ( publicType.userDef->containsBasicType(EbtInt)
|
||||||
@ -3805,6 +3846,9 @@ void TParseContext::globalQualifierTypeCheck(const TSourceLoc& loc, const TQuali
|
|||||||
if (qualifier.isPatch() && qualifier.isInterpolation())
|
if (qualifier.isPatch() && qualifier.isInterpolation())
|
||||||
error(loc, "cannot use interpolation qualifiers with patch", "patch", "");
|
error(loc, "cannot use interpolation qualifiers with patch", "patch", "");
|
||||||
|
|
||||||
|
if (qualifier.isTaskPayload() && publicType.basicType == EbtBlock)
|
||||||
|
error(loc, "taskPayloadSharedEXT variables should not be declared as interface blocks", "taskPayloadSharedEXT", "");
|
||||||
|
|
||||||
if (qualifier.isTaskMemory() && publicType.basicType != EbtBlock)
|
if (qualifier.isTaskMemory() && publicType.basicType != EbtBlock)
|
||||||
error(loc, "taskNV variables can be declared only as blocks", "taskNV", "");
|
error(loc, "taskNV variables can be declared only as blocks", "taskNV", "");
|
||||||
|
|
||||||
@ -3962,7 +4006,7 @@ void TParseContext::mergeQualifiers(const TSourceLoc& loc, TQualifier& dst, cons
|
|||||||
(src.workgroupcoherent && (dst.coherent || dst.devicecoherent || dst.queuefamilycoherent || dst.subgroupcoherent || dst.shadercallcoherent)) ||
|
(src.workgroupcoherent && (dst.coherent || dst.devicecoherent || dst.queuefamilycoherent || dst.subgroupcoherent || dst.shadercallcoherent)) ||
|
||||||
(src.subgroupcoherent && (dst.coherent || dst.devicecoherent || dst.queuefamilycoherent || dst.workgroupcoherent || dst.shadercallcoherent)) ||
|
(src.subgroupcoherent && (dst.coherent || dst.devicecoherent || dst.queuefamilycoherent || dst.workgroupcoherent || dst.shadercallcoherent)) ||
|
||||||
(src.shadercallcoherent && (dst.coherent || dst.devicecoherent || dst.queuefamilycoherent || dst.workgroupcoherent || dst.subgroupcoherent)))) {
|
(src.shadercallcoherent && (dst.coherent || dst.devicecoherent || dst.queuefamilycoherent || dst.workgroupcoherent || dst.subgroupcoherent)))) {
|
||||||
error(loc, "only one coherent/devicecoherent/queuefamilycoherent/workgroupcoherent/subgroupcoherent/shadercallcoherent qualifier allowed",
|
error(loc, "only one coherent/devicecoherent/queuefamilycoherent/workgroupcoherent/subgroupcoherent/shadercallcoherent qualifier allowed",
|
||||||
GetPrecisionQualifierString(src.precision), "");
|
GetPrecisionQualifierString(src.precision), "");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -4320,10 +4364,10 @@ void TParseContext::arraySizesCheck(const TSourceLoc& loc, const TQualifier& qua
|
|||||||
extensionsTurnedOn(Num_AEP_tessellation_shader, AEP_tessellation_shader))
|
extensionsTurnedOn(Num_AEP_tessellation_shader, AEP_tessellation_shader))
|
||||||
return;
|
return;
|
||||||
break;
|
break;
|
||||||
case EShLangMeshNV:
|
case EShLangMesh:
|
||||||
if (qualifier.storage == EvqVaryingOut)
|
if (qualifier.storage == EvqVaryingOut)
|
||||||
if ((isEsProfile() && version >= 320) ||
|
if ((isEsProfile() && version >= 320) ||
|
||||||
extensionTurnedOn(E_GL_NV_mesh_shader))
|
extensionsTurnedOn(Num_AEP_mesh_shader, AEP_mesh_shader))
|
||||||
return;
|
return;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -4591,7 +4635,7 @@ TSymbol* TParseContext::redeclareBuiltinVariable(const TSourceLoc& loc, const TS
|
|||||||
|
|
||||||
if (ssoPre150 ||
|
if (ssoPre150 ||
|
||||||
(identifier == "gl_FragDepth" && ((nonEsRedecls && version >= 420) || esRedecls)) ||
|
(identifier == "gl_FragDepth" && ((nonEsRedecls && version >= 420) || esRedecls)) ||
|
||||||
(identifier == "gl_FragCoord" && ((nonEsRedecls && version >= 150) || esRedecls)) ||
|
(identifier == "gl_FragCoord" && ((nonEsRedecls && version >= 140) || esRedecls)) ||
|
||||||
identifier == "gl_ClipDistance" ||
|
identifier == "gl_ClipDistance" ||
|
||||||
identifier == "gl_CullDistance" ||
|
identifier == "gl_CullDistance" ||
|
||||||
identifier == "gl_ShadingRateEXT" ||
|
identifier == "gl_ShadingRateEXT" ||
|
||||||
@ -4607,6 +4651,9 @@ TSymbol* TParseContext::redeclareBuiltinVariable(const TSourceLoc& loc, const TS
|
|||||||
identifier == "gl_SampleMask" ||
|
identifier == "gl_SampleMask" ||
|
||||||
identifier == "gl_Layer" ||
|
identifier == "gl_Layer" ||
|
||||||
identifier == "gl_PrimitiveIndicesNV" ||
|
identifier == "gl_PrimitiveIndicesNV" ||
|
||||||
|
identifier == "gl_PrimitivePointIndicesEXT" ||
|
||||||
|
identifier == "gl_PrimitiveLineIndicesEXT" ||
|
||||||
|
identifier == "gl_PrimitiveTriangleIndicesEXT" ||
|
||||||
identifier == "gl_TexCoord") {
|
identifier == "gl_TexCoord") {
|
||||||
|
|
||||||
// Find the existing symbol, if any.
|
// Find the existing symbol, if any.
|
||||||
@ -4660,7 +4707,7 @@ TSymbol* TParseContext::redeclareBuiltinVariable(const TSourceLoc& loc, const TS
|
|||||||
symbolQualifier.storage != qualifier.storage)
|
symbolQualifier.storage != qualifier.storage)
|
||||||
error(loc, "cannot change qualification of", "redeclaration", symbol->getName().c_str());
|
error(loc, "cannot change qualification of", "redeclaration", symbol->getName().c_str());
|
||||||
} else if (identifier == "gl_FragCoord") {
|
} else if (identifier == "gl_FragCoord") {
|
||||||
if (intermediate.inIoAccessed("gl_FragCoord"))
|
if (!intermediate.getTexCoordRedeclared() && intermediate.inIoAccessed("gl_FragCoord"))
|
||||||
error(loc, "cannot redeclare after use", "gl_FragCoord", "");
|
error(loc, "cannot redeclare after use", "gl_FragCoord", "");
|
||||||
if (qualifier.nopersp != symbolQualifier.nopersp || qualifier.flat != symbolQualifier.flat ||
|
if (qualifier.nopersp != symbolQualifier.nopersp || qualifier.flat != symbolQualifier.flat ||
|
||||||
qualifier.isMemory() || qualifier.isAuxiliary())
|
qualifier.isMemory() || qualifier.isAuxiliary())
|
||||||
@ -4670,6 +4717,9 @@ TSymbol* TParseContext::redeclareBuiltinVariable(const TSourceLoc& loc, const TS
|
|||||||
if (! builtIn && (publicType.pixelCenterInteger != intermediate.getPixelCenterInteger() ||
|
if (! builtIn && (publicType.pixelCenterInteger != intermediate.getPixelCenterInteger() ||
|
||||||
publicType.originUpperLeft != intermediate.getOriginUpperLeft()))
|
publicType.originUpperLeft != intermediate.getOriginUpperLeft()))
|
||||||
error(loc, "cannot redeclare with different qualification:", "redeclaration", symbol->getName().c_str());
|
error(loc, "cannot redeclare with different qualification:", "redeclaration", symbol->getName().c_str());
|
||||||
|
|
||||||
|
|
||||||
|
intermediate.setTexCoordRedeclared();
|
||||||
if (publicType.pixelCenterInteger)
|
if (publicType.pixelCenterInteger)
|
||||||
intermediate.setPixelCenterInteger();
|
intermediate.setPixelCenterInteger();
|
||||||
if (publicType.originUpperLeft)
|
if (publicType.originUpperLeft)
|
||||||
@ -4686,10 +4736,22 @@ TSymbol* TParseContext::redeclareBuiltinVariable(const TSourceLoc& loc, const TS
|
|||||||
if (! intermediate.setDepth(publicType.layoutDepth))
|
if (! intermediate.setDepth(publicType.layoutDepth))
|
||||||
error(loc, "all redeclarations must use the same depth layout on", "redeclaration", symbol->getName().c_str());
|
error(loc, "all redeclarations must use the same depth layout on", "redeclaration", symbol->getName().c_str());
|
||||||
}
|
}
|
||||||
|
} else if (identifier == "gl_FragStencilRefARB") {
|
||||||
|
if (qualifier.nopersp != symbolQualifier.nopersp || qualifier.flat != symbolQualifier.flat ||
|
||||||
|
qualifier.isMemory() || qualifier.isAuxiliary())
|
||||||
|
error(loc, "can only change layout qualification of", "redeclaration", symbol->getName().c_str());
|
||||||
|
if (qualifier.storage != EvqVaryingOut)
|
||||||
|
error(loc, "cannot change output storage qualification of", "redeclaration", symbol->getName().c_str());
|
||||||
|
if (publicType.layoutStencil != ElsNone) {
|
||||||
|
if (intermediate.inIoAccessed("gl_FragStencilRefARB"))
|
||||||
|
error(loc, "cannot redeclare after use", "gl_FragStencilRefARB", "");
|
||||||
|
if (!intermediate.setStencil(publicType.layoutStencil))
|
||||||
|
error(loc, "all redeclarations must use the same stencil layout on", "redeclaration",
|
||||||
|
symbol->getName().c_str());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (
|
else if (
|
||||||
identifier == "gl_PrimitiveIndicesNV" ||
|
identifier == "gl_PrimitiveIndicesNV") {
|
||||||
identifier == "gl_FragStencilRefARB") {
|
|
||||||
if (qualifier.hasLayout())
|
if (qualifier.hasLayout())
|
||||||
error(loc, "cannot apply layout qualifier to", "redeclaration", symbol->getName().c_str());
|
error(loc, "cannot apply layout qualifier to", "redeclaration", symbol->getName().c_str());
|
||||||
if (qualifier.storage != EvqVaryingOut)
|
if (qualifier.storage != EvqVaryingOut)
|
||||||
@ -4730,7 +4792,8 @@ void TParseContext::redeclareBuiltinBlock(const TSourceLoc& loc, TTypeList& newT
|
|||||||
profileRequires(loc, ~EEsProfile, 410, E_GL_ARB_separate_shader_objects, feature);
|
profileRequires(loc, ~EEsProfile, 410, E_GL_ARB_separate_shader_objects, feature);
|
||||||
|
|
||||||
if (blockName != "gl_PerVertex" && blockName != "gl_PerFragment" &&
|
if (blockName != "gl_PerVertex" && blockName != "gl_PerFragment" &&
|
||||||
blockName != "gl_MeshPerVertexNV" && blockName != "gl_MeshPerPrimitiveNV") {
|
blockName != "gl_MeshPerVertexNV" && blockName != "gl_MeshPerPrimitiveNV" &&
|
||||||
|
blockName != "gl_MeshPerVertexEXT" && blockName != "gl_MeshPerPrimitiveEXT") {
|
||||||
error(loc, "cannot redeclare block: ", "block declaration", blockName.c_str());
|
error(loc, "cannot redeclare block: ", "block declaration", blockName.c_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -5299,11 +5362,11 @@ void TParseContext::finish()
|
|||||||
if (!isEsProfile() && version < 430)
|
if (!isEsProfile() && version < 430)
|
||||||
requireExtensions(getCurrentLoc(), 1, &E_GL_ARB_compute_shader, "compute shaders");
|
requireExtensions(getCurrentLoc(), 1, &E_GL_ARB_compute_shader, "compute shaders");
|
||||||
break;
|
break;
|
||||||
case EShLangTaskNV:
|
case EShLangTask:
|
||||||
requireExtensions(getCurrentLoc(), 1, &E_GL_NV_mesh_shader, "task shaders");
|
requireExtensions(getCurrentLoc(), Num_AEP_mesh_shader, AEP_mesh_shader, "task shaders");
|
||||||
break;
|
break;
|
||||||
case EShLangMeshNV:
|
case EShLangMesh:
|
||||||
requireExtensions(getCurrentLoc(), 1, &E_GL_NV_mesh_shader, "mesh shaders");
|
requireExtensions(getCurrentLoc(), Num_AEP_mesh_shader, AEP_mesh_shader, "mesh shaders");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
@ -5413,12 +5476,12 @@ void TParseContext::setLayoutQualifier(const TSourceLoc& loc, TPublicType& publi
|
|||||||
intermediate.setUsePhysicalStorageBuffer();
|
intermediate.setUsePhysicalStorageBuffer();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (language == EShLangGeometry || language == EShLangTessEvaluation || language == EShLangMeshNV) {
|
if (language == EShLangGeometry || language == EShLangTessEvaluation || language == EShLangMesh) {
|
||||||
if (id == TQualifier::getGeometryString(ElgTriangles)) {
|
if (id == TQualifier::getGeometryString(ElgTriangles)) {
|
||||||
publicType.shaderQualifiers.geometry = ElgTriangles;
|
publicType.shaderQualifiers.geometry = ElgTriangles;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (language == EShLangGeometry || language == EShLangMeshNV) {
|
if (language == EShLangGeometry || language == EShLangMesh) {
|
||||||
if (id == TQualifier::getGeometryString(ElgPoints)) {
|
if (id == TQualifier::getGeometryString(ElgPoints)) {
|
||||||
publicType.shaderQualifiers.geometry = ElgPoints;
|
publicType.shaderQualifiers.geometry = ElgPoints;
|
||||||
return;
|
return;
|
||||||
@ -5501,12 +5564,19 @@ void TParseContext::setLayoutQualifier(const TSourceLoc& loc, TPublicType& publi
|
|||||||
}
|
}
|
||||||
if (language == EShLangFragment) {
|
if (language == EShLangFragment) {
|
||||||
if (id == "origin_upper_left") {
|
if (id == "origin_upper_left") {
|
||||||
requireProfile(loc, ECoreProfile | ECompatibilityProfile, "origin_upper_left");
|
requireProfile(loc, ECoreProfile | ECompatibilityProfile | ENoProfile, "origin_upper_left");
|
||||||
|
if (profile == ENoProfile) {
|
||||||
|
profileRequires(loc,ECoreProfile | ECompatibilityProfile, 140, E_GL_ARB_fragment_coord_conventions, "origin_upper_left");
|
||||||
|
}
|
||||||
|
|
||||||
publicType.shaderQualifiers.originUpperLeft = true;
|
publicType.shaderQualifiers.originUpperLeft = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (id == "pixel_center_integer") {
|
if (id == "pixel_center_integer") {
|
||||||
requireProfile(loc, ECoreProfile | ECompatibilityProfile, "pixel_center_integer");
|
requireProfile(loc, ECoreProfile | ECompatibilityProfile | ENoProfile, "pixel_center_integer");
|
||||||
|
if (profile == ENoProfile) {
|
||||||
|
profileRequires(loc,ECoreProfile | ECompatibilityProfile, 140, E_GL_ARB_fragment_coord_conventions, "pixel_center_integer");
|
||||||
|
}
|
||||||
publicType.shaderQualifiers.pixelCenterInteger = true;
|
publicType.shaderQualifiers.pixelCenterInteger = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -5516,6 +5586,12 @@ void TParseContext::setLayoutQualifier(const TSourceLoc& loc, TPublicType& publi
|
|||||||
publicType.shaderQualifiers.earlyFragmentTests = true;
|
publicType.shaderQualifiers.earlyFragmentTests = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (id == "early_and_late_fragment_tests_amd") {
|
||||||
|
profileRequires(loc, ENoProfile | ECoreProfile | ECompatibilityProfile, 420, E_GL_AMD_shader_early_and_late_fragment_tests, "early_and_late_fragment_tests_amd");
|
||||||
|
profileRequires(loc, EEsProfile, 310, nullptr, "early_and_late_fragment_tests_amd");
|
||||||
|
publicType.shaderQualifiers.earlyAndLateFragmentTestsAMD = true;
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (id == "post_depth_coverage") {
|
if (id == "post_depth_coverage") {
|
||||||
requireExtensions(loc, Num_post_depth_coverageEXTs, post_depth_coverageEXTs, "post depth coverage");
|
requireExtensions(loc, Num_post_depth_coverageEXTs, post_depth_coverageEXTs, "post depth coverage");
|
||||||
if (extensionTurnedOn(E_GL_ARB_post_depth_coverage)) {
|
if (extensionTurnedOn(E_GL_ARB_post_depth_coverage)) {
|
||||||
@ -5532,6 +5608,14 @@ void TParseContext::setLayoutQualifier(const TSourceLoc& loc, TPublicType& publi
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
for (TLayoutStencil stencil = (TLayoutStencil)(ElsNone + 1); stencil < ElsCount; stencil = (TLayoutStencil)(stencil+1)) {
|
||||||
|
if (id == TQualifier::getLayoutStencilString(stencil)) {
|
||||||
|
requireProfile(loc, ECoreProfile | ECompatibilityProfile, "stencil layout qualifier");
|
||||||
|
profileRequires(loc, ECoreProfile | ECompatibilityProfile, 420, nullptr, "stencil layout qualifier");
|
||||||
|
publicType.shaderQualifiers.layoutStencil = stencil;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
for (TInterlockOrdering order = (TInterlockOrdering)(EioNone + 1); order < EioCount; order = (TInterlockOrdering)(order+1)) {
|
for (TInterlockOrdering order = (TInterlockOrdering)(EioNone + 1); order < EioCount; order = (TInterlockOrdering)(order+1)) {
|
||||||
if (id == TQualifier::getInterlockOrderingString(order)) {
|
if (id == TQualifier::getInterlockOrderingString(order)) {
|
||||||
requireProfile(loc, ECoreProfile | ECompatibilityProfile, "fragment shader interlock layout qualifier");
|
requireProfile(loc, ECoreProfile | ECompatibilityProfile, "fragment shader interlock layout qualifier");
|
||||||
@ -5675,7 +5759,7 @@ void TParseContext::setLayoutQualifier(const TSourceLoc& loc, TPublicType& publi
|
|||||||
return;
|
return;
|
||||||
} else if (id == "location") {
|
} else if (id == "location") {
|
||||||
profileRequires(loc, EEsProfile, 300, nullptr, "location");
|
profileRequires(loc, EEsProfile, 300, nullptr, "location");
|
||||||
const char* exts[2] = { E_GL_ARB_separate_shader_objects, E_GL_ARB_explicit_attrib_location };
|
const char* exts[2] = { E_GL_ARB_separate_shader_objects, E_GL_ARB_explicit_attrib_location };
|
||||||
// GL_ARB_explicit_uniform_location requires 330 or GL_ARB_explicit_attrib_location we do not need to add it here
|
// GL_ARB_explicit_uniform_location requires 330 or GL_ARB_explicit_attrib_location we do not need to add it here
|
||||||
profileRequires(loc, ~EEsProfile, 330, 2, exts, "location");
|
profileRequires(loc, ~EEsProfile, 330, 2, exts, "location");
|
||||||
if ((unsigned int)value >= TQualifier::layoutLocationEnd)
|
if ((unsigned int)value >= TQualifier::layoutLocationEnd)
|
||||||
@ -5885,9 +5969,9 @@ void TParseContext::setLayoutQualifier(const TSourceLoc& loc, TPublicType& publi
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case EShLangMeshNV:
|
case EShLangMesh:
|
||||||
if (id == "max_vertices") {
|
if (id == "max_vertices") {
|
||||||
requireExtensions(loc, 1, &E_GL_NV_mesh_shader, "max_vertices");
|
requireExtensions(loc, Num_AEP_mesh_shader, AEP_mesh_shader, "max_vertices");
|
||||||
publicType.shaderQualifiers.vertices = value;
|
publicType.shaderQualifiers.vertices = value;
|
||||||
if (value > resources.maxMeshOutputVerticesNV)
|
if (value > resources.maxMeshOutputVerticesNV)
|
||||||
error(loc, "too large, must be less than gl_MaxMeshOutputVerticesNV", "max_vertices", "");
|
error(loc, "too large, must be less than gl_MaxMeshOutputVerticesNV", "max_vertices", "");
|
||||||
@ -5896,7 +5980,7 @@ void TParseContext::setLayoutQualifier(const TSourceLoc& loc, TPublicType& publi
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (id == "max_primitives") {
|
if (id == "max_primitives") {
|
||||||
requireExtensions(loc, 1, &E_GL_NV_mesh_shader, "max_primitives");
|
requireExtensions(loc, Num_AEP_mesh_shader, AEP_mesh_shader, "max_primitives");
|
||||||
publicType.shaderQualifiers.primitives = value;
|
publicType.shaderQualifiers.primitives = value;
|
||||||
if (value > resources.maxMeshOutputPrimitivesNV)
|
if (value > resources.maxMeshOutputPrimitivesNV)
|
||||||
error(loc, "too large, must be less than gl_MaxMeshOutputPrimitivesNV", "max_primitives", "");
|
error(loc, "too large, must be less than gl_MaxMeshOutputPrimitivesNV", "max_primitives", "");
|
||||||
@ -5906,14 +5990,14 @@ void TParseContext::setLayoutQualifier(const TSourceLoc& loc, TPublicType& publi
|
|||||||
}
|
}
|
||||||
// Fall through
|
// Fall through
|
||||||
|
|
||||||
case EShLangTaskNV:
|
case EShLangTask:
|
||||||
// Fall through
|
// Fall through
|
||||||
#endif
|
#endif
|
||||||
case EShLangCompute:
|
case EShLangCompute:
|
||||||
if (id.compare(0, 11, "local_size_") == 0) {
|
if (id.compare(0, 11, "local_size_") == 0) {
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
if (language == EShLangMeshNV || language == EShLangTaskNV) {
|
if (language == EShLangMesh || language == EShLangTask) {
|
||||||
requireExtensions(loc, 1, &E_GL_NV_mesh_shader, "gl_WorkGroupSize");
|
requireExtensions(loc, Num_AEP_mesh_shader, AEP_mesh_shader, "gl_WorkGroupSize");
|
||||||
} else {
|
} else {
|
||||||
profileRequires(loc, EEsProfile, 310, 0, "gl_WorkGroupSize");
|
profileRequires(loc, EEsProfile, 310, 0, "gl_WorkGroupSize");
|
||||||
profileRequires(loc, ~EEsProfile, 430, E_GL_ARB_compute_shader, "gl_WorkGroupSize");
|
profileRequires(loc, ~EEsProfile, 430, E_GL_ARB_compute_shader, "gl_WorkGroupSize");
|
||||||
@ -6039,6 +6123,8 @@ void TParseContext::mergeObjectLayoutQualifiers(TQualifier& dst, const TQualifie
|
|||||||
dst.layoutShaderRecord = true;
|
dst.layoutShaderRecord = true;
|
||||||
if (src.pervertexNV)
|
if (src.pervertexNV)
|
||||||
dst.pervertexNV = true;
|
dst.pervertexNV = true;
|
||||||
|
if (src.pervertexEXT)
|
||||||
|
dst.pervertexEXT = true;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -6187,6 +6273,9 @@ void TParseContext::layoutTypeCheck(const TSourceLoc& loc, const TType& type)
|
|||||||
if (type.getBasicType() == EbtBlock)
|
if (type.getBasicType() == EbtBlock)
|
||||||
error(loc, "cannot apply to uniform or buffer block", "location", "");
|
error(loc, "cannot apply to uniform or buffer block", "location", "");
|
||||||
break;
|
break;
|
||||||
|
case EvqtaskPayloadSharedEXT:
|
||||||
|
error(loc, "cannot apply to taskPayloadSharedEXT", "location", "");
|
||||||
|
break;
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
case EvqPayload:
|
case EvqPayload:
|
||||||
case EvqPayloadIn:
|
case EvqPayloadIn:
|
||||||
@ -6338,8 +6427,12 @@ void TParseContext::layoutTypeCheck(const TSourceLoc& loc, const TType& type)
|
|||||||
profileRequires(loc, ECoreProfile | ECompatibilityProfile, 0, E_GL_EXT_shader_image_load_formatted, explanation);
|
profileRequires(loc, ECoreProfile | ECompatibilityProfile, 0, E_GL_EXT_shader_image_load_formatted, explanation);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qualifier.isPushConstant() && type.getBasicType() != EbtBlock)
|
if (qualifier.isPushConstant()) {
|
||||||
error(loc, "can only be used with a block", "push_constant", "");
|
if (type.getBasicType() != EbtBlock)
|
||||||
|
error(loc, "can only be used with a block", "push_constant", "");
|
||||||
|
if (type.isArray())
|
||||||
|
error(loc, "Push constants blocks can't be an array", "push_constant", "");
|
||||||
|
}
|
||||||
|
|
||||||
if (qualifier.hasBufferReference() && type.getBasicType() != EbtBlock)
|
if (qualifier.hasBufferReference() && type.getBasicType() != EbtBlock)
|
||||||
error(loc, "can only be used with a block", "buffer_reference", "");
|
error(loc, "can only be used with a block", "buffer_reference", "");
|
||||||
@ -6544,7 +6637,7 @@ void TParseContext::checkNoShaderLayouts(const TSourceLoc& loc, const TShaderQua
|
|||||||
error(loc, message, "local_size id", "");
|
error(loc, message, "local_size id", "");
|
||||||
}
|
}
|
||||||
if (shaderQualifiers.vertices != TQualifier::layoutNotSet) {
|
if (shaderQualifiers.vertices != TQualifier::layoutNotSet) {
|
||||||
if (language == EShLangGeometry || language == EShLangMeshNV)
|
if (language == EShLangGeometry || language == EShLangMesh)
|
||||||
error(loc, message, "max_vertices", "");
|
error(loc, message, "max_vertices", "");
|
||||||
else if (language == EShLangTessControl)
|
else if (language == EShLangTessControl)
|
||||||
error(loc, message, "vertices", "");
|
error(loc, message, "vertices", "");
|
||||||
@ -6556,7 +6649,7 @@ void TParseContext::checkNoShaderLayouts(const TSourceLoc& loc, const TShaderQua
|
|||||||
if (shaderQualifiers.postDepthCoverage)
|
if (shaderQualifiers.postDepthCoverage)
|
||||||
error(loc, message, "post_depth_coverage", "");
|
error(loc, message, "post_depth_coverage", "");
|
||||||
if (shaderQualifiers.primitives != TQualifier::layoutNotSet) {
|
if (shaderQualifiers.primitives != TQualifier::layoutNotSet) {
|
||||||
if (language == EShLangMeshNV)
|
if (language == EShLangMesh)
|
||||||
error(loc, message, "max_primitives", "");
|
error(loc, message, "max_primitives", "");
|
||||||
else
|
else
|
||||||
assert(0);
|
assert(0);
|
||||||
@ -6967,12 +7060,14 @@ TIntermTyped* TParseContext::vkRelaxedRemapFunctionCall(const TSourceLoc& loc, T
|
|||||||
|
|
||||||
TFunction realFunc(&name, function->getType());
|
TFunction realFunc(&name, function->getType());
|
||||||
|
|
||||||
|
// Use copyParam to avoid shared ownership of the 'type' field
|
||||||
|
// of the parameter.
|
||||||
for (int i = 0; i < function->getParamCount(); ++i) {
|
for (int i = 0; i < function->getParamCount(); ++i) {
|
||||||
realFunc.addParameter((*function)[i]);
|
realFunc.addParameter(TParameter().copyParam((*function)[i]));
|
||||||
}
|
}
|
||||||
|
|
||||||
TParameter tmpP = { 0, &uintType };
|
TParameter tmpP = { 0, &uintType };
|
||||||
realFunc.addParameter(tmpP);
|
realFunc.addParameter(TParameter().copyParam(tmpP));
|
||||||
arguments = intermediate.growAggregate(arguments, intermediate.addConstantUnion(1, loc, true));
|
arguments = intermediate.growAggregate(arguments, intermediate.addConstantUnion(1, loc, true));
|
||||||
|
|
||||||
result = handleFunctionCall(loc, &realFunc, arguments);
|
result = handleFunctionCall(loc, &realFunc, arguments);
|
||||||
@ -6985,11 +7080,11 @@ TIntermTyped* TParseContext::vkRelaxedRemapFunctionCall(const TSourceLoc& loc, T
|
|||||||
TFunction realFunc(&name, function->getType());
|
TFunction realFunc(&name, function->getType());
|
||||||
|
|
||||||
for (int i = 0; i < function->getParamCount(); ++i) {
|
for (int i = 0; i < function->getParamCount(); ++i) {
|
||||||
realFunc.addParameter((*function)[i]);
|
realFunc.addParameter(TParameter().copyParam((*function)[i]));
|
||||||
}
|
}
|
||||||
|
|
||||||
TParameter tmpP = { 0, &uintType };
|
TParameter tmpP = { 0, &uintType };
|
||||||
realFunc.addParameter(tmpP);
|
realFunc.addParameter(TParameter().copyParam(tmpP));
|
||||||
arguments = intermediate.growAggregate(arguments, intermediate.addConstantUnion(-1, loc, true));
|
arguments = intermediate.growAggregate(arguments, intermediate.addConstantUnion(-1, loc, true));
|
||||||
|
|
||||||
result = handleFunctionCall(loc, &realFunc, arguments);
|
result = handleFunctionCall(loc, &realFunc, arguments);
|
||||||
@ -7200,6 +7295,8 @@ TIntermNode* TParseContext::declareVariable(const TSourceLoc& loc, TString& iden
|
|||||||
requireInt8Arithmetic(loc, "qualifier", "(u)int8 types can only be in uniform block or buffer storage");
|
requireInt8Arithmetic(loc, "qualifier", "(u)int8 types can only be in uniform block or buffer storage");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (type.getQualifier().storage == EvqtaskPayloadSharedEXT)
|
||||||
|
intermediate.addTaskPayloadEXTCount();
|
||||||
if (type.getQualifier().storage == EvqShared && type.containsCoopMat())
|
if (type.getQualifier().storage == EvqShared && type.containsCoopMat())
|
||||||
error(loc, "qualifier", "Cooperative matrix types must not be used in shared memory", "");
|
error(loc, "qualifier", "Cooperative matrix types must not be used in shared memory", "");
|
||||||
|
|
||||||
@ -7223,6 +7320,8 @@ TIntermNode* TParseContext::declareVariable(const TSourceLoc& loc, TString& iden
|
|||||||
error(loc, "can only apply origin_upper_left and pixel_center_origin to gl_FragCoord", "layout qualifier", "");
|
error(loc, "can only apply origin_upper_left and pixel_center_origin to gl_FragCoord", "layout qualifier", "");
|
||||||
if (identifier != "gl_FragDepth" && publicType.shaderQualifiers.getDepth() != EldNone)
|
if (identifier != "gl_FragDepth" && publicType.shaderQualifiers.getDepth() != EldNone)
|
||||||
error(loc, "can only apply depth layout to gl_FragDepth", "layout qualifier", "");
|
error(loc, "can only apply depth layout to gl_FragDepth", "layout qualifier", "");
|
||||||
|
if (identifier != "gl_FragStencilRefARB" && publicType.shaderQualifiers.getStencil() != ElsNone)
|
||||||
|
error(loc, "can only apply depth layout to gl_FragStencilRefARB", "layout qualifier", "");
|
||||||
|
|
||||||
// Check for redeclaration of built-ins and/or attempting to declare a reserved name
|
// Check for redeclaration of built-ins and/or attempting to declare a reserved name
|
||||||
TSymbol* symbol = redeclareBuiltinVariable(loc, identifier, type.getQualifier(), publicType.shaderQualifiers);
|
TSymbol* symbol = redeclareBuiltinVariable(loc, identifier, type.getQualifier(), publicType.shaderQualifiers);
|
||||||
@ -7430,14 +7529,14 @@ TIntermNode* TParseContext::executeInitializer(const TSourceLoc& loc, TIntermTyp
|
|||||||
// Uniforms require a compile-time constant initializer
|
// Uniforms require a compile-time constant initializer
|
||||||
if (qualifier == EvqUniform && ! initializer->getType().getQualifier().isFrontEndConstant()) {
|
if (qualifier == EvqUniform && ! initializer->getType().getQualifier().isFrontEndConstant()) {
|
||||||
error(loc, "uniform initializers must be constant", "=", "'%s'",
|
error(loc, "uniform initializers must be constant", "=", "'%s'",
|
||||||
variable->getType().getCompleteString().c_str());
|
variable->getType().getCompleteString(intermediate.getEnhancedMsgs()).c_str());
|
||||||
variable->getWritableType().getQualifier().makeTemporary();
|
variable->getWritableType().getQualifier().makeTemporary();
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
// Global consts require a constant initializer (specialization constant is okay)
|
// Global consts require a constant initializer (specialization constant is okay)
|
||||||
if (qualifier == EvqConst && symbolTable.atGlobalLevel() && ! initializer->getType().getQualifier().isConstant()) {
|
if (qualifier == EvqConst && symbolTable.atGlobalLevel() && ! initializer->getType().getQualifier().isConstant()) {
|
||||||
error(loc, "global const initializers must be constant", "=", "'%s'",
|
error(loc, "global const initializers must be constant", "=", "'%s'",
|
||||||
variable->getType().getCompleteString().c_str());
|
variable->getType().getCompleteString(intermediate.getEnhancedMsgs()).c_str());
|
||||||
variable->getWritableType().getQualifier().makeTemporary();
|
variable->getWritableType().getQualifier().makeTemporary();
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
@ -7500,7 +7599,7 @@ TIntermNode* TParseContext::executeInitializer(const TSourceLoc& loc, TIntermTyp
|
|||||||
TIntermSymbol* intermSymbol = intermediate.addSymbol(*variable, loc);
|
TIntermSymbol* intermSymbol = intermediate.addSymbol(*variable, loc);
|
||||||
TIntermTyped* initNode = intermediate.addAssign(EOpAssign, intermSymbol, initializer, loc);
|
TIntermTyped* initNode = intermediate.addAssign(EOpAssign, intermSymbol, initializer, loc);
|
||||||
if (! initNode)
|
if (! initNode)
|
||||||
assignError(loc, "=", intermSymbol->getCompleteString(), initializer->getCompleteString());
|
assignError(loc, "=", intermSymbol->getCompleteString(intermediate.getEnhancedMsgs()), initializer->getCompleteString(intermediate.getEnhancedMsgs()));
|
||||||
|
|
||||||
return initNode;
|
return initNode;
|
||||||
}
|
}
|
||||||
@ -7571,7 +7670,7 @@ TIntermTyped* TParseContext::convertInitializerList(const TSourceLoc& loc, const
|
|||||||
}
|
}
|
||||||
} else if (type.isMatrix()) {
|
} else if (type.isMatrix()) {
|
||||||
if (type.getMatrixCols() != (int)initList->getSequence().size()) {
|
if (type.getMatrixCols() != (int)initList->getSequence().size()) {
|
||||||
error(loc, "wrong number of matrix columns:", "initializer list", type.getCompleteString().c_str());
|
error(loc, "wrong number of matrix columns:", "initializer list", type.getCompleteString(intermediate.getEnhancedMsgs()).c_str());
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
TType vectorType(type, 0); // dereferenced type
|
TType vectorType(type, 0); // dereferenced type
|
||||||
@ -7582,20 +7681,20 @@ TIntermTyped* TParseContext::convertInitializerList(const TSourceLoc& loc, const
|
|||||||
}
|
}
|
||||||
} else if (type.isVector()) {
|
} else if (type.isVector()) {
|
||||||
if (type.getVectorSize() != (int)initList->getSequence().size()) {
|
if (type.getVectorSize() != (int)initList->getSequence().size()) {
|
||||||
error(loc, "wrong vector size (or rows in a matrix column):", "initializer list", type.getCompleteString().c_str());
|
error(loc, "wrong vector size (or rows in a matrix column):", "initializer list", type.getCompleteString(intermediate.getEnhancedMsgs()).c_str());
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
TBasicType destType = type.getBasicType();
|
TBasicType destType = type.getBasicType();
|
||||||
for (int i = 0; i < type.getVectorSize(); ++i) {
|
for (int i = 0; i < type.getVectorSize(); ++i) {
|
||||||
TBasicType initType = initList->getSequence()[i]->getAsTyped()->getBasicType();
|
TBasicType initType = initList->getSequence()[i]->getAsTyped()->getBasicType();
|
||||||
if (destType != initType && !intermediate.canImplicitlyPromote(initType, destType)) {
|
if (destType != initType && !intermediate.canImplicitlyPromote(initType, destType)) {
|
||||||
error(loc, "type mismatch in initializer list", "initializer list", type.getCompleteString().c_str());
|
error(loc, "type mismatch in initializer list", "initializer list", type.getCompleteString(intermediate.getEnhancedMsgs()).c_str());
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
error(loc, "unexpected initializer-list type:", "initializer list", type.getCompleteString().c_str());
|
error(loc, "unexpected initializer-list type:", "initializer list", type.getCompleteString(intermediate.getEnhancedMsgs()).c_str());
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -8059,12 +8158,12 @@ TIntermTyped* TParseContext::constructBuiltIn(const TType& type, TOperator op, T
|
|||||||
case EOpConstructAccStruct:
|
case EOpConstructAccStruct:
|
||||||
if ((node->getType().isScalar() && node->getType().getBasicType() == EbtUint64)) {
|
if ((node->getType().isScalar() && node->getType().getBasicType() == EbtUint64)) {
|
||||||
// construct acceleration structure from uint64
|
// construct acceleration structure from uint64
|
||||||
requireExtensions(loc, 1, &E_GL_EXT_ray_tracing, "uint64_t conversion to acclerationStructureEXT");
|
requireExtensions(loc, Num_ray_tracing_EXTs, ray_tracing_EXTs, "uint64_t conversion to acclerationStructureEXT");
|
||||||
return intermediate.addBuiltInFunctionCall(node->getLoc(), EOpConvUint64ToAccStruct, true, node,
|
return intermediate.addBuiltInFunctionCall(node->getLoc(), EOpConvUint64ToAccStruct, true, node,
|
||||||
type);
|
type);
|
||||||
} else if (node->getType().isVector() && node->getType().getBasicType() == EbtUint && node->getVectorSize() == 2) {
|
} else if (node->getType().isVector() && node->getType().getBasicType() == EbtUint && node->getVectorSize() == 2) {
|
||||||
// construct acceleration structure from uint64
|
// construct acceleration structure from uint64
|
||||||
requireExtensions(loc, 1, &E_GL_EXT_ray_tracing, "uvec2 conversion to accelerationStructureEXT");
|
requireExtensions(loc, Num_ray_tracing_EXTs, ray_tracing_EXTs, "uvec2 conversion to accelerationStructureEXT");
|
||||||
return intermediate.addBuiltInFunctionCall(node->getLoc(), EOpConvUvec2ToAccStruct, true, node,
|
return intermediate.addBuiltInFunctionCall(node->getLoc(), EOpConvUvec2ToAccStruct, true, node,
|
||||||
type);
|
type);
|
||||||
} else
|
} else
|
||||||
@ -8103,8 +8202,9 @@ TIntermTyped* TParseContext::constructAggregate(TIntermNode* node, const TType&
|
|||||||
{
|
{
|
||||||
TIntermTyped* converted = intermediate.addConversion(EOpConstructStruct, type, node->getAsTyped());
|
TIntermTyped* converted = intermediate.addConversion(EOpConstructStruct, type, node->getAsTyped());
|
||||||
if (! converted || converted->getType() != type) {
|
if (! converted || converted->getType() != type) {
|
||||||
|
bool enhanced = intermediate.getEnhancedMsgs();
|
||||||
error(loc, "", "constructor", "cannot convert parameter %d from '%s' to '%s'", paramCount,
|
error(loc, "", "constructor", "cannot convert parameter %d from '%s' to '%s'", paramCount,
|
||||||
node->getAsTyped()->getType().getCompleteString().c_str(), type.getCompleteString().c_str());
|
node->getAsTyped()->getType().getCompleteString(enhanced).c_str(), type.getCompleteString(enhanced).c_str());
|
||||||
|
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
@ -8163,6 +8263,8 @@ void TParseContext::declareBlock(const TSourceLoc& loc, TTypeList& typeList, con
|
|||||||
memberQualifier.perViewNV = currentBlockQualifier.perViewNV;
|
memberQualifier.perViewNV = currentBlockQualifier.perViewNV;
|
||||||
if (currentBlockQualifier.perTaskNV)
|
if (currentBlockQualifier.perTaskNV)
|
||||||
memberQualifier.perTaskNV = currentBlockQualifier.perTaskNV;
|
memberQualifier.perTaskNV = currentBlockQualifier.perTaskNV;
|
||||||
|
if (currentBlockQualifier.storage == EvqtaskPayloadSharedEXT)
|
||||||
|
memberQualifier.storage = EvqtaskPayloadSharedEXT;
|
||||||
if (memberQualifier.storage == EvqSpirvStorageClass)
|
if (memberQualifier.storage == EvqSpirvStorageClass)
|
||||||
error(memberLoc, "member cannot have a spirv_storage_class qualifier", memberType.getFieldName().c_str(), "");
|
error(memberLoc, "member cannot have a spirv_storage_class qualifier", memberType.getFieldName().c_str(), "");
|
||||||
if (memberQualifier.hasSprivDecorate() && !memberQualifier.getSpirvDecorate().decorateIds.empty())
|
if (memberQualifier.hasSprivDecorate() && !memberQualifier.getSpirvDecorate().decorateIds.empty())
|
||||||
@ -8463,23 +8565,23 @@ void TParseContext::blockStageIoCheck(const TSourceLoc& loc, const TQualifier& q
|
|||||||
// It is a compile-time error to have an input block in a vertex shader or an output block in a fragment shader
|
// It is a compile-time error to have an input block in a vertex shader or an output block in a fragment shader
|
||||||
// "Compute shaders do not permit user-defined input variables..."
|
// "Compute shaders do not permit user-defined input variables..."
|
||||||
requireStage(loc, (EShLanguageMask)(EShLangTessControlMask|EShLangTessEvaluationMask|EShLangGeometryMask|
|
requireStage(loc, (EShLanguageMask)(EShLangTessControlMask|EShLangTessEvaluationMask|EShLangGeometryMask|
|
||||||
EShLangFragmentMask|EShLangMeshNVMask), "input block");
|
EShLangFragmentMask|EShLangMeshMask), "input block");
|
||||||
if (language == EShLangFragment) {
|
if (language == EShLangFragment) {
|
||||||
profileRequires(loc, EEsProfile, 320, Num_AEP_shader_io_blocks, AEP_shader_io_blocks, "fragment input block");
|
profileRequires(loc, EEsProfile, 320, Num_AEP_shader_io_blocks, AEP_shader_io_blocks, "fragment input block");
|
||||||
} else if (language == EShLangMeshNV && ! qualifier.isTaskMemory()) {
|
} else if (language == EShLangMesh && ! qualifier.isTaskMemory()) {
|
||||||
error(loc, "input blocks cannot be used in a mesh shader", "out", "");
|
error(loc, "input blocks cannot be used in a mesh shader", "out", "");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case EvqVaryingOut:
|
case EvqVaryingOut:
|
||||||
profileRequires(loc, ~EEsProfile, 150, E_GL_ARB_separate_shader_objects, "output block");
|
profileRequires(loc, ~EEsProfile, 150, E_GL_ARB_separate_shader_objects, "output block");
|
||||||
requireStage(loc, (EShLanguageMask)(EShLangVertexMask|EShLangTessControlMask|EShLangTessEvaluationMask|
|
requireStage(loc, (EShLanguageMask)(EShLangVertexMask|EShLangTessControlMask|EShLangTessEvaluationMask|
|
||||||
EShLangGeometryMask|EShLangMeshNVMask|EShLangTaskNVMask), "output block");
|
EShLangGeometryMask|EShLangMeshMask|EShLangTaskMask), "output block");
|
||||||
// ES 310 can have a block before shader_io is turned on, so skip this test for built-ins
|
// ES 310 can have a block before shader_io is turned on, so skip this test for built-ins
|
||||||
if (language == EShLangVertex && ! parsingBuiltins) {
|
if (language == EShLangVertex && ! parsingBuiltins) {
|
||||||
profileRequires(loc, EEsProfile, 320, Num_AEP_shader_io_blocks, AEP_shader_io_blocks, "vertex output block");
|
profileRequires(loc, EEsProfile, 320, Num_AEP_shader_io_blocks, AEP_shader_io_blocks, "vertex output block");
|
||||||
} else if (language == EShLangMeshNV && qualifier.isTaskMemory()) {
|
} else if (language == EShLangMesh && qualifier.isTaskMemory()) {
|
||||||
error(loc, "can only use on input blocks in mesh shader", "taskNV", "");
|
error(loc, "can only use on input blocks in mesh shader", "taskNV", "");
|
||||||
} else if (language == EShLangTaskNV && ! qualifier.isTaskMemory()) {
|
} else if (language == EShLangTask && ! qualifier.isTaskMemory()) {
|
||||||
error(loc, "output blocks cannot be used in a task shader", "out", "");
|
error(loc, "output blocks cannot be used in a task shader", "out", "");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -8893,7 +8995,7 @@ void TParseContext::updateStandaloneQualifierDefaults(const TSourceLoc& loc, con
|
|||||||
{
|
{
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
if (publicType.shaderQualifiers.vertices != TQualifier::layoutNotSet) {
|
if (publicType.shaderQualifiers.vertices != TQualifier::layoutNotSet) {
|
||||||
assert(language == EShLangTessControl || language == EShLangGeometry || language == EShLangMeshNV);
|
assert(language == EShLangTessControl || language == EShLangGeometry || language == EShLangMesh);
|
||||||
const char* id = (language == EShLangTessControl) ? "vertices" : "max_vertices";
|
const char* id = (language == EShLangTessControl) ? "vertices" : "max_vertices";
|
||||||
|
|
||||||
if (publicType.qualifier.storage != EvqVaryingOut)
|
if (publicType.qualifier.storage != EvqVaryingOut)
|
||||||
@ -8905,7 +9007,7 @@ void TParseContext::updateStandaloneQualifierDefaults(const TSourceLoc& loc, con
|
|||||||
checkIoArraysConsistency(loc);
|
checkIoArraysConsistency(loc);
|
||||||
}
|
}
|
||||||
if (publicType.shaderQualifiers.primitives != TQualifier::layoutNotSet) {
|
if (publicType.shaderQualifiers.primitives != TQualifier::layoutNotSet) {
|
||||||
assert(language == EShLangMeshNV);
|
assert(language == EShLangMesh);
|
||||||
const char* id = "max_primitives";
|
const char* id = "max_primitives";
|
||||||
|
|
||||||
if (publicType.qualifier.storage != EvqVaryingOut)
|
if (publicType.qualifier.storage != EvqVaryingOut)
|
||||||
@ -8929,7 +9031,7 @@ void TParseContext::updateStandaloneQualifierDefaults(const TSourceLoc& loc, con
|
|||||||
case ElgTrianglesAdjacency:
|
case ElgTrianglesAdjacency:
|
||||||
case ElgQuads:
|
case ElgQuads:
|
||||||
case ElgIsolines:
|
case ElgIsolines:
|
||||||
if (language == EShLangMeshNV) {
|
if (language == EShLangMesh) {
|
||||||
error(loc, "cannot apply to input", TQualifier::getGeometryString(publicType.shaderQualifiers.geometry), "");
|
error(loc, "cannot apply to input", TQualifier::getGeometryString(publicType.shaderQualifiers.geometry), "");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -8946,7 +9048,7 @@ void TParseContext::updateStandaloneQualifierDefaults(const TSourceLoc& loc, con
|
|||||||
switch (publicType.shaderQualifiers.geometry) {
|
switch (publicType.shaderQualifiers.geometry) {
|
||||||
case ElgLines:
|
case ElgLines:
|
||||||
case ElgTriangles:
|
case ElgTriangles:
|
||||||
if (language != EShLangMeshNV) {
|
if (language != EShLangMesh) {
|
||||||
error(loc, "cannot apply to 'out'", TQualifier::getGeometryString(publicType.shaderQualifiers.geometry), "");
|
error(loc, "cannot apply to 'out'", TQualifier::getGeometryString(publicType.shaderQualifiers.geometry), "");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -9002,24 +9104,56 @@ void TParseContext::updateStandaloneQualifierDefaults(const TSourceLoc& loc, con
|
|||||||
error(loc, "too large; see gl_MaxComputeWorkGroupSize", "local_size", "");
|
error(loc, "too large; see gl_MaxComputeWorkGroupSize", "local_size", "");
|
||||||
}
|
}
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
else if (language == EShLangMeshNV) {
|
else if (language == EShLangMesh) {
|
||||||
switch (i) {
|
switch (i) {
|
||||||
case 0: max = resources.maxMeshWorkGroupSizeX_NV; break;
|
case 0:
|
||||||
case 1: max = resources.maxMeshWorkGroupSizeY_NV; break;
|
max = extensionTurnedOn(E_GL_EXT_mesh_shader) ?
|
||||||
case 2: max = resources.maxMeshWorkGroupSizeZ_NV; break;
|
resources.maxMeshWorkGroupSizeX_EXT :
|
||||||
|
resources.maxMeshWorkGroupSizeX_NV;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
max = extensionTurnedOn(E_GL_EXT_mesh_shader) ?
|
||||||
|
resources.maxMeshWorkGroupSizeY_EXT :
|
||||||
|
resources.maxMeshWorkGroupSizeY_NV ;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
max = extensionTurnedOn(E_GL_EXT_mesh_shader) ?
|
||||||
|
resources.maxMeshWorkGroupSizeZ_EXT :
|
||||||
|
resources.maxMeshWorkGroupSizeZ_NV ;
|
||||||
|
break;
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
if (intermediate.getLocalSize(i) > (unsigned int)max)
|
if (intermediate.getLocalSize(i) > (unsigned int)max) {
|
||||||
error(loc, "too large; see gl_MaxMeshWorkGroupSizeNV", "local_size", "");
|
TString maxsErrtring = "too large, see ";
|
||||||
} else if (language == EShLangTaskNV) {
|
maxsErrtring.append(extensionTurnedOn(E_GL_EXT_mesh_shader) ?
|
||||||
|
"gl_MaxMeshWorkGroupSizeEXT" : "gl_MaxMeshWorkGroupSizeNV");
|
||||||
|
error(loc, maxsErrtring.c_str(), "local_size", "");
|
||||||
|
}
|
||||||
|
} else if (language == EShLangTask) {
|
||||||
switch (i) {
|
switch (i) {
|
||||||
case 0: max = resources.maxTaskWorkGroupSizeX_NV; break;
|
case 0:
|
||||||
case 1: max = resources.maxTaskWorkGroupSizeY_NV; break;
|
max = extensionTurnedOn(E_GL_EXT_mesh_shader) ?
|
||||||
case 2: max = resources.maxTaskWorkGroupSizeZ_NV; break;
|
resources.maxTaskWorkGroupSizeX_EXT :
|
||||||
|
resources.maxTaskWorkGroupSizeX_NV;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
max = extensionTurnedOn(E_GL_EXT_mesh_shader) ?
|
||||||
|
resources.maxTaskWorkGroupSizeY_EXT:
|
||||||
|
resources.maxTaskWorkGroupSizeY_NV;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
max = extensionTurnedOn(E_GL_EXT_mesh_shader) ?
|
||||||
|
resources.maxTaskWorkGroupSizeZ_EXT:
|
||||||
|
resources.maxTaskWorkGroupSizeZ_NV;
|
||||||
|
break;
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
if (intermediate.getLocalSize(i) > (unsigned int)max)
|
if (intermediate.getLocalSize(i) > (unsigned int)max) {
|
||||||
error(loc, "too large; see gl_MaxTaskWorkGroupSizeNV", "local_size", "");
|
TString maxsErrtring = "too large, see ";
|
||||||
|
maxsErrtring.append(extensionTurnedOn(E_GL_EXT_mesh_shader) ?
|
||||||
|
"gl_MaxTaskWorkGroupSizeEXT" : "gl_MaxTaskWorkGroupSizeNV");
|
||||||
|
error(loc, maxsErrtring.c_str(), "local_size", "");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
else {
|
else {
|
||||||
@ -9054,6 +9188,12 @@ void TParseContext::updateStandaloneQualifierDefaults(const TSourceLoc& loc, con
|
|||||||
else
|
else
|
||||||
error(loc, "can only apply to 'in'", "early_fragment_tests", "");
|
error(loc, "can only apply to 'in'", "early_fragment_tests", "");
|
||||||
}
|
}
|
||||||
|
if (publicType.shaderQualifiers.earlyAndLateFragmentTestsAMD) {
|
||||||
|
if (publicType.qualifier.storage == EvqVaryingIn)
|
||||||
|
intermediate.setEarlyAndLateFragmentTestsAMD();
|
||||||
|
else
|
||||||
|
error(loc, "can only apply to 'in'", "early_and_late_fragment_tests_amd", "");
|
||||||
|
}
|
||||||
if (publicType.shaderQualifiers.postDepthCoverage) {
|
if (publicType.shaderQualifiers.postDepthCoverage) {
|
||||||
if (publicType.qualifier.storage == EvqVaryingIn)
|
if (publicType.qualifier.storage == EvqVaryingIn)
|
||||||
intermediate.setPostDepthCoverage();
|
intermediate.setPostDepthCoverage();
|
||||||
@ -9102,7 +9242,7 @@ void TParseContext::updateStandaloneQualifierDefaults(const TSourceLoc& loc, con
|
|||||||
error(loc, "can only apply to 'in'", "derivative_group_linearNV", "");
|
error(loc, "can only apply to 'in'", "derivative_group_linearNV", "");
|
||||||
}
|
}
|
||||||
// Check mesh out array sizes, once all the necessary out qualifiers are defined.
|
// Check mesh out array sizes, once all the necessary out qualifiers are defined.
|
||||||
if ((language == EShLangMeshNV) &&
|
if ((language == EShLangMesh) &&
|
||||||
(intermediate.getVertices() != TQualifier::layoutNotSet) &&
|
(intermediate.getVertices() != TQualifier::layoutNotSet) &&
|
||||||
(intermediate.getPrimitives() != TQualifier::layoutNotSet) &&
|
(intermediate.getPrimitives() != TQualifier::layoutNotSet) &&
|
||||||
(intermediate.getOutputPrimitive() != ElgNone))
|
(intermediate.getOutputPrimitive() != ElgNone))
|
||||||
@ -9119,7 +9259,7 @@ void TParseContext::updateStandaloneQualifierDefaults(const TSourceLoc& loc, con
|
|||||||
// Exit early as further checks are not valid
|
// Exit early as further checks are not valid
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
const TQualifier& qualifier = publicType.qualifier;
|
const TQualifier& qualifier = publicType.qualifier;
|
||||||
|
|
||||||
if (qualifier.isAuxiliary() ||
|
if (qualifier.isAuxiliary() ||
|
||||||
@ -9317,4 +9457,3 @@ const TTypeList* TParseContext::recordStructCopy(TStructRecord& record, const TT
|
|||||||
}
|
}
|
||||||
|
|
||||||
} // end namespace glslang
|
} // end namespace glslang
|
||||||
|
|
||||||
|
@ -739,6 +739,7 @@ void TScanContext::fillInKeywordMap()
|
|||||||
(*KeywordMap)["f16subpassInputMS"] = F16SUBPASSINPUTMS;
|
(*KeywordMap)["f16subpassInputMS"] = F16SUBPASSINPUTMS;
|
||||||
(*KeywordMap)["__explicitInterpAMD"] = EXPLICITINTERPAMD;
|
(*KeywordMap)["__explicitInterpAMD"] = EXPLICITINTERPAMD;
|
||||||
(*KeywordMap)["pervertexNV"] = PERVERTEXNV;
|
(*KeywordMap)["pervertexNV"] = PERVERTEXNV;
|
||||||
|
(*KeywordMap)["pervertexEXT"] = PERVERTEXEXT;
|
||||||
(*KeywordMap)["precise"] = PRECISE;
|
(*KeywordMap)["precise"] = PRECISE;
|
||||||
|
|
||||||
(*KeywordMap)["rayPayloadNV"] = PAYLOADNV;
|
(*KeywordMap)["rayPayloadNV"] = PAYLOADNV;
|
||||||
@ -757,6 +758,8 @@ void TScanContext::fillInKeywordMap()
|
|||||||
(*KeywordMap)["perprimitiveNV"] = PERPRIMITIVENV;
|
(*KeywordMap)["perprimitiveNV"] = PERPRIMITIVENV;
|
||||||
(*KeywordMap)["perviewNV"] = PERVIEWNV;
|
(*KeywordMap)["perviewNV"] = PERVIEWNV;
|
||||||
(*KeywordMap)["taskNV"] = PERTASKNV;
|
(*KeywordMap)["taskNV"] = PERTASKNV;
|
||||||
|
(*KeywordMap)["perprimitiveEXT"] = PERPRIMITIVEEXT;
|
||||||
|
(*KeywordMap)["taskPayloadSharedEXT"] = TASKPAYLOADWORKGROUPEXT;
|
||||||
|
|
||||||
(*KeywordMap)["fcoopmatNV"] = FCOOPMATNV;
|
(*KeywordMap)["fcoopmatNV"] = FCOOPMATNV;
|
||||||
(*KeywordMap)["icoopmatNV"] = ICOOPMATNV;
|
(*KeywordMap)["icoopmatNV"] = ICOOPMATNV;
|
||||||
@ -1719,6 +1722,12 @@ int TScanContext::tokenizeIdentifier()
|
|||||||
return keyword;
|
return keyword;
|
||||||
return identifierOrType();
|
return identifierOrType();
|
||||||
|
|
||||||
|
case PERVERTEXEXT:
|
||||||
|
if ((!parseContext.isEsProfile() && parseContext.version >= 450) ||
|
||||||
|
parseContext.extensionTurnedOn(E_GL_EXT_fragment_shader_barycentric))
|
||||||
|
return keyword;
|
||||||
|
return identifierOrType();
|
||||||
|
|
||||||
case PRECISE:
|
case PRECISE:
|
||||||
if ((parseContext.isEsProfile() &&
|
if ((parseContext.isEsProfile() &&
|
||||||
(parseContext.version >= 320 || parseContext.extensionsTurnedOn(Num_AEP_gpu_shader5, AEP_gpu_shader5))) ||
|
(parseContext.version >= 320 || parseContext.extensionsTurnedOn(Num_AEP_gpu_shader5, AEP_gpu_shader5))) ||
|
||||||
@ -1733,12 +1742,18 @@ int TScanContext::tokenizeIdentifier()
|
|||||||
case PERPRIMITIVENV:
|
case PERPRIMITIVENV:
|
||||||
case PERVIEWNV:
|
case PERVIEWNV:
|
||||||
case PERTASKNV:
|
case PERTASKNV:
|
||||||
if ((!parseContext.isEsProfile() && parseContext.version >= 450) ||
|
if (parseContext.symbolTable.atBuiltInLevel() ||
|
||||||
(parseContext.isEsProfile() && parseContext.version >= 320) ||
|
|
||||||
parseContext.extensionTurnedOn(E_GL_NV_mesh_shader))
|
parseContext.extensionTurnedOn(E_GL_NV_mesh_shader))
|
||||||
return keyword;
|
return keyword;
|
||||||
return identifierOrType();
|
return identifierOrType();
|
||||||
|
|
||||||
|
case PERPRIMITIVEEXT:
|
||||||
|
case TASKPAYLOADWORKGROUPEXT:
|
||||||
|
if (parseContext.symbolTable.atBuiltInLevel() ||
|
||||||
|
parseContext.extensionTurnedOn(E_GL_EXT_mesh_shader))
|
||||||
|
return keyword;
|
||||||
|
return identifierOrType();
|
||||||
|
|
||||||
case FCOOPMATNV:
|
case FCOOPMATNV:
|
||||||
afterType = true;
|
afterType = true;
|
||||||
if (parseContext.symbolTable.atBuiltInLevel() ||
|
if (parseContext.symbolTable.atBuiltInLevel() ||
|
||||||
|
@ -391,13 +391,13 @@ bool InitializeSymbolTables(TInfoSink& infoSink, TSymbolTable** commonTable, TS
|
|||||||
// check for mesh
|
// check for mesh
|
||||||
if ((profile != EEsProfile && version >= 450) ||
|
if ((profile != EEsProfile && version >= 450) ||
|
||||||
(profile == EEsProfile && version >= 320))
|
(profile == EEsProfile && version >= 320))
|
||||||
InitializeStageSymbolTable(*builtInParseables, version, profile, spvVersion, EShLangMeshNV, source,
|
InitializeStageSymbolTable(*builtInParseables, version, profile, spvVersion, EShLangMesh, source,
|
||||||
infoSink, commonTable, symbolTables);
|
infoSink, commonTable, symbolTables);
|
||||||
|
|
||||||
// check for task
|
// check for task
|
||||||
if ((profile != EEsProfile && version >= 450) ||
|
if ((profile != EEsProfile && version >= 450) ||
|
||||||
(profile == EEsProfile && version >= 320))
|
(profile == EEsProfile && version >= 320))
|
||||||
InitializeStageSymbolTable(*builtInParseables, version, profile, spvVersion, EShLangTaskNV, source,
|
InitializeStageSymbolTable(*builtInParseables, version, profile, spvVersion, EShLangTask, source,
|
||||||
infoSink, commonTable, symbolTables);
|
infoSink, commonTable, symbolTables);
|
||||||
#endif // !GLSLANG_ANGLE
|
#endif // !GLSLANG_ANGLE
|
||||||
#endif // !GLSLANG_WEB
|
#endif // !GLSLANG_WEB
|
||||||
@ -650,8 +650,8 @@ bool DeduceVersionProfile(TInfoSink& infoSink, EShLanguage stage, bool versionNo
|
|||||||
version = 460;
|
version = 460;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case EShLangMeshNV:
|
case EShLangMesh:
|
||||||
case EShLangTaskNV:
|
case EShLangTask:
|
||||||
if ((profile == EEsProfile && version < 320) ||
|
if ((profile == EEsProfile && version < 320) ||
|
||||||
(profile != EEsProfile && version < 450)) {
|
(profile != EEsProfile && version < 450)) {
|
||||||
correct = false;
|
correct = false;
|
||||||
@ -813,6 +813,7 @@ bool ProcessDeferred(
|
|||||||
// set version/profile to defaultVersion/defaultProfile regardless of the #version
|
// set version/profile to defaultVersion/defaultProfile regardless of the #version
|
||||||
// directive in the source code
|
// directive in the source code
|
||||||
bool forceDefaultVersionAndProfile,
|
bool forceDefaultVersionAndProfile,
|
||||||
|
int overrideVersion, // overrides version specified by #verison or default version
|
||||||
bool forwardCompatible, // give errors for use of deprecated features
|
bool forwardCompatible, // give errors for use of deprecated features
|
||||||
EShMessages messages, // warnings/errors/AST; things to print out
|
EShMessages messages, // warnings/errors/AST; things to print out
|
||||||
TIntermediate& intermediate, // returned tree, etc.
|
TIntermediate& intermediate, // returned tree, etc.
|
||||||
@ -900,6 +901,9 @@ bool ProcessDeferred(
|
|||||||
version = defaultVersion;
|
version = defaultVersion;
|
||||||
profile = defaultProfile;
|
profile = defaultProfile;
|
||||||
}
|
}
|
||||||
|
if (source == EShSourceGlsl && overrideVersion != 0) {
|
||||||
|
version = overrideVersion;
|
||||||
|
}
|
||||||
|
|
||||||
bool goodVersion = DeduceVersionProfile(compiler->infoSink, stage,
|
bool goodVersion = DeduceVersionProfile(compiler->infoSink, stage,
|
||||||
versionNotFirst, defaultVersion, source, version, profile, spvVersion);
|
versionNotFirst, defaultVersion, source, version, profile, spvVersion);
|
||||||
@ -1275,6 +1279,7 @@ bool PreprocessDeferred(
|
|||||||
int defaultVersion, // use 100 for ES environment, 110 for desktop
|
int defaultVersion, // use 100 for ES environment, 110 for desktop
|
||||||
EProfile defaultProfile,
|
EProfile defaultProfile,
|
||||||
bool forceDefaultVersionAndProfile,
|
bool forceDefaultVersionAndProfile,
|
||||||
|
int overrideVersion, // use 0 if not overriding GLSL version
|
||||||
bool forwardCompatible, // give errors for use of deprecated features
|
bool forwardCompatible, // give errors for use of deprecated features
|
||||||
EShMessages messages, // warnings/errors/AST; things to print out
|
EShMessages messages, // warnings/errors/AST; things to print out
|
||||||
TShader::Includer& includer,
|
TShader::Includer& includer,
|
||||||
@ -1285,7 +1290,7 @@ bool PreprocessDeferred(
|
|||||||
DoPreprocessing parser(outputString);
|
DoPreprocessing parser(outputString);
|
||||||
return ProcessDeferred(compiler, shaderStrings, numStrings, inputLengths, stringNames,
|
return ProcessDeferred(compiler, shaderStrings, numStrings, inputLengths, stringNames,
|
||||||
preamble, optLevel, resources, defaultVersion,
|
preamble, optLevel, resources, defaultVersion,
|
||||||
defaultProfile, forceDefaultVersionAndProfile,
|
defaultProfile, forceDefaultVersionAndProfile, overrideVersion,
|
||||||
forwardCompatible, messages, intermediate, parser,
|
forwardCompatible, messages, intermediate, parser,
|
||||||
false, includer, "", environment);
|
false, includer, "", environment);
|
||||||
}
|
}
|
||||||
@ -1314,6 +1319,7 @@ bool CompileDeferred(
|
|||||||
int defaultVersion, // use 100 for ES environment, 110 for desktop
|
int defaultVersion, // use 100 for ES environment, 110 for desktop
|
||||||
EProfile defaultProfile,
|
EProfile defaultProfile,
|
||||||
bool forceDefaultVersionAndProfile,
|
bool forceDefaultVersionAndProfile,
|
||||||
|
int overrideVersion, // use 0 if not overriding GLSL version
|
||||||
bool forwardCompatible, // give errors for use of deprecated features
|
bool forwardCompatible, // give errors for use of deprecated features
|
||||||
EShMessages messages, // warnings/errors/AST; things to print out
|
EShMessages messages, // warnings/errors/AST; things to print out
|
||||||
TIntermediate& intermediate,// returned tree, etc.
|
TIntermediate& intermediate,// returned tree, etc.
|
||||||
@ -1324,7 +1330,7 @@ bool CompileDeferred(
|
|||||||
DoFullParse parser;
|
DoFullParse parser;
|
||||||
return ProcessDeferred(compiler, shaderStrings, numStrings, inputLengths, stringNames,
|
return ProcessDeferred(compiler, shaderStrings, numStrings, inputLengths, stringNames,
|
||||||
preamble, optLevel, resources, defaultVersion,
|
preamble, optLevel, resources, defaultVersion,
|
||||||
defaultProfile, forceDefaultVersionAndProfile,
|
defaultProfile, forceDefaultVersionAndProfile, overrideVersion,
|
||||||
forwardCompatible, messages, intermediate, parser,
|
forwardCompatible, messages, intermediate, parser,
|
||||||
true, includer, sourceEntryPointName, environment);
|
true, includer, sourceEntryPointName, environment);
|
||||||
}
|
}
|
||||||
@ -1498,7 +1504,7 @@ int ShCompile(
|
|||||||
TIntermediate intermediate(compiler->getLanguage());
|
TIntermediate intermediate(compiler->getLanguage());
|
||||||
TShader::ForbidIncluder includer;
|
TShader::ForbidIncluder includer;
|
||||||
bool success = CompileDeferred(compiler, shaderStrings, numStrings, inputLengths, nullptr,
|
bool success = CompileDeferred(compiler, shaderStrings, numStrings, inputLengths, nullptr,
|
||||||
"", optLevel, resources, defaultVersion, ENoProfile, false,
|
"", optLevel, resources, defaultVersion, ENoProfile, false, 0,
|
||||||
forwardCompatible, messages, intermediate, includer);
|
forwardCompatible, messages, intermediate, includer);
|
||||||
|
|
||||||
//
|
//
|
||||||
@ -1759,7 +1765,7 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
TShader::TShader(EShLanguage s)
|
TShader::TShader(EShLanguage s)
|
||||||
: stage(s), lengths(nullptr), stringNames(nullptr), preamble("")
|
: stage(s), lengths(nullptr), stringNames(nullptr), preamble(""), overrideVersion(0)
|
||||||
{
|
{
|
||||||
pool = new TPoolAllocator;
|
pool = new TPoolAllocator;
|
||||||
infoSink = new TInfoSink;
|
infoSink = new TInfoSink;
|
||||||
@ -1828,8 +1834,15 @@ void TShader::setUniqueId(unsigned long long id)
|
|||||||
intermediate->setUniqueId(id);
|
intermediate->setUniqueId(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TShader::setOverrideVersion(int version)
|
||||||
|
{
|
||||||
|
overrideVersion = version;
|
||||||
|
}
|
||||||
|
|
||||||
|
void TShader::setDebugInfo(bool debugInfo) { intermediate->setDebugInfo(debugInfo); }
|
||||||
void TShader::setInvertY(bool invert) { intermediate->setInvertY(invert); }
|
void TShader::setInvertY(bool invert) { intermediate->setInvertY(invert); }
|
||||||
void TShader::setDxPositionW(bool invert) { intermediate->setDxPositionW(invert); }
|
void TShader::setDxPositionW(bool invert) { intermediate->setDxPositionW(invert); }
|
||||||
|
void TShader::setEnhancedMsgs() { intermediate->setEnhancedMsgs(); }
|
||||||
void TShader::setNanMinMaxClamp(bool useNonNan) { intermediate->setNanMinMaxClamp(useNonNan); }
|
void TShader::setNanMinMaxClamp(bool useNonNan) { intermediate->setNanMinMaxClamp(useNonNan); }
|
||||||
|
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
@ -1909,7 +1922,7 @@ bool TShader::parse(const TBuiltInResource* builtInResources, int defaultVersion
|
|||||||
|
|
||||||
return CompileDeferred(compiler, strings, numStrings, lengths, stringNames,
|
return CompileDeferred(compiler, strings, numStrings, lengths, stringNames,
|
||||||
preamble, EShOptNone, builtInResources, defaultVersion,
|
preamble, EShOptNone, builtInResources, defaultVersion,
|
||||||
defaultProfile, forceDefaultVersionAndProfile,
|
defaultProfile, forceDefaultVersionAndProfile, overrideVersion,
|
||||||
forwardCompatible, messages, *intermediate, includer, sourceEntryPointName,
|
forwardCompatible, messages, *intermediate, includer, sourceEntryPointName,
|
||||||
&environment);
|
&environment);
|
||||||
}
|
}
|
||||||
@ -1936,7 +1949,7 @@ bool TShader::preprocess(const TBuiltInResource* builtInResources,
|
|||||||
|
|
||||||
return PreprocessDeferred(compiler, strings, numStrings, lengths, stringNames, preamble,
|
return PreprocessDeferred(compiler, strings, numStrings, lengths, stringNames, preamble,
|
||||||
EShOptNone, builtInResources, defaultVersion,
|
EShOptNone, builtInResources, defaultVersion,
|
||||||
defaultProfile, forceDefaultVersionAndProfile,
|
defaultProfile, forceDefaultVersionAndProfile, overrideVersion,
|
||||||
forwardCompatible, message, includer, *intermediate, output_string,
|
forwardCompatible, message, includer, *intermediate, output_string,
|
||||||
&environment);
|
&environment);
|
||||||
}
|
}
|
||||||
@ -2049,6 +2062,8 @@ bool TProgram::linkStage(EShLanguage stage, EShMessages messages)
|
|||||||
firstIntermediate->getVersion(),
|
firstIntermediate->getVersion(),
|
||||||
firstIntermediate->getProfile());
|
firstIntermediate->getProfile());
|
||||||
intermediate[stage]->setLimits(firstIntermediate->getLimits());
|
intermediate[stage]->setLimits(firstIntermediate->getLimits());
|
||||||
|
if (firstIntermediate->getEnhancedMsgs())
|
||||||
|
intermediate[stage]->setEnhancedMsgs();
|
||||||
|
|
||||||
// The new TIntermediate must use the same origin as the original TIntermediates.
|
// The new TIntermediate must use the same origin as the original TIntermediates.
|
||||||
// Otherwise linking will fail due to different coordinate systems.
|
// Otherwise linking will fail due to different coordinate systems.
|
||||||
|
@ -383,7 +383,7 @@ TFunction::TFunction(const TFunction& copyOf) : TSymbol(copyOf)
|
|||||||
for (unsigned int i = 0; i < copyOf.parameters.size(); ++i) {
|
for (unsigned int i = 0; i < copyOf.parameters.size(); ++i) {
|
||||||
TParameter param;
|
TParameter param;
|
||||||
parameters.push_back(param);
|
parameters.push_back(param);
|
||||||
parameters.back().copyParam(copyOf.parameters[i]);
|
(void)parameters.back().copyParam(copyOf.parameters[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
extensions = nullptr;
|
extensions = nullptr;
|
||||||
|
@ -224,7 +224,7 @@ struct TParameter {
|
|||||||
TString *name;
|
TString *name;
|
||||||
TType* type;
|
TType* type;
|
||||||
TIntermTyped* defaultValue;
|
TIntermTyped* defaultValue;
|
||||||
void copyParam(const TParameter& param)
|
TParameter& copyParam(const TParameter& param)
|
||||||
{
|
{
|
||||||
if (param.name)
|
if (param.name)
|
||||||
name = NewPoolTString(param.name->c_str());
|
name = NewPoolTString(param.name->c_str());
|
||||||
@ -232,6 +232,7 @@ struct TParameter {
|
|||||||
name = 0;
|
name = 0;
|
||||||
type = param.type->clone();
|
type = param.type->clone();
|
||||||
defaultValue = param.defaultValue;
|
defaultValue = param.defaultValue;
|
||||||
|
return *this;
|
||||||
}
|
}
|
||||||
TBuiltInVariable getDeclaredBuiltIn() const { return type->getQualifier().declaredBuiltIn; }
|
TBuiltInVariable getDeclaredBuiltIn() const { return type->getQualifier().declaredBuiltIn; }
|
||||||
};
|
};
|
||||||
|
@ -166,7 +166,8 @@ void TParseVersions::initializeExtensionBehavior()
|
|||||||
} extensionData;
|
} extensionData;
|
||||||
|
|
||||||
const extensionData exts[] = { {E_GL_EXT_ray_tracing, EShTargetSpv_1_4},
|
const extensionData exts[] = { {E_GL_EXT_ray_tracing, EShTargetSpv_1_4},
|
||||||
{E_GL_NV_ray_tracing_motion_blur, EShTargetSpv_1_4}
|
{E_GL_NV_ray_tracing_motion_blur, EShTargetSpv_1_4},
|
||||||
|
{E_GL_EXT_mesh_shader, EShTargetSpv_1_4}
|
||||||
};
|
};
|
||||||
|
|
||||||
for (size_t ii = 0; ii < sizeof(exts) / sizeof(exts[0]); ii++) {
|
for (size_t ii = 0; ii < sizeof(exts) / sizeof(exts[0]); ii++) {
|
||||||
@ -259,6 +260,8 @@ void TParseVersions::initializeExtensionBehavior()
|
|||||||
extensionBehavior[E_GL_EXT_shader_8bit_storage] = EBhDisable;
|
extensionBehavior[E_GL_EXT_shader_8bit_storage] = EBhDisable;
|
||||||
extensionBehavior[E_GL_EXT_subgroup_uniform_control_flow] = EBhDisable;
|
extensionBehavior[E_GL_EXT_subgroup_uniform_control_flow] = EBhDisable;
|
||||||
|
|
||||||
|
extensionBehavior[E_GL_EXT_fragment_shader_barycentric] = EBhDisable;
|
||||||
|
|
||||||
// #line and #include
|
// #line and #include
|
||||||
extensionBehavior[E_GL_GOOGLE_cpp_style_line_directive] = EBhDisable;
|
extensionBehavior[E_GL_GOOGLE_cpp_style_line_directive] = EBhDisable;
|
||||||
extensionBehavior[E_GL_GOOGLE_include_directive] = EBhDisable;
|
extensionBehavior[E_GL_GOOGLE_include_directive] = EBhDisable;
|
||||||
@ -273,6 +276,7 @@ void TParseVersions::initializeExtensionBehavior()
|
|||||||
extensionBehavior[E_GL_AMD_shader_image_load_store_lod] = EBhDisable;
|
extensionBehavior[E_GL_AMD_shader_image_load_store_lod] = EBhDisable;
|
||||||
extensionBehavior[E_GL_AMD_shader_fragment_mask] = EBhDisable;
|
extensionBehavior[E_GL_AMD_shader_fragment_mask] = EBhDisable;
|
||||||
extensionBehavior[E_GL_AMD_gpu_shader_half_float_fetch] = EBhDisable;
|
extensionBehavior[E_GL_AMD_gpu_shader_half_float_fetch] = EBhDisable;
|
||||||
|
extensionBehavior[E_GL_AMD_shader_early_and_late_fragment_tests] = EBhDisable;
|
||||||
|
|
||||||
extensionBehavior[E_GL_INTEL_shader_integer_functions2] = EBhDisable;
|
extensionBehavior[E_GL_INTEL_shader_integer_functions2] = EBhDisable;
|
||||||
|
|
||||||
@ -334,13 +338,16 @@ void TParseVersions::initializeExtensionBehavior()
|
|||||||
extensionBehavior[E_GL_EXT_ray_tracing] = EBhDisable;
|
extensionBehavior[E_GL_EXT_ray_tracing] = EBhDisable;
|
||||||
extensionBehavior[E_GL_EXT_ray_query] = EBhDisable;
|
extensionBehavior[E_GL_EXT_ray_query] = EBhDisable;
|
||||||
extensionBehavior[E_GL_EXT_ray_flags_primitive_culling] = EBhDisable;
|
extensionBehavior[E_GL_EXT_ray_flags_primitive_culling] = EBhDisable;
|
||||||
|
extensionBehavior[E_GL_EXT_ray_cull_mask] = EBhDisable;
|
||||||
extensionBehavior[E_GL_EXT_blend_func_extended] = EBhDisable;
|
extensionBehavior[E_GL_EXT_blend_func_extended] = EBhDisable;
|
||||||
extensionBehavior[E_GL_EXT_shader_implicit_conversions] = EBhDisable;
|
extensionBehavior[E_GL_EXT_shader_implicit_conversions] = EBhDisable;
|
||||||
extensionBehavior[E_GL_EXT_fragment_shading_rate] = EBhDisable;
|
extensionBehavior[E_GL_EXT_fragment_shading_rate] = EBhDisable;
|
||||||
extensionBehavior[E_GL_EXT_shader_image_int64] = EBhDisable;
|
extensionBehavior[E_GL_EXT_shader_image_int64] = EBhDisable;
|
||||||
extensionBehavior[E_GL_EXT_terminate_invocation] = EBhDisable;
|
extensionBehavior[E_GL_EXT_terminate_invocation] = EBhDisable;
|
||||||
extensionBehavior[E_GL_EXT_shared_memory_block] = EBhDisable;
|
extensionBehavior[E_GL_EXT_shared_memory_block] = EBhDisable;
|
||||||
extensionBehavior[E_GL_EXT_spirv_intrinsics] = EBhDisable;
|
extensionBehavior[E_GL_EXT_spirv_intrinsics] = EBhDisable;
|
||||||
|
extensionBehavior[E_GL_EXT_mesh_shader] = EBhDisable;
|
||||||
|
extensionBehavior[E_GL_EXT_opacity_micromap] = EBhDisable;
|
||||||
|
|
||||||
// OVR extensions
|
// OVR extensions
|
||||||
extensionBehavior[E_GL_OVR_multiview] = EBhDisable;
|
extensionBehavior[E_GL_OVR_multiview] = EBhDisable;
|
||||||
@ -505,7 +512,9 @@ void TParseVersions::getPreamble(std::string& preamble)
|
|||||||
"#define GL_EXT_ray_tracing 1\n"
|
"#define GL_EXT_ray_tracing 1\n"
|
||||||
"#define GL_EXT_ray_query 1\n"
|
"#define GL_EXT_ray_query 1\n"
|
||||||
"#define GL_EXT_ray_flags_primitive_culling 1\n"
|
"#define GL_EXT_ray_flags_primitive_culling 1\n"
|
||||||
|
"#define GL_EXT_ray_cull_mask 1\n"
|
||||||
"#define GL_EXT_spirv_intrinsics 1\n"
|
"#define GL_EXT_spirv_intrinsics 1\n"
|
||||||
|
"#define GL_EXT_mesh_shader 1\n"
|
||||||
|
|
||||||
"#define GL_AMD_shader_ballot 1\n"
|
"#define GL_AMD_shader_ballot 1\n"
|
||||||
"#define GL_AMD_shader_trinary_minmax 1\n"
|
"#define GL_AMD_shader_trinary_minmax 1\n"
|
||||||
@ -552,6 +561,8 @@ void TParseVersions::getPreamble(std::string& preamble)
|
|||||||
|
|
||||||
"#define GL_EXT_shader_atomic_float 1\n"
|
"#define GL_EXT_shader_atomic_float 1\n"
|
||||||
"#define GL_EXT_shader_atomic_float2 1\n"
|
"#define GL_EXT_shader_atomic_float2 1\n"
|
||||||
|
|
||||||
|
"#define GL_EXT_fragment_shader_barycentric 1\n"
|
||||||
;
|
;
|
||||||
|
|
||||||
if (version >= 150) {
|
if (version >= 150) {
|
||||||
@ -634,8 +645,8 @@ void TParseVersions::getPreamble(std::string& preamble)
|
|||||||
case EShLangClosestHit: preamble += "#define GL_CLOSEST_HIT_SHADER_EXT 1 \n"; break;
|
case EShLangClosestHit: preamble += "#define GL_CLOSEST_HIT_SHADER_EXT 1 \n"; break;
|
||||||
case EShLangMiss: preamble += "#define GL_MISS_SHADER_EXT 1 \n"; break;
|
case EShLangMiss: preamble += "#define GL_MISS_SHADER_EXT 1 \n"; break;
|
||||||
case EShLangCallable: preamble += "#define GL_CALLABLE_SHADER_EXT 1 \n"; break;
|
case EShLangCallable: preamble += "#define GL_CALLABLE_SHADER_EXT 1 \n"; break;
|
||||||
case EShLangTaskNV: preamble += "#define GL_TASK_SHADER_NV 1 \n"; break;
|
case EShLangTask: preamble += "#define GL_TASK_SHADER_NV 1 \n"; break;
|
||||||
case EShLangMeshNV: preamble += "#define GL_MESH_SHADER_NV 1 \n"; break;
|
case EShLangMesh: preamble += "#define GL_MESH_SHADER_NV 1 \n"; break;
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -661,8 +672,8 @@ const char* StageName(EShLanguage stage)
|
|||||||
case EShLangClosestHit: return "closest-hit";
|
case EShLangClosestHit: return "closest-hit";
|
||||||
case EShLangMiss: return "miss";
|
case EShLangMiss: return "miss";
|
||||||
case EShLangCallable: return "callable";
|
case EShLangCallable: return "callable";
|
||||||
case EShLangMeshNV: return "mesh";
|
case EShLangMesh: return "mesh";
|
||||||
case EShLangTaskNV: return "task";
|
case EShLangTask: return "task";
|
||||||
#endif
|
#endif
|
||||||
default: return "unknown stage";
|
default: return "unknown stage";
|
||||||
}
|
}
|
||||||
@ -1053,10 +1064,22 @@ void TParseVersions::checkExtensionStage(const TSourceLoc& loc, const char * con
|
|||||||
{
|
{
|
||||||
// GL_NV_mesh_shader extension is only allowed in task/mesh shaders
|
// GL_NV_mesh_shader extension is only allowed in task/mesh shaders
|
||||||
if (strcmp(extension, "GL_NV_mesh_shader") == 0) {
|
if (strcmp(extension, "GL_NV_mesh_shader") == 0) {
|
||||||
requireStage(loc, (EShLanguageMask)(EShLangTaskNVMask | EShLangMeshNVMask | EShLangFragmentMask),
|
requireStage(loc, (EShLanguageMask)(EShLangTaskMask | EShLangMeshMask | EShLangFragmentMask),
|
||||||
"#extension GL_NV_mesh_shader");
|
"#extension GL_NV_mesh_shader");
|
||||||
profileRequires(loc, ECoreProfile, 450, 0, "#extension GL_NV_mesh_shader");
|
profileRequires(loc, ECoreProfile, 450, 0, "#extension GL_NV_mesh_shader");
|
||||||
profileRequires(loc, EEsProfile, 320, 0, "#extension GL_NV_mesh_shader");
|
profileRequires(loc, EEsProfile, 320, 0, "#extension GL_NV_mesh_shader");
|
||||||
|
if (extensionTurnedOn(E_GL_EXT_mesh_shader)) {
|
||||||
|
error(loc, "GL_EXT_mesh_shader is already turned on, and not allowed with", "#extension", extension);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (strcmp(extension, "GL_EXT_mesh_shader") == 0) {
|
||||||
|
requireStage(loc, (EShLanguageMask)(EShLangTaskMask | EShLangMeshMask | EShLangFragmentMask),
|
||||||
|
"#extension GL_EXT_mesh_shader");
|
||||||
|
profileRequires(loc, ECoreProfile, 450, 0, "#extension GL_EXT_mesh_shader");
|
||||||
|
profileRequires(loc, EEsProfile, 320, 0, "#extension GL_EXT_mesh_shader");
|
||||||
|
if (extensionTurnedOn(E_GL_NV_mesh_shader)) {
|
||||||
|
error(loc, "GL_NV_mesh_shader is already turned on, and not allowed with", "#extension", extension);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -201,6 +201,7 @@ const char* const E_GL_EXT_debug_printf = "GL_EXT_debug_prin
|
|||||||
const char* const E_GL_EXT_ray_tracing = "GL_EXT_ray_tracing";
|
const char* const E_GL_EXT_ray_tracing = "GL_EXT_ray_tracing";
|
||||||
const char* const E_GL_EXT_ray_query = "GL_EXT_ray_query";
|
const char* const E_GL_EXT_ray_query = "GL_EXT_ray_query";
|
||||||
const char* const E_GL_EXT_ray_flags_primitive_culling = "GL_EXT_ray_flags_primitive_culling";
|
const char* const E_GL_EXT_ray_flags_primitive_culling = "GL_EXT_ray_flags_primitive_culling";
|
||||||
|
const char* const E_GL_EXT_ray_cull_mask = "GL_EXT_ray_cull_mask";
|
||||||
const char* const E_GL_EXT_blend_func_extended = "GL_EXT_blend_func_extended";
|
const char* const E_GL_EXT_blend_func_extended = "GL_EXT_blend_func_extended";
|
||||||
const char* const E_GL_EXT_shader_implicit_conversions = "GL_EXT_shader_implicit_conversions";
|
const char* const E_GL_EXT_shader_implicit_conversions = "GL_EXT_shader_implicit_conversions";
|
||||||
const char* const E_GL_EXT_fragment_shading_rate = "GL_EXT_fragment_shading_rate";
|
const char* const E_GL_EXT_fragment_shading_rate = "GL_EXT_fragment_shading_rate";
|
||||||
@ -209,12 +210,19 @@ const char* const E_GL_EXT_null_initializer = "GL_EXT_null_initi
|
|||||||
const char* const E_GL_EXT_shared_memory_block = "GL_EXT_shared_memory_block";
|
const char* const E_GL_EXT_shared_memory_block = "GL_EXT_shared_memory_block";
|
||||||
const char* const E_GL_EXT_subgroup_uniform_control_flow = "GL_EXT_subgroup_uniform_control_flow";
|
const char* const E_GL_EXT_subgroup_uniform_control_flow = "GL_EXT_subgroup_uniform_control_flow";
|
||||||
const char* const E_GL_EXT_spirv_intrinsics = "GL_EXT_spirv_intrinsics";
|
const char* const E_GL_EXT_spirv_intrinsics = "GL_EXT_spirv_intrinsics";
|
||||||
|
const char* const E_GL_EXT_fragment_shader_barycentric = "GL_EXT_fragment_shader_barycentric";
|
||||||
|
const char* const E_GL_EXT_mesh_shader = "GL_EXT_mesh_shader";
|
||||||
|
const char* const E_GL_EXT_opacity_micromap = "GL_EXT_opacity_micromap";
|
||||||
|
|
||||||
// Arrays of extensions for the above viewportEXTs duplications
|
// Arrays of extensions for the above viewportEXTs duplications
|
||||||
|
|
||||||
const char* const post_depth_coverageEXTs[] = { E_GL_ARB_post_depth_coverage, E_GL_EXT_post_depth_coverage };
|
const char* const post_depth_coverageEXTs[] = { E_GL_ARB_post_depth_coverage, E_GL_EXT_post_depth_coverage };
|
||||||
const int Num_post_depth_coverageEXTs = sizeof(post_depth_coverageEXTs) / sizeof(post_depth_coverageEXTs[0]);
|
const int Num_post_depth_coverageEXTs = sizeof(post_depth_coverageEXTs) / sizeof(post_depth_coverageEXTs[0]);
|
||||||
|
|
||||||
|
// Array of extensions to cover both extensions providing ray tracing capabilities.
|
||||||
|
const char* const ray_tracing_EXTs[] = { E_GL_EXT_ray_query, E_GL_EXT_ray_tracing };
|
||||||
|
const int Num_ray_tracing_EXTs = sizeof(ray_tracing_EXTs) / sizeof(ray_tracing_EXTs[0]);
|
||||||
|
|
||||||
// OVR extensions
|
// OVR extensions
|
||||||
const char* const E_GL_OVR_multiview = "GL_OVR_multiview";
|
const char* const E_GL_OVR_multiview = "GL_OVR_multiview";
|
||||||
const char* const E_GL_OVR_multiview2 = "GL_OVR_multiview2";
|
const char* const E_GL_OVR_multiview2 = "GL_OVR_multiview2";
|
||||||
@ -236,6 +244,7 @@ const char* const E_GL_AMD_gpu_shader_int16 = "GL_AMD_gpu_sh
|
|||||||
const char* const E_GL_AMD_shader_image_load_store_lod = "GL_AMD_shader_image_load_store_lod";
|
const char* const E_GL_AMD_shader_image_load_store_lod = "GL_AMD_shader_image_load_store_lod";
|
||||||
const char* const E_GL_AMD_shader_fragment_mask = "GL_AMD_shader_fragment_mask";
|
const char* const E_GL_AMD_shader_fragment_mask = "GL_AMD_shader_fragment_mask";
|
||||||
const char* const E_GL_AMD_gpu_shader_half_float_fetch = "GL_AMD_gpu_shader_half_float_fetch";
|
const char* const E_GL_AMD_gpu_shader_half_float_fetch = "GL_AMD_gpu_shader_half_float_fetch";
|
||||||
|
const char* const E_GL_AMD_shader_early_and_late_fragment_tests = "GL_AMD_shader_early_and_late_fragment_tests";
|
||||||
|
|
||||||
const char* const E_GL_INTEL_shader_integer_functions2 = "GL_INTEL_shader_integer_functions2";
|
const char* const E_GL_INTEL_shader_integer_functions2 = "GL_INTEL_shader_integer_functions2";
|
||||||
|
|
||||||
@ -281,7 +290,7 @@ const char* const E_GL_EXT_tessellation_shader = "GL_EXT_tessel
|
|||||||
const char* const E_GL_EXT_tessellation_point_size = "GL_EXT_tessellation_point_size";
|
const char* const E_GL_EXT_tessellation_point_size = "GL_EXT_tessellation_point_size";
|
||||||
const char* const E_GL_EXT_texture_buffer = "GL_EXT_texture_buffer";
|
const char* const E_GL_EXT_texture_buffer = "GL_EXT_texture_buffer";
|
||||||
const char* const E_GL_EXT_texture_cube_map_array = "GL_EXT_texture_cube_map_array";
|
const char* const E_GL_EXT_texture_cube_map_array = "GL_EXT_texture_cube_map_array";
|
||||||
const char* const E_GL_EXT_shader_integer_mix = "GL_EXT_shader_integer_mix";
|
const char* const E_GL_EXT_shader_integer_mix = "GL_EXT_shader_integer_mix";
|
||||||
|
|
||||||
// OES matching AEP
|
// OES matching AEP
|
||||||
const char* const E_GL_OES_geometry_shader = "GL_OES_geometry_shader";
|
const char* const E_GL_OES_geometry_shader = "GL_OES_geometry_shader";
|
||||||
@ -342,6 +351,9 @@ const int Num_AEP_texture_buffer = sizeof(AEP_texture_buffer)/sizeof(AEP_texture
|
|||||||
const char* const AEP_texture_cube_map_array[] = { E_GL_EXT_texture_cube_map_array, E_GL_OES_texture_cube_map_array };
|
const char* const AEP_texture_cube_map_array[] = { E_GL_EXT_texture_cube_map_array, E_GL_OES_texture_cube_map_array };
|
||||||
const int Num_AEP_texture_cube_map_array = sizeof(AEP_texture_cube_map_array)/sizeof(AEP_texture_cube_map_array[0]);
|
const int Num_AEP_texture_cube_map_array = sizeof(AEP_texture_cube_map_array)/sizeof(AEP_texture_cube_map_array[0]);
|
||||||
|
|
||||||
|
const char* const AEP_mesh_shader[] = { E_GL_NV_mesh_shader, E_GL_EXT_mesh_shader };
|
||||||
|
const int Num_AEP_mesh_shader = sizeof(AEP_mesh_shader)/sizeof(AEP_mesh_shader[0]);
|
||||||
|
|
||||||
} // end namespace glslang
|
} // end namespace glslang
|
||||||
|
|
||||||
#endif // _VERSIONS_INCLUDED_
|
#endif // _VERSIONS_INCLUDED_
|
||||||
|
@ -151,7 +151,7 @@ extern int yylex(YYSTYPE*, TParseContext&);
|
|||||||
|
|
||||||
%parse-param {glslang::TParseContext* pParseContext}
|
%parse-param {glslang::TParseContext* pParseContext}
|
||||||
%lex-param {parseContext}
|
%lex-param {parseContext}
|
||||||
%pure-parser // enable thread safety
|
%define api.pure // enable thread safety
|
||||||
%expect 1 // One shift reduce conflict because of if | else
|
%expect 1 // One shift reduce conflict because of if | else
|
||||||
|
|
||||||
%token <lex> CONST BOOL INT UINT FLOAT
|
%token <lex> CONST BOOL INT UINT FLOAT
|
||||||
@ -315,7 +315,7 @@ extern int yylex(YYSTYPE*, TParseContext&);
|
|||||||
%token <lex> PATCH SAMPLE NONUNIFORM
|
%token <lex> PATCH SAMPLE NONUNIFORM
|
||||||
%token <lex> COHERENT VOLATILE RESTRICT READONLY WRITEONLY DEVICECOHERENT QUEUEFAMILYCOHERENT WORKGROUPCOHERENT
|
%token <lex> COHERENT VOLATILE RESTRICT READONLY WRITEONLY DEVICECOHERENT QUEUEFAMILYCOHERENT WORKGROUPCOHERENT
|
||||||
%token <lex> SUBGROUPCOHERENT NONPRIVATE SHADERCALLCOHERENT
|
%token <lex> SUBGROUPCOHERENT NONPRIVATE SHADERCALLCOHERENT
|
||||||
%token <lex> NOPERSPECTIVE EXPLICITINTERPAMD PERVERTEXNV PERPRIMITIVENV PERVIEWNV PERTASKNV
|
%token <lex> NOPERSPECTIVE EXPLICITINTERPAMD PERVERTEXEXT PERVERTEXNV PERPRIMITIVENV PERVIEWNV PERTASKNV PERPRIMITIVEEXT TASKPAYLOADWORKGROUPEXT
|
||||||
%token <lex> PRECISE
|
%token <lex> PRECISE
|
||||||
|
|
||||||
|
|
||||||
@ -798,7 +798,7 @@ conditional_expression
|
|||||||
parseContext.rValueErrorCheck($5.loc, ":", $6);
|
parseContext.rValueErrorCheck($5.loc, ":", $6);
|
||||||
$$ = parseContext.intermediate.addSelection($1, $4, $6, $2.loc);
|
$$ = parseContext.intermediate.addSelection($1, $4, $6, $2.loc);
|
||||||
if ($$ == 0) {
|
if ($$ == 0) {
|
||||||
parseContext.binaryOpError($2.loc, ":", $4->getCompleteString(), $6->getCompleteString());
|
parseContext.binaryOpError($2.loc, ":", $4->getCompleteString(parseContext.intermediate.getEnhancedMsgs()), $6->getCompleteString(parseContext.intermediate.getEnhancedMsgs()));
|
||||||
$$ = $6;
|
$$ = $6;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -815,7 +815,7 @@ assignment_expression
|
|||||||
parseContext.rValueErrorCheck($2.loc, "assign", $3);
|
parseContext.rValueErrorCheck($2.loc, "assign", $3);
|
||||||
$$ = parseContext.addAssign($2.loc, $2.op, $1, $3);
|
$$ = parseContext.addAssign($2.loc, $2.op, $1, $3);
|
||||||
if ($$ == 0) {
|
if ($$ == 0) {
|
||||||
parseContext.assignError($2.loc, "assign", $1->getCompleteString(), $3->getCompleteString());
|
parseContext.assignError($2.loc, "assign", $1->getCompleteString(parseContext.intermediate.getEnhancedMsgs()), $3->getCompleteString(parseContext.intermediate.getEnhancedMsgs()));
|
||||||
$$ = $1;
|
$$ = $1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -877,7 +877,7 @@ expression
|
|||||||
parseContext.samplerConstructorLocationCheck($2.loc, ",", $3);
|
parseContext.samplerConstructorLocationCheck($2.loc, ",", $3);
|
||||||
$$ = parseContext.intermediate.addComma($1, $3, $2.loc);
|
$$ = parseContext.intermediate.addComma($1, $3, $2.loc);
|
||||||
if ($$ == 0) {
|
if ($$ == 0) {
|
||||||
parseContext.binaryOpError($2.loc, ",", $1->getCompleteString(), $3->getCompleteString());
|
parseContext.binaryOpError($2.loc, ",", $1->getCompleteString(parseContext.intermediate.getEnhancedMsgs()), $3->getCompleteString(parseContext.intermediate.getEnhancedMsgs()));
|
||||||
$$ = $3;
|
$$ = $3;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1290,27 +1290,45 @@ interpolation_qualifier
|
|||||||
$$.init($1.loc);
|
$$.init($1.loc);
|
||||||
$$.qualifier.pervertexNV = true;
|
$$.qualifier.pervertexNV = true;
|
||||||
}
|
}
|
||||||
|
| PERVERTEXEXT {
|
||||||
|
parseContext.globalCheck($1.loc, "pervertexEXT");
|
||||||
|
parseContext.profileRequires($1.loc, ECoreProfile, 0, E_GL_EXT_fragment_shader_barycentric, "fragment shader barycentric");
|
||||||
|
parseContext.profileRequires($1.loc, ECompatibilityProfile, 0, E_GL_EXT_fragment_shader_barycentric, "fragment shader barycentric");
|
||||||
|
parseContext.profileRequires($1.loc, EEsProfile, 0, E_GL_EXT_fragment_shader_barycentric, "fragment shader barycentric");
|
||||||
|
$$.init($1.loc);
|
||||||
|
$$.qualifier.pervertexEXT = true;
|
||||||
|
}
|
||||||
| PERPRIMITIVENV {
|
| PERPRIMITIVENV {
|
||||||
// No need for profile version or extension check. Shader stage already checks both.
|
// No need for profile version or extension check. Shader stage already checks both.
|
||||||
parseContext.globalCheck($1.loc, "perprimitiveNV");
|
parseContext.globalCheck($1.loc, "perprimitiveNV");
|
||||||
parseContext.requireStage($1.loc, (EShLanguageMask)(EShLangFragmentMask | EShLangMeshNVMask), "perprimitiveNV");
|
parseContext.requireStage($1.loc, (EShLanguageMask)(EShLangFragmentMask | EShLangMeshMask), "perprimitiveNV");
|
||||||
// Fragment shader stage doesn't check for extension. So we explicitly add below extension check.
|
// Fragment shader stage doesn't check for extension. So we explicitly add below extension check.
|
||||||
if (parseContext.language == EShLangFragment)
|
if (parseContext.language == EShLangFragment)
|
||||||
parseContext.requireExtensions($1.loc, 1, &E_GL_NV_mesh_shader, "perprimitiveNV");
|
parseContext.requireExtensions($1.loc, 1, &E_GL_NV_mesh_shader, "perprimitiveNV");
|
||||||
$$.init($1.loc);
|
$$.init($1.loc);
|
||||||
$$.qualifier.perPrimitiveNV = true;
|
$$.qualifier.perPrimitiveNV = true;
|
||||||
}
|
}
|
||||||
|
| PERPRIMITIVEEXT {
|
||||||
|
// No need for profile version or extension check. Shader stage already checks both.
|
||||||
|
parseContext.globalCheck($1.loc, "perprimitiveEXT");
|
||||||
|
parseContext.requireStage($1.loc, (EShLanguageMask)(EShLangFragmentMask | EShLangMeshMask), "perprimitiveEXT");
|
||||||
|
// Fragment shader stage doesn't check for extension. So we explicitly add below extension check.
|
||||||
|
if (parseContext.language == EShLangFragment)
|
||||||
|
parseContext.requireExtensions($1.loc, 1, &E_GL_EXT_mesh_shader, "perprimitiveEXT");
|
||||||
|
$$.init($1.loc);
|
||||||
|
$$.qualifier.perPrimitiveNV = true;
|
||||||
|
}
|
||||||
| PERVIEWNV {
|
| PERVIEWNV {
|
||||||
// No need for profile version or extension check. Shader stage already checks both.
|
// No need for profile version or extension check. Shader stage already checks both.
|
||||||
parseContext.globalCheck($1.loc, "perviewNV");
|
parseContext.globalCheck($1.loc, "perviewNV");
|
||||||
parseContext.requireStage($1.loc, EShLangMeshNV, "perviewNV");
|
parseContext.requireStage($1.loc, EShLangMesh, "perviewNV");
|
||||||
$$.init($1.loc);
|
$$.init($1.loc);
|
||||||
$$.qualifier.perViewNV = true;
|
$$.qualifier.perViewNV = true;
|
||||||
}
|
}
|
||||||
| PERTASKNV {
|
| PERTASKNV {
|
||||||
// No need for profile version or extension check. Shader stage already checks both.
|
// No need for profile version or extension check. Shader stage already checks both.
|
||||||
parseContext.globalCheck($1.loc, "taskNV");
|
parseContext.globalCheck($1.loc, "taskNV");
|
||||||
parseContext.requireStage($1.loc, (EShLanguageMask)(EShLangTaskNVMask | EShLangMeshNVMask), "taskNV");
|
parseContext.requireStage($1.loc, (EShLanguageMask)(EShLangTaskMask | EShLangMeshMask), "taskNV");
|
||||||
$$.init($1.loc);
|
$$.init($1.loc);
|
||||||
$$.qualifier.perTaskNV = true;
|
$$.qualifier.perTaskNV = true;
|
||||||
}
|
}
|
||||||
@ -1461,7 +1479,7 @@ storage_qualifier
|
|||||||
parseContext.globalCheck($1.loc, "shared");
|
parseContext.globalCheck($1.loc, "shared");
|
||||||
parseContext.profileRequires($1.loc, ECoreProfile | ECompatibilityProfile, 430, E_GL_ARB_compute_shader, "shared");
|
parseContext.profileRequires($1.loc, ECoreProfile | ECompatibilityProfile, 430, E_GL_ARB_compute_shader, "shared");
|
||||||
parseContext.profileRequires($1.loc, EEsProfile, 310, 0, "shared");
|
parseContext.profileRequires($1.loc, EEsProfile, 310, 0, "shared");
|
||||||
parseContext.requireStage($1.loc, (EShLanguageMask)(EShLangComputeMask | EShLangMeshNVMask | EShLangTaskNVMask), "shared");
|
parseContext.requireStage($1.loc, (EShLanguageMask)(EShLangComputeMask | EShLangMeshMask | EShLangTaskMask), "shared");
|
||||||
$$.init($1.loc);
|
$$.init($1.loc);
|
||||||
$$.qualifier.storage = EvqShared;
|
$$.qualifier.storage = EvqShared;
|
||||||
}
|
}
|
||||||
@ -1648,6 +1666,13 @@ storage_qualifier
|
|||||||
parseContext.unimplemented($1.loc, "subroutine");
|
parseContext.unimplemented($1.loc, "subroutine");
|
||||||
$$.init($1.loc);
|
$$.init($1.loc);
|
||||||
}
|
}
|
||||||
|
| TASKPAYLOADWORKGROUPEXT {
|
||||||
|
// No need for profile version or extension check. Shader stage already checks both.
|
||||||
|
parseContext.globalCheck($1.loc, "taskPayloadSharedEXT");
|
||||||
|
parseContext.requireStage($1.loc, (EShLanguageMask)(EShLangTaskMask | EShLangMeshMask), "taskPayloadSharedEXT ");
|
||||||
|
$$.init($1.loc);
|
||||||
|
$$.qualifier.storage = EvqtaskPayloadSharedEXT;
|
||||||
|
}
|
||||||
|
|
||||||
;
|
;
|
||||||
|
|
||||||
@ -3718,7 +3743,7 @@ compound_statement
|
|||||||
}
|
}
|
||||||
RIGHT_BRACE {
|
RIGHT_BRACE {
|
||||||
if ($3 && $3->getAsAggregate())
|
if ($3 && $3->getAsAggregate())
|
||||||
$3->getAsAggregate()->setOperator(EOpSequence);
|
$3->getAsAggregate()->setOperator(parseContext.intermediate.getDebugInfo() ? EOpScope : EOpSequence);
|
||||||
$$ = $3;
|
$$ = $3;
|
||||||
}
|
}
|
||||||
;
|
;
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -501,11 +501,14 @@ extern int yydebug;
|
|||||||
SHADERCALLCOHERENT = 702, /* SHADERCALLCOHERENT */
|
SHADERCALLCOHERENT = 702, /* SHADERCALLCOHERENT */
|
||||||
NOPERSPECTIVE = 703, /* NOPERSPECTIVE */
|
NOPERSPECTIVE = 703, /* NOPERSPECTIVE */
|
||||||
EXPLICITINTERPAMD = 704, /* EXPLICITINTERPAMD */
|
EXPLICITINTERPAMD = 704, /* EXPLICITINTERPAMD */
|
||||||
PERVERTEXNV = 705, /* PERVERTEXNV */
|
PERVERTEXEXT = 705, /* PERVERTEXEXT */
|
||||||
PERPRIMITIVENV = 706, /* PERPRIMITIVENV */
|
PERVERTEXNV = 706, /* PERVERTEXNV */
|
||||||
PERVIEWNV = 707, /* PERVIEWNV */
|
PERPRIMITIVENV = 707, /* PERPRIMITIVENV */
|
||||||
PERTASKNV = 708, /* PERTASKNV */
|
PERVIEWNV = 708, /* PERVIEWNV */
|
||||||
PRECISE = 709 /* PRECISE */
|
PERTASKNV = 709, /* PERTASKNV */
|
||||||
|
PERPRIMITIVEEXT = 710, /* PERPRIMITIVEEXT */
|
||||||
|
TASKPAYLOADWORKGROUPEXT = 711, /* TASKPAYLOADWORKGROUPEXT */
|
||||||
|
PRECISE = 712 /* PRECISE */
|
||||||
};
|
};
|
||||||
typedef enum yytokentype yytoken_kind_t;
|
typedef enum yytokentype yytoken_kind_t;
|
||||||
#endif
|
#endif
|
||||||
@ -553,7 +556,7 @@ union YYSTYPE
|
|||||||
glslang::TArraySizes* typeParameters;
|
glslang::TArraySizes* typeParameters;
|
||||||
} interm;
|
} interm;
|
||||||
|
|
||||||
#line 557 "MachineIndependent/glslang_tab.cpp.h"
|
#line 560 "MachineIndependent/glslang_tab.cpp.h"
|
||||||
|
|
||||||
};
|
};
|
||||||
typedef union YYSTYPE YYSTYPE;
|
typedef union YYSTYPE YYSTYPE;
|
||||||
|
@ -665,6 +665,8 @@ bool TOutputTraverser::visitUnary(TVisit /* visit */, TIntermUnary* node)
|
|||||||
|
|
||||||
case EOpConstructReference: out.debug << "Construct reference type"; break;
|
case EOpConstructReference: out.debug << "Construct reference type"; break;
|
||||||
|
|
||||||
|
case EOpDeclare: out.debug << "Declare"; break;
|
||||||
|
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
case EOpSpirvInst: out.debug << "spirv_instruction"; break;
|
case EOpSpirvInst: out.debug << "spirv_instruction"; break;
|
||||||
#endif
|
#endif
|
||||||
@ -692,6 +694,7 @@ bool TOutputTraverser::visitAggregate(TVisit /* visit */, TIntermAggregate* node
|
|||||||
|
|
||||||
switch (node->getOp()) {
|
switch (node->getOp()) {
|
||||||
case EOpSequence: out.debug << "Sequence\n"; return true;
|
case EOpSequence: out.debug << "Sequence\n"; return true;
|
||||||
|
case EOpScope: out.debug << "Scope\n"; return true;
|
||||||
case EOpLinkerObjects: out.debug << "Linker Objects\n"; return true;
|
case EOpLinkerObjects: out.debug << "Linker Objects\n"; return true;
|
||||||
case EOpComma: out.debug << "Comma"; break;
|
case EOpComma: out.debug << "Comma"; break;
|
||||||
case EOpFunction: out.debug << "Function Definition: " << node->getName(); break;
|
case EOpFunction: out.debug << "Function Definition: " << node->getName(); break;
|
||||||
@ -1068,6 +1071,8 @@ bool TOutputTraverser::visitAggregate(TVisit /* visit */, TIntermAggregate* node
|
|||||||
case EOpExecuteCallableNV: out.debug << "executeCallableNV"; break;
|
case EOpExecuteCallableNV: out.debug << "executeCallableNV"; break;
|
||||||
case EOpExecuteCallableKHR: out.debug << "executeCallableKHR"; break;
|
case EOpExecuteCallableKHR: out.debug << "executeCallableKHR"; break;
|
||||||
case EOpWritePackedPrimitiveIndices4x8NV: out.debug << "writePackedPrimitiveIndices4x8NV"; break;
|
case EOpWritePackedPrimitiveIndices4x8NV: out.debug << "writePackedPrimitiveIndices4x8NV"; break;
|
||||||
|
case EOpEmitMeshTasksEXT: out.debug << "EmitMeshTasksEXT"; break;
|
||||||
|
case EOpSetMeshOutputsEXT: out.debug << "SetMeshOutputsEXT"; break;
|
||||||
|
|
||||||
case EOpRayQueryInitialize: out.debug << "rayQueryInitializeEXT"; break;
|
case EOpRayQueryInitialize: out.debug << "rayQueryInitializeEXT"; break;
|
||||||
case EOpRayQueryTerminate: out.debug << "rayQueryTerminateEXT"; break;
|
case EOpRayQueryTerminate: out.debug << "rayQueryTerminateEXT"; break;
|
||||||
@ -1107,7 +1112,7 @@ bool TOutputTraverser::visitAggregate(TVisit /* visit */, TIntermAggregate* node
|
|||||||
default: out.debug.message(EPrefixError, "Bad aggregation op");
|
default: out.debug.message(EPrefixError, "Bad aggregation op");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (node->getOp() != EOpSequence && node->getOp() != EOpParameters)
|
if (node->getOp() != EOpSequence && node->getOp() != EOpScope && node->getOp() != EOpParameters)
|
||||||
out.debug << " (" << node->getCompleteString() << ")";
|
out.debug << " (" << node->getCompleteString() << ")";
|
||||||
|
|
||||||
out.debug << "\n";
|
out.debug << "\n";
|
||||||
@ -1522,12 +1527,12 @@ void TIntermediate::output(TInfoSink& infoSink, bool tree)
|
|||||||
infoSink.debug << "interlock ordering = " << TQualifier::getInterlockOrderingString(interlockOrdering) << "\n";
|
infoSink.debug << "interlock ordering = " << TQualifier::getInterlockOrderingString(interlockOrdering) << "\n";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case EShLangMeshNV:
|
case EShLangMesh:
|
||||||
infoSink.debug << "max_vertices = " << vertices << "\n";
|
infoSink.debug << "max_vertices = " << vertices << "\n";
|
||||||
infoSink.debug << "max_primitives = " << primitives << "\n";
|
infoSink.debug << "max_primitives = " << primitives << "\n";
|
||||||
infoSink.debug << "output primitive = " << TQualifier::getGeometryString(outputPrimitive) << "\n";
|
infoSink.debug << "output primitive = " << TQualifier::getGeometryString(outputPrimitive) << "\n";
|
||||||
// Fall through
|
// Fall through
|
||||||
case EShLangTaskNV:
|
case EShLangTask:
|
||||||
// Fall through
|
// Fall through
|
||||||
case EShLangCompute:
|
case EShLangCompute:
|
||||||
infoSink.debug << "local_size = (" << localSize[0] << ", " << localSize[1] << ", " << localSize[2] << ")\n";
|
infoSink.debug << "local_size = (" << localSize[0] << ", " << localSize[1] << ", " << localSize[2] << ")\n";
|
||||||
|
@ -203,11 +203,7 @@ struct TResolverUniformAdaptor {
|
|||||||
|
|
||||||
inline void operator()(std::pair<const TString, TVarEntryInfo>& entKey) {
|
inline void operator()(std::pair<const TString, TVarEntryInfo>& entKey) {
|
||||||
TVarEntryInfo& ent = entKey.second;
|
TVarEntryInfo& ent = entKey.second;
|
||||||
ent.newLocation = -1;
|
ent.clearNewAssignments();
|
||||||
ent.newComponent = -1;
|
|
||||||
ent.newBinding = -1;
|
|
||||||
ent.newSet = -1;
|
|
||||||
ent.newIndex = -1;
|
|
||||||
const bool isValid = resolver.validateBinding(stage, ent);
|
const bool isValid = resolver.validateBinding(stage, ent);
|
||||||
if (isValid) {
|
if (isValid) {
|
||||||
resolver.resolveSet(ent.stage, ent);
|
resolver.resolveSet(ent.stage, ent);
|
||||||
@ -281,11 +277,7 @@ struct TResolverInOutAdaptor {
|
|||||||
inline void operator()(std::pair<const TString, TVarEntryInfo>& entKey)
|
inline void operator()(std::pair<const TString, TVarEntryInfo>& entKey)
|
||||||
{
|
{
|
||||||
TVarEntryInfo& ent = entKey.second;
|
TVarEntryInfo& ent = entKey.second;
|
||||||
ent.newLocation = -1;
|
ent.clearNewAssignments();
|
||||||
ent.newComponent = -1;
|
|
||||||
ent.newBinding = -1;
|
|
||||||
ent.newSet = -1;
|
|
||||||
ent.newIndex = -1;
|
|
||||||
const bool isValid = resolver.validateInOut(ent.stage, ent);
|
const bool isValid = resolver.validateInOut(ent.stage, ent);
|
||||||
if (isValid) {
|
if (isValid) {
|
||||||
resolver.resolveInOutLocation(stage, ent);
|
resolver.resolveInOutLocation(stage, ent);
|
||||||
@ -1670,6 +1662,10 @@ bool TGlslIoMapper::doMap(TIoMapResolver* resolver, TInfoSink& infoSink) {
|
|||||||
if (size <= int(autoPushConstantMaxSize)) {
|
if (size <= int(autoPushConstantMaxSize)) {
|
||||||
qualifier.setBlockStorage(EbsPushConstant);
|
qualifier.setBlockStorage(EbsPushConstant);
|
||||||
qualifier.layoutPacking = autoPushConstantBlockPacking;
|
qualifier.layoutPacking = autoPushConstantBlockPacking;
|
||||||
|
// Push constants don't have set/binding etc. decorations, remove those.
|
||||||
|
qualifier.layoutSet = TQualifier::layoutSetEnd;
|
||||||
|
at->second.clearNewAssignments();
|
||||||
|
|
||||||
upgraded = true;
|
upgraded = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1677,10 +1673,14 @@ bool TGlslIoMapper::doMap(TIoMapResolver* resolver, TInfoSink& infoSink) {
|
|||||||
// If it's been upgraded to push_constant, then remove it from the uniformVector
|
// If it's been upgraded to push_constant, then remove it from the uniformVector
|
||||||
// so it doesn't get a set/binding assigned to it.
|
// so it doesn't get a set/binding assigned to it.
|
||||||
if (upgraded) {
|
if (upgraded) {
|
||||||
auto at = std::find_if(uniformVector.begin(), uniformVector.end(),
|
while (1) {
|
||||||
[this](const TVarLivePair& p) { return p.first == autoPushConstantBlockName; });
|
auto at = std::find_if(uniformVector.begin(), uniformVector.end(),
|
||||||
if (at != uniformVector.end())
|
[this](const TVarLivePair& p) { return p.first == autoPushConstantBlockName; });
|
||||||
uniformVector.erase(at);
|
if (at != uniformVector.end())
|
||||||
|
uniformVector.erase(at);
|
||||||
|
else
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (size_t stage = 0; stage < EShLangCount; stage++) {
|
for (size_t stage = 0; stage < EShLangCount; stage++) {
|
||||||
|
@ -61,6 +61,15 @@ struct TVarEntryInfo {
|
|||||||
int newComponent;
|
int newComponent;
|
||||||
int newIndex;
|
int newIndex;
|
||||||
EShLanguage stage;
|
EShLanguage stage;
|
||||||
|
|
||||||
|
void clearNewAssignments() {
|
||||||
|
newBinding = -1;
|
||||||
|
newSet = -1;
|
||||||
|
newLocation = -1;
|
||||||
|
newComponent = -1;
|
||||||
|
newIndex = -1;
|
||||||
|
}
|
||||||
|
|
||||||
struct TOrderById {
|
struct TOrderById {
|
||||||
inline bool operator()(const TVarEntryInfo& l, const TVarEntryInfo& r) { return l.id < r.id; }
|
inline bool operator()(const TVarEntryInfo& l, const TVarEntryInfo& r) { return l.id < r.id; }
|
||||||
};
|
};
|
||||||
|
@ -55,22 +55,28 @@ namespace glslang {
|
|||||||
//
|
//
|
||||||
// Link-time error emitter.
|
// Link-time error emitter.
|
||||||
//
|
//
|
||||||
void TIntermediate::error(TInfoSink& infoSink, const char* message)
|
void TIntermediate::error(TInfoSink& infoSink, const char* message, EShLanguage unitStage)
|
||||||
{
|
{
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
infoSink.info.prefix(EPrefixError);
|
infoSink.info.prefix(EPrefixError);
|
||||||
infoSink.info << "Linking " << StageName(language) << " stage: " << message << "\n";
|
if (unitStage < EShLangCount)
|
||||||
|
infoSink.info << "Linking " << StageName(getStage()) << " and " << StageName(unitStage) << " stages: " << message << "\n";
|
||||||
|
else
|
||||||
|
infoSink.info << "Linking " << StageName(language) << " stage: " << message << "\n";
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
++numErrors;
|
++numErrors;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Link-time warning.
|
// Link-time warning.
|
||||||
void TIntermediate::warn(TInfoSink& infoSink, const char* message)
|
void TIntermediate::warn(TInfoSink& infoSink, const char* message, EShLanguage unitStage)
|
||||||
{
|
{
|
||||||
#ifndef GLSLANG_WEB
|
#ifndef GLSLANG_WEB
|
||||||
infoSink.info.prefix(EPrefixWarning);
|
infoSink.info.prefix(EPrefixWarning);
|
||||||
infoSink.info << "Linking " << StageName(language) << " stage: " << message << "\n";
|
if (unitStage < EShLangCount)
|
||||||
|
infoSink.info << "Linking " << StageName(language) << " and " << StageName(unitStage) << " stages: " << message << "\n";
|
||||||
|
else
|
||||||
|
infoSink.info << "Linking " << StageName(language) << " stage: " << message << "\n";
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -114,7 +120,7 @@ void TIntermediate::mergeUniformObjects(TInfoSink& infoSink, TIntermediate& unit
|
|||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// do error checking on the shader boundary in / out vars
|
// do error checking on the shader boundary in / out vars
|
||||||
//
|
//
|
||||||
void TIntermediate::checkStageIO(TInfoSink& infoSink, TIntermediate& unit) {
|
void TIntermediate::checkStageIO(TInfoSink& infoSink, TIntermediate& unit) {
|
||||||
if (unit.treeRoot == nullptr || treeRoot == nullptr)
|
if (unit.treeRoot == nullptr || treeRoot == nullptr)
|
||||||
@ -206,7 +212,7 @@ void TIntermediate::mergeModes(TInfoSink& infoSink, TIntermediate& unit)
|
|||||||
if (vertices == TQualifier::layoutNotSet)
|
if (vertices == TQualifier::layoutNotSet)
|
||||||
vertices = unit.vertices;
|
vertices = unit.vertices;
|
||||||
else if (unit.vertices != TQualifier::layoutNotSet && vertices != unit.vertices) {
|
else if (unit.vertices != TQualifier::layoutNotSet && vertices != unit.vertices) {
|
||||||
if (language == EShLangGeometry || language == EShLangMeshNV)
|
if (language == EShLangGeometry || language == EShLangMesh)
|
||||||
error(infoSink, "Contradictory layout max_vertices values");
|
error(infoSink, "Contradictory layout max_vertices values");
|
||||||
else if (language == EShLangTessControl)
|
else if (language == EShLangTessControl)
|
||||||
error(infoSink, "Contradictory layout vertices values");
|
error(infoSink, "Contradictory layout vertices values");
|
||||||
@ -216,7 +222,7 @@ void TIntermediate::mergeModes(TInfoSink& infoSink, TIntermediate& unit)
|
|||||||
if (primitives == TQualifier::layoutNotSet)
|
if (primitives == TQualifier::layoutNotSet)
|
||||||
primitives = unit.primitives;
|
primitives = unit.primitives;
|
||||||
else if (primitives != unit.primitives) {
|
else if (primitives != unit.primitives) {
|
||||||
if (language == EShLangMeshNV)
|
if (language == EShLangMesh)
|
||||||
error(infoSink, "Contradictory layout max_primitives values");
|
error(infoSink, "Contradictory layout max_primitives values");
|
||||||
else
|
else
|
||||||
assert(0);
|
assert(0);
|
||||||
@ -313,6 +319,7 @@ void TIntermediate::mergeModes(TInfoSink& infoSink, TIntermediate& unit)
|
|||||||
MERGE_TRUE(autoMapLocations);
|
MERGE_TRUE(autoMapLocations);
|
||||||
MERGE_TRUE(invertY);
|
MERGE_TRUE(invertY);
|
||||||
MERGE_TRUE(dxPositionW);
|
MERGE_TRUE(dxPositionW);
|
||||||
|
MERGE_TRUE(debugInfo);
|
||||||
MERGE_TRUE(flattenUniformArrays);
|
MERGE_TRUE(flattenUniformArrays);
|
||||||
MERGE_TRUE(useUnknownFormat);
|
MERGE_TRUE(useUnknownFormat);
|
||||||
MERGE_TRUE(hlslOffsets);
|
MERGE_TRUE(hlslOffsets);
|
||||||
@ -580,9 +587,6 @@ void TIntermediate::mergeGlobalUniformBlocks(TInfoSink& infoSink, TIntermediate&
|
|||||||
}
|
}
|
||||||
|
|
||||||
void TIntermediate::mergeBlockDefinitions(TInfoSink& infoSink, TIntermSymbol* block, TIntermSymbol* unitBlock, TIntermediate* unit) {
|
void TIntermediate::mergeBlockDefinitions(TInfoSink& infoSink, TIntermSymbol* block, TIntermSymbol* unitBlock, TIntermediate* unit) {
|
||||||
if (block->getType() == unitBlock->getType()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (block->getType().getTypeName() != unitBlock->getType().getTypeName() ||
|
if (block->getType().getTypeName() != unitBlock->getType().getTypeName() ||
|
||||||
block->getType().getBasicType() != unitBlock->getType().getBasicType() ||
|
block->getType().getBasicType() != unitBlock->getType().getBasicType() ||
|
||||||
@ -629,44 +633,42 @@ void TIntermediate::mergeBlockDefinitions(TInfoSink& infoSink, TIntermSymbol* bl
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TType unitType;
|
|
||||||
unitType.shallowCopy(unitBlock->getType());
|
|
||||||
|
|
||||||
// update symbol node in unit tree,
|
// update symbol node in unit tree,
|
||||||
// and other nodes that may reference it
|
// and other nodes that may reference it
|
||||||
class TMergeBlockTraverser : public TIntermTraverser {
|
class TMergeBlockTraverser : public TIntermTraverser {
|
||||||
public:
|
public:
|
||||||
TMergeBlockTraverser(const glslang::TType &type, const glslang::TType& unitType,
|
TMergeBlockTraverser(const TIntermSymbol* newSym)
|
||||||
glslang::TIntermediate& unit,
|
: newSymbol(newSym), newType(nullptr), unit(nullptr), memberIndexUpdates(nullptr)
|
||||||
const std::map<unsigned int, unsigned int>& memberIdxUpdates) :
|
{
|
||||||
newType(type), unitType(unitType), unit(unit), memberIndexUpdates(memberIdxUpdates)
|
}
|
||||||
{ }
|
TMergeBlockTraverser(const TIntermSymbol* newSym, const glslang::TType* unitType, glslang::TIntermediate* unit,
|
||||||
virtual ~TMergeBlockTraverser() { }
|
const std::map<unsigned int, unsigned int>* memberIdxUpdates)
|
||||||
|
: TIntermTraverser(false, true), newSymbol(newSym), newType(unitType), unit(unit), memberIndexUpdates(memberIdxUpdates)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
virtual ~TMergeBlockTraverser() {}
|
||||||
|
|
||||||
const glslang::TType& newType; // type with modifications
|
const TIntermSymbol* newSymbol;
|
||||||
const glslang::TType& unitType; // copy of original type
|
const glslang::TType* newType; // shallow copy of the new type
|
||||||
glslang::TIntermediate& unit; // intermediate that is being updated
|
glslang::TIntermediate* unit; // intermediate that is being updated
|
||||||
const std::map<unsigned int, unsigned int>& memberIndexUpdates;
|
const std::map<unsigned int, unsigned int>* memberIndexUpdates;
|
||||||
|
|
||||||
virtual void visitSymbol(TIntermSymbol* symbol)
|
virtual void visitSymbol(TIntermSymbol* symbol)
|
||||||
{
|
{
|
||||||
glslang::TType& symType = symbol->getWritableType();
|
if (newSymbol->getAccessName() == symbol->getAccessName() &&
|
||||||
|
newSymbol->getQualifier().getBlockStorage() == symbol->getQualifier().getBlockStorage()) {
|
||||||
if (symType == unitType) {
|
// Each symbol node may have a local copy of the block structure.
|
||||||
// each symbol node has a local copy of the unitType
|
// Update those structures to match the new one post-merge
|
||||||
// if merging involves changing properties that aren't shared objects
|
*(symbol->getWritableType().getWritableStruct()) = *(newSymbol->getType().getStruct());
|
||||||
// they should be updated in all instances
|
|
||||||
|
|
||||||
// e.g. the struct list is a ptr to an object, so it can be updated
|
|
||||||
// once, outside the traverser
|
|
||||||
//*symType.getWritableStruct() = *newType.getStruct();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual bool visitBinary(TVisit, glslang::TIntermBinary* node)
|
virtual bool visitBinary(TVisit, glslang::TIntermBinary* node)
|
||||||
{
|
{
|
||||||
if (node->getOp() == EOpIndexDirectStruct && node->getLeft()->getType() == unitType) {
|
if (!unit || !newType || !memberIndexUpdates || memberIndexUpdates->empty())
|
||||||
|
return true;
|
||||||
|
|
||||||
|
if (node->getOp() == EOpIndexDirectStruct && node->getLeft()->getType() == *newType) {
|
||||||
// this is a dereference to a member of the block since the
|
// this is a dereference to a member of the block since the
|
||||||
// member list changed, need to update this to point to the
|
// member list changed, need to update this to point to the
|
||||||
// right index
|
// right index
|
||||||
@ -674,8 +676,8 @@ void TIntermediate::mergeBlockDefinitions(TInfoSink& infoSink, TIntermSymbol* bl
|
|||||||
|
|
||||||
glslang::TIntermConstantUnion* constNode = node->getRight()->getAsConstantUnion();
|
glslang::TIntermConstantUnion* constNode = node->getRight()->getAsConstantUnion();
|
||||||
unsigned int memberIdx = constNode->getConstArray()[0].getUConst();
|
unsigned int memberIdx = constNode->getConstArray()[0].getUConst();
|
||||||
unsigned int newIdx = memberIndexUpdates.at(memberIdx);
|
unsigned int newIdx = memberIndexUpdates->at(memberIdx);
|
||||||
TIntermTyped* newConstNode = unit.addConstantUnion(newIdx, node->getRight()->getLoc());
|
TIntermTyped* newConstNode = unit->addConstantUnion(newIdx, node->getRight()->getLoc());
|
||||||
|
|
||||||
node->setRight(newConstNode);
|
node->setRight(newConstNode);
|
||||||
delete constNode;
|
delete constNode;
|
||||||
@ -684,10 +686,20 @@ void TIntermediate::mergeBlockDefinitions(TInfoSink& infoSink, TIntermSymbol* bl
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
} finalLinkTraverser(block->getType(), unitType, *unit, memberIndexUpdates);
|
};
|
||||||
|
|
||||||
// update the tree to use the new type
|
// 'this' may have symbols that are using the old block structure, so traverse the tree to update those
|
||||||
unit->getTreeRoot()->traverse(&finalLinkTraverser);
|
// in 'visitSymbol'
|
||||||
|
TMergeBlockTraverser finalLinkTraverser(block);
|
||||||
|
getTreeRoot()->traverse(&finalLinkTraverser);
|
||||||
|
|
||||||
|
// The 'unit' intermediate needs the block structures update, but also structure entry indices
|
||||||
|
// may have changed from the old block to the new one that it was merged into, so update those
|
||||||
|
// in 'visitBinary'
|
||||||
|
TType newType;
|
||||||
|
newType.shallowCopy(block->getType());
|
||||||
|
TMergeBlockTraverser unitFinalLinkTraverser(block, &newType, unit, &memberIndexUpdates);
|
||||||
|
unit->getTreeRoot()->traverse(&unitFinalLinkTraverser);
|
||||||
|
|
||||||
// update the member list
|
// update the member list
|
||||||
(*unitMemberList) = (*memberList);
|
(*unitMemberList) = (*memberList);
|
||||||
@ -819,6 +831,10 @@ void TIntermediate::mergeErrorCheck(TInfoSink& infoSink, const TIntermSymbol& sy
|
|||||||
#if !defined(GLSLANG_WEB) && !defined(GLSLANG_ANGLE)
|
#if !defined(GLSLANG_WEB) && !defined(GLSLANG_ANGLE)
|
||||||
bool crossStage = getStage() != unitStage;
|
bool crossStage = getStage() != unitStage;
|
||||||
bool writeTypeComparison = false;
|
bool writeTypeComparison = false;
|
||||||
|
bool errorReported = false;
|
||||||
|
bool printQualifiers = false;
|
||||||
|
bool printPrecision = false;
|
||||||
|
bool printType = false;
|
||||||
|
|
||||||
// Types have to match
|
// Types have to match
|
||||||
{
|
{
|
||||||
@ -850,11 +866,48 @@ void TIntermediate::mergeErrorCheck(TInfoSink& infoSink, const TIntermSymbol& sy
|
|||||||
(symbol.getType().isUnsizedArray() || unitSymbol.getType().isUnsizedArray()));
|
(symbol.getType().isUnsizedArray() || unitSymbol.getType().isUnsizedArray()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!symbol.getType().sameElementType(unitSymbol.getType()) ||
|
int lpidx = -1;
|
||||||
!symbol.getType().sameTypeParameters(unitSymbol.getType()) ||
|
int rpidx = -1;
|
||||||
!arraysMatch ) {
|
if (!symbol.getType().sameElementType(unitSymbol.getType(), &lpidx, &rpidx)) {
|
||||||
|
if (lpidx >= 0 && rpidx >= 0) {
|
||||||
|
error(infoSink, "Member names and types must match:", unitStage);
|
||||||
|
infoSink.info << " Block: " << symbol.getType().getTypeName() << "\n";
|
||||||
|
infoSink.info << " " << StageName(getStage()) << " stage: \""
|
||||||
|
<< (*symbol.getType().getStruct())[lpidx].type->getCompleteString(true, false, false, true,
|
||||||
|
(*symbol.getType().getStruct())[lpidx].type->getFieldName()) << "\"\n";
|
||||||
|
infoSink.info << " " << StageName(unitStage) << " stage: \""
|
||||||
|
<< (*unitSymbol.getType().getStruct())[rpidx].type->getCompleteString(true, false, false, true,
|
||||||
|
(*unitSymbol.getType().getStruct())[rpidx].type->getFieldName()) << "\"\n";
|
||||||
|
errorReported = true;
|
||||||
|
} else if (lpidx >= 0 && rpidx == -1) {
|
||||||
|
TString errmsg = StageName(getStage());
|
||||||
|
errmsg.append(" block member has no corresponding member in ").append(StageName(unitStage)).append(" block:");
|
||||||
|
error(infoSink, errmsg.c_str(), unitStage);
|
||||||
|
infoSink.info << " " << StageName(getStage()) << " stage: Block: " << symbol.getType().getTypeName() << ", Member: "
|
||||||
|
<< (*symbol.getType().getStruct())[lpidx].type->getFieldName() << "\n";
|
||||||
|
infoSink.info << " " << StageName(unitStage) << " stage: Block: " << unitSymbol.getType().getTypeName() << ", Member: n/a \n";
|
||||||
|
errorReported = true;
|
||||||
|
} else if (lpidx == -1 && rpidx >= 0) {
|
||||||
|
TString errmsg = StageName(unitStage);
|
||||||
|
errmsg.append(" block member has no corresponding member in ").append(StageName(getStage())).append(" block:");
|
||||||
|
error(infoSink, errmsg.c_str(), unitStage);
|
||||||
|
infoSink.info << " " << StageName(unitStage) << " stage: Block: " << unitSymbol.getType().getTypeName() << ", Member: "
|
||||||
|
<< (*unitSymbol.getType().getStruct())[rpidx].type->getFieldName() << "\n";
|
||||||
|
infoSink.info << " " << StageName(getStage()) << " stage: Block: " << symbol.getType().getTypeName() << ", Member: n/a \n";
|
||||||
|
errorReported = true;
|
||||||
|
} else {
|
||||||
|
error(infoSink, "Types must match:", unitStage);
|
||||||
|
writeTypeComparison = true;
|
||||||
|
printType = true;
|
||||||
|
}
|
||||||
|
} else if (!arraysMatch) {
|
||||||
|
error(infoSink, "Array sizes must be compatible:", unitStage);
|
||||||
writeTypeComparison = true;
|
writeTypeComparison = true;
|
||||||
error(infoSink, "Types must match:");
|
printType = true;
|
||||||
|
} else if (!symbol.getType().sameTypeParameters(unitSymbol.getType())) {
|
||||||
|
error(infoSink, "Type parameters must match:", unitStage);
|
||||||
|
writeTypeComparison = true;
|
||||||
|
printType = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -875,13 +928,35 @@ void TIntermediate::mergeErrorCheck(TInfoSink& infoSink, const TIntermSymbol& sy
|
|||||||
}
|
}
|
||||||
const TQualifier& qualifier = (*symbol.getType().getStruct())[li].type->getQualifier();
|
const TQualifier& qualifier = (*symbol.getType().getStruct())[li].type->getQualifier();
|
||||||
const TQualifier & unitQualifier = (*unitSymbol.getType().getStruct())[ri].type->getQualifier();
|
const TQualifier & unitQualifier = (*unitSymbol.getType().getStruct())[ri].type->getQualifier();
|
||||||
if (qualifier.layoutMatrix != unitQualifier.layoutMatrix ||
|
bool layoutQualifierError = false;
|
||||||
qualifier.layoutOffset != unitQualifier.layoutOffset ||
|
if (qualifier.layoutMatrix != unitQualifier.layoutMatrix) {
|
||||||
qualifier.layoutAlign != unitQualifier.layoutAlign ||
|
error(infoSink, "Interface block member layout matrix qualifier must match:", unitStage);
|
||||||
qualifier.layoutLocation != unitQualifier.layoutLocation ||
|
layoutQualifierError = true;
|
||||||
qualifier.layoutComponent != unitQualifier.layoutComponent) {
|
}
|
||||||
error(infoSink, "Interface block member layout qualifiers must match:");
|
if (qualifier.layoutOffset != unitQualifier.layoutOffset) {
|
||||||
writeTypeComparison = true;
|
error(infoSink, "Interface block member layout offset qualifier must match:", unitStage);
|
||||||
|
layoutQualifierError = true;
|
||||||
|
}
|
||||||
|
if (qualifier.layoutAlign != unitQualifier.layoutAlign) {
|
||||||
|
error(infoSink, "Interface block member layout align qualifier must match:", unitStage);
|
||||||
|
layoutQualifierError = true;
|
||||||
|
}
|
||||||
|
if (qualifier.layoutLocation != unitQualifier.layoutLocation) {
|
||||||
|
error(infoSink, "Interface block member layout location qualifier must match:", unitStage);
|
||||||
|
layoutQualifierError = true;
|
||||||
|
}
|
||||||
|
if (qualifier.layoutComponent != unitQualifier.layoutComponent) {
|
||||||
|
error(infoSink, "Interface block member layout component qualifier must match:", unitStage);
|
||||||
|
layoutQualifierError = true;
|
||||||
|
}
|
||||||
|
if (layoutQualifierError) {
|
||||||
|
infoSink.info << " " << StageName(getStage()) << " stage: Block: " << symbol.getType().getTypeName() << ", Member: "
|
||||||
|
<< (*symbol.getType().getStruct())[li].type->getFieldName() << " \""
|
||||||
|
<< (*symbol.getType().getStruct())[li].type->getCompleteString(true, true, false, false) << "\"\n";
|
||||||
|
infoSink.info << " " << StageName(unitStage) << " stage: Block: " << unitSymbol.getType().getTypeName() << ", Member: "
|
||||||
|
<< (*unitSymbol.getType().getStruct())[ri].type->getFieldName() << " \""
|
||||||
|
<< (*unitSymbol.getType().getStruct())[ri].type->getCompleteString(true, true, false, false) << "\"\n";
|
||||||
|
errorReported = true;
|
||||||
}
|
}
|
||||||
++li;
|
++li;
|
||||||
++ri;
|
++ri;
|
||||||
@ -895,8 +970,9 @@ void TIntermediate::mergeErrorCheck(TInfoSink& infoSink, const TIntermSymbol& sy
|
|||||||
// Qualifiers have to (almost) match
|
// Qualifiers have to (almost) match
|
||||||
// Storage...
|
// Storage...
|
||||||
if (!isInOut && symbol.getQualifier().storage != unitSymbol.getQualifier().storage) {
|
if (!isInOut && symbol.getQualifier().storage != unitSymbol.getQualifier().storage) {
|
||||||
error(infoSink, "Storage qualifiers must match:");
|
error(infoSink, "Storage qualifiers must match:", unitStage);
|
||||||
writeTypeComparison = true;
|
writeTypeComparison = true;
|
||||||
|
printQualifiers = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Uniform and buffer blocks must either both have an instance name, or
|
// Uniform and buffer blocks must either both have an instance name, or
|
||||||
@ -904,37 +980,40 @@ void TIntermediate::mergeErrorCheck(TInfoSink& infoSink, const TIntermSymbol& sy
|
|||||||
if (symbol.getQualifier().isUniformOrBuffer() &&
|
if (symbol.getQualifier().isUniformOrBuffer() &&
|
||||||
(IsAnonymous(symbol.getName()) != IsAnonymous(unitSymbol.getName()))) {
|
(IsAnonymous(symbol.getName()) != IsAnonymous(unitSymbol.getName()))) {
|
||||||
error(infoSink, "Matched Uniform or Storage blocks must all be anonymous,"
|
error(infoSink, "Matched Uniform or Storage blocks must all be anonymous,"
|
||||||
" or all be named:");
|
" or all be named:", unitStage);
|
||||||
writeTypeComparison = true;
|
writeTypeComparison = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (symbol.getQualifier().storage == unitSymbol.getQualifier().storage &&
|
if (symbol.getQualifier().storage == unitSymbol.getQualifier().storage &&
|
||||||
(IsAnonymous(symbol.getName()) != IsAnonymous(unitSymbol.getName()) ||
|
(IsAnonymous(symbol.getName()) != IsAnonymous(unitSymbol.getName()) ||
|
||||||
(!IsAnonymous(symbol.getName()) && symbol.getName() != unitSymbol.getName()))) {
|
(!IsAnonymous(symbol.getName()) && symbol.getName() != unitSymbol.getName()))) {
|
||||||
warn(infoSink, "Matched shader interfaces are using different instance names.");
|
warn(infoSink, "Matched shader interfaces are using different instance names.", unitStage);
|
||||||
writeTypeComparison = true;
|
writeTypeComparison = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Precision...
|
// Precision...
|
||||||
if (!isInOut && symbol.getQualifier().precision != unitSymbol.getQualifier().precision) {
|
if (!isInOut && symbol.getQualifier().precision != unitSymbol.getQualifier().precision) {
|
||||||
error(infoSink, "Precision qualifiers must match:");
|
error(infoSink, "Precision qualifiers must match:", unitStage);
|
||||||
writeTypeComparison = true;
|
writeTypeComparison = true;
|
||||||
|
printPrecision = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Invariance...
|
// Invariance...
|
||||||
if (! crossStage && symbol.getQualifier().invariant != unitSymbol.getQualifier().invariant) {
|
if (! crossStage && symbol.getQualifier().invariant != unitSymbol.getQualifier().invariant) {
|
||||||
error(infoSink, "Presence of invariant qualifier must match:");
|
error(infoSink, "Presence of invariant qualifier must match:", unitStage);
|
||||||
writeTypeComparison = true;
|
writeTypeComparison = true;
|
||||||
|
printQualifiers = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Precise...
|
// Precise...
|
||||||
if (! crossStage && symbol.getQualifier().isNoContraction() != unitSymbol.getQualifier().isNoContraction()) {
|
if (! crossStage && symbol.getQualifier().isNoContraction() != unitSymbol.getQualifier().isNoContraction()) {
|
||||||
error(infoSink, "Presence of precise qualifier must match:");
|
error(infoSink, "Presence of precise qualifier must match:", unitStage);
|
||||||
writeTypeComparison = true;
|
writeTypeComparison = true;
|
||||||
|
printPrecision = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Auxiliary and interpolation...
|
// Auxiliary and interpolation...
|
||||||
// "interpolation qualification (e.g., flat) and auxiliary qualification (e.g. centroid) may differ.
|
// "interpolation qualification (e.g., flat) and auxiliary qualification (e.g. centroid) may differ.
|
||||||
// These mismatches are allowed between any pair of stages ...
|
// These mismatches are allowed between any pair of stages ...
|
||||||
// those provided in the fragment shader supersede those provided in previous stages."
|
// those provided in the fragment shader supersede those provided in previous stages."
|
||||||
if (!crossStage &&
|
if (!crossStage &&
|
||||||
@ -944,57 +1023,137 @@ void TIntermediate::mergeErrorCheck(TInfoSink& infoSink, const TIntermSymbol& sy
|
|||||||
symbol.getQualifier().isSample()!= unitSymbol.getQualifier().isSample() ||
|
symbol.getQualifier().isSample()!= unitSymbol.getQualifier().isSample() ||
|
||||||
symbol.getQualifier().isPatch() != unitSymbol.getQualifier().isPatch() ||
|
symbol.getQualifier().isPatch() != unitSymbol.getQualifier().isPatch() ||
|
||||||
symbol.getQualifier().isNonPerspective() != unitSymbol.getQualifier().isNonPerspective())) {
|
symbol.getQualifier().isNonPerspective() != unitSymbol.getQualifier().isNonPerspective())) {
|
||||||
error(infoSink, "Interpolation and auxiliary storage qualifiers must match:");
|
error(infoSink, "Interpolation and auxiliary storage qualifiers must match:", unitStage);
|
||||||
writeTypeComparison = true;
|
writeTypeComparison = true;
|
||||||
|
printQualifiers = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Memory...
|
// Memory...
|
||||||
if (symbol.getQualifier().coherent != unitSymbol.getQualifier().coherent ||
|
bool memoryQualifierError = false;
|
||||||
symbol.getQualifier().devicecoherent != unitSymbol.getQualifier().devicecoherent ||
|
if (symbol.getQualifier().coherent != unitSymbol.getQualifier().coherent) {
|
||||||
symbol.getQualifier().queuefamilycoherent != unitSymbol.getQualifier().queuefamilycoherent ||
|
error(infoSink, "Memory coherent qualifier must match:", unitStage);
|
||||||
symbol.getQualifier().workgroupcoherent != unitSymbol.getQualifier().workgroupcoherent ||
|
memoryQualifierError = true;
|
||||||
symbol.getQualifier().subgroupcoherent != unitSymbol.getQualifier().subgroupcoherent ||
|
}
|
||||||
symbol.getQualifier().shadercallcoherent!= unitSymbol.getQualifier().shadercallcoherent ||
|
if (symbol.getQualifier().devicecoherent != unitSymbol.getQualifier().devicecoherent) {
|
||||||
symbol.getQualifier().nonprivate != unitSymbol.getQualifier().nonprivate ||
|
error(infoSink, "Memory devicecoherent qualifier must match:", unitStage);
|
||||||
symbol.getQualifier().volatil != unitSymbol.getQualifier().volatil ||
|
memoryQualifierError = true;
|
||||||
symbol.getQualifier().restrict != unitSymbol.getQualifier().restrict ||
|
}
|
||||||
symbol.getQualifier().readonly != unitSymbol.getQualifier().readonly ||
|
if (symbol.getQualifier().queuefamilycoherent != unitSymbol.getQualifier().queuefamilycoherent) {
|
||||||
symbol.getQualifier().writeonly != unitSymbol.getQualifier().writeonly) {
|
error(infoSink, "Memory queuefamilycoherent qualifier must match:", unitStage);
|
||||||
error(infoSink, "Memory qualifiers must match:");
|
memoryQualifierError = true;
|
||||||
writeTypeComparison = true;
|
}
|
||||||
|
if (symbol.getQualifier().workgroupcoherent != unitSymbol.getQualifier().workgroupcoherent) {
|
||||||
|
error(infoSink, "Memory workgroupcoherent qualifier must match:", unitStage);
|
||||||
|
memoryQualifierError = true;
|
||||||
|
}
|
||||||
|
if (symbol.getQualifier().subgroupcoherent != unitSymbol.getQualifier().subgroupcoherent) {
|
||||||
|
error(infoSink, "Memory subgroupcoherent qualifier must match:", unitStage);
|
||||||
|
memoryQualifierError = true;
|
||||||
|
}
|
||||||
|
if (symbol.getQualifier().shadercallcoherent != unitSymbol.getQualifier().shadercallcoherent) {
|
||||||
|
error(infoSink, "Memory shadercallcoherent qualifier must match:", unitStage);
|
||||||
|
memoryQualifierError = true;
|
||||||
|
}
|
||||||
|
if (symbol.getQualifier().nonprivate != unitSymbol.getQualifier().nonprivate) {
|
||||||
|
error(infoSink, "Memory nonprivate qualifier must match:", unitStage);
|
||||||
|
memoryQualifierError = true;
|
||||||
|
}
|
||||||
|
if (symbol.getQualifier().volatil != unitSymbol.getQualifier().volatil) {
|
||||||
|
error(infoSink, "Memory volatil qualifier must match:", unitStage);
|
||||||
|
memoryQualifierError = true;
|
||||||
|
}
|
||||||
|
if (symbol.getQualifier().restrict != unitSymbol.getQualifier().restrict) {
|
||||||
|
error(infoSink, "Memory restrict qualifier must match:", unitStage);
|
||||||
|
memoryQualifierError = true;
|
||||||
|
}
|
||||||
|
if (symbol.getQualifier().readonly != unitSymbol.getQualifier().readonly) {
|
||||||
|
error(infoSink, "Memory readonly qualifier must match:", unitStage);
|
||||||
|
memoryQualifierError = true;
|
||||||
|
}
|
||||||
|
if (symbol.getQualifier().writeonly != unitSymbol.getQualifier().writeonly) {
|
||||||
|
error(infoSink, "Memory writeonly qualifier must match:", unitStage);
|
||||||
|
memoryQualifierError = true;
|
||||||
|
}
|
||||||
|
if (memoryQualifierError) {
|
||||||
|
writeTypeComparison = true;
|
||||||
|
printQualifiers = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Layouts...
|
// Layouts...
|
||||||
// TODO: 4.4 enhanced layouts: Generalize to include offset/align: current spec
|
// TODO: 4.4 enhanced layouts: Generalize to include offset/align: current spec
|
||||||
// requires separate user-supplied offset from actual computed offset, but
|
// requires separate user-supplied offset from actual computed offset, but
|
||||||
// current implementation only has one offset.
|
// current implementation only has one offset.
|
||||||
if (symbol.getQualifier().layoutMatrix != unitSymbol.getQualifier().layoutMatrix ||
|
bool layoutQualifierError = false;
|
||||||
symbol.getQualifier().layoutPacking != unitSymbol.getQualifier().layoutPacking ||
|
if (symbol.getQualifier().layoutMatrix != unitSymbol.getQualifier().layoutMatrix) {
|
||||||
(symbol.getQualifier().hasLocation() && unitSymbol.getQualifier().hasLocation() && symbol.getQualifier().layoutLocation != unitSymbol.getQualifier().layoutLocation) ||
|
error(infoSink, "Layout matrix qualifier must match:", unitStage);
|
||||||
symbol.getQualifier().layoutComponent != unitSymbol.getQualifier().layoutComponent ||
|
layoutQualifierError = true;
|
||||||
symbol.getQualifier().layoutIndex != unitSymbol.getQualifier().layoutIndex ||
|
}
|
||||||
(symbol.getQualifier().hasBinding() && unitSymbol.getQualifier().hasBinding() && symbol.getQualifier().layoutBinding != unitSymbol.getQualifier().layoutBinding) ||
|
if (symbol.getQualifier().layoutPacking != unitSymbol.getQualifier().layoutPacking) {
|
||||||
(symbol.getQualifier().hasBinding() && (symbol.getQualifier().layoutOffset != unitSymbol.getQualifier().layoutOffset))) {
|
error(infoSink, "Layout packing qualifier must match:", unitStage);
|
||||||
error(infoSink, "Layout qualification must match:");
|
layoutQualifierError = true;
|
||||||
|
}
|
||||||
|
if (symbol.getQualifier().hasLocation() && unitSymbol.getQualifier().hasLocation() && symbol.getQualifier().layoutLocation != unitSymbol.getQualifier().layoutLocation) {
|
||||||
|
error(infoSink, "Layout location qualifier must match:", unitStage);
|
||||||
|
layoutQualifierError = true;
|
||||||
|
}
|
||||||
|
if (symbol.getQualifier().layoutComponent != unitSymbol.getQualifier().layoutComponent) {
|
||||||
|
error(infoSink, "Layout component qualifier must match:", unitStage);
|
||||||
|
layoutQualifierError = true;
|
||||||
|
}
|
||||||
|
if (symbol.getQualifier().layoutIndex != unitSymbol.getQualifier().layoutIndex) {
|
||||||
|
error(infoSink, "Layout index qualifier must match:", unitStage);
|
||||||
|
layoutQualifierError = true;
|
||||||
|
}
|
||||||
|
if (symbol.getQualifier().hasBinding() && unitSymbol.getQualifier().hasBinding() && symbol.getQualifier().layoutBinding != unitSymbol.getQualifier().layoutBinding) {
|
||||||
|
error(infoSink, "Layout binding qualifier must match:", unitStage);
|
||||||
|
layoutQualifierError = true;
|
||||||
|
}
|
||||||
|
if (symbol.getQualifier().hasBinding() && (symbol.getQualifier().layoutOffset != unitSymbol.getQualifier().layoutOffset)) {
|
||||||
|
error(infoSink, "Layout offset qualifier must match:", unitStage);
|
||||||
|
layoutQualifierError = true;
|
||||||
|
}
|
||||||
|
if (layoutQualifierError) {
|
||||||
writeTypeComparison = true;
|
writeTypeComparison = true;
|
||||||
|
printQualifiers = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Initializers have to match, if both are present, and if we don't already know the types don't match
|
// Initializers have to match, if both are present, and if we don't already know the types don't match
|
||||||
if (! writeTypeComparison) {
|
if (! writeTypeComparison && ! errorReported) {
|
||||||
if (! symbol.getConstArray().empty() && ! unitSymbol.getConstArray().empty()) {
|
if (! symbol.getConstArray().empty() && ! unitSymbol.getConstArray().empty()) {
|
||||||
if (symbol.getConstArray() != unitSymbol.getConstArray()) {
|
if (symbol.getConstArray() != unitSymbol.getConstArray()) {
|
||||||
error(infoSink, "Initializers must match:");
|
error(infoSink, "Initializers must match:", unitStage);
|
||||||
infoSink.info << " " << symbol.getName() << "\n";
|
infoSink.info << " " << symbol.getName() << "\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (writeTypeComparison) {
|
if (writeTypeComparison) {
|
||||||
infoSink.info << " " << symbol.getName() << ": \"" << symbol.getType().getCompleteString() << "\" versus ";
|
if (symbol.getType().getBasicType() == EbtBlock && unitSymbol.getType().getBasicType() == EbtBlock &&
|
||||||
if (symbol.getName() != unitSymbol.getName())
|
symbol.getType().getStruct() && unitSymbol.getType().getStruct()) {
|
||||||
infoSink.info << unitSymbol.getName() << ": ";
|
if (printType) {
|
||||||
|
infoSink.info << " " << StageName(getStage()) << " stage: \"" << symbol.getType().getCompleteString(true, printQualifiers, printPrecision,
|
||||||
infoSink.info << "\"" << unitSymbol.getType().getCompleteString() << "\"\n";
|
printType, symbol.getName(), symbol.getType().getTypeName()) << "\"\n";
|
||||||
|
infoSink.info << " " << StageName(unitStage) << " stage: \"" << unitSymbol.getType().getCompleteString(true, printQualifiers, printPrecision,
|
||||||
|
printType, unitSymbol.getName(), unitSymbol.getType().getTypeName()) << "\"\n";
|
||||||
|
} else {
|
||||||
|
infoSink.info << " " << StageName(getStage()) << " stage: Block: " << symbol.getType().getTypeName() << " Instance: " << symbol.getName()
|
||||||
|
<< ": \"" << symbol.getType().getCompleteString(true, printQualifiers, printPrecision, printType) << "\"\n";
|
||||||
|
infoSink.info << " " << StageName(unitStage) << " stage: Block: " << unitSymbol.getType().getTypeName() << " Instance: " << unitSymbol.getName()
|
||||||
|
<< ": \"" << unitSymbol.getType().getCompleteString(true, printQualifiers, printPrecision, printType) << "\"\n";
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (printType) {
|
||||||
|
infoSink.info << " " << StageName(getStage()) << " stage: \""
|
||||||
|
<< symbol.getType().getCompleteString(true, printQualifiers, printPrecision, printType, symbol.getName()) << "\"\n";
|
||||||
|
infoSink.info << " " << StageName(unitStage) << " stage: \""
|
||||||
|
<< unitSymbol.getType().getCompleteString(true, printQualifiers, printPrecision, printType, unitSymbol.getName()) << "\"\n";
|
||||||
|
} else {
|
||||||
|
infoSink.info << " " << StageName(getStage()) << " stage: " << symbol.getName() << " \""
|
||||||
|
<< symbol.getType().getCompleteString(true, printQualifiers, printPrecision, printType) << "\"\n";
|
||||||
|
infoSink.info << " " << StageName(unitStage) << " stage: " << unitSymbol.getName() << " \""
|
||||||
|
<< unitSymbol.getType().getCompleteString(true, printQualifiers, printPrecision, printType) << "\"\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -1136,8 +1295,8 @@ void TIntermediate::finalCheck(TInfoSink& infoSink, bool keepUncalled)
|
|||||||
error(infoSink, "At least one shader must specify a layout(max_vertices = value)");
|
error(infoSink, "At least one shader must specify a layout(max_vertices = value)");
|
||||||
break;
|
break;
|
||||||
case EShLangFragment:
|
case EShLangFragment:
|
||||||
// for GL_ARB_post_depth_coverage, EarlyFragmentTest is set automatically in
|
// for GL_ARB_post_depth_coverage, EarlyFragmentTest is set automatically in
|
||||||
// ParseHelper.cpp. So if we reach here, this must be GL_EXT_post_depth_coverage
|
// ParseHelper.cpp. So if we reach here, this must be GL_EXT_post_depth_coverage
|
||||||
// requiring explicit early_fragment_tests
|
// requiring explicit early_fragment_tests
|
||||||
if (getPostDepthCoverage() && !getEarlyFragmentTests())
|
if (getPostDepthCoverage() && !getEarlyFragmentTests())
|
||||||
error(infoSink, "post_depth_coverage requires early_fragment_tests");
|
error(infoSink, "post_depth_coverage requires early_fragment_tests");
|
||||||
@ -1154,7 +1313,7 @@ void TIntermediate::finalCheck(TInfoSink& infoSink, bool keepUncalled)
|
|||||||
if (numShaderRecordBlocks > 1)
|
if (numShaderRecordBlocks > 1)
|
||||||
error(infoSink, "Only one shaderRecordNV buffer block is allowed per stage");
|
error(infoSink, "Only one shaderRecordNV buffer block is allowed per stage");
|
||||||
break;
|
break;
|
||||||
case EShLangMeshNV:
|
case EShLangMesh:
|
||||||
// NV_mesh_shader doesn't allow use of both single-view and per-view builtins.
|
// NV_mesh_shader doesn't allow use of both single-view and per-view builtins.
|
||||||
if (inIoAccessed("gl_Position") && inIoAccessed("gl_PositionPerViewNV"))
|
if (inIoAccessed("gl_Position") && inIoAccessed("gl_PositionPerViewNV"))
|
||||||
error(infoSink, "Can only use one of gl_Position or gl_PositionPerViewNV");
|
error(infoSink, "Can only use one of gl_Position or gl_PositionPerViewNV");
|
||||||
@ -1173,9 +1332,11 @@ void TIntermediate::finalCheck(TInfoSink& infoSink, bool keepUncalled)
|
|||||||
if (primitives == TQualifier::layoutNotSet)
|
if (primitives == TQualifier::layoutNotSet)
|
||||||
error(infoSink, "At least one shader must specify a layout(max_primitives = value)");
|
error(infoSink, "At least one shader must specify a layout(max_primitives = value)");
|
||||||
// fall through
|
// fall through
|
||||||
case EShLangTaskNV:
|
case EShLangTask:
|
||||||
if (numTaskNVBlocks > 1)
|
if (numTaskNVBlocks > 1)
|
||||||
error(infoSink, "Only one taskNV interface block is allowed per shader");
|
error(infoSink, "Only one taskNV interface block is allowed per shader");
|
||||||
|
if (numTaskEXTPayloads > 1)
|
||||||
|
error(infoSink, "Only single variable of type taskPayloadSharedEXT is allowed per shader");
|
||||||
sharedBlockCheck(infoSink);
|
sharedBlockCheck(infoSink);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -2068,7 +2229,7 @@ int TIntermediate::getScalarAlignment(const TType& type, int& size, int& stride,
|
|||||||
|
|
||||||
if (type.isVector()) {
|
if (type.isVector()) {
|
||||||
int scalarAlign = getBaseAlignmentScalar(type, size);
|
int scalarAlign = getBaseAlignmentScalar(type, size);
|
||||||
|
|
||||||
size *= type.getVectorSize();
|
size *= type.getVectorSize();
|
||||||
return scalarAlign;
|
return scalarAlign;
|
||||||
}
|
}
|
||||||
@ -2089,7 +2250,7 @@ int TIntermediate::getScalarAlignment(const TType& type, int& size, int& stride,
|
|||||||
|
|
||||||
assert(0); // all cases should be covered above
|
assert(0); // all cases should be covered above
|
||||||
size = 1;
|
size = 1;
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int TIntermediate::getMemberAlignment(const TType& type, int& size, int& stride, TLayoutPacking layoutPacking, bool rowMajor)
|
int TIntermediate::getMemberAlignment(const TType& type, int& size, int& stride, TLayoutPacking layoutPacking, bool rowMajor)
|
||||||
@ -2179,8 +2340,8 @@ bool TIntermediate::isIoResizeArray(const TType& type, EShLanguage language) {
|
|||||||
! type.getQualifier().patch) ||
|
! type.getQualifier().patch) ||
|
||||||
(language == EShLangTessEvaluation && type.getQualifier().storage == EvqVaryingIn) ||
|
(language == EShLangTessEvaluation && type.getQualifier().storage == EvqVaryingIn) ||
|
||||||
(language == EShLangFragment && type.getQualifier().storage == EvqVaryingIn &&
|
(language == EShLangFragment && type.getQualifier().storage == EvqVaryingIn &&
|
||||||
type.getQualifier().pervertexNV) ||
|
(type.getQualifier().pervertexNV || type.getQualifier().pervertexEXT)) ||
|
||||||
(language == EShLangMeshNV && type.getQualifier().storage == EvqVaryingOut &&
|
(language == EShLangMesh && type.getQualifier().storage == EvqVaryingOut &&
|
||||||
!type.getQualifier().perTaskNV));
|
!type.getQualifier().perTaskNV));
|
||||||
}
|
}
|
||||||
#endif // not GLSLANG_WEB
|
#endif // not GLSLANG_WEB
|
||||||
|
@ -291,10 +291,13 @@ public:
|
|||||||
numEntryPoints(0), numErrors(0), numPushConstants(0), recursive(false),
|
numEntryPoints(0), numErrors(0), numPushConstants(0), recursive(false),
|
||||||
invertY(false),
|
invertY(false),
|
||||||
dxPositionW(false),
|
dxPositionW(false),
|
||||||
|
enhancedMsgs(false),
|
||||||
|
debugInfo(false),
|
||||||
useStorageBuffer(false),
|
useStorageBuffer(false),
|
||||||
invariantAll(false),
|
invariantAll(false),
|
||||||
nanMinMaxClamp(false),
|
nanMinMaxClamp(false),
|
||||||
depthReplacing(false),
|
depthReplacing(false),
|
||||||
|
stencilReplacing(false),
|
||||||
uniqueId(0),
|
uniqueId(0),
|
||||||
globalUniformBlockName(""),
|
globalUniformBlockName(""),
|
||||||
atomicCounterBlockName(""),
|
atomicCounterBlockName(""),
|
||||||
@ -308,9 +311,9 @@ public:
|
|||||||
useVulkanMemoryModel(false),
|
useVulkanMemoryModel(false),
|
||||||
invocations(TQualifier::layoutNotSet), vertices(TQualifier::layoutNotSet),
|
invocations(TQualifier::layoutNotSet), vertices(TQualifier::layoutNotSet),
|
||||||
inputPrimitive(ElgNone), outputPrimitive(ElgNone),
|
inputPrimitive(ElgNone), outputPrimitive(ElgNone),
|
||||||
pixelCenterInteger(false), originUpperLeft(false),
|
pixelCenterInteger(false), originUpperLeft(false),texCoordBuiltinRedeclared(false),
|
||||||
vertexSpacing(EvsNone), vertexOrder(EvoNone), interlockOrdering(EioNone), pointMode(false), earlyFragmentTests(false),
|
vertexSpacing(EvsNone), vertexOrder(EvoNone), interlockOrdering(EioNone), pointMode(false), earlyFragmentTests(false),
|
||||||
postDepthCoverage(false), depthLayout(EldNone),
|
postDepthCoverage(false), earlyAndLateFragmentTestsAMD(false), depthLayout(EldNone), stencilLayout(ElsNone),
|
||||||
hlslFunctionality1(false),
|
hlslFunctionality1(false),
|
||||||
blendEquations(0), xfbMode(false), multiStream(false),
|
blendEquations(0), xfbMode(false), multiStream(false),
|
||||||
layoutOverrideCoverage(false),
|
layoutOverrideCoverage(false),
|
||||||
@ -320,6 +323,7 @@ public:
|
|||||||
primitives(TQualifier::layoutNotSet),
|
primitives(TQualifier::layoutNotSet),
|
||||||
numTaskNVBlocks(0),
|
numTaskNVBlocks(0),
|
||||||
layoutPrimitiveCulling(false),
|
layoutPrimitiveCulling(false),
|
||||||
|
numTaskEXTPayloads(0),
|
||||||
autoMapBindings(false),
|
autoMapBindings(false),
|
||||||
autoMapLocations(false),
|
autoMapLocations(false),
|
||||||
flattenUniformArrays(false),
|
flattenUniformArrays(false),
|
||||||
@ -459,6 +463,12 @@ public:
|
|||||||
const std::string& getEntryPointName() const { return entryPointName; }
|
const std::string& getEntryPointName() const { return entryPointName; }
|
||||||
const std::string& getEntryPointMangledName() const { return entryPointMangledName; }
|
const std::string& getEntryPointMangledName() const { return entryPointMangledName; }
|
||||||
|
|
||||||
|
void setDebugInfo(bool debuginfo)
|
||||||
|
{
|
||||||
|
debugInfo = debuginfo;
|
||||||
|
}
|
||||||
|
bool getDebugInfo() const { return debugInfo; }
|
||||||
|
|
||||||
void setInvertY(bool invert)
|
void setInvertY(bool invert)
|
||||||
{
|
{
|
||||||
invertY = invert;
|
invertY = invert;
|
||||||
@ -469,12 +479,18 @@ public:
|
|||||||
|
|
||||||
void setDxPositionW(bool dxPosW)
|
void setDxPositionW(bool dxPosW)
|
||||||
{
|
{
|
||||||
dxPositionW = dxPosW;
|
dxPositionW = dxPosW;
|
||||||
if (dxPositionW)
|
if (dxPositionW)
|
||||||
processes.addProcess("dx-position-w");
|
processes.addProcess("dx-position-w");
|
||||||
}
|
}
|
||||||
bool getDxPositionW() const { return dxPositionW; }
|
bool getDxPositionW() const { return dxPositionW; }
|
||||||
|
|
||||||
|
void setEnhancedMsgs()
|
||||||
|
{
|
||||||
|
enhancedMsgs = true;
|
||||||
|
}
|
||||||
|
bool getEnhancedMsgs() const { return enhancedMsgs && getSource() == EShSourceGlsl; }
|
||||||
|
|
||||||
#ifdef ENABLE_HLSL
|
#ifdef ENABLE_HLSL
|
||||||
void setSource(EShSource s) { source = s; }
|
void setSource(EShSource s) { source = s; }
|
||||||
EShSource getSource() const { return source; }
|
EShSource getSource() const { return source; }
|
||||||
@ -580,6 +596,8 @@ public:
|
|||||||
bool isInvariantAll() const { return invariantAll; }
|
bool isInvariantAll() const { return invariantAll; }
|
||||||
void setDepthReplacing() { depthReplacing = true; }
|
void setDepthReplacing() { depthReplacing = true; }
|
||||||
bool isDepthReplacing() const { return depthReplacing; }
|
bool isDepthReplacing() const { return depthReplacing; }
|
||||||
|
void setStencilReplacing() { stencilReplacing = true; }
|
||||||
|
bool isStencilReplacing() const { return stencilReplacing; }
|
||||||
bool setLocalSize(int dim, int size)
|
bool setLocalSize(int dim, int size)
|
||||||
{
|
{
|
||||||
if (localSizeNotDefault[dim])
|
if (localSizeNotDefault[dim])
|
||||||
@ -629,6 +647,7 @@ public:
|
|||||||
int getNumPushConstants() const { return 0; }
|
int getNumPushConstants() const { return 0; }
|
||||||
void addShaderRecordCount() { }
|
void addShaderRecordCount() { }
|
||||||
void addTaskNVCount() { }
|
void addTaskNVCount() { }
|
||||||
|
void addTaskPayloadEXTCount() { }
|
||||||
void setUseVulkanMemoryModel() { }
|
void setUseVulkanMemoryModel() { }
|
||||||
bool usingVulkanMemoryModel() const { return false; }
|
bool usingVulkanMemoryModel() const { return false; }
|
||||||
bool usingPhysicalStorageBuffer() const { return false; }
|
bool usingPhysicalStorageBuffer() const { return false; }
|
||||||
@ -746,6 +765,7 @@ public:
|
|||||||
int getNumPushConstants() const { return numPushConstants; }
|
int getNumPushConstants() const { return numPushConstants; }
|
||||||
void addShaderRecordCount() { ++numShaderRecordBlocks; }
|
void addShaderRecordCount() { ++numShaderRecordBlocks; }
|
||||||
void addTaskNVCount() { ++numTaskNVBlocks; }
|
void addTaskNVCount() { ++numTaskNVBlocks; }
|
||||||
|
void addTaskPayloadEXTCount() { ++numTaskEXTPayloads; }
|
||||||
|
|
||||||
bool setInvocations(int i)
|
bool setInvocations(int i)
|
||||||
{
|
{
|
||||||
@ -814,7 +834,9 @@ public:
|
|||||||
void setPostDepthCoverage() { postDepthCoverage = true; }
|
void setPostDepthCoverage() { postDepthCoverage = true; }
|
||||||
bool getPostDepthCoverage() const { return postDepthCoverage; }
|
bool getPostDepthCoverage() const { return postDepthCoverage; }
|
||||||
void setEarlyFragmentTests() { earlyFragmentTests = true; }
|
void setEarlyFragmentTests() { earlyFragmentTests = true; }
|
||||||
|
void setEarlyAndLateFragmentTestsAMD() { earlyAndLateFragmentTestsAMD = true; }
|
||||||
bool getEarlyFragmentTests() const { return earlyFragmentTests; }
|
bool getEarlyFragmentTests() const { return earlyFragmentTests; }
|
||||||
|
bool getEarlyAndLateFragmentTestsAMD() const { return earlyAndLateFragmentTestsAMD; }
|
||||||
bool setDepth(TLayoutDepth d)
|
bool setDepth(TLayoutDepth d)
|
||||||
{
|
{
|
||||||
if (depthLayout != EldNone)
|
if (depthLayout != EldNone)
|
||||||
@ -822,11 +844,21 @@ public:
|
|||||||
depthLayout = d;
|
depthLayout = d;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
bool setStencil(TLayoutStencil s)
|
||||||
|
{
|
||||||
|
if (stencilLayout != ElsNone)
|
||||||
|
return stencilLayout == s;
|
||||||
|
stencilLayout = s;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
TLayoutDepth getDepth() const { return depthLayout; }
|
TLayoutDepth getDepth() const { return depthLayout; }
|
||||||
|
TLayoutStencil getStencil() const { return stencilLayout; }
|
||||||
void setOriginUpperLeft() { originUpperLeft = true; }
|
void setOriginUpperLeft() { originUpperLeft = true; }
|
||||||
bool getOriginUpperLeft() const { return originUpperLeft; }
|
bool getOriginUpperLeft() const { return originUpperLeft; }
|
||||||
void setPixelCenterInteger() { pixelCenterInteger = true; }
|
void setPixelCenterInteger() { pixelCenterInteger = true; }
|
||||||
bool getPixelCenterInteger() const { return pixelCenterInteger; }
|
bool getPixelCenterInteger() const { return pixelCenterInteger; }
|
||||||
|
void setTexCoordRedeclared() { texCoordBuiltinRedeclared = true; }
|
||||||
|
bool getTexCoordRedeclared() const { return texCoordBuiltinRedeclared; }
|
||||||
void addBlendEquation(TBlendEquationShift b) { blendEquations |= (1 << b); }
|
void addBlendEquation(TBlendEquationShift b) { blendEquations |= (1 << b); }
|
||||||
unsigned int getBlendEquations() const { return blendEquations; }
|
unsigned int getBlendEquations() const { return blendEquations; }
|
||||||
bool setXfbBufferStride(int buffer, unsigned stride)
|
bool setXfbBufferStride(int buffer, unsigned stride)
|
||||||
@ -1031,8 +1063,8 @@ public:
|
|||||||
|
|
||||||
protected:
|
protected:
|
||||||
TIntermSymbol* addSymbol(long long Id, const TString&, const TType&, const TConstUnionArray&, TIntermTyped* subtree, const TSourceLoc&);
|
TIntermSymbol* addSymbol(long long Id, const TString&, const TType&, const TConstUnionArray&, TIntermTyped* subtree, const TSourceLoc&);
|
||||||
void error(TInfoSink& infoSink, const char*);
|
void error(TInfoSink& infoSink, const char*, EShLanguage unitStage = EShLangCount);
|
||||||
void warn(TInfoSink& infoSink, const char*);
|
void warn(TInfoSink& infoSink, const char*, EShLanguage unitStage = EShLangCount);
|
||||||
void mergeCallGraphs(TInfoSink&, TIntermediate&);
|
void mergeCallGraphs(TInfoSink&, TIntermediate&);
|
||||||
void mergeModes(TInfoSink&, TIntermediate&);
|
void mergeModes(TInfoSink&, TIntermediate&);
|
||||||
void mergeTrees(TInfoSink&, TIntermediate&);
|
void mergeTrees(TInfoSink&, TIntermediate&);
|
||||||
@ -1086,10 +1118,13 @@ protected:
|
|||||||
bool recursive;
|
bool recursive;
|
||||||
bool invertY;
|
bool invertY;
|
||||||
bool dxPositionW;
|
bool dxPositionW;
|
||||||
|
bool enhancedMsgs;
|
||||||
|
bool debugInfo;
|
||||||
bool useStorageBuffer;
|
bool useStorageBuffer;
|
||||||
bool invariantAll;
|
bool invariantAll;
|
||||||
bool nanMinMaxClamp; // true if desiring min/max/clamp to favor non-NaN over NaN
|
bool nanMinMaxClamp; // true if desiring min/max/clamp to favor non-NaN over NaN
|
||||||
bool depthReplacing;
|
bool depthReplacing;
|
||||||
|
bool stencilReplacing;
|
||||||
int localSize[3];
|
int localSize[3];
|
||||||
bool localSizeNotDefault[3];
|
bool localSizeNotDefault[3];
|
||||||
int localSizeSpecId[3];
|
int localSizeSpecId[3];
|
||||||
@ -1114,13 +1149,16 @@ protected:
|
|||||||
TLayoutGeometry outputPrimitive;
|
TLayoutGeometry outputPrimitive;
|
||||||
bool pixelCenterInteger;
|
bool pixelCenterInteger;
|
||||||
bool originUpperLeft;
|
bool originUpperLeft;
|
||||||
|
bool texCoordBuiltinRedeclared;
|
||||||
TVertexSpacing vertexSpacing;
|
TVertexSpacing vertexSpacing;
|
||||||
TVertexOrder vertexOrder;
|
TVertexOrder vertexOrder;
|
||||||
TInterlockOrdering interlockOrdering;
|
TInterlockOrdering interlockOrdering;
|
||||||
bool pointMode;
|
bool pointMode;
|
||||||
bool earlyFragmentTests;
|
bool earlyFragmentTests;
|
||||||
bool postDepthCoverage;
|
bool postDepthCoverage;
|
||||||
|
bool earlyAndLateFragmentTestsAMD;
|
||||||
TLayoutDepth depthLayout;
|
TLayoutDepth depthLayout;
|
||||||
|
TLayoutStencil stencilLayout;
|
||||||
bool hlslFunctionality1;
|
bool hlslFunctionality1;
|
||||||
int blendEquations; // an 'or'ing of masks of shifts of TBlendEquationShift
|
int blendEquations; // an 'or'ing of masks of shifts of TBlendEquationShift
|
||||||
bool xfbMode;
|
bool xfbMode;
|
||||||
@ -1133,6 +1171,7 @@ protected:
|
|||||||
int primitives;
|
int primitives;
|
||||||
int numTaskNVBlocks;
|
int numTaskNVBlocks;
|
||||||
bool layoutPrimitiveCulling;
|
bool layoutPrimitiveCulling;
|
||||||
|
int numTaskEXTPayloads;
|
||||||
|
|
||||||
// Base shift values
|
// Base shift values
|
||||||
std::array<unsigned int, EResCount> shiftBinding;
|
std::array<unsigned int, EResCount> shiftBinding;
|
||||||
@ -1174,6 +1213,7 @@ protected:
|
|||||||
// for callableData/callableDataIn
|
// for callableData/callableDataIn
|
||||||
// set of names of statically read/written I/O that might need extra checking
|
// set of names of statically read/written I/O that might need extra checking
|
||||||
std::set<TString> ioAccessed;
|
std::set<TString> ioAccessed;
|
||||||
|
|
||||||
// source code of shader, useful as part of debug information
|
// source code of shader, useful as part of debug information
|
||||||
std::string sourceFile;
|
std::string sourceFile;
|
||||||
std::string sourceText;
|
std::string sourceText;
|
||||||
|
@ -56,15 +56,6 @@ namespace glslang {
|
|||||||
// Thread cleanup
|
// Thread cleanup
|
||||||
//
|
//
|
||||||
|
|
||||||
//
|
|
||||||
// Wrapper for Linux call to DetachThread. This is required as pthread_cleanup_push() expects
|
|
||||||
// the cleanup routine to return void.
|
|
||||||
//
|
|
||||||
static void DetachThreadLinux(void *)
|
|
||||||
{
|
|
||||||
DetachThread();
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Thread Local Storage Operations
|
// Thread Local Storage Operations
|
||||||
//
|
//
|
||||||
|
23
thirdparty/glslang/glslang/Public/ShaderLang.h
vendored
23
thirdparty/glslang/glslang/Public/ShaderLang.h
vendored
@ -108,8 +108,10 @@ typedef enum {
|
|||||||
EShLangMissNV = EShLangMiss,
|
EShLangMissNV = EShLangMiss,
|
||||||
EShLangCallable,
|
EShLangCallable,
|
||||||
EShLangCallableNV = EShLangCallable,
|
EShLangCallableNV = EShLangCallable,
|
||||||
EShLangTaskNV,
|
EShLangTask,
|
||||||
EShLangMeshNV,
|
EShLangTaskNV = EShLangTask,
|
||||||
|
EShLangMesh,
|
||||||
|
EShLangMeshNV = EShLangMesh,
|
||||||
LAST_ELEMENT_MARKER(EShLangCount),
|
LAST_ELEMENT_MARKER(EShLangCount),
|
||||||
} EShLanguage; // would be better as stage, but this is ancient now
|
} EShLanguage; // would be better as stage, but this is ancient now
|
||||||
|
|
||||||
@ -132,8 +134,10 @@ typedef enum : unsigned {
|
|||||||
EShLangMissNVMask = EShLangMissMask,
|
EShLangMissNVMask = EShLangMissMask,
|
||||||
EShLangCallableMask = (1 << EShLangCallable),
|
EShLangCallableMask = (1 << EShLangCallable),
|
||||||
EShLangCallableNVMask = EShLangCallableMask,
|
EShLangCallableNVMask = EShLangCallableMask,
|
||||||
EShLangTaskNVMask = (1 << EShLangTaskNV),
|
EShLangTaskMask = (1 << EShLangTask),
|
||||||
EShLangMeshNVMask = (1 << EShLangMeshNV),
|
EShLangTaskNVMask = EShLangTaskMask,
|
||||||
|
EShLangMeshMask = (1 << EShLangMesh),
|
||||||
|
EShLangMeshNVMask = EShLangMeshMask,
|
||||||
LAST_ELEMENT_MARKER(EShLanguageMaskCount),
|
LAST_ELEMENT_MARKER(EShLanguageMaskCount),
|
||||||
} EShLanguageMask;
|
} EShLanguageMask;
|
||||||
|
|
||||||
@ -264,6 +268,7 @@ enum EShMessages : unsigned {
|
|||||||
EShMsgHlslLegalization = (1 << 12), // enable HLSL Legalization messages
|
EShMsgHlslLegalization = (1 << 12), // enable HLSL Legalization messages
|
||||||
EShMsgHlslDX9Compatible = (1 << 13), // enable HLSL DX9 compatible mode (for samplers and semantics)
|
EShMsgHlslDX9Compatible = (1 << 13), // enable HLSL DX9 compatible mode (for samplers and semantics)
|
||||||
EShMsgBuiltinSymbolTable = (1 << 14), // print the builtin symbol table
|
EShMsgBuiltinSymbolTable = (1 << 14), // print the builtin symbol table
|
||||||
|
EShMsgEnhanced = (1 << 15), // enhanced message readability
|
||||||
LAST_ELEMENT_MARKER(EShMsgCount),
|
LAST_ELEMENT_MARKER(EShMsgCount),
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -300,7 +305,7 @@ typedef struct {
|
|||||||
|
|
||||||
//
|
//
|
||||||
// ShHandle held by but opaque to the driver. It is allocated,
|
// ShHandle held by but opaque to the driver. It is allocated,
|
||||||
// managed, and de-allocated by the compiler/linker. It's contents
|
// managed, and de-allocated by the compiler/linker. Its contents
|
||||||
// are defined by and used by the compiler and linker. For example,
|
// are defined by and used by the compiler and linker. For example,
|
||||||
// symbol table information and object code passed from the compiler
|
// symbol table information and object code passed from the compiler
|
||||||
// to the linker can be stored where ShHandle points.
|
// to the linker can be stored where ShHandle points.
|
||||||
@ -470,6 +475,8 @@ public:
|
|||||||
GLSLANG_EXPORT void setSourceEntryPoint(const char* sourceEntryPointName);
|
GLSLANG_EXPORT void setSourceEntryPoint(const char* sourceEntryPointName);
|
||||||
GLSLANG_EXPORT void addProcesses(const std::vector<std::string>&);
|
GLSLANG_EXPORT void addProcesses(const std::vector<std::string>&);
|
||||||
GLSLANG_EXPORT void setUniqueId(unsigned long long id);
|
GLSLANG_EXPORT void setUniqueId(unsigned long long id);
|
||||||
|
GLSLANG_EXPORT void setOverrideVersion(int version);
|
||||||
|
GLSLANG_EXPORT void setDebugInfo(bool debugInfo);
|
||||||
|
|
||||||
// IO resolver binding data: see comments in ShaderLang.cpp
|
// IO resolver binding data: see comments in ShaderLang.cpp
|
||||||
GLSLANG_EXPORT void setShiftBinding(TResourceType res, unsigned int base);
|
GLSLANG_EXPORT void setShiftBinding(TResourceType res, unsigned int base);
|
||||||
@ -488,6 +495,7 @@ public:
|
|||||||
GLSLANG_EXPORT void setUniformLocationBase(int base);
|
GLSLANG_EXPORT void setUniformLocationBase(int base);
|
||||||
GLSLANG_EXPORT void setInvertY(bool invert);
|
GLSLANG_EXPORT void setInvertY(bool invert);
|
||||||
GLSLANG_EXPORT void setDxPositionW(bool dxPosW);
|
GLSLANG_EXPORT void setDxPositionW(bool dxPosW);
|
||||||
|
GLSLANG_EXPORT void setEnhancedMsgs();
|
||||||
#ifdef ENABLE_HLSL
|
#ifdef ENABLE_HLSL
|
||||||
GLSLANG_EXPORT void setHlslIoMapping(bool hlslIoMap);
|
GLSLANG_EXPORT void setHlslIoMapping(bool hlslIoMap);
|
||||||
GLSLANG_EXPORT void setFlattenUniformArrays(bool flatten);
|
GLSLANG_EXPORT void setFlattenUniformArrays(bool flatten);
|
||||||
@ -522,7 +530,7 @@ public:
|
|||||||
// See the definitions of TEnvironment, EShSource, EShLanguage,
|
// See the definitions of TEnvironment, EShSource, EShLanguage,
|
||||||
// and EShClient for choices and more detail.
|
// and EShClient for choices and more detail.
|
||||||
//
|
//
|
||||||
// setEnvClient: The client that will be hosting the execution, and it's version.
|
// setEnvClient: The client that will be hosting the execution, and its version.
|
||||||
// Note 'version' is not the version of the languages involved, but
|
// Note 'version' is not the version of the languages involved, but
|
||||||
// the version of the client environment.
|
// the version of the client environment.
|
||||||
// Use EShClientNone and version of 0 if there is no client, e.g.
|
// Use EShClientNone and version of 0 if there is no client, e.g.
|
||||||
@ -709,6 +717,9 @@ protected:
|
|||||||
// a function in the source string can be renamed FROM this TO the name given in setEntryPoint.
|
// a function in the source string can be renamed FROM this TO the name given in setEntryPoint.
|
||||||
std::string sourceEntryPointName;
|
std::string sourceEntryPointName;
|
||||||
|
|
||||||
|
// overrides #version in shader source or default version if #version isn't present
|
||||||
|
int overrideVersion;
|
||||||
|
|
||||||
TEnvironment environment;
|
TEnvironment environment;
|
||||||
|
|
||||||
friend class TProgram;
|
friend class TProgram;
|
||||||
|
26
thirdparty/glslang/glslang/build_info.h
vendored
26
thirdparty/glslang/glslang/build_info.h
vendored
@ -35,28 +35,28 @@
|
|||||||
#define GLSLANG_BUILD_INFO
|
#define GLSLANG_BUILD_INFO
|
||||||
|
|
||||||
#define GLSLANG_VERSION_MAJOR 11
|
#define GLSLANG_VERSION_MAJOR 11
|
||||||
#define GLSLANG_VERSION_MINOR 8
|
#define GLSLANG_VERSION_MINOR 12
|
||||||
#define GLSLANG_VERSION_PATCH 0
|
#define GLSLANG_VERSION_PATCH 0
|
||||||
#define GLSLANG_VERSION_FLAVOR ""
|
#define GLSLANG_VERSION_FLAVOR ""
|
||||||
|
|
||||||
#define GLSLANG_VERSION_GREATER_THAN(major, minor, patch) \
|
#define GLSLANG_VERSION_GREATER_THAN(major, minor, patch) \
|
||||||
(((major) > GLSLANG_VERSION_MAJOR) || ((major) == GLSLANG_VERSION_MAJOR && \
|
((GLSLANG_VERSION_MAJOR) > (major) || ((major) == GLSLANG_VERSION_MAJOR && \
|
||||||
(((minor) > GLSLANG_VERSION_MINOR) || ((minor) == GLSLANG_VERSION_MINOR && \
|
((GLSLANG_VERSION_MINOR) > (minor) || ((minor) == GLSLANG_VERSION_MINOR && \
|
||||||
((patch) > GLSLANG_VERSION_PATCH)))))
|
(GLSLANG_VERSION_PATCH) > (patch)))))
|
||||||
|
|
||||||
#define GLSLANG_VERSION_GREATER_OR_EQUAL_TO(major, minor, patch) \
|
#define GLSLANG_VERSION_GREATER_OR_EQUAL_TO(major, minor, patch) \
|
||||||
(((major) > GLSLANG_VERSION_MAJOR) || ((major) == GLSLANG_VERSION_MAJOR && \
|
((GLSLANG_VERSION_MAJOR) > (major) || ((major) == GLSLANG_VERSION_MAJOR && \
|
||||||
(((minor) > GLSLANG_VERSION_MINOR) || ((minor) == GLSLANG_VERSION_MINOR && \
|
((GLSLANG_VERSION_MINOR) > (minor) || ((minor) == GLSLANG_VERSION_MINOR && \
|
||||||
((patch) >= GLSLANG_VERSION_PATCH)))))
|
(GLSLANG_VERSION_PATCH >= (patch))))))
|
||||||
|
|
||||||
#define GLSLANG_VERSION_LESS_THAN(major, minor, patch) \
|
#define GLSLANG_VERSION_LESS_THAN(major, minor, patch) \
|
||||||
(((major) < GLSLANG_VERSION_MAJOR) || ((major) == GLSLANG_VERSION_MAJOR && \
|
((GLSLANG_VERSION_MAJOR) < (major) || ((major) == GLSLANG_VERSION_MAJOR && \
|
||||||
(((minor) < GLSLANG_VERSION_MINOR) || ((minor) == GLSLANG_VERSION_MINOR && \
|
((GLSLANG_VERSION_MINOR) < (minor) || ((minor) == GLSLANG_VERSION_MINOR && \
|
||||||
((patch) < GLSLANG_VERSION_PATCH)))))
|
(GLSLANG_VERSION_PATCH) < (patch)))))
|
||||||
|
|
||||||
#define GLSLANG_VERSION_LESS_OR_EQUAL_TO(major, minor, patch) \
|
#define GLSLANG_VERSION_LESS_OR_EQUAL_TO(major, minor, patch) \
|
||||||
(((major) < GLSLANG_VERSION_MAJOR) || ((major) == GLSLANG_VERSION_MAJOR && \
|
((GLSLANG_VERSION_MAJOR) < (major) || ((major) == GLSLANG_VERSION_MAJOR && \
|
||||||
(((minor) < GLSLANG_VERSION_MINOR) || ((minor) == GLSLANG_VERSION_MINOR && \
|
((GLSLANG_VERSION_MINOR) < (minor) || ((minor) == GLSLANG_VERSION_MINOR && \
|
||||||
((patch) <= GLSLANG_VERSION_PATCH)))))
|
(GLSLANG_VERSION_PATCH <= (patch))))))
|
||||||
|
|
||||||
#endif // GLSLANG_BUILD_INFO
|
#endif // GLSLANG_BUILD_INFO
|
||||||
|
61
thirdparty/glslang/patches/unused_cleanup.diff
vendored
61
thirdparty/glslang/patches/unused_cleanup.diff
vendored
@ -1,61 +0,0 @@
|
|||||||
diff --git a/thirdparty/glslang/glslang/OSDependent/Unix/ossource.cpp b/thirdparty/glslang/glslang/OSDependent/Unix/ossource.cpp
|
|
||||||
index 81da99c2c4..1cbd616e98 100644
|
|
||||||
--- a/thirdparty/glslang/glslang/OSDependent/Unix/ossource.cpp
|
|
||||||
+++ b/thirdparty/glslang/glslang/OSDependent/Unix/ossource.cpp
|
|
||||||
@@ -65,43 +65,6 @@ static void DetachThreadLinux(void *)
|
|
||||||
DetachThread();
|
|
||||||
}
|
|
||||||
|
|
||||||
-//
|
|
||||||
-// Registers cleanup handler, sets cancel type and state, and executes the thread specific
|
|
||||||
-// cleanup handler. This function will be called in the Standalone.cpp for regression
|
|
||||||
-// testing. When OpenGL applications are run with the driver code, Linux OS does the
|
|
||||||
-// thread cleanup.
|
|
||||||
-//
|
|
||||||
-void OS_CleanupThreadData(void)
|
|
||||||
-{
|
|
||||||
-#if defined(__ANDROID__) || defined(__Fuchsia__)
|
|
||||||
- DetachThreadLinux(NULL);
|
|
||||||
-#else
|
|
||||||
- int old_cancel_state, old_cancel_type;
|
|
||||||
- void *cleanupArg = NULL;
|
|
||||||
-
|
|
||||||
- //
|
|
||||||
- // Set thread cancel state and push cleanup handler.
|
|
||||||
- //
|
|
||||||
- pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, &old_cancel_state);
|
|
||||||
- pthread_cleanup_push(DetachThreadLinux, (void *) cleanupArg);
|
|
||||||
-
|
|
||||||
- //
|
|
||||||
- // Put the thread in deferred cancellation mode.
|
|
||||||
- //
|
|
||||||
- pthread_setcanceltype(PTHREAD_CANCEL_DEFERRED, &old_cancel_type);
|
|
||||||
-
|
|
||||||
- //
|
|
||||||
- // Pop cleanup handler and execute it prior to unregistering the cleanup handler.
|
|
||||||
- //
|
|
||||||
- pthread_cleanup_pop(1);
|
|
||||||
-
|
|
||||||
- //
|
|
||||||
- // Restore the thread's previous cancellation mode.
|
|
||||||
- //
|
|
||||||
- pthread_setcanceltype(old_cancel_state, NULL);
|
|
||||||
-#endif
|
|
||||||
-}
|
|
||||||
-
|
|
||||||
//
|
|
||||||
// Thread Local Storage Operations
|
|
||||||
//
|
|
||||||
diff --git a/thirdparty/glslang/glslang/OSDependent/osinclude.h b/thirdparty/glslang/glslang/OSDependent/osinclude.h
|
|
||||||
index 218abe4f23..fcfeff2cc4 100644
|
|
||||||
--- a/thirdparty/glslang/glslang/OSDependent/osinclude.h
|
|
||||||
+++ b/thirdparty/glslang/glslang/OSDependent/osinclude.h
|
|
||||||
@@ -54,8 +54,6 @@ void ReleaseGlobalLock();
|
|
||||||
|
|
||||||
typedef unsigned int (*TThreadEntrypoint)(void*);
|
|
||||||
|
|
||||||
-void OS_CleanupThreadData(void);
|
|
||||||
-
|
|
||||||
void OS_DumpMemoryCounters();
|
|
||||||
|
|
||||||
} // end namespace glslang
|
|
@ -1,5 +1,5 @@
|
|||||||
diff --git a/thirdparty/spirv-reflect/spirv_reflect.c b/thirdparty/spirv-reflect/spirv_reflect.c
|
diff --git a/thirdparty/spirv-reflect/spirv_reflect.c b/thirdparty/spirv-reflect/spirv_reflect.c
|
||||||
index cdcf3ca663..c174ae1900 100644
|
index 8c70ebecfb..c5ed7ab07d 100644
|
||||||
--- a/thirdparty/spirv-reflect/spirv_reflect.c
|
--- a/thirdparty/spirv-reflect/spirv_reflect.c
|
||||||
+++ b/thirdparty/spirv-reflect/spirv_reflect.c
|
+++ b/thirdparty/spirv-reflect/spirv_reflect.c
|
||||||
@@ -126,6 +126,9 @@ typedef struct SpvReflectPrvDecorations {
|
@@ -126,6 +126,9 @@ typedef struct SpvReflectPrvDecorations {
|
||||||
@ -12,7 +12,7 @@ index cdcf3ca663..c174ae1900 100644
|
|||||||
SpvReflectPrvStringDecoration semantic;
|
SpvReflectPrvStringDecoration semantic;
|
||||||
uint32_t array_stride;
|
uint32_t array_stride;
|
||||||
uint32_t matrix_stride;
|
uint32_t matrix_stride;
|
||||||
@@ -639,6 +642,9 @@ static SpvReflectResult ParseNodes(SpvReflectPrvParser* p_parser)
|
@@ -641,6 +644,9 @@ static SpvReflectResult ParseNodes(SpvReflectPrvParser* p_parser)
|
||||||
p_parser->nodes[i].decorations.offset.value = (uint32_t)INVALID_VALUE;
|
p_parser->nodes[i].decorations.offset.value = (uint32_t)INVALID_VALUE;
|
||||||
p_parser->nodes[i].decorations.uav_counter_buffer.value = (uint32_t)INVALID_VALUE;
|
p_parser->nodes[i].decorations.uav_counter_buffer.value = (uint32_t)INVALID_VALUE;
|
||||||
p_parser->nodes[i].decorations.built_in = (SpvBuiltIn)INVALID_VALUE;
|
p_parser->nodes[i].decorations.built_in = (SpvBuiltIn)INVALID_VALUE;
|
||||||
@ -22,7 +22,7 @@ index cdcf3ca663..c174ae1900 100644
|
|||||||
}
|
}
|
||||||
// Mark source file id node
|
// Mark source file id node
|
||||||
p_parser->source_file_id = (uint32_t)INVALID_VALUE;
|
p_parser->source_file_id = (uint32_t)INVALID_VALUE;
|
||||||
@@ -829,10 +835,16 @@ static SpvReflectResult ParseNodes(SpvReflectPrvParser* p_parser)
|
@@ -837,10 +843,16 @@ static SpvReflectResult ParseNodes(SpvReflectPrvParser* p_parser)
|
||||||
CHECKED_READU32(p_parser, p_node->word_offset + 2, p_node->result_id);
|
CHECKED_READU32(p_parser, p_node->word_offset + 2, p_node->result_id);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -41,7 +41,7 @@ index cdcf3ca663..c174ae1900 100644
|
|||||||
case SpvOpSpecConstantComposite:
|
case SpvOpSpecConstantComposite:
|
||||||
case SpvOpSpecConstantOp: {
|
case SpvOpSpecConstantOp: {
|
||||||
CHECKED_READU32(p_parser, p_node->word_offset + 1, p_node->result_type_id);
|
CHECKED_READU32(p_parser, p_node->word_offset + 1, p_node->result_type_id);
|
||||||
@@ -864,7 +876,7 @@ static SpvReflectResult ParseNodes(SpvReflectPrvParser* p_parser)
|
@@ -872,7 +884,7 @@ static SpvReflectResult ParseNodes(SpvReflectPrvParser* p_parser)
|
||||||
CHECKED_READU32(p_parser, p_node->word_offset + 3, p_access_chain->base_id);
|
CHECKED_READU32(p_parser, p_node->word_offset + 3, p_access_chain->base_id);
|
||||||
//
|
//
|
||||||
// SPIRV_ACCESS_CHAIN_INDEX_OFFSET (4) is the number of words up until the first index:
|
// SPIRV_ACCESS_CHAIN_INDEX_OFFSET (4) is the number of words up until the first index:
|
||||||
@ -50,7 +50,7 @@ index cdcf3ca663..c174ae1900 100644
|
|||||||
//
|
//
|
||||||
p_access_chain->index_count = (node_word_count - SPIRV_ACCESS_CHAIN_INDEX_OFFSET);
|
p_access_chain->index_count = (node_word_count - SPIRV_ACCESS_CHAIN_INDEX_OFFSET);
|
||||||
if (p_access_chain->index_count > 0) {
|
if (p_access_chain->index_count > 0) {
|
||||||
@@ -1346,6 +1358,9 @@ static SpvReflectResult ParseDecorations(SpvReflectPrvParser* p_parser)
|
@@ -1354,6 +1366,9 @@ static SpvReflectResult ParseDecorations(SpvReflectPrvParser* p_parser)
|
||||||
skip = true;
|
skip = true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -60,7 +60,7 @@ index cdcf3ca663..c174ae1900 100644
|
|||||||
case SpvDecorationRelaxedPrecision:
|
case SpvDecorationRelaxedPrecision:
|
||||||
case SpvDecorationBlock:
|
case SpvDecorationBlock:
|
||||||
case SpvDecorationBufferBlock:
|
case SpvDecorationBufferBlock:
|
||||||
@@ -1495,7 +1510,14 @@ static SpvReflectResult ParseDecorations(SpvReflectPrvParser* p_parser)
|
@@ -1503,7 +1518,14 @@ static SpvReflectResult ParseDecorations(SpvReflectPrvParser* p_parser)
|
||||||
p_target_decorations->input_attachment_index.word_offset = word_offset;
|
p_target_decorations->input_attachment_index.word_offset = word_offset;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -76,7 +76,7 @@ index cdcf3ca663..c174ae1900 100644
|
|||||||
case SpvReflectDecorationHlslCounterBufferGOOGLE: {
|
case SpvReflectDecorationHlslCounterBufferGOOGLE: {
|
||||||
uint32_t word_offset = p_node->word_offset + member_offset+ 3;
|
uint32_t word_offset = p_node->word_offset + member_offset+ 3;
|
||||||
CHECKED_READU32(p_parser, word_offset, p_target_decorations->uav_counter_buffer.value);
|
CHECKED_READU32(p_parser, word_offset, p_target_decorations->uav_counter_buffer.value);
|
||||||
@@ -1803,6 +1825,13 @@ static SpvReflectResult ParseType(
|
@@ -1811,6 +1833,13 @@ static SpvReflectResult ParseType(
|
||||||
p_type->type_flags |= SPV_REFLECT_TYPE_FLAG_EXTERNAL_ACCELERATION_STRUCTURE;
|
p_type->type_flags |= SPV_REFLECT_TYPE_FLAG_EXTERNAL_ACCELERATION_STRUCTURE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -90,7 +90,7 @@ index cdcf3ca663..c174ae1900 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (result == SPV_REFLECT_RESULT_SUCCESS) {
|
if (result == SPV_REFLECT_RESULT_SUCCESS) {
|
||||||
@@ -3332,6 +3361,69 @@ static SpvReflectResult ParseExecutionModes(
|
@@ -3378,6 +3407,69 @@ static SpvReflectResult ParseExecutionModes(
|
||||||
return SPV_REFLECT_RESULT_SUCCESS;
|
return SPV_REFLECT_RESULT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -160,7 +160,7 @@ index cdcf3ca663..c174ae1900 100644
|
|||||||
static SpvReflectResult ParsePushConstantBlocks(
|
static SpvReflectResult ParsePushConstantBlocks(
|
||||||
SpvReflectPrvParser* p_parser,
|
SpvReflectPrvParser* p_parser,
|
||||||
SpvReflectShaderModule* p_module)
|
SpvReflectShaderModule* p_module)
|
||||||
@@ -3717,6 +3809,12 @@ static SpvReflectResult CreateShaderModule(
|
@@ -3763,6 +3855,12 @@ static SpvReflectResult CreateShaderModule(
|
||||||
result = ParsePushConstantBlocks(&parser, p_module);
|
result = ParsePushConstantBlocks(&parser, p_module);
|
||||||
SPV_REFLECT_ASSERT(result == SPV_REFLECT_RESULT_SUCCESS);
|
SPV_REFLECT_ASSERT(result == SPV_REFLECT_RESULT_SUCCESS);
|
||||||
}
|
}
|
||||||
@ -173,9 +173,9 @@ index cdcf3ca663..c174ae1900 100644
|
|||||||
if (result == SPV_REFLECT_RESULT_SUCCESS) {
|
if (result == SPV_REFLECT_RESULT_SUCCESS) {
|
||||||
result = ParseEntryPoints(&parser, p_module);
|
result = ParseEntryPoints(&parser, p_module);
|
||||||
SPV_REFLECT_ASSERT(result == SPV_REFLECT_RESULT_SUCCESS);
|
SPV_REFLECT_ASSERT(result == SPV_REFLECT_RESULT_SUCCESS);
|
||||||
@@ -3875,6 +3973,9 @@ void spvReflectDestroyShaderModule(SpvReflectShaderModule* p_module)
|
@@ -3926,6 +4024,9 @@ void spvReflectDestroyShaderModule(SpvReflectShaderModule* p_module)
|
||||||
SafeFree(p_entry->execution_modes);
|
|
||||||
}
|
}
|
||||||
|
SafeFree(p_module->capabilities);
|
||||||
SafeFree(p_module->entry_points);
|
SafeFree(p_module->entry_points);
|
||||||
+// -- GODOT begin --
|
+// -- GODOT begin --
|
||||||
+ SafeFree(p_module->specialization_constants);
|
+ SafeFree(p_module->specialization_constants);
|
||||||
@ -183,7 +183,7 @@ index cdcf3ca663..c174ae1900 100644
|
|||||||
|
|
||||||
// Push constants
|
// Push constants
|
||||||
for (size_t i = 0; i < p_module->push_constant_block_count; ++i) {
|
for (size_t i = 0; i < p_module->push_constant_block_count; ++i) {
|
||||||
@@ -4145,6 +4246,38 @@ SpvReflectResult spvReflectEnumerateEntryPointInterfaceVariables(
|
@@ -4196,6 +4297,38 @@ SpvReflectResult spvReflectEnumerateEntryPointInterfaceVariables(
|
||||||
return SPV_REFLECT_RESULT_SUCCESS;
|
return SPV_REFLECT_RESULT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -223,7 +223,7 @@ index cdcf3ca663..c174ae1900 100644
|
|||||||
const SpvReflectShaderModule* p_module,
|
const SpvReflectShaderModule* p_module,
|
||||||
uint32_t* p_count,
|
uint32_t* p_count,
|
||||||
diff --git a/thirdparty/spirv-reflect/spirv_reflect.h b/thirdparty/spirv-reflect/spirv_reflect.h
|
diff --git a/thirdparty/spirv-reflect/spirv_reflect.h b/thirdparty/spirv-reflect/spirv_reflect.h
|
||||||
index 02b81613a1..02850f8811 100644
|
index 690ae6c105..1ea99d8266 100644
|
||||||
--- a/thirdparty/spirv-reflect/spirv_reflect.h
|
--- a/thirdparty/spirv-reflect/spirv_reflect.h
|
||||||
+++ b/thirdparty/spirv-reflect/spirv_reflect.h
|
+++ b/thirdparty/spirv-reflect/spirv_reflect.h
|
||||||
@@ -329,6 +329,28 @@ typedef struct SpvReflectTypeDescription {
|
@@ -329,6 +329,28 @@ typedef struct SpvReflectTypeDescription {
|
||||||
@ -255,7 +255,7 @@ index 02b81613a1..02850f8811 100644
|
|||||||
|
|
||||||
/*! @struct SpvReflectInterfaceVariable
|
/*! @struct SpvReflectInterfaceVariable
|
||||||
|
|
||||||
@@ -483,6 +505,10 @@ typedef struct SpvReflectShaderModule {
|
@@ -493,6 +515,10 @@ typedef struct SpvReflectShaderModule {
|
||||||
SpvReflectInterfaceVariable* interface_variables; // Uses value(s) from first entry point
|
SpvReflectInterfaceVariable* interface_variables; // Uses value(s) from first entry point
|
||||||
uint32_t push_constant_block_count; // Uses value(s) from first entry point
|
uint32_t push_constant_block_count; // Uses value(s) from first entry point
|
||||||
SpvReflectBlockVariable* push_constant_blocks; // Uses value(s) from first entry point
|
SpvReflectBlockVariable* push_constant_blocks; // Uses value(s) from first entry point
|
||||||
@ -266,7 +266,7 @@ index 02b81613a1..02850f8811 100644
|
|||||||
|
|
||||||
struct Internal {
|
struct Internal {
|
||||||
SpvReflectModuleFlags module_flags;
|
SpvReflectModuleFlags module_flags;
|
||||||
@@ -755,6 +781,33 @@ SpvReflectResult spvReflectEnumerateInputVariables(
|
@@ -765,6 +791,33 @@ SpvReflectResult spvReflectEnumerateInputVariables(
|
||||||
SpvReflectInterfaceVariable** pp_variables
|
SpvReflectInterfaceVariable** pp_variables
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
diff --git a/thirdparty/spirv-reflect/spirv_reflect.c b/thirdparty/spirv-reflect/spirv_reflect.c
|
diff --git a/thirdparty/spirv-reflect/spirv_reflect.c b/thirdparty/spirv-reflect/spirv_reflect.c
|
||||||
index c174ae1900..11ccbdee3a 100644
|
index c5ed7ab07d..f2be1f8cae 100644
|
||||||
--- a/thirdparty/spirv-reflect/spirv_reflect.c
|
--- a/thirdparty/spirv-reflect/spirv_reflect.c
|
||||||
+++ b/thirdparty/spirv-reflect/spirv_reflect.c
|
+++ b/thirdparty/spirv-reflect/spirv_reflect.c
|
||||||
@@ -3322,12 +3322,18 @@ static SpvReflectResult ParseExecutionModes(
|
@@ -3368,12 +3368,18 @@ static SpvReflectResult ParseExecutionModes(
|
||||||
}
|
}
|
||||||
for (size_t entry_point_idx = 0; entry_point_idx < p_module->entry_point_count; ++entry_point_idx) {
|
for (size_t entry_point_idx = 0; entry_point_idx < p_module->entry_point_count; ++entry_point_idx) {
|
||||||
SpvReflectEntryPoint* p_entry_point = &p_module->entry_points[entry_point_idx];
|
SpvReflectEntryPoint* p_entry_point = &p_module->entry_points[entry_point_idx];
|
||||||
|
51
thirdparty/spirv-reflect/spirv_reflect.c
vendored
51
thirdparty/spirv-reflect/spirv_reflect.c
vendored
@ -142,6 +142,7 @@ typedef struct SpvReflectPrvNode {
|
|||||||
SpvOp op;
|
SpvOp op;
|
||||||
uint32_t result_type_id;
|
uint32_t result_type_id;
|
||||||
uint32_t type_id;
|
uint32_t type_id;
|
||||||
|
SpvCapability capability;
|
||||||
SpvStorageClass storage_class;
|
SpvStorageClass storage_class;
|
||||||
uint32_t word_offset;
|
uint32_t word_offset;
|
||||||
uint32_t word_count;
|
uint32_t word_count;
|
||||||
@ -208,6 +209,7 @@ typedef struct SpvReflectPrvParser {
|
|||||||
size_t node_count;
|
size_t node_count;
|
||||||
SpvReflectPrvNode* nodes;
|
SpvReflectPrvNode* nodes;
|
||||||
uint32_t entry_point_count;
|
uint32_t entry_point_count;
|
||||||
|
uint32_t capability_count;
|
||||||
uint32_t function_count;
|
uint32_t function_count;
|
||||||
SpvReflectPrvFunction* functions;
|
SpvReflectPrvFunction* functions;
|
||||||
uint32_t access_chain_count;
|
uint32_t access_chain_count;
|
||||||
@ -739,6 +741,12 @@ static SpvReflectResult ParseNodes(SpvReflectPrvParser* p_parser)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case SpvOpCapability: {
|
||||||
|
CHECKED_READU32(p_parser, p_node->word_offset + 1, p_node->capability);
|
||||||
|
++(p_parser->capability_count);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case SpvOpName:
|
case SpvOpName:
|
||||||
case SpvOpMemberName:
|
case SpvOpMemberName:
|
||||||
{
|
{
|
||||||
@ -1886,6 +1894,44 @@ static SpvReflectResult ParseTypes(
|
|||||||
return SPV_REFLECT_RESULT_SUCCESS;
|
return SPV_REFLECT_RESULT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static SpvReflectResult ParseCapabilities(
|
||||||
|
SpvReflectPrvParser* p_parser,
|
||||||
|
SpvReflectShaderModule* p_module)
|
||||||
|
{
|
||||||
|
if (p_parser->capability_count == 0) {
|
||||||
|
return SPV_REFLECT_RESULT_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
p_module->capability_count = p_parser->capability_count;
|
||||||
|
p_module->capabilities = (SpvReflectCapability*)calloc(p_module->capability_count,
|
||||||
|
sizeof(*(p_module->capabilities)));
|
||||||
|
if (IsNull(p_module->capabilities)) {
|
||||||
|
return SPV_REFLECT_RESULT_ERROR_ALLOC_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Mark all types with an invalid state
|
||||||
|
for (size_t i = 0; i < p_module->capability_count; ++i) {
|
||||||
|
SpvReflectCapability* p_cap = &(p_module->capabilities[i]);
|
||||||
|
p_cap->value = SpvCapabilityMax;
|
||||||
|
p_cap->word_offset = (uint32_t)INVALID_VALUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t capability_index = 0;
|
||||||
|
for (size_t i = 0; i < p_parser->node_count; ++i) {
|
||||||
|
SpvReflectPrvNode* p_node = &(p_parser->nodes[i]);
|
||||||
|
if (SpvOpCapability != p_node->op) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
SpvReflectCapability* p_cap = &(p_module->capabilities[capability_index]);
|
||||||
|
p_cap->value = p_node->capability;
|
||||||
|
p_cap->word_offset = p_node->word_offset + 1;
|
||||||
|
++capability_index;
|
||||||
|
}
|
||||||
|
|
||||||
|
return SPV_REFLECT_RESULT_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
static int SortCompareDescriptorBinding(const void* a, const void* b)
|
static int SortCompareDescriptorBinding(const void* a, const void* b)
|
||||||
{
|
{
|
||||||
const SpvReflectDescriptorBinding* p_elem_a = (const SpvReflectDescriptorBinding*)a;
|
const SpvReflectDescriptorBinding* p_elem_a = (const SpvReflectDescriptorBinding*)a;
|
||||||
@ -3825,6 +3871,10 @@ static SpvReflectResult CreateShaderModule(
|
|||||||
result = ParseEntryPoints(&parser, p_module);
|
result = ParseEntryPoints(&parser, p_module);
|
||||||
SPV_REFLECT_ASSERT(result == SPV_REFLECT_RESULT_SUCCESS);
|
SPV_REFLECT_ASSERT(result == SPV_REFLECT_RESULT_SUCCESS);
|
||||||
}
|
}
|
||||||
|
if (result == SPV_REFLECT_RESULT_SUCCESS) {
|
||||||
|
result = ParseCapabilities(&parser, p_module);
|
||||||
|
SPV_REFLECT_ASSERT(result == SPV_REFLECT_RESULT_SUCCESS);
|
||||||
|
}
|
||||||
if (result == SPV_REFLECT_RESULT_SUCCESS && p_module->entry_point_count > 0) {
|
if (result == SPV_REFLECT_RESULT_SUCCESS && p_module->entry_point_count > 0) {
|
||||||
SpvReflectEntryPoint* p_entry = &(p_module->entry_points[0]);
|
SpvReflectEntryPoint* p_entry = &(p_module->entry_points[0]);
|
||||||
p_module->entry_point_name = p_entry->name;
|
p_module->entry_point_name = p_entry->name;
|
||||||
@ -3978,6 +4028,7 @@ void spvReflectDestroyShaderModule(SpvReflectShaderModule* p_module)
|
|||||||
SafeFree(p_entry->used_push_constants);
|
SafeFree(p_entry->used_push_constants);
|
||||||
SafeFree(p_entry->execution_modes);
|
SafeFree(p_entry->execution_modes);
|
||||||
}
|
}
|
||||||
|
SafeFree(p_module->capabilities);
|
||||||
SafeFree(p_module->entry_points);
|
SafeFree(p_module->entry_points);
|
||||||
// -- GODOT begin --
|
// -- GODOT begin --
|
||||||
SafeFree(p_module->specialization_constants);
|
SafeFree(p_module->specialization_constants);
|
||||||
|
10
thirdparty/spirv-reflect/spirv_reflect.h
vendored
10
thirdparty/spirv-reflect/spirv_reflect.h
vendored
@ -478,6 +478,14 @@ typedef struct SpvReflectEntryPoint {
|
|||||||
uint32_t output_vertices; // valid for geometry, tesselation
|
uint32_t output_vertices; // valid for geometry, tesselation
|
||||||
} SpvReflectEntryPoint;
|
} SpvReflectEntryPoint;
|
||||||
|
|
||||||
|
/*! @struct SpvReflectCapability
|
||||||
|
|
||||||
|
*/
|
||||||
|
typedef struct SpvReflectCapability {
|
||||||
|
SpvCapability value;
|
||||||
|
uint32_t word_offset;
|
||||||
|
} SpvReflectCapability;
|
||||||
|
|
||||||
/*! @struct SpvReflectShaderModule
|
/*! @struct SpvReflectShaderModule
|
||||||
|
|
||||||
*/
|
*/
|
||||||
@ -491,6 +499,8 @@ typedef struct SpvReflectShaderModule {
|
|||||||
uint32_t source_language_version;
|
uint32_t source_language_version;
|
||||||
const char* source_file;
|
const char* source_file;
|
||||||
const char* source_source;
|
const char* source_source;
|
||||||
|
uint32_t capability_count;
|
||||||
|
SpvReflectCapability* capabilities;
|
||||||
SpvExecutionModel spirv_execution_model; // Uses value(s) from first entry point
|
SpvExecutionModel spirv_execution_model; // Uses value(s) from first entry point
|
||||||
SpvReflectShaderStageFlagBits shader_stage; // Uses value(s) from first entry point
|
SpvReflectShaderStageFlagBits shader_stage; // Uses value(s) from first entry point
|
||||||
uint32_t descriptor_binding_count; // Uses value(s) from first entry point
|
uint32_t descriptor_binding_count; // Uses value(s) from first entry point
|
||||||
|
2
thirdparty/volk/LICENSE.md
vendored
2
thirdparty/volk/LICENSE.md
vendored
@ -1,4 +1,4 @@
|
|||||||
Copyright (c) 2018-2019 Arseny Kapoulkine
|
Copyright (c) 2018-2022 Arseny Kapoulkine
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
265
thirdparty/volk/volk.c
vendored
265
thirdparty/volk/volk.c
vendored
@ -338,6 +338,9 @@ static void volkGenLoadInstance(void* context, PFN_vkVoidFunction (*load)(void*,
|
|||||||
#if defined(VK_NV_external_memory_capabilities)
|
#if defined(VK_NV_external_memory_capabilities)
|
||||||
vkGetPhysicalDeviceExternalImageFormatPropertiesNV = (PFN_vkGetPhysicalDeviceExternalImageFormatPropertiesNV)load(context, "vkGetPhysicalDeviceExternalImageFormatPropertiesNV");
|
vkGetPhysicalDeviceExternalImageFormatPropertiesNV = (PFN_vkGetPhysicalDeviceExternalImageFormatPropertiesNV)load(context, "vkGetPhysicalDeviceExternalImageFormatPropertiesNV");
|
||||||
#endif /* defined(VK_NV_external_memory_capabilities) */
|
#endif /* defined(VK_NV_external_memory_capabilities) */
|
||||||
|
#if defined(VK_NV_optical_flow)
|
||||||
|
vkGetPhysicalDeviceOpticalFlowImageFormatsNV = (PFN_vkGetPhysicalDeviceOpticalFlowImageFormatsNV)load(context, "vkGetPhysicalDeviceOpticalFlowImageFormatsNV");
|
||||||
|
#endif /* defined(VK_NV_optical_flow) */
|
||||||
#if defined(VK_QNX_screen_surface)
|
#if defined(VK_QNX_screen_surface)
|
||||||
vkCreateScreenSurfaceQNX = (PFN_vkCreateScreenSurfaceQNX)load(context, "vkCreateScreenSurfaceQNX");
|
vkCreateScreenSurfaceQNX = (PFN_vkCreateScreenSurfaceQNX)load(context, "vkCreateScreenSurfaceQNX");
|
||||||
vkGetPhysicalDeviceScreenPresentationSupportQNX = (PFN_vkGetPhysicalDeviceScreenPresentationSupportQNX)load(context, "vkGetPhysicalDeviceScreenPresentationSupportQNX");
|
vkGetPhysicalDeviceScreenPresentationSupportQNX = (PFN_vkGetPhysicalDeviceScreenPresentationSupportQNX)load(context, "vkGetPhysicalDeviceScreenPresentationSupportQNX");
|
||||||
@ -581,6 +584,9 @@ static void volkGenLoadDevice(void* context, PFN_vkVoidFunction (*load)(void*, c
|
|||||||
vkDebugMarkerSetObjectNameEXT = (PFN_vkDebugMarkerSetObjectNameEXT)load(context, "vkDebugMarkerSetObjectNameEXT");
|
vkDebugMarkerSetObjectNameEXT = (PFN_vkDebugMarkerSetObjectNameEXT)load(context, "vkDebugMarkerSetObjectNameEXT");
|
||||||
vkDebugMarkerSetObjectTagEXT = (PFN_vkDebugMarkerSetObjectTagEXT)load(context, "vkDebugMarkerSetObjectTagEXT");
|
vkDebugMarkerSetObjectTagEXT = (PFN_vkDebugMarkerSetObjectTagEXT)load(context, "vkDebugMarkerSetObjectTagEXT");
|
||||||
#endif /* defined(VK_EXT_debug_marker) */
|
#endif /* defined(VK_EXT_debug_marker) */
|
||||||
|
#if defined(VK_EXT_device_fault)
|
||||||
|
vkGetDeviceFaultInfoEXT = (PFN_vkGetDeviceFaultInfoEXT)load(context, "vkGetDeviceFaultInfoEXT");
|
||||||
|
#endif /* defined(VK_EXT_device_fault) */
|
||||||
#if defined(VK_EXT_discard_rectangles)
|
#if defined(VK_EXT_discard_rectangles)
|
||||||
vkCmdSetDiscardRectangleEXT = (PFN_vkCmdSetDiscardRectangleEXT)load(context, "vkCmdSetDiscardRectangleEXT");
|
vkCmdSetDiscardRectangleEXT = (PFN_vkCmdSetDiscardRectangleEXT)load(context, "vkCmdSetDiscardRectangleEXT");
|
||||||
#endif /* defined(VK_EXT_discard_rectangles) */
|
#endif /* defined(VK_EXT_discard_rectangles) */
|
||||||
@ -611,6 +617,39 @@ static void volkGenLoadDevice(void* context, PFN_vkVoidFunction (*load)(void*, c
|
|||||||
vkCmdSetPrimitiveRestartEnableEXT = (PFN_vkCmdSetPrimitiveRestartEnableEXT)load(context, "vkCmdSetPrimitiveRestartEnableEXT");
|
vkCmdSetPrimitiveRestartEnableEXT = (PFN_vkCmdSetPrimitiveRestartEnableEXT)load(context, "vkCmdSetPrimitiveRestartEnableEXT");
|
||||||
vkCmdSetRasterizerDiscardEnableEXT = (PFN_vkCmdSetRasterizerDiscardEnableEXT)load(context, "vkCmdSetRasterizerDiscardEnableEXT");
|
vkCmdSetRasterizerDiscardEnableEXT = (PFN_vkCmdSetRasterizerDiscardEnableEXT)load(context, "vkCmdSetRasterizerDiscardEnableEXT");
|
||||||
#endif /* defined(VK_EXT_extended_dynamic_state2) */
|
#endif /* defined(VK_EXT_extended_dynamic_state2) */
|
||||||
|
#if defined(VK_EXT_extended_dynamic_state3)
|
||||||
|
vkCmdSetAlphaToCoverageEnableEXT = (PFN_vkCmdSetAlphaToCoverageEnableEXT)load(context, "vkCmdSetAlphaToCoverageEnableEXT");
|
||||||
|
vkCmdSetAlphaToOneEnableEXT = (PFN_vkCmdSetAlphaToOneEnableEXT)load(context, "vkCmdSetAlphaToOneEnableEXT");
|
||||||
|
vkCmdSetColorBlendAdvancedEXT = (PFN_vkCmdSetColorBlendAdvancedEXT)load(context, "vkCmdSetColorBlendAdvancedEXT");
|
||||||
|
vkCmdSetColorBlendEnableEXT = (PFN_vkCmdSetColorBlendEnableEXT)load(context, "vkCmdSetColorBlendEnableEXT");
|
||||||
|
vkCmdSetColorBlendEquationEXT = (PFN_vkCmdSetColorBlendEquationEXT)load(context, "vkCmdSetColorBlendEquationEXT");
|
||||||
|
vkCmdSetColorWriteMaskEXT = (PFN_vkCmdSetColorWriteMaskEXT)load(context, "vkCmdSetColorWriteMaskEXT");
|
||||||
|
vkCmdSetConservativeRasterizationModeEXT = (PFN_vkCmdSetConservativeRasterizationModeEXT)load(context, "vkCmdSetConservativeRasterizationModeEXT");
|
||||||
|
vkCmdSetCoverageModulationModeNV = (PFN_vkCmdSetCoverageModulationModeNV)load(context, "vkCmdSetCoverageModulationModeNV");
|
||||||
|
vkCmdSetCoverageModulationTableEnableNV = (PFN_vkCmdSetCoverageModulationTableEnableNV)load(context, "vkCmdSetCoverageModulationTableEnableNV");
|
||||||
|
vkCmdSetCoverageModulationTableNV = (PFN_vkCmdSetCoverageModulationTableNV)load(context, "vkCmdSetCoverageModulationTableNV");
|
||||||
|
vkCmdSetCoverageReductionModeNV = (PFN_vkCmdSetCoverageReductionModeNV)load(context, "vkCmdSetCoverageReductionModeNV");
|
||||||
|
vkCmdSetCoverageToColorEnableNV = (PFN_vkCmdSetCoverageToColorEnableNV)load(context, "vkCmdSetCoverageToColorEnableNV");
|
||||||
|
vkCmdSetCoverageToColorLocationNV = (PFN_vkCmdSetCoverageToColorLocationNV)load(context, "vkCmdSetCoverageToColorLocationNV");
|
||||||
|
vkCmdSetDepthClampEnableEXT = (PFN_vkCmdSetDepthClampEnableEXT)load(context, "vkCmdSetDepthClampEnableEXT");
|
||||||
|
vkCmdSetDepthClipEnableEXT = (PFN_vkCmdSetDepthClipEnableEXT)load(context, "vkCmdSetDepthClipEnableEXT");
|
||||||
|
vkCmdSetDepthClipNegativeOneToOneEXT = (PFN_vkCmdSetDepthClipNegativeOneToOneEXT)load(context, "vkCmdSetDepthClipNegativeOneToOneEXT");
|
||||||
|
vkCmdSetExtraPrimitiveOverestimationSizeEXT = (PFN_vkCmdSetExtraPrimitiveOverestimationSizeEXT)load(context, "vkCmdSetExtraPrimitiveOverestimationSizeEXT");
|
||||||
|
vkCmdSetLineRasterizationModeEXT = (PFN_vkCmdSetLineRasterizationModeEXT)load(context, "vkCmdSetLineRasterizationModeEXT");
|
||||||
|
vkCmdSetLineStippleEnableEXT = (PFN_vkCmdSetLineStippleEnableEXT)load(context, "vkCmdSetLineStippleEnableEXT");
|
||||||
|
vkCmdSetLogicOpEnableEXT = (PFN_vkCmdSetLogicOpEnableEXT)load(context, "vkCmdSetLogicOpEnableEXT");
|
||||||
|
vkCmdSetPolygonModeEXT = (PFN_vkCmdSetPolygonModeEXT)load(context, "vkCmdSetPolygonModeEXT");
|
||||||
|
vkCmdSetProvokingVertexModeEXT = (PFN_vkCmdSetProvokingVertexModeEXT)load(context, "vkCmdSetProvokingVertexModeEXT");
|
||||||
|
vkCmdSetRasterizationSamplesEXT = (PFN_vkCmdSetRasterizationSamplesEXT)load(context, "vkCmdSetRasterizationSamplesEXT");
|
||||||
|
vkCmdSetRasterizationStreamEXT = (PFN_vkCmdSetRasterizationStreamEXT)load(context, "vkCmdSetRasterizationStreamEXT");
|
||||||
|
vkCmdSetRepresentativeFragmentTestEnableNV = (PFN_vkCmdSetRepresentativeFragmentTestEnableNV)load(context, "vkCmdSetRepresentativeFragmentTestEnableNV");
|
||||||
|
vkCmdSetSampleLocationsEnableEXT = (PFN_vkCmdSetSampleLocationsEnableEXT)load(context, "vkCmdSetSampleLocationsEnableEXT");
|
||||||
|
vkCmdSetSampleMaskEXT = (PFN_vkCmdSetSampleMaskEXT)load(context, "vkCmdSetSampleMaskEXT");
|
||||||
|
vkCmdSetShadingRateImageEnableNV = (PFN_vkCmdSetShadingRateImageEnableNV)load(context, "vkCmdSetShadingRateImageEnableNV");
|
||||||
|
vkCmdSetTessellationDomainOriginEXT = (PFN_vkCmdSetTessellationDomainOriginEXT)load(context, "vkCmdSetTessellationDomainOriginEXT");
|
||||||
|
vkCmdSetViewportSwizzleNV = (PFN_vkCmdSetViewportSwizzleNV)load(context, "vkCmdSetViewportSwizzleNV");
|
||||||
|
vkCmdSetViewportWScalingEnableNV = (PFN_vkCmdSetViewportWScalingEnableNV)load(context, "vkCmdSetViewportWScalingEnableNV");
|
||||||
|
#endif /* defined(VK_EXT_extended_dynamic_state3) */
|
||||||
#if defined(VK_EXT_external_memory_host)
|
#if defined(VK_EXT_external_memory_host)
|
||||||
vkGetMemoryHostPointerPropertiesEXT = (PFN_vkGetMemoryHostPointerPropertiesEXT)load(context, "vkGetMemoryHostPointerPropertiesEXT");
|
vkGetMemoryHostPointerPropertiesEXT = (PFN_vkGetMemoryHostPointerPropertiesEXT)load(context, "vkGetMemoryHostPointerPropertiesEXT");
|
||||||
#endif /* defined(VK_EXT_external_memory_host) */
|
#endif /* defined(VK_EXT_external_memory_host) */
|
||||||
@ -624,19 +663,49 @@ static void volkGenLoadDevice(void* context, PFN_vkVoidFunction (*load)(void*, c
|
|||||||
#if defined(VK_EXT_host_query_reset)
|
#if defined(VK_EXT_host_query_reset)
|
||||||
vkResetQueryPoolEXT = (PFN_vkResetQueryPoolEXT)load(context, "vkResetQueryPoolEXT");
|
vkResetQueryPoolEXT = (PFN_vkResetQueryPoolEXT)load(context, "vkResetQueryPoolEXT");
|
||||||
#endif /* defined(VK_EXT_host_query_reset) */
|
#endif /* defined(VK_EXT_host_query_reset) */
|
||||||
|
#if defined(VK_EXT_image_compression_control)
|
||||||
|
vkGetImageSubresourceLayout2EXT = (PFN_vkGetImageSubresourceLayout2EXT)load(context, "vkGetImageSubresourceLayout2EXT");
|
||||||
|
#endif /* defined(VK_EXT_image_compression_control) */
|
||||||
#if defined(VK_EXT_image_drm_format_modifier)
|
#if defined(VK_EXT_image_drm_format_modifier)
|
||||||
vkGetImageDrmFormatModifierPropertiesEXT = (PFN_vkGetImageDrmFormatModifierPropertiesEXT)load(context, "vkGetImageDrmFormatModifierPropertiesEXT");
|
vkGetImageDrmFormatModifierPropertiesEXT = (PFN_vkGetImageDrmFormatModifierPropertiesEXT)load(context, "vkGetImageDrmFormatModifierPropertiesEXT");
|
||||||
#endif /* defined(VK_EXT_image_drm_format_modifier) */
|
#endif /* defined(VK_EXT_image_drm_format_modifier) */
|
||||||
#if defined(VK_EXT_line_rasterization)
|
#if defined(VK_EXT_line_rasterization)
|
||||||
vkCmdSetLineStippleEXT = (PFN_vkCmdSetLineStippleEXT)load(context, "vkCmdSetLineStippleEXT");
|
vkCmdSetLineStippleEXT = (PFN_vkCmdSetLineStippleEXT)load(context, "vkCmdSetLineStippleEXT");
|
||||||
#endif /* defined(VK_EXT_line_rasterization) */
|
#endif /* defined(VK_EXT_line_rasterization) */
|
||||||
|
#if defined(VK_EXT_mesh_shader)
|
||||||
|
vkCmdDrawMeshTasksEXT = (PFN_vkCmdDrawMeshTasksEXT)load(context, "vkCmdDrawMeshTasksEXT");
|
||||||
|
vkCmdDrawMeshTasksIndirectCountEXT = (PFN_vkCmdDrawMeshTasksIndirectCountEXT)load(context, "vkCmdDrawMeshTasksIndirectCountEXT");
|
||||||
|
vkCmdDrawMeshTasksIndirectEXT = (PFN_vkCmdDrawMeshTasksIndirectEXT)load(context, "vkCmdDrawMeshTasksIndirectEXT");
|
||||||
|
#endif /* defined(VK_EXT_mesh_shader) */
|
||||||
|
#if defined(VK_EXT_metal_objects)
|
||||||
|
vkExportMetalObjectsEXT = (PFN_vkExportMetalObjectsEXT)load(context, "vkExportMetalObjectsEXT");
|
||||||
|
#endif /* defined(VK_EXT_metal_objects) */
|
||||||
#if defined(VK_EXT_multi_draw)
|
#if defined(VK_EXT_multi_draw)
|
||||||
vkCmdDrawMultiEXT = (PFN_vkCmdDrawMultiEXT)load(context, "vkCmdDrawMultiEXT");
|
vkCmdDrawMultiEXT = (PFN_vkCmdDrawMultiEXT)load(context, "vkCmdDrawMultiEXT");
|
||||||
vkCmdDrawMultiIndexedEXT = (PFN_vkCmdDrawMultiIndexedEXT)load(context, "vkCmdDrawMultiIndexedEXT");
|
vkCmdDrawMultiIndexedEXT = (PFN_vkCmdDrawMultiIndexedEXT)load(context, "vkCmdDrawMultiIndexedEXT");
|
||||||
#endif /* defined(VK_EXT_multi_draw) */
|
#endif /* defined(VK_EXT_multi_draw) */
|
||||||
|
#if defined(VK_EXT_opacity_micromap)
|
||||||
|
vkBuildMicromapsEXT = (PFN_vkBuildMicromapsEXT)load(context, "vkBuildMicromapsEXT");
|
||||||
|
vkCmdBuildMicromapsEXT = (PFN_vkCmdBuildMicromapsEXT)load(context, "vkCmdBuildMicromapsEXT");
|
||||||
|
vkCmdCopyMemoryToMicromapEXT = (PFN_vkCmdCopyMemoryToMicromapEXT)load(context, "vkCmdCopyMemoryToMicromapEXT");
|
||||||
|
vkCmdCopyMicromapEXT = (PFN_vkCmdCopyMicromapEXT)load(context, "vkCmdCopyMicromapEXT");
|
||||||
|
vkCmdCopyMicromapToMemoryEXT = (PFN_vkCmdCopyMicromapToMemoryEXT)load(context, "vkCmdCopyMicromapToMemoryEXT");
|
||||||
|
vkCmdWriteMicromapsPropertiesEXT = (PFN_vkCmdWriteMicromapsPropertiesEXT)load(context, "vkCmdWriteMicromapsPropertiesEXT");
|
||||||
|
vkCopyMemoryToMicromapEXT = (PFN_vkCopyMemoryToMicromapEXT)load(context, "vkCopyMemoryToMicromapEXT");
|
||||||
|
vkCopyMicromapEXT = (PFN_vkCopyMicromapEXT)load(context, "vkCopyMicromapEXT");
|
||||||
|
vkCopyMicromapToMemoryEXT = (PFN_vkCopyMicromapToMemoryEXT)load(context, "vkCopyMicromapToMemoryEXT");
|
||||||
|
vkCreateMicromapEXT = (PFN_vkCreateMicromapEXT)load(context, "vkCreateMicromapEXT");
|
||||||
|
vkDestroyMicromapEXT = (PFN_vkDestroyMicromapEXT)load(context, "vkDestroyMicromapEXT");
|
||||||
|
vkGetDeviceMicromapCompatibilityEXT = (PFN_vkGetDeviceMicromapCompatibilityEXT)load(context, "vkGetDeviceMicromapCompatibilityEXT");
|
||||||
|
vkGetMicromapBuildSizesEXT = (PFN_vkGetMicromapBuildSizesEXT)load(context, "vkGetMicromapBuildSizesEXT");
|
||||||
|
vkWriteMicromapsPropertiesEXT = (PFN_vkWriteMicromapsPropertiesEXT)load(context, "vkWriteMicromapsPropertiesEXT");
|
||||||
|
#endif /* defined(VK_EXT_opacity_micromap) */
|
||||||
#if defined(VK_EXT_pageable_device_local_memory)
|
#if defined(VK_EXT_pageable_device_local_memory)
|
||||||
vkSetDeviceMemoryPriorityEXT = (PFN_vkSetDeviceMemoryPriorityEXT)load(context, "vkSetDeviceMemoryPriorityEXT");
|
vkSetDeviceMemoryPriorityEXT = (PFN_vkSetDeviceMemoryPriorityEXT)load(context, "vkSetDeviceMemoryPriorityEXT");
|
||||||
#endif /* defined(VK_EXT_pageable_device_local_memory) */
|
#endif /* defined(VK_EXT_pageable_device_local_memory) */
|
||||||
|
#if defined(VK_EXT_pipeline_properties)
|
||||||
|
vkGetPipelinePropertiesEXT = (PFN_vkGetPipelinePropertiesEXT)load(context, "vkGetPipelinePropertiesEXT");
|
||||||
|
#endif /* defined(VK_EXT_pipeline_properties) */
|
||||||
#if defined(VK_EXT_private_data)
|
#if defined(VK_EXT_private_data)
|
||||||
vkCreatePrivateDataSlotEXT = (PFN_vkCreatePrivateDataSlotEXT)load(context, "vkCreatePrivateDataSlotEXT");
|
vkCreatePrivateDataSlotEXT = (PFN_vkCreatePrivateDataSlotEXT)load(context, "vkCreatePrivateDataSlotEXT");
|
||||||
vkDestroyPrivateDataSlotEXT = (PFN_vkDestroyPrivateDataSlotEXT)load(context, "vkDestroyPrivateDataSlotEXT");
|
vkDestroyPrivateDataSlotEXT = (PFN_vkDestroyPrivateDataSlotEXT)load(context, "vkDestroyPrivateDataSlotEXT");
|
||||||
@ -646,6 +715,10 @@ static void volkGenLoadDevice(void* context, PFN_vkVoidFunction (*load)(void*, c
|
|||||||
#if defined(VK_EXT_sample_locations)
|
#if defined(VK_EXT_sample_locations)
|
||||||
vkCmdSetSampleLocationsEXT = (PFN_vkCmdSetSampleLocationsEXT)load(context, "vkCmdSetSampleLocationsEXT");
|
vkCmdSetSampleLocationsEXT = (PFN_vkCmdSetSampleLocationsEXT)load(context, "vkCmdSetSampleLocationsEXT");
|
||||||
#endif /* defined(VK_EXT_sample_locations) */
|
#endif /* defined(VK_EXT_sample_locations) */
|
||||||
|
#if defined(VK_EXT_shader_module_identifier)
|
||||||
|
vkGetShaderModuleCreateInfoIdentifierEXT = (PFN_vkGetShaderModuleCreateInfoIdentifierEXT)load(context, "vkGetShaderModuleCreateInfoIdentifierEXT");
|
||||||
|
vkGetShaderModuleIdentifierEXT = (PFN_vkGetShaderModuleIdentifierEXT)load(context, "vkGetShaderModuleIdentifierEXT");
|
||||||
|
#endif /* defined(VK_EXT_shader_module_identifier) */
|
||||||
#if defined(VK_EXT_transform_feedback)
|
#if defined(VK_EXT_transform_feedback)
|
||||||
vkCmdBeginQueryIndexedEXT = (PFN_vkCmdBeginQueryIndexedEXT)load(context, "vkCmdBeginQueryIndexedEXT");
|
vkCmdBeginQueryIndexedEXT = (PFN_vkCmdBeginQueryIndexedEXT)load(context, "vkCmdBeginQueryIndexedEXT");
|
||||||
vkCmdBeginTransformFeedbackEXT = (PFN_vkCmdBeginTransformFeedbackEXT)load(context, "vkCmdBeginTransformFeedbackEXT");
|
vkCmdBeginTransformFeedbackEXT = (PFN_vkCmdBeginTransformFeedbackEXT)load(context, "vkCmdBeginTransformFeedbackEXT");
|
||||||
@ -827,6 +900,9 @@ static void volkGenLoadDevice(void* context, PFN_vkVoidFunction (*load)(void*, c
|
|||||||
#if defined(VK_KHR_push_descriptor)
|
#if defined(VK_KHR_push_descriptor)
|
||||||
vkCmdPushDescriptorSetKHR = (PFN_vkCmdPushDescriptorSetKHR)load(context, "vkCmdPushDescriptorSetKHR");
|
vkCmdPushDescriptorSetKHR = (PFN_vkCmdPushDescriptorSetKHR)load(context, "vkCmdPushDescriptorSetKHR");
|
||||||
#endif /* defined(VK_KHR_push_descriptor) */
|
#endif /* defined(VK_KHR_push_descriptor) */
|
||||||
|
#if defined(VK_KHR_ray_tracing_maintenance1) && defined(VK_KHR_ray_tracing_pipeline)
|
||||||
|
vkCmdTraceRaysIndirect2KHR = (PFN_vkCmdTraceRaysIndirect2KHR)load(context, "vkCmdTraceRaysIndirect2KHR");
|
||||||
|
#endif /* defined(VK_KHR_ray_tracing_maintenance1) && defined(VK_KHR_ray_tracing_pipeline) */
|
||||||
#if defined(VK_KHR_ray_tracing_pipeline)
|
#if defined(VK_KHR_ray_tracing_pipeline)
|
||||||
vkCmdSetRayTracingPipelineStackSizeKHR = (PFN_vkCmdSetRayTracingPipelineStackSizeKHR)load(context, "vkCmdSetRayTracingPipelineStackSizeKHR");
|
vkCmdSetRayTracingPipelineStackSizeKHR = (PFN_vkCmdSetRayTracingPipelineStackSizeKHR)load(context, "vkCmdSetRayTracingPipelineStackSizeKHR");
|
||||||
vkCmdTraceRaysIndirectKHR = (PFN_vkCmdTraceRaysIndirectKHR)load(context, "vkCmdTraceRaysIndirectKHR");
|
vkCmdTraceRaysIndirectKHR = (PFN_vkCmdTraceRaysIndirectKHR)load(context, "vkCmdTraceRaysIndirectKHR");
|
||||||
@ -927,6 +1003,12 @@ static void volkGenLoadDevice(void* context, PFN_vkVoidFunction (*load)(void*, c
|
|||||||
vkCmdDrawMeshTasksIndirectNV = (PFN_vkCmdDrawMeshTasksIndirectNV)load(context, "vkCmdDrawMeshTasksIndirectNV");
|
vkCmdDrawMeshTasksIndirectNV = (PFN_vkCmdDrawMeshTasksIndirectNV)load(context, "vkCmdDrawMeshTasksIndirectNV");
|
||||||
vkCmdDrawMeshTasksNV = (PFN_vkCmdDrawMeshTasksNV)load(context, "vkCmdDrawMeshTasksNV");
|
vkCmdDrawMeshTasksNV = (PFN_vkCmdDrawMeshTasksNV)load(context, "vkCmdDrawMeshTasksNV");
|
||||||
#endif /* defined(VK_NV_mesh_shader) */
|
#endif /* defined(VK_NV_mesh_shader) */
|
||||||
|
#if defined(VK_NV_optical_flow)
|
||||||
|
vkBindOpticalFlowSessionImageNV = (PFN_vkBindOpticalFlowSessionImageNV)load(context, "vkBindOpticalFlowSessionImageNV");
|
||||||
|
vkCmdOpticalFlowExecuteNV = (PFN_vkCmdOpticalFlowExecuteNV)load(context, "vkCmdOpticalFlowExecuteNV");
|
||||||
|
vkCreateOpticalFlowSessionNV = (PFN_vkCreateOpticalFlowSessionNV)load(context, "vkCreateOpticalFlowSessionNV");
|
||||||
|
vkDestroyOpticalFlowSessionNV = (PFN_vkDestroyOpticalFlowSessionNV)load(context, "vkDestroyOpticalFlowSessionNV");
|
||||||
|
#endif /* defined(VK_NV_optical_flow) */
|
||||||
#if defined(VK_NV_ray_tracing)
|
#if defined(VK_NV_ray_tracing)
|
||||||
vkBindAccelerationStructureMemoryNV = (PFN_vkBindAccelerationStructureMemoryNV)load(context, "vkBindAccelerationStructureMemoryNV");
|
vkBindAccelerationStructureMemoryNV = (PFN_vkBindAccelerationStructureMemoryNV)load(context, "vkBindAccelerationStructureMemoryNV");
|
||||||
vkCmdBuildAccelerationStructureNV = (PFN_vkCmdBuildAccelerationStructureNV)load(context, "vkCmdBuildAccelerationStructureNV");
|
vkCmdBuildAccelerationStructureNV = (PFN_vkCmdBuildAccelerationStructureNV)load(context, "vkCmdBuildAccelerationStructureNV");
|
||||||
@ -949,6 +1031,14 @@ static void volkGenLoadDevice(void* context, PFN_vkVoidFunction (*load)(void*, c
|
|||||||
vkCmdSetCoarseSampleOrderNV = (PFN_vkCmdSetCoarseSampleOrderNV)load(context, "vkCmdSetCoarseSampleOrderNV");
|
vkCmdSetCoarseSampleOrderNV = (PFN_vkCmdSetCoarseSampleOrderNV)load(context, "vkCmdSetCoarseSampleOrderNV");
|
||||||
vkCmdSetViewportShadingRatePaletteNV = (PFN_vkCmdSetViewportShadingRatePaletteNV)load(context, "vkCmdSetViewportShadingRatePaletteNV");
|
vkCmdSetViewportShadingRatePaletteNV = (PFN_vkCmdSetViewportShadingRatePaletteNV)load(context, "vkCmdSetViewportShadingRatePaletteNV");
|
||||||
#endif /* defined(VK_NV_shading_rate_image) */
|
#endif /* defined(VK_NV_shading_rate_image) */
|
||||||
|
#if defined(VK_QCOM_tile_properties)
|
||||||
|
vkGetDynamicRenderingTilePropertiesQCOM = (PFN_vkGetDynamicRenderingTilePropertiesQCOM)load(context, "vkGetDynamicRenderingTilePropertiesQCOM");
|
||||||
|
vkGetFramebufferTilePropertiesQCOM = (PFN_vkGetFramebufferTilePropertiesQCOM)load(context, "vkGetFramebufferTilePropertiesQCOM");
|
||||||
|
#endif /* defined(VK_QCOM_tile_properties) */
|
||||||
|
#if defined(VK_VALVE_descriptor_set_host_mapping)
|
||||||
|
vkGetDescriptorSetHostMappingVALVE = (PFN_vkGetDescriptorSetHostMappingVALVE)load(context, "vkGetDescriptorSetHostMappingVALVE");
|
||||||
|
vkGetDescriptorSetLayoutHostMappingInfoVALVE = (PFN_vkGetDescriptorSetLayoutHostMappingInfoVALVE)load(context, "vkGetDescriptorSetLayoutHostMappingInfoVALVE");
|
||||||
|
#endif /* defined(VK_VALVE_descriptor_set_host_mapping) */
|
||||||
#if (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1))
|
#if (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1))
|
||||||
vkGetDeviceGroupSurfacePresentModes2EXT = (PFN_vkGetDeviceGroupSurfacePresentModes2EXT)load(context, "vkGetDeviceGroupSurfacePresentModes2EXT");
|
vkGetDeviceGroupSurfacePresentModes2EXT = (PFN_vkGetDeviceGroupSurfacePresentModes2EXT)load(context, "vkGetDeviceGroupSurfacePresentModes2EXT");
|
||||||
#endif /* (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1)) */
|
#endif /* (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1)) */
|
||||||
@ -1198,6 +1288,9 @@ static void volkGenLoadDeviceTable(struct VolkDeviceTable* table, void* context,
|
|||||||
table->vkDebugMarkerSetObjectNameEXT = (PFN_vkDebugMarkerSetObjectNameEXT)load(context, "vkDebugMarkerSetObjectNameEXT");
|
table->vkDebugMarkerSetObjectNameEXT = (PFN_vkDebugMarkerSetObjectNameEXT)load(context, "vkDebugMarkerSetObjectNameEXT");
|
||||||
table->vkDebugMarkerSetObjectTagEXT = (PFN_vkDebugMarkerSetObjectTagEXT)load(context, "vkDebugMarkerSetObjectTagEXT");
|
table->vkDebugMarkerSetObjectTagEXT = (PFN_vkDebugMarkerSetObjectTagEXT)load(context, "vkDebugMarkerSetObjectTagEXT");
|
||||||
#endif /* defined(VK_EXT_debug_marker) */
|
#endif /* defined(VK_EXT_debug_marker) */
|
||||||
|
#if defined(VK_EXT_device_fault)
|
||||||
|
table->vkGetDeviceFaultInfoEXT = (PFN_vkGetDeviceFaultInfoEXT)load(context, "vkGetDeviceFaultInfoEXT");
|
||||||
|
#endif /* defined(VK_EXT_device_fault) */
|
||||||
#if defined(VK_EXT_discard_rectangles)
|
#if defined(VK_EXT_discard_rectangles)
|
||||||
table->vkCmdSetDiscardRectangleEXT = (PFN_vkCmdSetDiscardRectangleEXT)load(context, "vkCmdSetDiscardRectangleEXT");
|
table->vkCmdSetDiscardRectangleEXT = (PFN_vkCmdSetDiscardRectangleEXT)load(context, "vkCmdSetDiscardRectangleEXT");
|
||||||
#endif /* defined(VK_EXT_discard_rectangles) */
|
#endif /* defined(VK_EXT_discard_rectangles) */
|
||||||
@ -1228,6 +1321,39 @@ static void volkGenLoadDeviceTable(struct VolkDeviceTable* table, void* context,
|
|||||||
table->vkCmdSetPrimitiveRestartEnableEXT = (PFN_vkCmdSetPrimitiveRestartEnableEXT)load(context, "vkCmdSetPrimitiveRestartEnableEXT");
|
table->vkCmdSetPrimitiveRestartEnableEXT = (PFN_vkCmdSetPrimitiveRestartEnableEXT)load(context, "vkCmdSetPrimitiveRestartEnableEXT");
|
||||||
table->vkCmdSetRasterizerDiscardEnableEXT = (PFN_vkCmdSetRasterizerDiscardEnableEXT)load(context, "vkCmdSetRasterizerDiscardEnableEXT");
|
table->vkCmdSetRasterizerDiscardEnableEXT = (PFN_vkCmdSetRasterizerDiscardEnableEXT)load(context, "vkCmdSetRasterizerDiscardEnableEXT");
|
||||||
#endif /* defined(VK_EXT_extended_dynamic_state2) */
|
#endif /* defined(VK_EXT_extended_dynamic_state2) */
|
||||||
|
#if defined(VK_EXT_extended_dynamic_state3)
|
||||||
|
table->vkCmdSetAlphaToCoverageEnableEXT = (PFN_vkCmdSetAlphaToCoverageEnableEXT)load(context, "vkCmdSetAlphaToCoverageEnableEXT");
|
||||||
|
table->vkCmdSetAlphaToOneEnableEXT = (PFN_vkCmdSetAlphaToOneEnableEXT)load(context, "vkCmdSetAlphaToOneEnableEXT");
|
||||||
|
table->vkCmdSetColorBlendAdvancedEXT = (PFN_vkCmdSetColorBlendAdvancedEXT)load(context, "vkCmdSetColorBlendAdvancedEXT");
|
||||||
|
table->vkCmdSetColorBlendEnableEXT = (PFN_vkCmdSetColorBlendEnableEXT)load(context, "vkCmdSetColorBlendEnableEXT");
|
||||||
|
table->vkCmdSetColorBlendEquationEXT = (PFN_vkCmdSetColorBlendEquationEXT)load(context, "vkCmdSetColorBlendEquationEXT");
|
||||||
|
table->vkCmdSetColorWriteMaskEXT = (PFN_vkCmdSetColorWriteMaskEXT)load(context, "vkCmdSetColorWriteMaskEXT");
|
||||||
|
table->vkCmdSetConservativeRasterizationModeEXT = (PFN_vkCmdSetConservativeRasterizationModeEXT)load(context, "vkCmdSetConservativeRasterizationModeEXT");
|
||||||
|
table->vkCmdSetCoverageModulationModeNV = (PFN_vkCmdSetCoverageModulationModeNV)load(context, "vkCmdSetCoverageModulationModeNV");
|
||||||
|
table->vkCmdSetCoverageModulationTableEnableNV = (PFN_vkCmdSetCoverageModulationTableEnableNV)load(context, "vkCmdSetCoverageModulationTableEnableNV");
|
||||||
|
table->vkCmdSetCoverageModulationTableNV = (PFN_vkCmdSetCoverageModulationTableNV)load(context, "vkCmdSetCoverageModulationTableNV");
|
||||||
|
table->vkCmdSetCoverageReductionModeNV = (PFN_vkCmdSetCoverageReductionModeNV)load(context, "vkCmdSetCoverageReductionModeNV");
|
||||||
|
table->vkCmdSetCoverageToColorEnableNV = (PFN_vkCmdSetCoverageToColorEnableNV)load(context, "vkCmdSetCoverageToColorEnableNV");
|
||||||
|
table->vkCmdSetCoverageToColorLocationNV = (PFN_vkCmdSetCoverageToColorLocationNV)load(context, "vkCmdSetCoverageToColorLocationNV");
|
||||||
|
table->vkCmdSetDepthClampEnableEXT = (PFN_vkCmdSetDepthClampEnableEXT)load(context, "vkCmdSetDepthClampEnableEXT");
|
||||||
|
table->vkCmdSetDepthClipEnableEXT = (PFN_vkCmdSetDepthClipEnableEXT)load(context, "vkCmdSetDepthClipEnableEXT");
|
||||||
|
table->vkCmdSetDepthClipNegativeOneToOneEXT = (PFN_vkCmdSetDepthClipNegativeOneToOneEXT)load(context, "vkCmdSetDepthClipNegativeOneToOneEXT");
|
||||||
|
table->vkCmdSetExtraPrimitiveOverestimationSizeEXT = (PFN_vkCmdSetExtraPrimitiveOverestimationSizeEXT)load(context, "vkCmdSetExtraPrimitiveOverestimationSizeEXT");
|
||||||
|
table->vkCmdSetLineRasterizationModeEXT = (PFN_vkCmdSetLineRasterizationModeEXT)load(context, "vkCmdSetLineRasterizationModeEXT");
|
||||||
|
table->vkCmdSetLineStippleEnableEXT = (PFN_vkCmdSetLineStippleEnableEXT)load(context, "vkCmdSetLineStippleEnableEXT");
|
||||||
|
table->vkCmdSetLogicOpEnableEXT = (PFN_vkCmdSetLogicOpEnableEXT)load(context, "vkCmdSetLogicOpEnableEXT");
|
||||||
|
table->vkCmdSetPolygonModeEXT = (PFN_vkCmdSetPolygonModeEXT)load(context, "vkCmdSetPolygonModeEXT");
|
||||||
|
table->vkCmdSetProvokingVertexModeEXT = (PFN_vkCmdSetProvokingVertexModeEXT)load(context, "vkCmdSetProvokingVertexModeEXT");
|
||||||
|
table->vkCmdSetRasterizationSamplesEXT = (PFN_vkCmdSetRasterizationSamplesEXT)load(context, "vkCmdSetRasterizationSamplesEXT");
|
||||||
|
table->vkCmdSetRasterizationStreamEXT = (PFN_vkCmdSetRasterizationStreamEXT)load(context, "vkCmdSetRasterizationStreamEXT");
|
||||||
|
table->vkCmdSetRepresentativeFragmentTestEnableNV = (PFN_vkCmdSetRepresentativeFragmentTestEnableNV)load(context, "vkCmdSetRepresentativeFragmentTestEnableNV");
|
||||||
|
table->vkCmdSetSampleLocationsEnableEXT = (PFN_vkCmdSetSampleLocationsEnableEXT)load(context, "vkCmdSetSampleLocationsEnableEXT");
|
||||||
|
table->vkCmdSetSampleMaskEXT = (PFN_vkCmdSetSampleMaskEXT)load(context, "vkCmdSetSampleMaskEXT");
|
||||||
|
table->vkCmdSetShadingRateImageEnableNV = (PFN_vkCmdSetShadingRateImageEnableNV)load(context, "vkCmdSetShadingRateImageEnableNV");
|
||||||
|
table->vkCmdSetTessellationDomainOriginEXT = (PFN_vkCmdSetTessellationDomainOriginEXT)load(context, "vkCmdSetTessellationDomainOriginEXT");
|
||||||
|
table->vkCmdSetViewportSwizzleNV = (PFN_vkCmdSetViewportSwizzleNV)load(context, "vkCmdSetViewportSwizzleNV");
|
||||||
|
table->vkCmdSetViewportWScalingEnableNV = (PFN_vkCmdSetViewportWScalingEnableNV)load(context, "vkCmdSetViewportWScalingEnableNV");
|
||||||
|
#endif /* defined(VK_EXT_extended_dynamic_state3) */
|
||||||
#if defined(VK_EXT_external_memory_host)
|
#if defined(VK_EXT_external_memory_host)
|
||||||
table->vkGetMemoryHostPointerPropertiesEXT = (PFN_vkGetMemoryHostPointerPropertiesEXT)load(context, "vkGetMemoryHostPointerPropertiesEXT");
|
table->vkGetMemoryHostPointerPropertiesEXT = (PFN_vkGetMemoryHostPointerPropertiesEXT)load(context, "vkGetMemoryHostPointerPropertiesEXT");
|
||||||
#endif /* defined(VK_EXT_external_memory_host) */
|
#endif /* defined(VK_EXT_external_memory_host) */
|
||||||
@ -1241,19 +1367,49 @@ static void volkGenLoadDeviceTable(struct VolkDeviceTable* table, void* context,
|
|||||||
#if defined(VK_EXT_host_query_reset)
|
#if defined(VK_EXT_host_query_reset)
|
||||||
table->vkResetQueryPoolEXT = (PFN_vkResetQueryPoolEXT)load(context, "vkResetQueryPoolEXT");
|
table->vkResetQueryPoolEXT = (PFN_vkResetQueryPoolEXT)load(context, "vkResetQueryPoolEXT");
|
||||||
#endif /* defined(VK_EXT_host_query_reset) */
|
#endif /* defined(VK_EXT_host_query_reset) */
|
||||||
|
#if defined(VK_EXT_image_compression_control)
|
||||||
|
table->vkGetImageSubresourceLayout2EXT = (PFN_vkGetImageSubresourceLayout2EXT)load(context, "vkGetImageSubresourceLayout2EXT");
|
||||||
|
#endif /* defined(VK_EXT_image_compression_control) */
|
||||||
#if defined(VK_EXT_image_drm_format_modifier)
|
#if defined(VK_EXT_image_drm_format_modifier)
|
||||||
table->vkGetImageDrmFormatModifierPropertiesEXT = (PFN_vkGetImageDrmFormatModifierPropertiesEXT)load(context, "vkGetImageDrmFormatModifierPropertiesEXT");
|
table->vkGetImageDrmFormatModifierPropertiesEXT = (PFN_vkGetImageDrmFormatModifierPropertiesEXT)load(context, "vkGetImageDrmFormatModifierPropertiesEXT");
|
||||||
#endif /* defined(VK_EXT_image_drm_format_modifier) */
|
#endif /* defined(VK_EXT_image_drm_format_modifier) */
|
||||||
#if defined(VK_EXT_line_rasterization)
|
#if defined(VK_EXT_line_rasterization)
|
||||||
table->vkCmdSetLineStippleEXT = (PFN_vkCmdSetLineStippleEXT)load(context, "vkCmdSetLineStippleEXT");
|
table->vkCmdSetLineStippleEXT = (PFN_vkCmdSetLineStippleEXT)load(context, "vkCmdSetLineStippleEXT");
|
||||||
#endif /* defined(VK_EXT_line_rasterization) */
|
#endif /* defined(VK_EXT_line_rasterization) */
|
||||||
|
#if defined(VK_EXT_mesh_shader)
|
||||||
|
table->vkCmdDrawMeshTasksEXT = (PFN_vkCmdDrawMeshTasksEXT)load(context, "vkCmdDrawMeshTasksEXT");
|
||||||
|
table->vkCmdDrawMeshTasksIndirectCountEXT = (PFN_vkCmdDrawMeshTasksIndirectCountEXT)load(context, "vkCmdDrawMeshTasksIndirectCountEXT");
|
||||||
|
table->vkCmdDrawMeshTasksIndirectEXT = (PFN_vkCmdDrawMeshTasksIndirectEXT)load(context, "vkCmdDrawMeshTasksIndirectEXT");
|
||||||
|
#endif /* defined(VK_EXT_mesh_shader) */
|
||||||
|
#if defined(VK_EXT_metal_objects)
|
||||||
|
table->vkExportMetalObjectsEXT = (PFN_vkExportMetalObjectsEXT)load(context, "vkExportMetalObjectsEXT");
|
||||||
|
#endif /* defined(VK_EXT_metal_objects) */
|
||||||
#if defined(VK_EXT_multi_draw)
|
#if defined(VK_EXT_multi_draw)
|
||||||
table->vkCmdDrawMultiEXT = (PFN_vkCmdDrawMultiEXT)load(context, "vkCmdDrawMultiEXT");
|
table->vkCmdDrawMultiEXT = (PFN_vkCmdDrawMultiEXT)load(context, "vkCmdDrawMultiEXT");
|
||||||
table->vkCmdDrawMultiIndexedEXT = (PFN_vkCmdDrawMultiIndexedEXT)load(context, "vkCmdDrawMultiIndexedEXT");
|
table->vkCmdDrawMultiIndexedEXT = (PFN_vkCmdDrawMultiIndexedEXT)load(context, "vkCmdDrawMultiIndexedEXT");
|
||||||
#endif /* defined(VK_EXT_multi_draw) */
|
#endif /* defined(VK_EXT_multi_draw) */
|
||||||
|
#if defined(VK_EXT_opacity_micromap)
|
||||||
|
table->vkBuildMicromapsEXT = (PFN_vkBuildMicromapsEXT)load(context, "vkBuildMicromapsEXT");
|
||||||
|
table->vkCmdBuildMicromapsEXT = (PFN_vkCmdBuildMicromapsEXT)load(context, "vkCmdBuildMicromapsEXT");
|
||||||
|
table->vkCmdCopyMemoryToMicromapEXT = (PFN_vkCmdCopyMemoryToMicromapEXT)load(context, "vkCmdCopyMemoryToMicromapEXT");
|
||||||
|
table->vkCmdCopyMicromapEXT = (PFN_vkCmdCopyMicromapEXT)load(context, "vkCmdCopyMicromapEXT");
|
||||||
|
table->vkCmdCopyMicromapToMemoryEXT = (PFN_vkCmdCopyMicromapToMemoryEXT)load(context, "vkCmdCopyMicromapToMemoryEXT");
|
||||||
|
table->vkCmdWriteMicromapsPropertiesEXT = (PFN_vkCmdWriteMicromapsPropertiesEXT)load(context, "vkCmdWriteMicromapsPropertiesEXT");
|
||||||
|
table->vkCopyMemoryToMicromapEXT = (PFN_vkCopyMemoryToMicromapEXT)load(context, "vkCopyMemoryToMicromapEXT");
|
||||||
|
table->vkCopyMicromapEXT = (PFN_vkCopyMicromapEXT)load(context, "vkCopyMicromapEXT");
|
||||||
|
table->vkCopyMicromapToMemoryEXT = (PFN_vkCopyMicromapToMemoryEXT)load(context, "vkCopyMicromapToMemoryEXT");
|
||||||
|
table->vkCreateMicromapEXT = (PFN_vkCreateMicromapEXT)load(context, "vkCreateMicromapEXT");
|
||||||
|
table->vkDestroyMicromapEXT = (PFN_vkDestroyMicromapEXT)load(context, "vkDestroyMicromapEXT");
|
||||||
|
table->vkGetDeviceMicromapCompatibilityEXT = (PFN_vkGetDeviceMicromapCompatibilityEXT)load(context, "vkGetDeviceMicromapCompatibilityEXT");
|
||||||
|
table->vkGetMicromapBuildSizesEXT = (PFN_vkGetMicromapBuildSizesEXT)load(context, "vkGetMicromapBuildSizesEXT");
|
||||||
|
table->vkWriteMicromapsPropertiesEXT = (PFN_vkWriteMicromapsPropertiesEXT)load(context, "vkWriteMicromapsPropertiesEXT");
|
||||||
|
#endif /* defined(VK_EXT_opacity_micromap) */
|
||||||
#if defined(VK_EXT_pageable_device_local_memory)
|
#if defined(VK_EXT_pageable_device_local_memory)
|
||||||
table->vkSetDeviceMemoryPriorityEXT = (PFN_vkSetDeviceMemoryPriorityEXT)load(context, "vkSetDeviceMemoryPriorityEXT");
|
table->vkSetDeviceMemoryPriorityEXT = (PFN_vkSetDeviceMemoryPriorityEXT)load(context, "vkSetDeviceMemoryPriorityEXT");
|
||||||
#endif /* defined(VK_EXT_pageable_device_local_memory) */
|
#endif /* defined(VK_EXT_pageable_device_local_memory) */
|
||||||
|
#if defined(VK_EXT_pipeline_properties)
|
||||||
|
table->vkGetPipelinePropertiesEXT = (PFN_vkGetPipelinePropertiesEXT)load(context, "vkGetPipelinePropertiesEXT");
|
||||||
|
#endif /* defined(VK_EXT_pipeline_properties) */
|
||||||
#if defined(VK_EXT_private_data)
|
#if defined(VK_EXT_private_data)
|
||||||
table->vkCreatePrivateDataSlotEXT = (PFN_vkCreatePrivateDataSlotEXT)load(context, "vkCreatePrivateDataSlotEXT");
|
table->vkCreatePrivateDataSlotEXT = (PFN_vkCreatePrivateDataSlotEXT)load(context, "vkCreatePrivateDataSlotEXT");
|
||||||
table->vkDestroyPrivateDataSlotEXT = (PFN_vkDestroyPrivateDataSlotEXT)load(context, "vkDestroyPrivateDataSlotEXT");
|
table->vkDestroyPrivateDataSlotEXT = (PFN_vkDestroyPrivateDataSlotEXT)load(context, "vkDestroyPrivateDataSlotEXT");
|
||||||
@ -1263,6 +1419,10 @@ static void volkGenLoadDeviceTable(struct VolkDeviceTable* table, void* context,
|
|||||||
#if defined(VK_EXT_sample_locations)
|
#if defined(VK_EXT_sample_locations)
|
||||||
table->vkCmdSetSampleLocationsEXT = (PFN_vkCmdSetSampleLocationsEXT)load(context, "vkCmdSetSampleLocationsEXT");
|
table->vkCmdSetSampleLocationsEXT = (PFN_vkCmdSetSampleLocationsEXT)load(context, "vkCmdSetSampleLocationsEXT");
|
||||||
#endif /* defined(VK_EXT_sample_locations) */
|
#endif /* defined(VK_EXT_sample_locations) */
|
||||||
|
#if defined(VK_EXT_shader_module_identifier)
|
||||||
|
table->vkGetShaderModuleCreateInfoIdentifierEXT = (PFN_vkGetShaderModuleCreateInfoIdentifierEXT)load(context, "vkGetShaderModuleCreateInfoIdentifierEXT");
|
||||||
|
table->vkGetShaderModuleIdentifierEXT = (PFN_vkGetShaderModuleIdentifierEXT)load(context, "vkGetShaderModuleIdentifierEXT");
|
||||||
|
#endif /* defined(VK_EXT_shader_module_identifier) */
|
||||||
#if defined(VK_EXT_transform_feedback)
|
#if defined(VK_EXT_transform_feedback)
|
||||||
table->vkCmdBeginQueryIndexedEXT = (PFN_vkCmdBeginQueryIndexedEXT)load(context, "vkCmdBeginQueryIndexedEXT");
|
table->vkCmdBeginQueryIndexedEXT = (PFN_vkCmdBeginQueryIndexedEXT)load(context, "vkCmdBeginQueryIndexedEXT");
|
||||||
table->vkCmdBeginTransformFeedbackEXT = (PFN_vkCmdBeginTransformFeedbackEXT)load(context, "vkCmdBeginTransformFeedbackEXT");
|
table->vkCmdBeginTransformFeedbackEXT = (PFN_vkCmdBeginTransformFeedbackEXT)load(context, "vkCmdBeginTransformFeedbackEXT");
|
||||||
@ -1444,6 +1604,9 @@ static void volkGenLoadDeviceTable(struct VolkDeviceTable* table, void* context,
|
|||||||
#if defined(VK_KHR_push_descriptor)
|
#if defined(VK_KHR_push_descriptor)
|
||||||
table->vkCmdPushDescriptorSetKHR = (PFN_vkCmdPushDescriptorSetKHR)load(context, "vkCmdPushDescriptorSetKHR");
|
table->vkCmdPushDescriptorSetKHR = (PFN_vkCmdPushDescriptorSetKHR)load(context, "vkCmdPushDescriptorSetKHR");
|
||||||
#endif /* defined(VK_KHR_push_descriptor) */
|
#endif /* defined(VK_KHR_push_descriptor) */
|
||||||
|
#if defined(VK_KHR_ray_tracing_maintenance1) && defined(VK_KHR_ray_tracing_pipeline)
|
||||||
|
table->vkCmdTraceRaysIndirect2KHR = (PFN_vkCmdTraceRaysIndirect2KHR)load(context, "vkCmdTraceRaysIndirect2KHR");
|
||||||
|
#endif /* defined(VK_KHR_ray_tracing_maintenance1) && defined(VK_KHR_ray_tracing_pipeline) */
|
||||||
#if defined(VK_KHR_ray_tracing_pipeline)
|
#if defined(VK_KHR_ray_tracing_pipeline)
|
||||||
table->vkCmdSetRayTracingPipelineStackSizeKHR = (PFN_vkCmdSetRayTracingPipelineStackSizeKHR)load(context, "vkCmdSetRayTracingPipelineStackSizeKHR");
|
table->vkCmdSetRayTracingPipelineStackSizeKHR = (PFN_vkCmdSetRayTracingPipelineStackSizeKHR)load(context, "vkCmdSetRayTracingPipelineStackSizeKHR");
|
||||||
table->vkCmdTraceRaysIndirectKHR = (PFN_vkCmdTraceRaysIndirectKHR)load(context, "vkCmdTraceRaysIndirectKHR");
|
table->vkCmdTraceRaysIndirectKHR = (PFN_vkCmdTraceRaysIndirectKHR)load(context, "vkCmdTraceRaysIndirectKHR");
|
||||||
@ -1544,6 +1707,12 @@ static void volkGenLoadDeviceTable(struct VolkDeviceTable* table, void* context,
|
|||||||
table->vkCmdDrawMeshTasksIndirectNV = (PFN_vkCmdDrawMeshTasksIndirectNV)load(context, "vkCmdDrawMeshTasksIndirectNV");
|
table->vkCmdDrawMeshTasksIndirectNV = (PFN_vkCmdDrawMeshTasksIndirectNV)load(context, "vkCmdDrawMeshTasksIndirectNV");
|
||||||
table->vkCmdDrawMeshTasksNV = (PFN_vkCmdDrawMeshTasksNV)load(context, "vkCmdDrawMeshTasksNV");
|
table->vkCmdDrawMeshTasksNV = (PFN_vkCmdDrawMeshTasksNV)load(context, "vkCmdDrawMeshTasksNV");
|
||||||
#endif /* defined(VK_NV_mesh_shader) */
|
#endif /* defined(VK_NV_mesh_shader) */
|
||||||
|
#if defined(VK_NV_optical_flow)
|
||||||
|
table->vkBindOpticalFlowSessionImageNV = (PFN_vkBindOpticalFlowSessionImageNV)load(context, "vkBindOpticalFlowSessionImageNV");
|
||||||
|
table->vkCmdOpticalFlowExecuteNV = (PFN_vkCmdOpticalFlowExecuteNV)load(context, "vkCmdOpticalFlowExecuteNV");
|
||||||
|
table->vkCreateOpticalFlowSessionNV = (PFN_vkCreateOpticalFlowSessionNV)load(context, "vkCreateOpticalFlowSessionNV");
|
||||||
|
table->vkDestroyOpticalFlowSessionNV = (PFN_vkDestroyOpticalFlowSessionNV)load(context, "vkDestroyOpticalFlowSessionNV");
|
||||||
|
#endif /* defined(VK_NV_optical_flow) */
|
||||||
#if defined(VK_NV_ray_tracing)
|
#if defined(VK_NV_ray_tracing)
|
||||||
table->vkBindAccelerationStructureMemoryNV = (PFN_vkBindAccelerationStructureMemoryNV)load(context, "vkBindAccelerationStructureMemoryNV");
|
table->vkBindAccelerationStructureMemoryNV = (PFN_vkBindAccelerationStructureMemoryNV)load(context, "vkBindAccelerationStructureMemoryNV");
|
||||||
table->vkCmdBuildAccelerationStructureNV = (PFN_vkCmdBuildAccelerationStructureNV)load(context, "vkCmdBuildAccelerationStructureNV");
|
table->vkCmdBuildAccelerationStructureNV = (PFN_vkCmdBuildAccelerationStructureNV)load(context, "vkCmdBuildAccelerationStructureNV");
|
||||||
@ -1566,6 +1735,14 @@ static void volkGenLoadDeviceTable(struct VolkDeviceTable* table, void* context,
|
|||||||
table->vkCmdSetCoarseSampleOrderNV = (PFN_vkCmdSetCoarseSampleOrderNV)load(context, "vkCmdSetCoarseSampleOrderNV");
|
table->vkCmdSetCoarseSampleOrderNV = (PFN_vkCmdSetCoarseSampleOrderNV)load(context, "vkCmdSetCoarseSampleOrderNV");
|
||||||
table->vkCmdSetViewportShadingRatePaletteNV = (PFN_vkCmdSetViewportShadingRatePaletteNV)load(context, "vkCmdSetViewportShadingRatePaletteNV");
|
table->vkCmdSetViewportShadingRatePaletteNV = (PFN_vkCmdSetViewportShadingRatePaletteNV)load(context, "vkCmdSetViewportShadingRatePaletteNV");
|
||||||
#endif /* defined(VK_NV_shading_rate_image) */
|
#endif /* defined(VK_NV_shading_rate_image) */
|
||||||
|
#if defined(VK_QCOM_tile_properties)
|
||||||
|
table->vkGetDynamicRenderingTilePropertiesQCOM = (PFN_vkGetDynamicRenderingTilePropertiesQCOM)load(context, "vkGetDynamicRenderingTilePropertiesQCOM");
|
||||||
|
table->vkGetFramebufferTilePropertiesQCOM = (PFN_vkGetFramebufferTilePropertiesQCOM)load(context, "vkGetFramebufferTilePropertiesQCOM");
|
||||||
|
#endif /* defined(VK_QCOM_tile_properties) */
|
||||||
|
#if defined(VK_VALVE_descriptor_set_host_mapping)
|
||||||
|
table->vkGetDescriptorSetHostMappingVALVE = (PFN_vkGetDescriptorSetHostMappingVALVE)load(context, "vkGetDescriptorSetHostMappingVALVE");
|
||||||
|
table->vkGetDescriptorSetLayoutHostMappingInfoVALVE = (PFN_vkGetDescriptorSetLayoutHostMappingInfoVALVE)load(context, "vkGetDescriptorSetLayoutHostMappingInfoVALVE");
|
||||||
|
#endif /* defined(VK_VALVE_descriptor_set_host_mapping) */
|
||||||
#if (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1))
|
#if (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1))
|
||||||
table->vkGetDeviceGroupSurfacePresentModes2EXT = (PFN_vkGetDeviceGroupSurfacePresentModes2EXT)load(context, "vkGetDeviceGroupSurfacePresentModes2EXT");
|
table->vkGetDeviceGroupSurfacePresentModes2EXT = (PFN_vkGetDeviceGroupSurfacePresentModes2EXT)load(context, "vkGetDeviceGroupSurfacePresentModes2EXT");
|
||||||
#endif /* (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1)) */
|
#endif /* (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1)) */
|
||||||
@ -1878,6 +2055,9 @@ PFN_vkSetDebugUtilsObjectNameEXT vkSetDebugUtilsObjectNameEXT;
|
|||||||
PFN_vkSetDebugUtilsObjectTagEXT vkSetDebugUtilsObjectTagEXT;
|
PFN_vkSetDebugUtilsObjectTagEXT vkSetDebugUtilsObjectTagEXT;
|
||||||
PFN_vkSubmitDebugUtilsMessageEXT vkSubmitDebugUtilsMessageEXT;
|
PFN_vkSubmitDebugUtilsMessageEXT vkSubmitDebugUtilsMessageEXT;
|
||||||
#endif /* defined(VK_EXT_debug_utils) */
|
#endif /* defined(VK_EXT_debug_utils) */
|
||||||
|
#if defined(VK_EXT_device_fault)
|
||||||
|
PFN_vkGetDeviceFaultInfoEXT vkGetDeviceFaultInfoEXT;
|
||||||
|
#endif /* defined(VK_EXT_device_fault) */
|
||||||
#if defined(VK_EXT_direct_mode_display)
|
#if defined(VK_EXT_direct_mode_display)
|
||||||
PFN_vkReleaseDisplayEXT vkReleaseDisplayEXT;
|
PFN_vkReleaseDisplayEXT vkReleaseDisplayEXT;
|
||||||
#endif /* defined(VK_EXT_direct_mode_display) */
|
#endif /* defined(VK_EXT_direct_mode_display) */
|
||||||
@ -1918,6 +2098,39 @@ PFN_vkCmdSetPatchControlPointsEXT vkCmdSetPatchControlPointsEXT;
|
|||||||
PFN_vkCmdSetPrimitiveRestartEnableEXT vkCmdSetPrimitiveRestartEnableEXT;
|
PFN_vkCmdSetPrimitiveRestartEnableEXT vkCmdSetPrimitiveRestartEnableEXT;
|
||||||
PFN_vkCmdSetRasterizerDiscardEnableEXT vkCmdSetRasterizerDiscardEnableEXT;
|
PFN_vkCmdSetRasterizerDiscardEnableEXT vkCmdSetRasterizerDiscardEnableEXT;
|
||||||
#endif /* defined(VK_EXT_extended_dynamic_state2) */
|
#endif /* defined(VK_EXT_extended_dynamic_state2) */
|
||||||
|
#if defined(VK_EXT_extended_dynamic_state3)
|
||||||
|
PFN_vkCmdSetAlphaToCoverageEnableEXT vkCmdSetAlphaToCoverageEnableEXT;
|
||||||
|
PFN_vkCmdSetAlphaToOneEnableEXT vkCmdSetAlphaToOneEnableEXT;
|
||||||
|
PFN_vkCmdSetColorBlendAdvancedEXT vkCmdSetColorBlendAdvancedEXT;
|
||||||
|
PFN_vkCmdSetColorBlendEnableEXT vkCmdSetColorBlendEnableEXT;
|
||||||
|
PFN_vkCmdSetColorBlendEquationEXT vkCmdSetColorBlendEquationEXT;
|
||||||
|
PFN_vkCmdSetColorWriteMaskEXT vkCmdSetColorWriteMaskEXT;
|
||||||
|
PFN_vkCmdSetConservativeRasterizationModeEXT vkCmdSetConservativeRasterizationModeEXT;
|
||||||
|
PFN_vkCmdSetCoverageModulationModeNV vkCmdSetCoverageModulationModeNV;
|
||||||
|
PFN_vkCmdSetCoverageModulationTableEnableNV vkCmdSetCoverageModulationTableEnableNV;
|
||||||
|
PFN_vkCmdSetCoverageModulationTableNV vkCmdSetCoverageModulationTableNV;
|
||||||
|
PFN_vkCmdSetCoverageReductionModeNV vkCmdSetCoverageReductionModeNV;
|
||||||
|
PFN_vkCmdSetCoverageToColorEnableNV vkCmdSetCoverageToColorEnableNV;
|
||||||
|
PFN_vkCmdSetCoverageToColorLocationNV vkCmdSetCoverageToColorLocationNV;
|
||||||
|
PFN_vkCmdSetDepthClampEnableEXT vkCmdSetDepthClampEnableEXT;
|
||||||
|
PFN_vkCmdSetDepthClipEnableEXT vkCmdSetDepthClipEnableEXT;
|
||||||
|
PFN_vkCmdSetDepthClipNegativeOneToOneEXT vkCmdSetDepthClipNegativeOneToOneEXT;
|
||||||
|
PFN_vkCmdSetExtraPrimitiveOverestimationSizeEXT vkCmdSetExtraPrimitiveOverestimationSizeEXT;
|
||||||
|
PFN_vkCmdSetLineRasterizationModeEXT vkCmdSetLineRasterizationModeEXT;
|
||||||
|
PFN_vkCmdSetLineStippleEnableEXT vkCmdSetLineStippleEnableEXT;
|
||||||
|
PFN_vkCmdSetLogicOpEnableEXT vkCmdSetLogicOpEnableEXT;
|
||||||
|
PFN_vkCmdSetPolygonModeEXT vkCmdSetPolygonModeEXT;
|
||||||
|
PFN_vkCmdSetProvokingVertexModeEXT vkCmdSetProvokingVertexModeEXT;
|
||||||
|
PFN_vkCmdSetRasterizationSamplesEXT vkCmdSetRasterizationSamplesEXT;
|
||||||
|
PFN_vkCmdSetRasterizationStreamEXT vkCmdSetRasterizationStreamEXT;
|
||||||
|
PFN_vkCmdSetRepresentativeFragmentTestEnableNV vkCmdSetRepresentativeFragmentTestEnableNV;
|
||||||
|
PFN_vkCmdSetSampleLocationsEnableEXT vkCmdSetSampleLocationsEnableEXT;
|
||||||
|
PFN_vkCmdSetSampleMaskEXT vkCmdSetSampleMaskEXT;
|
||||||
|
PFN_vkCmdSetShadingRateImageEnableNV vkCmdSetShadingRateImageEnableNV;
|
||||||
|
PFN_vkCmdSetTessellationDomainOriginEXT vkCmdSetTessellationDomainOriginEXT;
|
||||||
|
PFN_vkCmdSetViewportSwizzleNV vkCmdSetViewportSwizzleNV;
|
||||||
|
PFN_vkCmdSetViewportWScalingEnableNV vkCmdSetViewportWScalingEnableNV;
|
||||||
|
#endif /* defined(VK_EXT_extended_dynamic_state3) */
|
||||||
#if defined(VK_EXT_external_memory_host)
|
#if defined(VK_EXT_external_memory_host)
|
||||||
PFN_vkGetMemoryHostPointerPropertiesEXT vkGetMemoryHostPointerPropertiesEXT;
|
PFN_vkGetMemoryHostPointerPropertiesEXT vkGetMemoryHostPointerPropertiesEXT;
|
||||||
#endif /* defined(VK_EXT_external_memory_host) */
|
#endif /* defined(VK_EXT_external_memory_host) */
|
||||||
@ -1935,12 +2148,23 @@ PFN_vkCreateHeadlessSurfaceEXT vkCreateHeadlessSurfaceEXT;
|
|||||||
#if defined(VK_EXT_host_query_reset)
|
#if defined(VK_EXT_host_query_reset)
|
||||||
PFN_vkResetQueryPoolEXT vkResetQueryPoolEXT;
|
PFN_vkResetQueryPoolEXT vkResetQueryPoolEXT;
|
||||||
#endif /* defined(VK_EXT_host_query_reset) */
|
#endif /* defined(VK_EXT_host_query_reset) */
|
||||||
|
#if defined(VK_EXT_image_compression_control)
|
||||||
|
PFN_vkGetImageSubresourceLayout2EXT vkGetImageSubresourceLayout2EXT;
|
||||||
|
#endif /* defined(VK_EXT_image_compression_control) */
|
||||||
#if defined(VK_EXT_image_drm_format_modifier)
|
#if defined(VK_EXT_image_drm_format_modifier)
|
||||||
PFN_vkGetImageDrmFormatModifierPropertiesEXT vkGetImageDrmFormatModifierPropertiesEXT;
|
PFN_vkGetImageDrmFormatModifierPropertiesEXT vkGetImageDrmFormatModifierPropertiesEXT;
|
||||||
#endif /* defined(VK_EXT_image_drm_format_modifier) */
|
#endif /* defined(VK_EXT_image_drm_format_modifier) */
|
||||||
#if defined(VK_EXT_line_rasterization)
|
#if defined(VK_EXT_line_rasterization)
|
||||||
PFN_vkCmdSetLineStippleEXT vkCmdSetLineStippleEXT;
|
PFN_vkCmdSetLineStippleEXT vkCmdSetLineStippleEXT;
|
||||||
#endif /* defined(VK_EXT_line_rasterization) */
|
#endif /* defined(VK_EXT_line_rasterization) */
|
||||||
|
#if defined(VK_EXT_mesh_shader)
|
||||||
|
PFN_vkCmdDrawMeshTasksEXT vkCmdDrawMeshTasksEXT;
|
||||||
|
PFN_vkCmdDrawMeshTasksIndirectCountEXT vkCmdDrawMeshTasksIndirectCountEXT;
|
||||||
|
PFN_vkCmdDrawMeshTasksIndirectEXT vkCmdDrawMeshTasksIndirectEXT;
|
||||||
|
#endif /* defined(VK_EXT_mesh_shader) */
|
||||||
|
#if defined(VK_EXT_metal_objects)
|
||||||
|
PFN_vkExportMetalObjectsEXT vkExportMetalObjectsEXT;
|
||||||
|
#endif /* defined(VK_EXT_metal_objects) */
|
||||||
#if defined(VK_EXT_metal_surface)
|
#if defined(VK_EXT_metal_surface)
|
||||||
PFN_vkCreateMetalSurfaceEXT vkCreateMetalSurfaceEXT;
|
PFN_vkCreateMetalSurfaceEXT vkCreateMetalSurfaceEXT;
|
||||||
#endif /* defined(VK_EXT_metal_surface) */
|
#endif /* defined(VK_EXT_metal_surface) */
|
||||||
@ -1948,9 +2172,28 @@ PFN_vkCreateMetalSurfaceEXT vkCreateMetalSurfaceEXT;
|
|||||||
PFN_vkCmdDrawMultiEXT vkCmdDrawMultiEXT;
|
PFN_vkCmdDrawMultiEXT vkCmdDrawMultiEXT;
|
||||||
PFN_vkCmdDrawMultiIndexedEXT vkCmdDrawMultiIndexedEXT;
|
PFN_vkCmdDrawMultiIndexedEXT vkCmdDrawMultiIndexedEXT;
|
||||||
#endif /* defined(VK_EXT_multi_draw) */
|
#endif /* defined(VK_EXT_multi_draw) */
|
||||||
|
#if defined(VK_EXT_opacity_micromap)
|
||||||
|
PFN_vkBuildMicromapsEXT vkBuildMicromapsEXT;
|
||||||
|
PFN_vkCmdBuildMicromapsEXT vkCmdBuildMicromapsEXT;
|
||||||
|
PFN_vkCmdCopyMemoryToMicromapEXT vkCmdCopyMemoryToMicromapEXT;
|
||||||
|
PFN_vkCmdCopyMicromapEXT vkCmdCopyMicromapEXT;
|
||||||
|
PFN_vkCmdCopyMicromapToMemoryEXT vkCmdCopyMicromapToMemoryEXT;
|
||||||
|
PFN_vkCmdWriteMicromapsPropertiesEXT vkCmdWriteMicromapsPropertiesEXT;
|
||||||
|
PFN_vkCopyMemoryToMicromapEXT vkCopyMemoryToMicromapEXT;
|
||||||
|
PFN_vkCopyMicromapEXT vkCopyMicromapEXT;
|
||||||
|
PFN_vkCopyMicromapToMemoryEXT vkCopyMicromapToMemoryEXT;
|
||||||
|
PFN_vkCreateMicromapEXT vkCreateMicromapEXT;
|
||||||
|
PFN_vkDestroyMicromapEXT vkDestroyMicromapEXT;
|
||||||
|
PFN_vkGetDeviceMicromapCompatibilityEXT vkGetDeviceMicromapCompatibilityEXT;
|
||||||
|
PFN_vkGetMicromapBuildSizesEXT vkGetMicromapBuildSizesEXT;
|
||||||
|
PFN_vkWriteMicromapsPropertiesEXT vkWriteMicromapsPropertiesEXT;
|
||||||
|
#endif /* defined(VK_EXT_opacity_micromap) */
|
||||||
#if defined(VK_EXT_pageable_device_local_memory)
|
#if defined(VK_EXT_pageable_device_local_memory)
|
||||||
PFN_vkSetDeviceMemoryPriorityEXT vkSetDeviceMemoryPriorityEXT;
|
PFN_vkSetDeviceMemoryPriorityEXT vkSetDeviceMemoryPriorityEXT;
|
||||||
#endif /* defined(VK_EXT_pageable_device_local_memory) */
|
#endif /* defined(VK_EXT_pageable_device_local_memory) */
|
||||||
|
#if defined(VK_EXT_pipeline_properties)
|
||||||
|
PFN_vkGetPipelinePropertiesEXT vkGetPipelinePropertiesEXT;
|
||||||
|
#endif /* defined(VK_EXT_pipeline_properties) */
|
||||||
#if defined(VK_EXT_private_data)
|
#if defined(VK_EXT_private_data)
|
||||||
PFN_vkCreatePrivateDataSlotEXT vkCreatePrivateDataSlotEXT;
|
PFN_vkCreatePrivateDataSlotEXT vkCreatePrivateDataSlotEXT;
|
||||||
PFN_vkDestroyPrivateDataSlotEXT vkDestroyPrivateDataSlotEXT;
|
PFN_vkDestroyPrivateDataSlotEXT vkDestroyPrivateDataSlotEXT;
|
||||||
@ -1961,6 +2204,10 @@ PFN_vkSetPrivateDataEXT vkSetPrivateDataEXT;
|
|||||||
PFN_vkCmdSetSampleLocationsEXT vkCmdSetSampleLocationsEXT;
|
PFN_vkCmdSetSampleLocationsEXT vkCmdSetSampleLocationsEXT;
|
||||||
PFN_vkGetPhysicalDeviceMultisamplePropertiesEXT vkGetPhysicalDeviceMultisamplePropertiesEXT;
|
PFN_vkGetPhysicalDeviceMultisamplePropertiesEXT vkGetPhysicalDeviceMultisamplePropertiesEXT;
|
||||||
#endif /* defined(VK_EXT_sample_locations) */
|
#endif /* defined(VK_EXT_sample_locations) */
|
||||||
|
#if defined(VK_EXT_shader_module_identifier)
|
||||||
|
PFN_vkGetShaderModuleCreateInfoIdentifierEXT vkGetShaderModuleCreateInfoIdentifierEXT;
|
||||||
|
PFN_vkGetShaderModuleIdentifierEXT vkGetShaderModuleIdentifierEXT;
|
||||||
|
#endif /* defined(VK_EXT_shader_module_identifier) */
|
||||||
#if defined(VK_EXT_tooling_info)
|
#if defined(VK_EXT_tooling_info)
|
||||||
PFN_vkGetPhysicalDeviceToolPropertiesEXT vkGetPhysicalDeviceToolPropertiesEXT;
|
PFN_vkGetPhysicalDeviceToolPropertiesEXT vkGetPhysicalDeviceToolPropertiesEXT;
|
||||||
#endif /* defined(VK_EXT_tooling_info) */
|
#endif /* defined(VK_EXT_tooling_info) */
|
||||||
@ -2197,6 +2444,9 @@ PFN_vkWaitForPresentKHR vkWaitForPresentKHR;
|
|||||||
#if defined(VK_KHR_push_descriptor)
|
#if defined(VK_KHR_push_descriptor)
|
||||||
PFN_vkCmdPushDescriptorSetKHR vkCmdPushDescriptorSetKHR;
|
PFN_vkCmdPushDescriptorSetKHR vkCmdPushDescriptorSetKHR;
|
||||||
#endif /* defined(VK_KHR_push_descriptor) */
|
#endif /* defined(VK_KHR_push_descriptor) */
|
||||||
|
#if defined(VK_KHR_ray_tracing_maintenance1) && defined(VK_KHR_ray_tracing_pipeline)
|
||||||
|
PFN_vkCmdTraceRaysIndirect2KHR vkCmdTraceRaysIndirect2KHR;
|
||||||
|
#endif /* defined(VK_KHR_ray_tracing_maintenance1) && defined(VK_KHR_ray_tracing_pipeline) */
|
||||||
#if defined(VK_KHR_ray_tracing_pipeline)
|
#if defined(VK_KHR_ray_tracing_pipeline)
|
||||||
PFN_vkCmdSetRayTracingPipelineStackSizeKHR vkCmdSetRayTracingPipelineStackSizeKHR;
|
PFN_vkCmdSetRayTracingPipelineStackSizeKHR vkCmdSetRayTracingPipelineStackSizeKHR;
|
||||||
PFN_vkCmdTraceRaysIndirectKHR vkCmdTraceRaysIndirectKHR;
|
PFN_vkCmdTraceRaysIndirectKHR vkCmdTraceRaysIndirectKHR;
|
||||||
@ -2344,6 +2594,13 @@ PFN_vkCmdDrawMeshTasksIndirectCountNV vkCmdDrawMeshTasksIndirectCountNV;
|
|||||||
PFN_vkCmdDrawMeshTasksIndirectNV vkCmdDrawMeshTasksIndirectNV;
|
PFN_vkCmdDrawMeshTasksIndirectNV vkCmdDrawMeshTasksIndirectNV;
|
||||||
PFN_vkCmdDrawMeshTasksNV vkCmdDrawMeshTasksNV;
|
PFN_vkCmdDrawMeshTasksNV vkCmdDrawMeshTasksNV;
|
||||||
#endif /* defined(VK_NV_mesh_shader) */
|
#endif /* defined(VK_NV_mesh_shader) */
|
||||||
|
#if defined(VK_NV_optical_flow)
|
||||||
|
PFN_vkBindOpticalFlowSessionImageNV vkBindOpticalFlowSessionImageNV;
|
||||||
|
PFN_vkCmdOpticalFlowExecuteNV vkCmdOpticalFlowExecuteNV;
|
||||||
|
PFN_vkCreateOpticalFlowSessionNV vkCreateOpticalFlowSessionNV;
|
||||||
|
PFN_vkDestroyOpticalFlowSessionNV vkDestroyOpticalFlowSessionNV;
|
||||||
|
PFN_vkGetPhysicalDeviceOpticalFlowImageFormatsNV vkGetPhysicalDeviceOpticalFlowImageFormatsNV;
|
||||||
|
#endif /* defined(VK_NV_optical_flow) */
|
||||||
#if defined(VK_NV_ray_tracing)
|
#if defined(VK_NV_ray_tracing)
|
||||||
PFN_vkBindAccelerationStructureMemoryNV vkBindAccelerationStructureMemoryNV;
|
PFN_vkBindAccelerationStructureMemoryNV vkBindAccelerationStructureMemoryNV;
|
||||||
PFN_vkCmdBuildAccelerationStructureNV vkCmdBuildAccelerationStructureNV;
|
PFN_vkCmdBuildAccelerationStructureNV vkCmdBuildAccelerationStructureNV;
|
||||||
@ -2366,10 +2623,18 @@ PFN_vkCmdBindShadingRateImageNV vkCmdBindShadingRateImageNV;
|
|||||||
PFN_vkCmdSetCoarseSampleOrderNV vkCmdSetCoarseSampleOrderNV;
|
PFN_vkCmdSetCoarseSampleOrderNV vkCmdSetCoarseSampleOrderNV;
|
||||||
PFN_vkCmdSetViewportShadingRatePaletteNV vkCmdSetViewportShadingRatePaletteNV;
|
PFN_vkCmdSetViewportShadingRatePaletteNV vkCmdSetViewportShadingRatePaletteNV;
|
||||||
#endif /* defined(VK_NV_shading_rate_image) */
|
#endif /* defined(VK_NV_shading_rate_image) */
|
||||||
|
#if defined(VK_QCOM_tile_properties)
|
||||||
|
PFN_vkGetDynamicRenderingTilePropertiesQCOM vkGetDynamicRenderingTilePropertiesQCOM;
|
||||||
|
PFN_vkGetFramebufferTilePropertiesQCOM vkGetFramebufferTilePropertiesQCOM;
|
||||||
|
#endif /* defined(VK_QCOM_tile_properties) */
|
||||||
#if defined(VK_QNX_screen_surface)
|
#if defined(VK_QNX_screen_surface)
|
||||||
PFN_vkCreateScreenSurfaceQNX vkCreateScreenSurfaceQNX;
|
PFN_vkCreateScreenSurfaceQNX vkCreateScreenSurfaceQNX;
|
||||||
PFN_vkGetPhysicalDeviceScreenPresentationSupportQNX vkGetPhysicalDeviceScreenPresentationSupportQNX;
|
PFN_vkGetPhysicalDeviceScreenPresentationSupportQNX vkGetPhysicalDeviceScreenPresentationSupportQNX;
|
||||||
#endif /* defined(VK_QNX_screen_surface) */
|
#endif /* defined(VK_QNX_screen_surface) */
|
||||||
|
#if defined(VK_VALVE_descriptor_set_host_mapping)
|
||||||
|
PFN_vkGetDescriptorSetHostMappingVALVE vkGetDescriptorSetHostMappingVALVE;
|
||||||
|
PFN_vkGetDescriptorSetLayoutHostMappingInfoVALVE vkGetDescriptorSetLayoutHostMappingInfoVALVE;
|
||||||
|
#endif /* defined(VK_VALVE_descriptor_set_host_mapping) */
|
||||||
#if (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1))
|
#if (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1))
|
||||||
PFN_vkGetDeviceGroupSurfacePresentModes2EXT vkGetDeviceGroupSurfacePresentModes2EXT;
|
PFN_vkGetDeviceGroupSurfacePresentModes2EXT vkGetDeviceGroupSurfacePresentModes2EXT;
|
||||||
#endif /* (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1)) */
|
#endif /* (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1)) */
|
||||||
|
181
thirdparty/volk/volk.h
vendored
181
thirdparty/volk/volk.h
vendored
@ -1,7 +1,7 @@
|
|||||||
/**
|
/**
|
||||||
* volk
|
* volk
|
||||||
*
|
*
|
||||||
* Copyright (C) 2018-2019, by Arseny Kapoulkine (arseny.kapoulkine@gmail.com)
|
* Copyright (C) 2018-2022, by Arseny Kapoulkine (arseny.kapoulkine@gmail.com)
|
||||||
* Report bugs and download new versions at https://github.com/zeux/volk
|
* Report bugs and download new versions at https://github.com/zeux/volk
|
||||||
*
|
*
|
||||||
* This library is distributed under the MIT License. See notice at the end of this file.
|
* This library is distributed under the MIT License. See notice at the end of this file.
|
||||||
@ -15,7 +15,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* VOLK_GENERATE_VERSION_DEFINE */
|
/* VOLK_GENERATE_VERSION_DEFINE */
|
||||||
#define VOLK_HEADER_VERSION 204
|
#define VOLK_HEADER_VERSION 231
|
||||||
/* VOLK_GENERATE_VERSION_DEFINE */
|
/* VOLK_GENERATE_VERSION_DEFINE */
|
||||||
|
|
||||||
#ifndef VK_NO_PROTOTYPES
|
#ifndef VK_NO_PROTOTYPES
|
||||||
@ -360,6 +360,9 @@ struct VolkDeviceTable
|
|||||||
PFN_vkDebugMarkerSetObjectNameEXT vkDebugMarkerSetObjectNameEXT;
|
PFN_vkDebugMarkerSetObjectNameEXT vkDebugMarkerSetObjectNameEXT;
|
||||||
PFN_vkDebugMarkerSetObjectTagEXT vkDebugMarkerSetObjectTagEXT;
|
PFN_vkDebugMarkerSetObjectTagEXT vkDebugMarkerSetObjectTagEXT;
|
||||||
#endif /* defined(VK_EXT_debug_marker) */
|
#endif /* defined(VK_EXT_debug_marker) */
|
||||||
|
#if defined(VK_EXT_device_fault)
|
||||||
|
PFN_vkGetDeviceFaultInfoEXT vkGetDeviceFaultInfoEXT;
|
||||||
|
#endif /* defined(VK_EXT_device_fault) */
|
||||||
#if defined(VK_EXT_discard_rectangles)
|
#if defined(VK_EXT_discard_rectangles)
|
||||||
PFN_vkCmdSetDiscardRectangleEXT vkCmdSetDiscardRectangleEXT;
|
PFN_vkCmdSetDiscardRectangleEXT vkCmdSetDiscardRectangleEXT;
|
||||||
#endif /* defined(VK_EXT_discard_rectangles) */
|
#endif /* defined(VK_EXT_discard_rectangles) */
|
||||||
@ -390,6 +393,39 @@ struct VolkDeviceTable
|
|||||||
PFN_vkCmdSetPrimitiveRestartEnableEXT vkCmdSetPrimitiveRestartEnableEXT;
|
PFN_vkCmdSetPrimitiveRestartEnableEXT vkCmdSetPrimitiveRestartEnableEXT;
|
||||||
PFN_vkCmdSetRasterizerDiscardEnableEXT vkCmdSetRasterizerDiscardEnableEXT;
|
PFN_vkCmdSetRasterizerDiscardEnableEXT vkCmdSetRasterizerDiscardEnableEXT;
|
||||||
#endif /* defined(VK_EXT_extended_dynamic_state2) */
|
#endif /* defined(VK_EXT_extended_dynamic_state2) */
|
||||||
|
#if defined(VK_EXT_extended_dynamic_state3)
|
||||||
|
PFN_vkCmdSetAlphaToCoverageEnableEXT vkCmdSetAlphaToCoverageEnableEXT;
|
||||||
|
PFN_vkCmdSetAlphaToOneEnableEXT vkCmdSetAlphaToOneEnableEXT;
|
||||||
|
PFN_vkCmdSetColorBlendAdvancedEXT vkCmdSetColorBlendAdvancedEXT;
|
||||||
|
PFN_vkCmdSetColorBlendEnableEXT vkCmdSetColorBlendEnableEXT;
|
||||||
|
PFN_vkCmdSetColorBlendEquationEXT vkCmdSetColorBlendEquationEXT;
|
||||||
|
PFN_vkCmdSetColorWriteMaskEXT vkCmdSetColorWriteMaskEXT;
|
||||||
|
PFN_vkCmdSetConservativeRasterizationModeEXT vkCmdSetConservativeRasterizationModeEXT;
|
||||||
|
PFN_vkCmdSetCoverageModulationModeNV vkCmdSetCoverageModulationModeNV;
|
||||||
|
PFN_vkCmdSetCoverageModulationTableEnableNV vkCmdSetCoverageModulationTableEnableNV;
|
||||||
|
PFN_vkCmdSetCoverageModulationTableNV vkCmdSetCoverageModulationTableNV;
|
||||||
|
PFN_vkCmdSetCoverageReductionModeNV vkCmdSetCoverageReductionModeNV;
|
||||||
|
PFN_vkCmdSetCoverageToColorEnableNV vkCmdSetCoverageToColorEnableNV;
|
||||||
|
PFN_vkCmdSetCoverageToColorLocationNV vkCmdSetCoverageToColorLocationNV;
|
||||||
|
PFN_vkCmdSetDepthClampEnableEXT vkCmdSetDepthClampEnableEXT;
|
||||||
|
PFN_vkCmdSetDepthClipEnableEXT vkCmdSetDepthClipEnableEXT;
|
||||||
|
PFN_vkCmdSetDepthClipNegativeOneToOneEXT vkCmdSetDepthClipNegativeOneToOneEXT;
|
||||||
|
PFN_vkCmdSetExtraPrimitiveOverestimationSizeEXT vkCmdSetExtraPrimitiveOverestimationSizeEXT;
|
||||||
|
PFN_vkCmdSetLineRasterizationModeEXT vkCmdSetLineRasterizationModeEXT;
|
||||||
|
PFN_vkCmdSetLineStippleEnableEXT vkCmdSetLineStippleEnableEXT;
|
||||||
|
PFN_vkCmdSetLogicOpEnableEXT vkCmdSetLogicOpEnableEXT;
|
||||||
|
PFN_vkCmdSetPolygonModeEXT vkCmdSetPolygonModeEXT;
|
||||||
|
PFN_vkCmdSetProvokingVertexModeEXT vkCmdSetProvokingVertexModeEXT;
|
||||||
|
PFN_vkCmdSetRasterizationSamplesEXT vkCmdSetRasterizationSamplesEXT;
|
||||||
|
PFN_vkCmdSetRasterizationStreamEXT vkCmdSetRasterizationStreamEXT;
|
||||||
|
PFN_vkCmdSetRepresentativeFragmentTestEnableNV vkCmdSetRepresentativeFragmentTestEnableNV;
|
||||||
|
PFN_vkCmdSetSampleLocationsEnableEXT vkCmdSetSampleLocationsEnableEXT;
|
||||||
|
PFN_vkCmdSetSampleMaskEXT vkCmdSetSampleMaskEXT;
|
||||||
|
PFN_vkCmdSetShadingRateImageEnableNV vkCmdSetShadingRateImageEnableNV;
|
||||||
|
PFN_vkCmdSetTessellationDomainOriginEXT vkCmdSetTessellationDomainOriginEXT;
|
||||||
|
PFN_vkCmdSetViewportSwizzleNV vkCmdSetViewportSwizzleNV;
|
||||||
|
PFN_vkCmdSetViewportWScalingEnableNV vkCmdSetViewportWScalingEnableNV;
|
||||||
|
#endif /* defined(VK_EXT_extended_dynamic_state3) */
|
||||||
#if defined(VK_EXT_external_memory_host)
|
#if defined(VK_EXT_external_memory_host)
|
||||||
PFN_vkGetMemoryHostPointerPropertiesEXT vkGetMemoryHostPointerPropertiesEXT;
|
PFN_vkGetMemoryHostPointerPropertiesEXT vkGetMemoryHostPointerPropertiesEXT;
|
||||||
#endif /* defined(VK_EXT_external_memory_host) */
|
#endif /* defined(VK_EXT_external_memory_host) */
|
||||||
@ -403,19 +439,49 @@ struct VolkDeviceTable
|
|||||||
#if defined(VK_EXT_host_query_reset)
|
#if defined(VK_EXT_host_query_reset)
|
||||||
PFN_vkResetQueryPoolEXT vkResetQueryPoolEXT;
|
PFN_vkResetQueryPoolEXT vkResetQueryPoolEXT;
|
||||||
#endif /* defined(VK_EXT_host_query_reset) */
|
#endif /* defined(VK_EXT_host_query_reset) */
|
||||||
|
#if defined(VK_EXT_image_compression_control)
|
||||||
|
PFN_vkGetImageSubresourceLayout2EXT vkGetImageSubresourceLayout2EXT;
|
||||||
|
#endif /* defined(VK_EXT_image_compression_control) */
|
||||||
#if defined(VK_EXT_image_drm_format_modifier)
|
#if defined(VK_EXT_image_drm_format_modifier)
|
||||||
PFN_vkGetImageDrmFormatModifierPropertiesEXT vkGetImageDrmFormatModifierPropertiesEXT;
|
PFN_vkGetImageDrmFormatModifierPropertiesEXT vkGetImageDrmFormatModifierPropertiesEXT;
|
||||||
#endif /* defined(VK_EXT_image_drm_format_modifier) */
|
#endif /* defined(VK_EXT_image_drm_format_modifier) */
|
||||||
#if defined(VK_EXT_line_rasterization)
|
#if defined(VK_EXT_line_rasterization)
|
||||||
PFN_vkCmdSetLineStippleEXT vkCmdSetLineStippleEXT;
|
PFN_vkCmdSetLineStippleEXT vkCmdSetLineStippleEXT;
|
||||||
#endif /* defined(VK_EXT_line_rasterization) */
|
#endif /* defined(VK_EXT_line_rasterization) */
|
||||||
|
#if defined(VK_EXT_mesh_shader)
|
||||||
|
PFN_vkCmdDrawMeshTasksEXT vkCmdDrawMeshTasksEXT;
|
||||||
|
PFN_vkCmdDrawMeshTasksIndirectCountEXT vkCmdDrawMeshTasksIndirectCountEXT;
|
||||||
|
PFN_vkCmdDrawMeshTasksIndirectEXT vkCmdDrawMeshTasksIndirectEXT;
|
||||||
|
#endif /* defined(VK_EXT_mesh_shader) */
|
||||||
|
#if defined(VK_EXT_metal_objects)
|
||||||
|
PFN_vkExportMetalObjectsEXT vkExportMetalObjectsEXT;
|
||||||
|
#endif /* defined(VK_EXT_metal_objects) */
|
||||||
#if defined(VK_EXT_multi_draw)
|
#if defined(VK_EXT_multi_draw)
|
||||||
PFN_vkCmdDrawMultiEXT vkCmdDrawMultiEXT;
|
PFN_vkCmdDrawMultiEXT vkCmdDrawMultiEXT;
|
||||||
PFN_vkCmdDrawMultiIndexedEXT vkCmdDrawMultiIndexedEXT;
|
PFN_vkCmdDrawMultiIndexedEXT vkCmdDrawMultiIndexedEXT;
|
||||||
#endif /* defined(VK_EXT_multi_draw) */
|
#endif /* defined(VK_EXT_multi_draw) */
|
||||||
|
#if defined(VK_EXT_opacity_micromap)
|
||||||
|
PFN_vkBuildMicromapsEXT vkBuildMicromapsEXT;
|
||||||
|
PFN_vkCmdBuildMicromapsEXT vkCmdBuildMicromapsEXT;
|
||||||
|
PFN_vkCmdCopyMemoryToMicromapEXT vkCmdCopyMemoryToMicromapEXT;
|
||||||
|
PFN_vkCmdCopyMicromapEXT vkCmdCopyMicromapEXT;
|
||||||
|
PFN_vkCmdCopyMicromapToMemoryEXT vkCmdCopyMicromapToMemoryEXT;
|
||||||
|
PFN_vkCmdWriteMicromapsPropertiesEXT vkCmdWriteMicromapsPropertiesEXT;
|
||||||
|
PFN_vkCopyMemoryToMicromapEXT vkCopyMemoryToMicromapEXT;
|
||||||
|
PFN_vkCopyMicromapEXT vkCopyMicromapEXT;
|
||||||
|
PFN_vkCopyMicromapToMemoryEXT vkCopyMicromapToMemoryEXT;
|
||||||
|
PFN_vkCreateMicromapEXT vkCreateMicromapEXT;
|
||||||
|
PFN_vkDestroyMicromapEXT vkDestroyMicromapEXT;
|
||||||
|
PFN_vkGetDeviceMicromapCompatibilityEXT vkGetDeviceMicromapCompatibilityEXT;
|
||||||
|
PFN_vkGetMicromapBuildSizesEXT vkGetMicromapBuildSizesEXT;
|
||||||
|
PFN_vkWriteMicromapsPropertiesEXT vkWriteMicromapsPropertiesEXT;
|
||||||
|
#endif /* defined(VK_EXT_opacity_micromap) */
|
||||||
#if defined(VK_EXT_pageable_device_local_memory)
|
#if defined(VK_EXT_pageable_device_local_memory)
|
||||||
PFN_vkSetDeviceMemoryPriorityEXT vkSetDeviceMemoryPriorityEXT;
|
PFN_vkSetDeviceMemoryPriorityEXT vkSetDeviceMemoryPriorityEXT;
|
||||||
#endif /* defined(VK_EXT_pageable_device_local_memory) */
|
#endif /* defined(VK_EXT_pageable_device_local_memory) */
|
||||||
|
#if defined(VK_EXT_pipeline_properties)
|
||||||
|
PFN_vkGetPipelinePropertiesEXT vkGetPipelinePropertiesEXT;
|
||||||
|
#endif /* defined(VK_EXT_pipeline_properties) */
|
||||||
#if defined(VK_EXT_private_data)
|
#if defined(VK_EXT_private_data)
|
||||||
PFN_vkCreatePrivateDataSlotEXT vkCreatePrivateDataSlotEXT;
|
PFN_vkCreatePrivateDataSlotEXT vkCreatePrivateDataSlotEXT;
|
||||||
PFN_vkDestroyPrivateDataSlotEXT vkDestroyPrivateDataSlotEXT;
|
PFN_vkDestroyPrivateDataSlotEXT vkDestroyPrivateDataSlotEXT;
|
||||||
@ -425,6 +491,10 @@ struct VolkDeviceTable
|
|||||||
#if defined(VK_EXT_sample_locations)
|
#if defined(VK_EXT_sample_locations)
|
||||||
PFN_vkCmdSetSampleLocationsEXT vkCmdSetSampleLocationsEXT;
|
PFN_vkCmdSetSampleLocationsEXT vkCmdSetSampleLocationsEXT;
|
||||||
#endif /* defined(VK_EXT_sample_locations) */
|
#endif /* defined(VK_EXT_sample_locations) */
|
||||||
|
#if defined(VK_EXT_shader_module_identifier)
|
||||||
|
PFN_vkGetShaderModuleCreateInfoIdentifierEXT vkGetShaderModuleCreateInfoIdentifierEXT;
|
||||||
|
PFN_vkGetShaderModuleIdentifierEXT vkGetShaderModuleIdentifierEXT;
|
||||||
|
#endif /* defined(VK_EXT_shader_module_identifier) */
|
||||||
#if defined(VK_EXT_transform_feedback)
|
#if defined(VK_EXT_transform_feedback)
|
||||||
PFN_vkCmdBeginQueryIndexedEXT vkCmdBeginQueryIndexedEXT;
|
PFN_vkCmdBeginQueryIndexedEXT vkCmdBeginQueryIndexedEXT;
|
||||||
PFN_vkCmdBeginTransformFeedbackEXT vkCmdBeginTransformFeedbackEXT;
|
PFN_vkCmdBeginTransformFeedbackEXT vkCmdBeginTransformFeedbackEXT;
|
||||||
@ -606,6 +676,9 @@ struct VolkDeviceTable
|
|||||||
#if defined(VK_KHR_push_descriptor)
|
#if defined(VK_KHR_push_descriptor)
|
||||||
PFN_vkCmdPushDescriptorSetKHR vkCmdPushDescriptorSetKHR;
|
PFN_vkCmdPushDescriptorSetKHR vkCmdPushDescriptorSetKHR;
|
||||||
#endif /* defined(VK_KHR_push_descriptor) */
|
#endif /* defined(VK_KHR_push_descriptor) */
|
||||||
|
#if defined(VK_KHR_ray_tracing_maintenance1) && defined(VK_KHR_ray_tracing_pipeline)
|
||||||
|
PFN_vkCmdTraceRaysIndirect2KHR vkCmdTraceRaysIndirect2KHR;
|
||||||
|
#endif /* defined(VK_KHR_ray_tracing_maintenance1) && defined(VK_KHR_ray_tracing_pipeline) */
|
||||||
#if defined(VK_KHR_ray_tracing_pipeline)
|
#if defined(VK_KHR_ray_tracing_pipeline)
|
||||||
PFN_vkCmdSetRayTracingPipelineStackSizeKHR vkCmdSetRayTracingPipelineStackSizeKHR;
|
PFN_vkCmdSetRayTracingPipelineStackSizeKHR vkCmdSetRayTracingPipelineStackSizeKHR;
|
||||||
PFN_vkCmdTraceRaysIndirectKHR vkCmdTraceRaysIndirectKHR;
|
PFN_vkCmdTraceRaysIndirectKHR vkCmdTraceRaysIndirectKHR;
|
||||||
@ -706,6 +779,12 @@ struct VolkDeviceTable
|
|||||||
PFN_vkCmdDrawMeshTasksIndirectNV vkCmdDrawMeshTasksIndirectNV;
|
PFN_vkCmdDrawMeshTasksIndirectNV vkCmdDrawMeshTasksIndirectNV;
|
||||||
PFN_vkCmdDrawMeshTasksNV vkCmdDrawMeshTasksNV;
|
PFN_vkCmdDrawMeshTasksNV vkCmdDrawMeshTasksNV;
|
||||||
#endif /* defined(VK_NV_mesh_shader) */
|
#endif /* defined(VK_NV_mesh_shader) */
|
||||||
|
#if defined(VK_NV_optical_flow)
|
||||||
|
PFN_vkBindOpticalFlowSessionImageNV vkBindOpticalFlowSessionImageNV;
|
||||||
|
PFN_vkCmdOpticalFlowExecuteNV vkCmdOpticalFlowExecuteNV;
|
||||||
|
PFN_vkCreateOpticalFlowSessionNV vkCreateOpticalFlowSessionNV;
|
||||||
|
PFN_vkDestroyOpticalFlowSessionNV vkDestroyOpticalFlowSessionNV;
|
||||||
|
#endif /* defined(VK_NV_optical_flow) */
|
||||||
#if defined(VK_NV_ray_tracing)
|
#if defined(VK_NV_ray_tracing)
|
||||||
PFN_vkBindAccelerationStructureMemoryNV vkBindAccelerationStructureMemoryNV;
|
PFN_vkBindAccelerationStructureMemoryNV vkBindAccelerationStructureMemoryNV;
|
||||||
PFN_vkCmdBuildAccelerationStructureNV vkCmdBuildAccelerationStructureNV;
|
PFN_vkCmdBuildAccelerationStructureNV vkCmdBuildAccelerationStructureNV;
|
||||||
@ -728,6 +807,14 @@ struct VolkDeviceTable
|
|||||||
PFN_vkCmdSetCoarseSampleOrderNV vkCmdSetCoarseSampleOrderNV;
|
PFN_vkCmdSetCoarseSampleOrderNV vkCmdSetCoarseSampleOrderNV;
|
||||||
PFN_vkCmdSetViewportShadingRatePaletteNV vkCmdSetViewportShadingRatePaletteNV;
|
PFN_vkCmdSetViewportShadingRatePaletteNV vkCmdSetViewportShadingRatePaletteNV;
|
||||||
#endif /* defined(VK_NV_shading_rate_image) */
|
#endif /* defined(VK_NV_shading_rate_image) */
|
||||||
|
#if defined(VK_QCOM_tile_properties)
|
||||||
|
PFN_vkGetDynamicRenderingTilePropertiesQCOM vkGetDynamicRenderingTilePropertiesQCOM;
|
||||||
|
PFN_vkGetFramebufferTilePropertiesQCOM vkGetFramebufferTilePropertiesQCOM;
|
||||||
|
#endif /* defined(VK_QCOM_tile_properties) */
|
||||||
|
#if defined(VK_VALVE_descriptor_set_host_mapping)
|
||||||
|
PFN_vkGetDescriptorSetHostMappingVALVE vkGetDescriptorSetHostMappingVALVE;
|
||||||
|
PFN_vkGetDescriptorSetLayoutHostMappingInfoVALVE vkGetDescriptorSetLayoutHostMappingInfoVALVE;
|
||||||
|
#endif /* defined(VK_VALVE_descriptor_set_host_mapping) */
|
||||||
#if (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1))
|
#if (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1))
|
||||||
PFN_vkGetDeviceGroupSurfacePresentModes2EXT vkGetDeviceGroupSurfacePresentModes2EXT;
|
PFN_vkGetDeviceGroupSurfacePresentModes2EXT vkGetDeviceGroupSurfacePresentModes2EXT;
|
||||||
#endif /* (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1)) */
|
#endif /* (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1)) */
|
||||||
@ -1032,6 +1119,9 @@ extern PFN_vkSetDebugUtilsObjectNameEXT vkSetDebugUtilsObjectNameEXT;
|
|||||||
extern PFN_vkSetDebugUtilsObjectTagEXT vkSetDebugUtilsObjectTagEXT;
|
extern PFN_vkSetDebugUtilsObjectTagEXT vkSetDebugUtilsObjectTagEXT;
|
||||||
extern PFN_vkSubmitDebugUtilsMessageEXT vkSubmitDebugUtilsMessageEXT;
|
extern PFN_vkSubmitDebugUtilsMessageEXT vkSubmitDebugUtilsMessageEXT;
|
||||||
#endif /* defined(VK_EXT_debug_utils) */
|
#endif /* defined(VK_EXT_debug_utils) */
|
||||||
|
#if defined(VK_EXT_device_fault)
|
||||||
|
extern PFN_vkGetDeviceFaultInfoEXT vkGetDeviceFaultInfoEXT;
|
||||||
|
#endif /* defined(VK_EXT_device_fault) */
|
||||||
#if defined(VK_EXT_direct_mode_display)
|
#if defined(VK_EXT_direct_mode_display)
|
||||||
extern PFN_vkReleaseDisplayEXT vkReleaseDisplayEXT;
|
extern PFN_vkReleaseDisplayEXT vkReleaseDisplayEXT;
|
||||||
#endif /* defined(VK_EXT_direct_mode_display) */
|
#endif /* defined(VK_EXT_direct_mode_display) */
|
||||||
@ -1072,6 +1162,39 @@ extern PFN_vkCmdSetPatchControlPointsEXT vkCmdSetPatchControlPointsEXT;
|
|||||||
extern PFN_vkCmdSetPrimitiveRestartEnableEXT vkCmdSetPrimitiveRestartEnableEXT;
|
extern PFN_vkCmdSetPrimitiveRestartEnableEXT vkCmdSetPrimitiveRestartEnableEXT;
|
||||||
extern PFN_vkCmdSetRasterizerDiscardEnableEXT vkCmdSetRasterizerDiscardEnableEXT;
|
extern PFN_vkCmdSetRasterizerDiscardEnableEXT vkCmdSetRasterizerDiscardEnableEXT;
|
||||||
#endif /* defined(VK_EXT_extended_dynamic_state2) */
|
#endif /* defined(VK_EXT_extended_dynamic_state2) */
|
||||||
|
#if defined(VK_EXT_extended_dynamic_state3)
|
||||||
|
extern PFN_vkCmdSetAlphaToCoverageEnableEXT vkCmdSetAlphaToCoverageEnableEXT;
|
||||||
|
extern PFN_vkCmdSetAlphaToOneEnableEXT vkCmdSetAlphaToOneEnableEXT;
|
||||||
|
extern PFN_vkCmdSetColorBlendAdvancedEXT vkCmdSetColorBlendAdvancedEXT;
|
||||||
|
extern PFN_vkCmdSetColorBlendEnableEXT vkCmdSetColorBlendEnableEXT;
|
||||||
|
extern PFN_vkCmdSetColorBlendEquationEXT vkCmdSetColorBlendEquationEXT;
|
||||||
|
extern PFN_vkCmdSetColorWriteMaskEXT vkCmdSetColorWriteMaskEXT;
|
||||||
|
extern PFN_vkCmdSetConservativeRasterizationModeEXT vkCmdSetConservativeRasterizationModeEXT;
|
||||||
|
extern PFN_vkCmdSetCoverageModulationModeNV vkCmdSetCoverageModulationModeNV;
|
||||||
|
extern PFN_vkCmdSetCoverageModulationTableEnableNV vkCmdSetCoverageModulationTableEnableNV;
|
||||||
|
extern PFN_vkCmdSetCoverageModulationTableNV vkCmdSetCoverageModulationTableNV;
|
||||||
|
extern PFN_vkCmdSetCoverageReductionModeNV vkCmdSetCoverageReductionModeNV;
|
||||||
|
extern PFN_vkCmdSetCoverageToColorEnableNV vkCmdSetCoverageToColorEnableNV;
|
||||||
|
extern PFN_vkCmdSetCoverageToColorLocationNV vkCmdSetCoverageToColorLocationNV;
|
||||||
|
extern PFN_vkCmdSetDepthClampEnableEXT vkCmdSetDepthClampEnableEXT;
|
||||||
|
extern PFN_vkCmdSetDepthClipEnableEXT vkCmdSetDepthClipEnableEXT;
|
||||||
|
extern PFN_vkCmdSetDepthClipNegativeOneToOneEXT vkCmdSetDepthClipNegativeOneToOneEXT;
|
||||||
|
extern PFN_vkCmdSetExtraPrimitiveOverestimationSizeEXT vkCmdSetExtraPrimitiveOverestimationSizeEXT;
|
||||||
|
extern PFN_vkCmdSetLineRasterizationModeEXT vkCmdSetLineRasterizationModeEXT;
|
||||||
|
extern PFN_vkCmdSetLineStippleEnableEXT vkCmdSetLineStippleEnableEXT;
|
||||||
|
extern PFN_vkCmdSetLogicOpEnableEXT vkCmdSetLogicOpEnableEXT;
|
||||||
|
extern PFN_vkCmdSetPolygonModeEXT vkCmdSetPolygonModeEXT;
|
||||||
|
extern PFN_vkCmdSetProvokingVertexModeEXT vkCmdSetProvokingVertexModeEXT;
|
||||||
|
extern PFN_vkCmdSetRasterizationSamplesEXT vkCmdSetRasterizationSamplesEXT;
|
||||||
|
extern PFN_vkCmdSetRasterizationStreamEXT vkCmdSetRasterizationStreamEXT;
|
||||||
|
extern PFN_vkCmdSetRepresentativeFragmentTestEnableNV vkCmdSetRepresentativeFragmentTestEnableNV;
|
||||||
|
extern PFN_vkCmdSetSampleLocationsEnableEXT vkCmdSetSampleLocationsEnableEXT;
|
||||||
|
extern PFN_vkCmdSetSampleMaskEXT vkCmdSetSampleMaskEXT;
|
||||||
|
extern PFN_vkCmdSetShadingRateImageEnableNV vkCmdSetShadingRateImageEnableNV;
|
||||||
|
extern PFN_vkCmdSetTessellationDomainOriginEXT vkCmdSetTessellationDomainOriginEXT;
|
||||||
|
extern PFN_vkCmdSetViewportSwizzleNV vkCmdSetViewportSwizzleNV;
|
||||||
|
extern PFN_vkCmdSetViewportWScalingEnableNV vkCmdSetViewportWScalingEnableNV;
|
||||||
|
#endif /* defined(VK_EXT_extended_dynamic_state3) */
|
||||||
#if defined(VK_EXT_external_memory_host)
|
#if defined(VK_EXT_external_memory_host)
|
||||||
extern PFN_vkGetMemoryHostPointerPropertiesEXT vkGetMemoryHostPointerPropertiesEXT;
|
extern PFN_vkGetMemoryHostPointerPropertiesEXT vkGetMemoryHostPointerPropertiesEXT;
|
||||||
#endif /* defined(VK_EXT_external_memory_host) */
|
#endif /* defined(VK_EXT_external_memory_host) */
|
||||||
@ -1089,12 +1212,23 @@ extern PFN_vkCreateHeadlessSurfaceEXT vkCreateHeadlessSurfaceEXT;
|
|||||||
#if defined(VK_EXT_host_query_reset)
|
#if defined(VK_EXT_host_query_reset)
|
||||||
extern PFN_vkResetQueryPoolEXT vkResetQueryPoolEXT;
|
extern PFN_vkResetQueryPoolEXT vkResetQueryPoolEXT;
|
||||||
#endif /* defined(VK_EXT_host_query_reset) */
|
#endif /* defined(VK_EXT_host_query_reset) */
|
||||||
|
#if defined(VK_EXT_image_compression_control)
|
||||||
|
extern PFN_vkGetImageSubresourceLayout2EXT vkGetImageSubresourceLayout2EXT;
|
||||||
|
#endif /* defined(VK_EXT_image_compression_control) */
|
||||||
#if defined(VK_EXT_image_drm_format_modifier)
|
#if defined(VK_EXT_image_drm_format_modifier)
|
||||||
extern PFN_vkGetImageDrmFormatModifierPropertiesEXT vkGetImageDrmFormatModifierPropertiesEXT;
|
extern PFN_vkGetImageDrmFormatModifierPropertiesEXT vkGetImageDrmFormatModifierPropertiesEXT;
|
||||||
#endif /* defined(VK_EXT_image_drm_format_modifier) */
|
#endif /* defined(VK_EXT_image_drm_format_modifier) */
|
||||||
#if defined(VK_EXT_line_rasterization)
|
#if defined(VK_EXT_line_rasterization)
|
||||||
extern PFN_vkCmdSetLineStippleEXT vkCmdSetLineStippleEXT;
|
extern PFN_vkCmdSetLineStippleEXT vkCmdSetLineStippleEXT;
|
||||||
#endif /* defined(VK_EXT_line_rasterization) */
|
#endif /* defined(VK_EXT_line_rasterization) */
|
||||||
|
#if defined(VK_EXT_mesh_shader)
|
||||||
|
extern PFN_vkCmdDrawMeshTasksEXT vkCmdDrawMeshTasksEXT;
|
||||||
|
extern PFN_vkCmdDrawMeshTasksIndirectCountEXT vkCmdDrawMeshTasksIndirectCountEXT;
|
||||||
|
extern PFN_vkCmdDrawMeshTasksIndirectEXT vkCmdDrawMeshTasksIndirectEXT;
|
||||||
|
#endif /* defined(VK_EXT_mesh_shader) */
|
||||||
|
#if defined(VK_EXT_metal_objects)
|
||||||
|
extern PFN_vkExportMetalObjectsEXT vkExportMetalObjectsEXT;
|
||||||
|
#endif /* defined(VK_EXT_metal_objects) */
|
||||||
#if defined(VK_EXT_metal_surface)
|
#if defined(VK_EXT_metal_surface)
|
||||||
extern PFN_vkCreateMetalSurfaceEXT vkCreateMetalSurfaceEXT;
|
extern PFN_vkCreateMetalSurfaceEXT vkCreateMetalSurfaceEXT;
|
||||||
#endif /* defined(VK_EXT_metal_surface) */
|
#endif /* defined(VK_EXT_metal_surface) */
|
||||||
@ -1102,9 +1236,28 @@ extern PFN_vkCreateMetalSurfaceEXT vkCreateMetalSurfaceEXT;
|
|||||||
extern PFN_vkCmdDrawMultiEXT vkCmdDrawMultiEXT;
|
extern PFN_vkCmdDrawMultiEXT vkCmdDrawMultiEXT;
|
||||||
extern PFN_vkCmdDrawMultiIndexedEXT vkCmdDrawMultiIndexedEXT;
|
extern PFN_vkCmdDrawMultiIndexedEXT vkCmdDrawMultiIndexedEXT;
|
||||||
#endif /* defined(VK_EXT_multi_draw) */
|
#endif /* defined(VK_EXT_multi_draw) */
|
||||||
|
#if defined(VK_EXT_opacity_micromap)
|
||||||
|
extern PFN_vkBuildMicromapsEXT vkBuildMicromapsEXT;
|
||||||
|
extern PFN_vkCmdBuildMicromapsEXT vkCmdBuildMicromapsEXT;
|
||||||
|
extern PFN_vkCmdCopyMemoryToMicromapEXT vkCmdCopyMemoryToMicromapEXT;
|
||||||
|
extern PFN_vkCmdCopyMicromapEXT vkCmdCopyMicromapEXT;
|
||||||
|
extern PFN_vkCmdCopyMicromapToMemoryEXT vkCmdCopyMicromapToMemoryEXT;
|
||||||
|
extern PFN_vkCmdWriteMicromapsPropertiesEXT vkCmdWriteMicromapsPropertiesEXT;
|
||||||
|
extern PFN_vkCopyMemoryToMicromapEXT vkCopyMemoryToMicromapEXT;
|
||||||
|
extern PFN_vkCopyMicromapEXT vkCopyMicromapEXT;
|
||||||
|
extern PFN_vkCopyMicromapToMemoryEXT vkCopyMicromapToMemoryEXT;
|
||||||
|
extern PFN_vkCreateMicromapEXT vkCreateMicromapEXT;
|
||||||
|
extern PFN_vkDestroyMicromapEXT vkDestroyMicromapEXT;
|
||||||
|
extern PFN_vkGetDeviceMicromapCompatibilityEXT vkGetDeviceMicromapCompatibilityEXT;
|
||||||
|
extern PFN_vkGetMicromapBuildSizesEXT vkGetMicromapBuildSizesEXT;
|
||||||
|
extern PFN_vkWriteMicromapsPropertiesEXT vkWriteMicromapsPropertiesEXT;
|
||||||
|
#endif /* defined(VK_EXT_opacity_micromap) */
|
||||||
#if defined(VK_EXT_pageable_device_local_memory)
|
#if defined(VK_EXT_pageable_device_local_memory)
|
||||||
extern PFN_vkSetDeviceMemoryPriorityEXT vkSetDeviceMemoryPriorityEXT;
|
extern PFN_vkSetDeviceMemoryPriorityEXT vkSetDeviceMemoryPriorityEXT;
|
||||||
#endif /* defined(VK_EXT_pageable_device_local_memory) */
|
#endif /* defined(VK_EXT_pageable_device_local_memory) */
|
||||||
|
#if defined(VK_EXT_pipeline_properties)
|
||||||
|
extern PFN_vkGetPipelinePropertiesEXT vkGetPipelinePropertiesEXT;
|
||||||
|
#endif /* defined(VK_EXT_pipeline_properties) */
|
||||||
#if defined(VK_EXT_private_data)
|
#if defined(VK_EXT_private_data)
|
||||||
extern PFN_vkCreatePrivateDataSlotEXT vkCreatePrivateDataSlotEXT;
|
extern PFN_vkCreatePrivateDataSlotEXT vkCreatePrivateDataSlotEXT;
|
||||||
extern PFN_vkDestroyPrivateDataSlotEXT vkDestroyPrivateDataSlotEXT;
|
extern PFN_vkDestroyPrivateDataSlotEXT vkDestroyPrivateDataSlotEXT;
|
||||||
@ -1115,6 +1268,10 @@ extern PFN_vkSetPrivateDataEXT vkSetPrivateDataEXT;
|
|||||||
extern PFN_vkCmdSetSampleLocationsEXT vkCmdSetSampleLocationsEXT;
|
extern PFN_vkCmdSetSampleLocationsEXT vkCmdSetSampleLocationsEXT;
|
||||||
extern PFN_vkGetPhysicalDeviceMultisamplePropertiesEXT vkGetPhysicalDeviceMultisamplePropertiesEXT;
|
extern PFN_vkGetPhysicalDeviceMultisamplePropertiesEXT vkGetPhysicalDeviceMultisamplePropertiesEXT;
|
||||||
#endif /* defined(VK_EXT_sample_locations) */
|
#endif /* defined(VK_EXT_sample_locations) */
|
||||||
|
#if defined(VK_EXT_shader_module_identifier)
|
||||||
|
extern PFN_vkGetShaderModuleCreateInfoIdentifierEXT vkGetShaderModuleCreateInfoIdentifierEXT;
|
||||||
|
extern PFN_vkGetShaderModuleIdentifierEXT vkGetShaderModuleIdentifierEXT;
|
||||||
|
#endif /* defined(VK_EXT_shader_module_identifier) */
|
||||||
#if defined(VK_EXT_tooling_info)
|
#if defined(VK_EXT_tooling_info)
|
||||||
extern PFN_vkGetPhysicalDeviceToolPropertiesEXT vkGetPhysicalDeviceToolPropertiesEXT;
|
extern PFN_vkGetPhysicalDeviceToolPropertiesEXT vkGetPhysicalDeviceToolPropertiesEXT;
|
||||||
#endif /* defined(VK_EXT_tooling_info) */
|
#endif /* defined(VK_EXT_tooling_info) */
|
||||||
@ -1351,6 +1508,9 @@ extern PFN_vkWaitForPresentKHR vkWaitForPresentKHR;
|
|||||||
#if defined(VK_KHR_push_descriptor)
|
#if defined(VK_KHR_push_descriptor)
|
||||||
extern PFN_vkCmdPushDescriptorSetKHR vkCmdPushDescriptorSetKHR;
|
extern PFN_vkCmdPushDescriptorSetKHR vkCmdPushDescriptorSetKHR;
|
||||||
#endif /* defined(VK_KHR_push_descriptor) */
|
#endif /* defined(VK_KHR_push_descriptor) */
|
||||||
|
#if defined(VK_KHR_ray_tracing_maintenance1) && defined(VK_KHR_ray_tracing_pipeline)
|
||||||
|
extern PFN_vkCmdTraceRaysIndirect2KHR vkCmdTraceRaysIndirect2KHR;
|
||||||
|
#endif /* defined(VK_KHR_ray_tracing_maintenance1) && defined(VK_KHR_ray_tracing_pipeline) */
|
||||||
#if defined(VK_KHR_ray_tracing_pipeline)
|
#if defined(VK_KHR_ray_tracing_pipeline)
|
||||||
extern PFN_vkCmdSetRayTracingPipelineStackSizeKHR vkCmdSetRayTracingPipelineStackSizeKHR;
|
extern PFN_vkCmdSetRayTracingPipelineStackSizeKHR vkCmdSetRayTracingPipelineStackSizeKHR;
|
||||||
extern PFN_vkCmdTraceRaysIndirectKHR vkCmdTraceRaysIndirectKHR;
|
extern PFN_vkCmdTraceRaysIndirectKHR vkCmdTraceRaysIndirectKHR;
|
||||||
@ -1498,6 +1658,13 @@ extern PFN_vkCmdDrawMeshTasksIndirectCountNV vkCmdDrawMeshTasksIndirectCountNV;
|
|||||||
extern PFN_vkCmdDrawMeshTasksIndirectNV vkCmdDrawMeshTasksIndirectNV;
|
extern PFN_vkCmdDrawMeshTasksIndirectNV vkCmdDrawMeshTasksIndirectNV;
|
||||||
extern PFN_vkCmdDrawMeshTasksNV vkCmdDrawMeshTasksNV;
|
extern PFN_vkCmdDrawMeshTasksNV vkCmdDrawMeshTasksNV;
|
||||||
#endif /* defined(VK_NV_mesh_shader) */
|
#endif /* defined(VK_NV_mesh_shader) */
|
||||||
|
#if defined(VK_NV_optical_flow)
|
||||||
|
extern PFN_vkBindOpticalFlowSessionImageNV vkBindOpticalFlowSessionImageNV;
|
||||||
|
extern PFN_vkCmdOpticalFlowExecuteNV vkCmdOpticalFlowExecuteNV;
|
||||||
|
extern PFN_vkCreateOpticalFlowSessionNV vkCreateOpticalFlowSessionNV;
|
||||||
|
extern PFN_vkDestroyOpticalFlowSessionNV vkDestroyOpticalFlowSessionNV;
|
||||||
|
extern PFN_vkGetPhysicalDeviceOpticalFlowImageFormatsNV vkGetPhysicalDeviceOpticalFlowImageFormatsNV;
|
||||||
|
#endif /* defined(VK_NV_optical_flow) */
|
||||||
#if defined(VK_NV_ray_tracing)
|
#if defined(VK_NV_ray_tracing)
|
||||||
extern PFN_vkBindAccelerationStructureMemoryNV vkBindAccelerationStructureMemoryNV;
|
extern PFN_vkBindAccelerationStructureMemoryNV vkBindAccelerationStructureMemoryNV;
|
||||||
extern PFN_vkCmdBuildAccelerationStructureNV vkCmdBuildAccelerationStructureNV;
|
extern PFN_vkCmdBuildAccelerationStructureNV vkCmdBuildAccelerationStructureNV;
|
||||||
@ -1520,10 +1687,18 @@ extern PFN_vkCmdBindShadingRateImageNV vkCmdBindShadingRateImageNV;
|
|||||||
extern PFN_vkCmdSetCoarseSampleOrderNV vkCmdSetCoarseSampleOrderNV;
|
extern PFN_vkCmdSetCoarseSampleOrderNV vkCmdSetCoarseSampleOrderNV;
|
||||||
extern PFN_vkCmdSetViewportShadingRatePaletteNV vkCmdSetViewportShadingRatePaletteNV;
|
extern PFN_vkCmdSetViewportShadingRatePaletteNV vkCmdSetViewportShadingRatePaletteNV;
|
||||||
#endif /* defined(VK_NV_shading_rate_image) */
|
#endif /* defined(VK_NV_shading_rate_image) */
|
||||||
|
#if defined(VK_QCOM_tile_properties)
|
||||||
|
extern PFN_vkGetDynamicRenderingTilePropertiesQCOM vkGetDynamicRenderingTilePropertiesQCOM;
|
||||||
|
extern PFN_vkGetFramebufferTilePropertiesQCOM vkGetFramebufferTilePropertiesQCOM;
|
||||||
|
#endif /* defined(VK_QCOM_tile_properties) */
|
||||||
#if defined(VK_QNX_screen_surface)
|
#if defined(VK_QNX_screen_surface)
|
||||||
extern PFN_vkCreateScreenSurfaceQNX vkCreateScreenSurfaceQNX;
|
extern PFN_vkCreateScreenSurfaceQNX vkCreateScreenSurfaceQNX;
|
||||||
extern PFN_vkGetPhysicalDeviceScreenPresentationSupportQNX vkGetPhysicalDeviceScreenPresentationSupportQNX;
|
extern PFN_vkGetPhysicalDeviceScreenPresentationSupportQNX vkGetPhysicalDeviceScreenPresentationSupportQNX;
|
||||||
#endif /* defined(VK_QNX_screen_surface) */
|
#endif /* defined(VK_QNX_screen_surface) */
|
||||||
|
#if defined(VK_VALVE_descriptor_set_host_mapping)
|
||||||
|
extern PFN_vkGetDescriptorSetHostMappingVALVE vkGetDescriptorSetHostMappingVALVE;
|
||||||
|
extern PFN_vkGetDescriptorSetLayoutHostMappingInfoVALVE vkGetDescriptorSetLayoutHostMappingInfoVALVE;
|
||||||
|
#endif /* defined(VK_VALVE_descriptor_set_host_mapping) */
|
||||||
#if (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1))
|
#if (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1))
|
||||||
extern PFN_vkGetDeviceGroupSurfacePresentModes2EXT vkGetDeviceGroupSurfacePresentModes2EXT;
|
extern PFN_vkGetDeviceGroupSurfacePresentModes2EXT vkGetDeviceGroupSurfacePresentModes2EXT;
|
||||||
#endif /* (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1)) */
|
#endif /* (defined(VK_EXT_full_screen_exclusive) && defined(VK_KHR_device_group)) || (defined(VK_EXT_full_screen_exclusive) && defined(VK_VERSION_1_1)) */
|
||||||
@ -1555,7 +1730,7 @@ extern PFN_vkAcquireNextImage2KHR vkAcquireNextImage2KHR;
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Copyright (c) 2018-2019 Arseny Kapoulkine
|
* Copyright (c) 2018-2022 Arseny Kapoulkine
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
* of this software and associated documentation files (the "Software"), to deal
|
* of this software and associated documentation files (the "Software"), to deal
|
||||||
|
@ -21,16 +21,13 @@ extern "C" {
|
|||||||
|
|
||||||
#define vulkan_video_codec_h264std 1
|
#define vulkan_video_codec_h264std 1
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
// Vulkan 0.9 provisional Vulkan video H.264 encode and decode std specification version number
|
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H264_API_VERSION_0_9_5 VK_MAKE_VIDEO_STD_VERSION(0, 9, 5) // Patch version should always be set to 0
|
|
||||||
|
|
||||||
#define STD_VIDEO_H264_CPB_CNT_LIST_SIZE 32
|
#define STD_VIDEO_H264_CPB_CNT_LIST_SIZE 32
|
||||||
#define STD_VIDEO_H264_SCALING_LIST_4X4_NUM_LISTS 6
|
#define STD_VIDEO_H264_SCALING_LIST_4X4_NUM_LISTS 6
|
||||||
#define STD_VIDEO_H264_SCALING_LIST_4X4_NUM_ELEMENTS 16
|
#define STD_VIDEO_H264_SCALING_LIST_4X4_NUM_ELEMENTS 16
|
||||||
#define STD_VIDEO_H264_SCALING_LIST_8X8_NUM_LISTS 2
|
#define STD_VIDEO_H264_SCALING_LIST_8X8_NUM_LISTS 6
|
||||||
#define STD_VIDEO_H264_SCALING_LIST_8X8_NUM_ELEMENTS 64
|
#define STD_VIDEO_H264_SCALING_LIST_8X8_NUM_ELEMENTS 64
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H264_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H264_API_VERSION_0_9_5
|
#define STD_VIDEO_H264_MAX_NUM_LIST_REF 32
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H264_EXTENSION_NAME "VK_STD_vulkan_video_codec_h264"
|
#define STD_VIDEO_H264_MAX_CHROMA_PLANES 2
|
||||||
|
|
||||||
typedef enum StdVideoH264ChromaFormatIdc {
|
typedef enum StdVideoH264ChromaFormatIdc {
|
||||||
STD_VIDEO_H264_CHROMA_FORMAT_IDC_MONOCHROME = 0,
|
STD_VIDEO_H264_CHROMA_FORMAT_IDC_MONOCHROME = 0,
|
||||||
@ -50,29 +47,29 @@ typedef enum StdVideoH264ProfileIdc {
|
|||||||
STD_VIDEO_H264_PROFILE_IDC_MAX_ENUM = 0x7FFFFFFF
|
STD_VIDEO_H264_PROFILE_IDC_MAX_ENUM = 0x7FFFFFFF
|
||||||
} StdVideoH264ProfileIdc;
|
} StdVideoH264ProfileIdc;
|
||||||
|
|
||||||
typedef enum StdVideoH264Level {
|
typedef enum StdVideoH264LevelIdc {
|
||||||
STD_VIDEO_H264_LEVEL_1_0 = 0,
|
STD_VIDEO_H264_LEVEL_IDC_1_0 = 0,
|
||||||
STD_VIDEO_H264_LEVEL_1_1 = 1,
|
STD_VIDEO_H264_LEVEL_IDC_1_1 = 1,
|
||||||
STD_VIDEO_H264_LEVEL_1_2 = 2,
|
STD_VIDEO_H264_LEVEL_IDC_1_2 = 2,
|
||||||
STD_VIDEO_H264_LEVEL_1_3 = 3,
|
STD_VIDEO_H264_LEVEL_IDC_1_3 = 3,
|
||||||
STD_VIDEO_H264_LEVEL_2_0 = 4,
|
STD_VIDEO_H264_LEVEL_IDC_2_0 = 4,
|
||||||
STD_VIDEO_H264_LEVEL_2_1 = 5,
|
STD_VIDEO_H264_LEVEL_IDC_2_1 = 5,
|
||||||
STD_VIDEO_H264_LEVEL_2_2 = 6,
|
STD_VIDEO_H264_LEVEL_IDC_2_2 = 6,
|
||||||
STD_VIDEO_H264_LEVEL_3_0 = 7,
|
STD_VIDEO_H264_LEVEL_IDC_3_0 = 7,
|
||||||
STD_VIDEO_H264_LEVEL_3_1 = 8,
|
STD_VIDEO_H264_LEVEL_IDC_3_1 = 8,
|
||||||
STD_VIDEO_H264_LEVEL_3_2 = 9,
|
STD_VIDEO_H264_LEVEL_IDC_3_2 = 9,
|
||||||
STD_VIDEO_H264_LEVEL_4_0 = 10,
|
STD_VIDEO_H264_LEVEL_IDC_4_0 = 10,
|
||||||
STD_VIDEO_H264_LEVEL_4_1 = 11,
|
STD_VIDEO_H264_LEVEL_IDC_4_1 = 11,
|
||||||
STD_VIDEO_H264_LEVEL_4_2 = 12,
|
STD_VIDEO_H264_LEVEL_IDC_4_2 = 12,
|
||||||
STD_VIDEO_H264_LEVEL_5_0 = 13,
|
STD_VIDEO_H264_LEVEL_IDC_5_0 = 13,
|
||||||
STD_VIDEO_H264_LEVEL_5_1 = 14,
|
STD_VIDEO_H264_LEVEL_IDC_5_1 = 14,
|
||||||
STD_VIDEO_H264_LEVEL_5_2 = 15,
|
STD_VIDEO_H264_LEVEL_IDC_5_2 = 15,
|
||||||
STD_VIDEO_H264_LEVEL_6_0 = 16,
|
STD_VIDEO_H264_LEVEL_IDC_6_0 = 16,
|
||||||
STD_VIDEO_H264_LEVEL_6_1 = 17,
|
STD_VIDEO_H264_LEVEL_IDC_6_1 = 17,
|
||||||
STD_VIDEO_H264_LEVEL_6_2 = 18,
|
STD_VIDEO_H264_LEVEL_IDC_6_2 = 18,
|
||||||
STD_VIDEO_H264_LEVEL_INVALID = 0x7FFFFFFF,
|
STD_VIDEO_H264_LEVEL_IDC_INVALID = 0x7FFFFFFF,
|
||||||
STD_VIDEO_H264_LEVEL_MAX_ENUM = 0x7FFFFFFF
|
STD_VIDEO_H264_LEVEL_IDC_MAX_ENUM = 0x7FFFFFFF
|
||||||
} StdVideoH264Level;
|
} StdVideoH264LevelIdc;
|
||||||
|
|
||||||
typedef enum StdVideoH264PocType {
|
typedef enum StdVideoH264PocType {
|
||||||
STD_VIDEO_H264_POC_TYPE_0 = 0,
|
STD_VIDEO_H264_POC_TYPE_0 = 0,
|
||||||
@ -197,6 +194,7 @@ typedef struct StdVideoH264HrdParameters {
|
|||||||
uint8_t cpb_cnt_minus1;
|
uint8_t cpb_cnt_minus1;
|
||||||
uint8_t bit_rate_scale;
|
uint8_t bit_rate_scale;
|
||||||
uint8_t cpb_size_scale;
|
uint8_t cpb_size_scale;
|
||||||
|
uint8_t reserved1;
|
||||||
uint32_t bit_rate_value_minus1[STD_VIDEO_H264_CPB_CNT_LIST_SIZE];
|
uint32_t bit_rate_value_minus1[STD_VIDEO_H264_CPB_CNT_LIST_SIZE];
|
||||||
uint32_t cpb_size_value_minus1[STD_VIDEO_H264_CPB_CNT_LIST_SIZE];
|
uint32_t cpb_size_value_minus1[STD_VIDEO_H264_CPB_CNT_LIST_SIZE];
|
||||||
uint8_t cbr_flag[STD_VIDEO_H264_CPB_CNT_LIST_SIZE];
|
uint8_t cbr_flag[STD_VIDEO_H264_CPB_CNT_LIST_SIZE];
|
||||||
@ -207,19 +205,22 @@ typedef struct StdVideoH264HrdParameters {
|
|||||||
} StdVideoH264HrdParameters;
|
} StdVideoH264HrdParameters;
|
||||||
|
|
||||||
typedef struct StdVideoH264SequenceParameterSetVui {
|
typedef struct StdVideoH264SequenceParameterSetVui {
|
||||||
StdVideoH264AspectRatioIdc aspect_ratio_idc;
|
StdVideoH264SpsVuiFlags flags;
|
||||||
uint16_t sar_width;
|
StdVideoH264AspectRatioIdc aspect_ratio_idc;
|
||||||
uint16_t sar_height;
|
uint16_t sar_width;
|
||||||
uint8_t video_format;
|
uint16_t sar_height;
|
||||||
uint8_t color_primaries;
|
uint8_t video_format;
|
||||||
uint8_t transfer_characteristics;
|
uint8_t colour_primaries;
|
||||||
uint8_t matrix_coefficients;
|
uint8_t transfer_characteristics;
|
||||||
uint32_t num_units_in_tick;
|
uint8_t matrix_coefficients;
|
||||||
uint32_t time_scale;
|
uint32_t num_units_in_tick;
|
||||||
StdVideoH264HrdParameters* pHrdParameters;
|
uint32_t time_scale;
|
||||||
uint8_t max_num_reorder_frames;
|
uint8_t max_num_reorder_frames;
|
||||||
uint8_t max_dec_frame_buffering;
|
uint8_t max_dec_frame_buffering;
|
||||||
StdVideoH264SpsVuiFlags flags;
|
uint8_t chroma_sample_loc_type_top_field;
|
||||||
|
uint8_t chroma_sample_loc_type_bottom_field;
|
||||||
|
uint32_t reserved1;
|
||||||
|
const StdVideoH264HrdParameters* pHrdParameters;
|
||||||
} StdVideoH264SequenceParameterSetVui;
|
} StdVideoH264SequenceParameterSetVui;
|
||||||
|
|
||||||
typedef struct StdVideoH264SpsFlags {
|
typedef struct StdVideoH264SpsFlags {
|
||||||
@ -242,36 +243,38 @@ typedef struct StdVideoH264SpsFlags {
|
|||||||
} StdVideoH264SpsFlags;
|
} StdVideoH264SpsFlags;
|
||||||
|
|
||||||
typedef struct StdVideoH264ScalingLists {
|
typedef struct StdVideoH264ScalingLists {
|
||||||
uint8_t scaling_list_present_mask;
|
uint16_t scaling_list_present_mask;
|
||||||
uint8_t use_default_scaling_matrix_mask;
|
uint16_t use_default_scaling_matrix_mask;
|
||||||
uint8_t ScalingList4x4[STD_VIDEO_H264_SCALING_LIST_4X4_NUM_LISTS][STD_VIDEO_H264_SCALING_LIST_4X4_NUM_ELEMENTS];
|
uint8_t ScalingList4x4[STD_VIDEO_H264_SCALING_LIST_4X4_NUM_LISTS][STD_VIDEO_H264_SCALING_LIST_4X4_NUM_ELEMENTS];
|
||||||
uint8_t ScalingList8x8[STD_VIDEO_H264_SCALING_LIST_8X8_NUM_LISTS][STD_VIDEO_H264_SCALING_LIST_8X8_NUM_ELEMENTS];
|
uint8_t ScalingList8x8[STD_VIDEO_H264_SCALING_LIST_8X8_NUM_LISTS][STD_VIDEO_H264_SCALING_LIST_8X8_NUM_ELEMENTS];
|
||||||
} StdVideoH264ScalingLists;
|
} StdVideoH264ScalingLists;
|
||||||
|
|
||||||
typedef struct StdVideoH264SequenceParameterSet {
|
typedef struct StdVideoH264SequenceParameterSet {
|
||||||
StdVideoH264ProfileIdc profile_idc;
|
StdVideoH264SpsFlags flags;
|
||||||
StdVideoH264Level level_idc;
|
StdVideoH264ProfileIdc profile_idc;
|
||||||
uint8_t seq_parameter_set_id;
|
StdVideoH264LevelIdc level_idc;
|
||||||
StdVideoH264ChromaFormatIdc chroma_format_idc;
|
StdVideoH264ChromaFormatIdc chroma_format_idc;
|
||||||
uint8_t bit_depth_luma_minus8;
|
uint8_t seq_parameter_set_id;
|
||||||
uint8_t bit_depth_chroma_minus8;
|
uint8_t bit_depth_luma_minus8;
|
||||||
uint8_t log2_max_frame_num_minus4;
|
uint8_t bit_depth_chroma_minus8;
|
||||||
StdVideoH264PocType pic_order_cnt_type;
|
uint8_t log2_max_frame_num_minus4;
|
||||||
uint8_t log2_max_pic_order_cnt_lsb_minus4;
|
StdVideoH264PocType pic_order_cnt_type;
|
||||||
int32_t offset_for_non_ref_pic;
|
int32_t offset_for_non_ref_pic;
|
||||||
int32_t offset_for_top_to_bottom_field;
|
int32_t offset_for_top_to_bottom_field;
|
||||||
uint8_t num_ref_frames_in_pic_order_cnt_cycle;
|
uint8_t log2_max_pic_order_cnt_lsb_minus4;
|
||||||
uint8_t max_num_ref_frames;
|
uint8_t num_ref_frames_in_pic_order_cnt_cycle;
|
||||||
uint32_t pic_width_in_mbs_minus1;
|
uint8_t max_num_ref_frames;
|
||||||
uint32_t pic_height_in_map_units_minus1;
|
uint8_t reserved1;
|
||||||
uint32_t frame_crop_left_offset;
|
uint32_t pic_width_in_mbs_minus1;
|
||||||
uint32_t frame_crop_right_offset;
|
uint32_t pic_height_in_map_units_minus1;
|
||||||
uint32_t frame_crop_top_offset;
|
uint32_t frame_crop_left_offset;
|
||||||
uint32_t frame_crop_bottom_offset;
|
uint32_t frame_crop_right_offset;
|
||||||
StdVideoH264SpsFlags flags;
|
uint32_t frame_crop_top_offset;
|
||||||
int32_t* pOffsetForRefFrame;
|
uint32_t frame_crop_bottom_offset;
|
||||||
StdVideoH264ScalingLists* pScalingLists;
|
uint32_t reserved2;
|
||||||
StdVideoH264SequenceParameterSetVui* pSequenceParameterSetVui;
|
const int32_t* pOffsetForRefFrame;
|
||||||
|
const StdVideoH264ScalingLists* pScalingLists;
|
||||||
|
const StdVideoH264SequenceParameterSetVui* pSequenceParameterSetVui;
|
||||||
} StdVideoH264SequenceParameterSet;
|
} StdVideoH264SequenceParameterSet;
|
||||||
|
|
||||||
typedef struct StdVideoH264PpsFlags {
|
typedef struct StdVideoH264PpsFlags {
|
||||||
@ -279,25 +282,24 @@ typedef struct StdVideoH264PpsFlags {
|
|||||||
uint32_t redundant_pic_cnt_present_flag : 1;
|
uint32_t redundant_pic_cnt_present_flag : 1;
|
||||||
uint32_t constrained_intra_pred_flag : 1;
|
uint32_t constrained_intra_pred_flag : 1;
|
||||||
uint32_t deblocking_filter_control_present_flag : 1;
|
uint32_t deblocking_filter_control_present_flag : 1;
|
||||||
uint32_t weighted_bipred_idc_flag : 1;
|
|
||||||
uint32_t weighted_pred_flag : 1;
|
uint32_t weighted_pred_flag : 1;
|
||||||
uint32_t pic_order_present_flag : 1;
|
uint32_t bottom_field_pic_order_in_frame_present_flag : 1;
|
||||||
uint32_t entropy_coding_mode_flag : 1;
|
uint32_t entropy_coding_mode_flag : 1;
|
||||||
uint32_t pic_scaling_matrix_present_flag : 1;
|
uint32_t pic_scaling_matrix_present_flag : 1;
|
||||||
} StdVideoH264PpsFlags;
|
} StdVideoH264PpsFlags;
|
||||||
|
|
||||||
typedef struct StdVideoH264PictureParameterSet {
|
typedef struct StdVideoH264PictureParameterSet {
|
||||||
uint8_t seq_parameter_set_id;
|
StdVideoH264PpsFlags flags;
|
||||||
uint8_t pic_parameter_set_id;
|
uint8_t seq_parameter_set_id;
|
||||||
uint8_t num_ref_idx_l0_default_active_minus1;
|
uint8_t pic_parameter_set_id;
|
||||||
uint8_t num_ref_idx_l1_default_active_minus1;
|
uint8_t num_ref_idx_l0_default_active_minus1;
|
||||||
StdVideoH264WeightedBipredIdc weighted_bipred_idc;
|
uint8_t num_ref_idx_l1_default_active_minus1;
|
||||||
int8_t pic_init_qp_minus26;
|
StdVideoH264WeightedBipredIdc weighted_bipred_idc;
|
||||||
int8_t pic_init_qs_minus26;
|
int8_t pic_init_qp_minus26;
|
||||||
int8_t chroma_qp_index_offset;
|
int8_t pic_init_qs_minus26;
|
||||||
int8_t second_chroma_qp_index_offset;
|
int8_t chroma_qp_index_offset;
|
||||||
StdVideoH264PpsFlags flags;
|
int8_t second_chroma_qp_index_offset;
|
||||||
StdVideoH264ScalingLists* pScalingLists;
|
const StdVideoH264ScalingLists* pScalingLists;
|
||||||
} StdVideoH264PictureParameterSet;
|
} StdVideoH264PictureParameterSet;
|
||||||
|
|
||||||
|
|
||||||
|
@ -20,8 +20,12 @@ extern "C" {
|
|||||||
|
|
||||||
|
|
||||||
#define vulkan_video_codec_h264std_decode 1
|
#define vulkan_video_codec_h264std_decode 1
|
||||||
|
// Vulkan 0.9 provisional Vulkan video H.264 decode std specification version number
|
||||||
|
#define VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_API_VERSION_0_9_8 VK_MAKE_VIDEO_STD_VERSION(0, 9, 8) // Patch version should always be set to 0
|
||||||
|
|
||||||
#define STD_VIDEO_DECODE_H264_FIELD_ORDER_COUNT_LIST_SIZE 2
|
#define STD_VIDEO_DECODE_H264_FIELD_ORDER_COUNT_LIST_SIZE 2
|
||||||
#define STD_VIDEO_DECODE_H264_MVC_REF_LIST_SIZE 15
|
#define VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_API_VERSION_0_9_8
|
||||||
|
#define VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_EXTENSION_NAME "VK_STD_vulkan_video_codec_h264_decode"
|
||||||
|
|
||||||
typedef enum StdVideoDecodeH264FieldOrderCount {
|
typedef enum StdVideoDecodeH264FieldOrderCount {
|
||||||
STD_VIDEO_DECODE_H264_FIELD_ORDER_COUNT_TOP = 0,
|
STD_VIDEO_DECODE_H264_FIELD_ORDER_COUNT_TOP = 0,
|
||||||
@ -39,57 +43,30 @@ typedef struct StdVideoDecodeH264PictureInfoFlags {
|
|||||||
} StdVideoDecodeH264PictureInfoFlags;
|
} StdVideoDecodeH264PictureInfoFlags;
|
||||||
|
|
||||||
typedef struct StdVideoDecodeH264PictureInfo {
|
typedef struct StdVideoDecodeH264PictureInfo {
|
||||||
|
StdVideoDecodeH264PictureInfoFlags flags;
|
||||||
uint8_t seq_parameter_set_id;
|
uint8_t seq_parameter_set_id;
|
||||||
uint8_t pic_parameter_set_id;
|
uint8_t pic_parameter_set_id;
|
||||||
uint16_t reserved;
|
uint8_t reserved1;
|
||||||
|
uint8_t reserved2;
|
||||||
uint16_t frame_num;
|
uint16_t frame_num;
|
||||||
uint16_t idr_pic_id;
|
uint16_t idr_pic_id;
|
||||||
int32_t PicOrderCnt[STD_VIDEO_DECODE_H264_FIELD_ORDER_COUNT_LIST_SIZE];
|
int32_t PicOrderCnt[STD_VIDEO_DECODE_H264_FIELD_ORDER_COUNT_LIST_SIZE];
|
||||||
StdVideoDecodeH264PictureInfoFlags flags;
|
|
||||||
} StdVideoDecodeH264PictureInfo;
|
} StdVideoDecodeH264PictureInfo;
|
||||||
|
|
||||||
typedef struct StdVideoDecodeH264ReferenceInfoFlags {
|
typedef struct StdVideoDecodeH264ReferenceInfoFlags {
|
||||||
uint32_t top_field_flag : 1;
|
uint32_t top_field_flag : 1;
|
||||||
uint32_t bottom_field_flag : 1;
|
uint32_t bottom_field_flag : 1;
|
||||||
uint32_t is_long_term : 1;
|
uint32_t used_for_long_term_reference : 1;
|
||||||
uint32_t is_non_existing : 1;
|
uint32_t is_non_existing : 1;
|
||||||
} StdVideoDecodeH264ReferenceInfoFlags;
|
} StdVideoDecodeH264ReferenceInfoFlags;
|
||||||
|
|
||||||
typedef struct StdVideoDecodeH264ReferenceInfo {
|
typedef struct StdVideoDecodeH264ReferenceInfo {
|
||||||
|
StdVideoDecodeH264ReferenceInfoFlags flags;
|
||||||
uint16_t FrameNum;
|
uint16_t FrameNum;
|
||||||
uint16_t reserved;
|
uint16_t reserved;
|
||||||
int32_t PicOrderCnt[2];
|
int32_t PicOrderCnt[STD_VIDEO_DECODE_H264_FIELD_ORDER_COUNT_LIST_SIZE];
|
||||||
StdVideoDecodeH264ReferenceInfoFlags flags;
|
|
||||||
} StdVideoDecodeH264ReferenceInfo;
|
} StdVideoDecodeH264ReferenceInfo;
|
||||||
|
|
||||||
typedef struct StdVideoDecodeH264MvcElementFlags {
|
|
||||||
uint32_t non_idr : 1;
|
|
||||||
uint32_t anchor_pic : 1;
|
|
||||||
uint32_t inter_view : 1;
|
|
||||||
} StdVideoDecodeH264MvcElementFlags;
|
|
||||||
|
|
||||||
typedef struct StdVideoDecodeH264MvcElement {
|
|
||||||
StdVideoDecodeH264MvcElementFlags flags;
|
|
||||||
uint16_t viewOrderIndex;
|
|
||||||
uint16_t viewId;
|
|
||||||
uint16_t temporalId;
|
|
||||||
uint16_t priorityId;
|
|
||||||
uint16_t numOfAnchorRefsInL0;
|
|
||||||
uint16_t viewIdOfAnchorRefsInL0[STD_VIDEO_DECODE_H264_MVC_REF_LIST_SIZE];
|
|
||||||
uint16_t numOfAnchorRefsInL1;
|
|
||||||
uint16_t viewIdOfAnchorRefsInL1[STD_VIDEO_DECODE_H264_MVC_REF_LIST_SIZE];
|
|
||||||
uint16_t numOfNonAnchorRefsInL0;
|
|
||||||
uint16_t viewIdOfNonAnchorRefsInL0[STD_VIDEO_DECODE_H264_MVC_REF_LIST_SIZE];
|
|
||||||
uint16_t numOfNonAnchorRefsInL1;
|
|
||||||
uint16_t viewIdOfNonAnchorRefsInL1[STD_VIDEO_DECODE_H264_MVC_REF_LIST_SIZE];
|
|
||||||
} StdVideoDecodeH264MvcElement;
|
|
||||||
|
|
||||||
typedef struct StdVideoDecodeH264Mvc {
|
|
||||||
uint32_t viewId0;
|
|
||||||
uint32_t mvcElementCount;
|
|
||||||
StdVideoDecodeH264MvcElement* pMvcElements;
|
|
||||||
} StdVideoDecodeH264Mvc;
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
@ -20,12 +20,36 @@ extern "C" {
|
|||||||
|
|
||||||
|
|
||||||
#define vulkan_video_codec_h264std_encode 1
|
#define vulkan_video_codec_h264std_encode 1
|
||||||
|
// Vulkan 0.9 provisional Vulkan video H.264 encode std specification version number
|
||||||
|
#define VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_API_VERSION_0_9_8 VK_MAKE_VIDEO_STD_VERSION(0, 9, 8) // Patch version should always be set to 0
|
||||||
|
|
||||||
|
#define VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_API_VERSION_0_9_8
|
||||||
|
#define VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_EXTENSION_NAME "VK_STD_vulkan_video_codec_h264_encode"
|
||||||
|
typedef struct StdVideoEncodeH264WeightTableFlags {
|
||||||
|
uint32_t luma_weight_l0_flag;
|
||||||
|
uint32_t chroma_weight_l0_flag;
|
||||||
|
uint32_t luma_weight_l1_flag;
|
||||||
|
uint32_t chroma_weight_l1_flag;
|
||||||
|
} StdVideoEncodeH264WeightTableFlags;
|
||||||
|
|
||||||
|
typedef struct StdVideoEncodeH264WeightTable {
|
||||||
|
StdVideoEncodeH264WeightTableFlags flags;
|
||||||
|
uint8_t luma_log2_weight_denom;
|
||||||
|
uint8_t chroma_log2_weight_denom;
|
||||||
|
int8_t luma_weight_l0[STD_VIDEO_H264_MAX_NUM_LIST_REF];
|
||||||
|
int8_t luma_offset_l0[STD_VIDEO_H264_MAX_NUM_LIST_REF];
|
||||||
|
int8_t chroma_weight_l0[STD_VIDEO_H264_MAX_NUM_LIST_REF][STD_VIDEO_H264_MAX_CHROMA_PLANES];
|
||||||
|
int8_t chroma_offset_l0[STD_VIDEO_H264_MAX_NUM_LIST_REF][STD_VIDEO_H264_MAX_CHROMA_PLANES];
|
||||||
|
int8_t luma_weight_l1[STD_VIDEO_H264_MAX_NUM_LIST_REF];
|
||||||
|
int8_t luma_offset_l1[STD_VIDEO_H264_MAX_NUM_LIST_REF];
|
||||||
|
int8_t chroma_weight_l1[STD_VIDEO_H264_MAX_NUM_LIST_REF][STD_VIDEO_H264_MAX_CHROMA_PLANES];
|
||||||
|
int8_t chroma_offset_l1[STD_VIDEO_H264_MAX_NUM_LIST_REF][STD_VIDEO_H264_MAX_CHROMA_PLANES];
|
||||||
|
} StdVideoEncodeH264WeightTable;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH264SliceHeaderFlags {
|
typedef struct StdVideoEncodeH264SliceHeaderFlags {
|
||||||
uint32_t idr_flag : 1;
|
uint32_t direct_spatial_mv_pred_flag : 1;
|
||||||
uint32_t is_reference_flag : 1;
|
|
||||||
uint32_t num_ref_idx_active_override_flag : 1;
|
uint32_t num_ref_idx_active_override_flag : 1;
|
||||||
uint32_t no_output_of_prior_pics_flag : 1;
|
uint32_t no_output_of_prior_pics_flag : 1;
|
||||||
uint32_t long_term_reference_flag : 1;
|
|
||||||
uint32_t adaptive_ref_pic_marking_mode_flag : 1;
|
uint32_t adaptive_ref_pic_marking_mode_flag : 1;
|
||||||
uint32_t no_prior_references_available_flag : 1;
|
uint32_t no_prior_references_available_flag : 1;
|
||||||
} StdVideoEncodeH264SliceHeaderFlags;
|
} StdVideoEncodeH264SliceHeaderFlags;
|
||||||
@ -33,9 +57,13 @@ typedef struct StdVideoEncodeH264SliceHeaderFlags {
|
|||||||
typedef struct StdVideoEncodeH264PictureInfoFlags {
|
typedef struct StdVideoEncodeH264PictureInfoFlags {
|
||||||
uint32_t idr_flag : 1;
|
uint32_t idr_flag : 1;
|
||||||
uint32_t is_reference_flag : 1;
|
uint32_t is_reference_flag : 1;
|
||||||
uint32_t long_term_reference_flag : 1;
|
uint32_t used_for_long_term_reference : 1;
|
||||||
} StdVideoEncodeH264PictureInfoFlags;
|
} StdVideoEncodeH264PictureInfoFlags;
|
||||||
|
|
||||||
|
typedef struct StdVideoEncodeH264ReferenceInfoFlags {
|
||||||
|
uint32_t used_for_long_term_reference : 1;
|
||||||
|
} StdVideoEncodeH264ReferenceInfoFlags;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH264RefMgmtFlags {
|
typedef struct StdVideoEncodeH264RefMgmtFlags {
|
||||||
uint32_t ref_pic_list_modification_l0_flag : 1;
|
uint32_t ref_pic_list_modification_l0_flag : 1;
|
||||||
uint32_t ref_pic_list_modification_l1_flag : 1;
|
uint32_t ref_pic_list_modification_l1_flag : 1;
|
||||||
@ -56,37 +84,44 @@ typedef struct StdVideoEncodeH264RefPicMarkingEntry {
|
|||||||
} StdVideoEncodeH264RefPicMarkingEntry;
|
} StdVideoEncodeH264RefPicMarkingEntry;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH264RefMemMgmtCtrlOperations {
|
typedef struct StdVideoEncodeH264RefMemMgmtCtrlOperations {
|
||||||
StdVideoEncodeH264RefMgmtFlags flags;
|
StdVideoEncodeH264RefMgmtFlags flags;
|
||||||
uint8_t refList0ModOpCount;
|
uint8_t refList0ModOpCount;
|
||||||
StdVideoEncodeH264RefListModEntry* pRefList0ModOperations;
|
const StdVideoEncodeH264RefListModEntry* pRefList0ModOperations;
|
||||||
uint8_t refList1ModOpCount;
|
uint8_t refList1ModOpCount;
|
||||||
StdVideoEncodeH264RefListModEntry* pRefList1ModOperations;
|
const StdVideoEncodeH264RefListModEntry* pRefList1ModOperations;
|
||||||
uint8_t refPicMarkingOpCount;
|
uint8_t refPicMarkingOpCount;
|
||||||
StdVideoEncodeH264RefPicMarkingEntry* pRefPicMarkingOperations;
|
const StdVideoEncodeH264RefPicMarkingEntry* pRefPicMarkingOperations;
|
||||||
} StdVideoEncodeH264RefMemMgmtCtrlOperations;
|
} StdVideoEncodeH264RefMemMgmtCtrlOperations;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH264PictureInfo {
|
typedef struct StdVideoEncodeH264PictureInfo {
|
||||||
StdVideoEncodeH264PictureInfoFlags flags;
|
StdVideoEncodeH264PictureInfoFlags flags;
|
||||||
|
uint8_t seq_parameter_set_id;
|
||||||
|
uint8_t pic_parameter_set_id;
|
||||||
StdVideoH264PictureType pictureType;
|
StdVideoH264PictureType pictureType;
|
||||||
uint32_t frameNum;
|
uint32_t frame_num;
|
||||||
uint32_t pictureOrderCount;
|
int32_t PicOrderCnt;
|
||||||
uint16_t long_term_pic_num;
|
|
||||||
uint16_t long_term_frame_idx;
|
|
||||||
} StdVideoEncodeH264PictureInfo;
|
} StdVideoEncodeH264PictureInfo;
|
||||||
|
|
||||||
|
typedef struct StdVideoEncodeH264ReferenceInfo {
|
||||||
|
StdVideoEncodeH264ReferenceInfoFlags flags;
|
||||||
|
uint32_t FrameNum;
|
||||||
|
int32_t PicOrderCnt;
|
||||||
|
uint16_t long_term_pic_num;
|
||||||
|
uint16_t long_term_frame_idx;
|
||||||
|
} StdVideoEncodeH264ReferenceInfo;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH264SliceHeader {
|
typedef struct StdVideoEncodeH264SliceHeader {
|
||||||
StdVideoEncodeH264SliceHeaderFlags flags;
|
StdVideoEncodeH264SliceHeaderFlags flags;
|
||||||
StdVideoH264SliceType slice_type;
|
uint32_t first_mb_in_slice;
|
||||||
uint8_t seq_parameter_set_id;
|
StdVideoH264SliceType slice_type;
|
||||||
uint8_t pic_parameter_set_id;
|
uint16_t idr_pic_id;
|
||||||
uint16_t idr_pic_id;
|
uint8_t num_ref_idx_l0_active_minus1;
|
||||||
uint8_t num_ref_idx_l0_active_minus1;
|
uint8_t num_ref_idx_l1_active_minus1;
|
||||||
uint8_t num_ref_idx_l1_active_minus1;
|
StdVideoH264CabacInitIdc cabac_init_idc;
|
||||||
StdVideoH264CabacInitIdc cabac_init_idc;
|
StdVideoH264DisableDeblockingFilterIdc disable_deblocking_filter_idc;
|
||||||
StdVideoH264DisableDeblockingFilterIdc disable_deblocking_filter_idc;
|
int8_t slice_alpha_c0_offset_div2;
|
||||||
int8_t slice_alpha_c0_offset_div2;
|
int8_t slice_beta_offset_div2;
|
||||||
int8_t slice_beta_offset_div2;
|
const StdVideoEncodeH264WeightTable* pWeightTable;
|
||||||
StdVideoEncodeH264RefMemMgmtCtrlOperations* pMemMgmtCtrlOperations;
|
|
||||||
} StdVideoEncodeH264SliceHeader;
|
} StdVideoEncodeH264SliceHeader;
|
||||||
|
|
||||||
|
|
||||||
|
@ -20,10 +20,7 @@ extern "C" {
|
|||||||
|
|
||||||
|
|
||||||
#define vulkan_video_codec_h265std 1
|
#define vulkan_video_codec_h265std 1
|
||||||
// Vulkan 0.5 version number WIP
|
#define STD_VIDEO_H265_SUBLAYERS_LIST_SIZE 7
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H265_API_VERSION_0_9_5 VK_MAKE_VIDEO_STD_VERSION(0, 9, 5) // Patch version should always be set to 0
|
|
||||||
|
|
||||||
#define STD_VIDEO_H265_SUBLAYERS_MINUS1_LIST_SIZE 7
|
|
||||||
#define STD_VIDEO_H265_CPB_CNT_LIST_SIZE 32
|
#define STD_VIDEO_H265_CPB_CNT_LIST_SIZE 32
|
||||||
#define STD_VIDEO_H265_SCALING_LIST_4X4_NUM_LISTS 6
|
#define STD_VIDEO_H265_SCALING_LIST_4X4_NUM_LISTS 6
|
||||||
#define STD_VIDEO_H265_SCALING_LIST_4X4_NUM_ELEMENTS 16
|
#define STD_VIDEO_H265_SCALING_LIST_4X4_NUM_ELEMENTS 16
|
||||||
@ -35,11 +32,16 @@ extern "C" {
|
|||||||
#define STD_VIDEO_H265_SCALING_LIST_32X32_NUM_ELEMENTS 64
|
#define STD_VIDEO_H265_SCALING_LIST_32X32_NUM_ELEMENTS 64
|
||||||
#define STD_VIDEO_H265_PREDICTOR_PALETTE_COMPONENTS_LIST_SIZE 3
|
#define STD_VIDEO_H265_PREDICTOR_PALETTE_COMPONENTS_LIST_SIZE 3
|
||||||
#define STD_VIDEO_H265_PREDICTOR_PALETTE_COMP_ENTRIES_LIST_SIZE 128
|
#define STD_VIDEO_H265_PREDICTOR_PALETTE_COMP_ENTRIES_LIST_SIZE 128
|
||||||
|
#define STD_VIDEO_H265_MAX_DPB_SIZE 16
|
||||||
|
#define STD_VIDEO_H265_MAX_LONG_TERM_REF_PICS_SPS 32
|
||||||
|
#define STD_VIDEO_H265_CHROMA_QP_OFFSET_LIST_SIZE 6
|
||||||
#define STD_VIDEO_H265_CHROMA_QP_OFFSET_TILE_COLS_LIST_SIZE 19
|
#define STD_VIDEO_H265_CHROMA_QP_OFFSET_TILE_COLS_LIST_SIZE 19
|
||||||
#define STD_VIDEO_H265_CHROMA_QP_OFFSET_TILE_ROWS_LIST_SIZE 21
|
#define STD_VIDEO_H265_CHROMA_QP_OFFSET_TILE_ROWS_LIST_SIZE 21
|
||||||
#define STD_VIDEO_H265_CHROMA_QP_OFFSET_LIST_SIZE 6
|
#define STD_VIDEO_H265_MAX_NUM_LIST_REF 15
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H265_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H265_API_VERSION_0_9_5
|
#define STD_VIDEO_H265_MAX_CHROMA_PLANES 2
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H265_EXTENSION_NAME "VK_STD_vulkan_video_codec_h265"
|
#define STD_VIDEO_H265_MAX_SHORT_TERM_REF_PIC_SETS 64
|
||||||
|
#define STD_VIDEO_H265_MAX_LONG_TERM_PICS 16
|
||||||
|
#define STD_VIDEO_H265_MAX_DELTA_POC 48
|
||||||
|
|
||||||
typedef enum StdVideoH265ChromaFormatIdc {
|
typedef enum StdVideoH265ChromaFormatIdc {
|
||||||
STD_VIDEO_H265_CHROMA_FORMAT_IDC_MONOCHROME = 0,
|
STD_VIDEO_H265_CHROMA_FORMAT_IDC_MONOCHROME = 0,
|
||||||
@ -60,23 +62,23 @@ typedef enum StdVideoH265ProfileIdc {
|
|||||||
STD_VIDEO_H265_PROFILE_IDC_MAX_ENUM = 0x7FFFFFFF
|
STD_VIDEO_H265_PROFILE_IDC_MAX_ENUM = 0x7FFFFFFF
|
||||||
} StdVideoH265ProfileIdc;
|
} StdVideoH265ProfileIdc;
|
||||||
|
|
||||||
typedef enum StdVideoH265Level {
|
typedef enum StdVideoH265LevelIdc {
|
||||||
STD_VIDEO_H265_LEVEL_1_0 = 0,
|
STD_VIDEO_H265_LEVEL_IDC_1_0 = 0,
|
||||||
STD_VIDEO_H265_LEVEL_2_0 = 1,
|
STD_VIDEO_H265_LEVEL_IDC_2_0 = 1,
|
||||||
STD_VIDEO_H265_LEVEL_2_1 = 2,
|
STD_VIDEO_H265_LEVEL_IDC_2_1 = 2,
|
||||||
STD_VIDEO_H265_LEVEL_3_0 = 3,
|
STD_VIDEO_H265_LEVEL_IDC_3_0 = 3,
|
||||||
STD_VIDEO_H265_LEVEL_3_1 = 4,
|
STD_VIDEO_H265_LEVEL_IDC_3_1 = 4,
|
||||||
STD_VIDEO_H265_LEVEL_4_0 = 5,
|
STD_VIDEO_H265_LEVEL_IDC_4_0 = 5,
|
||||||
STD_VIDEO_H265_LEVEL_4_1 = 6,
|
STD_VIDEO_H265_LEVEL_IDC_4_1 = 6,
|
||||||
STD_VIDEO_H265_LEVEL_5_0 = 7,
|
STD_VIDEO_H265_LEVEL_IDC_5_0 = 7,
|
||||||
STD_VIDEO_H265_LEVEL_5_1 = 8,
|
STD_VIDEO_H265_LEVEL_IDC_5_1 = 8,
|
||||||
STD_VIDEO_H265_LEVEL_5_2 = 9,
|
STD_VIDEO_H265_LEVEL_IDC_5_2 = 9,
|
||||||
STD_VIDEO_H265_LEVEL_6_0 = 10,
|
STD_VIDEO_H265_LEVEL_IDC_6_0 = 10,
|
||||||
STD_VIDEO_H265_LEVEL_6_1 = 11,
|
STD_VIDEO_H265_LEVEL_IDC_6_1 = 11,
|
||||||
STD_VIDEO_H265_LEVEL_6_2 = 12,
|
STD_VIDEO_H265_LEVEL_IDC_6_2 = 12,
|
||||||
STD_VIDEO_H265_LEVEL_INVALID = 0x7FFFFFFF,
|
STD_VIDEO_H265_LEVEL_IDC_INVALID = 0x7FFFFFFF,
|
||||||
STD_VIDEO_H265_LEVEL_MAX_ENUM = 0x7FFFFFFF
|
STD_VIDEO_H265_LEVEL_IDC_MAX_ENUM = 0x7FFFFFFF
|
||||||
} StdVideoH265Level;
|
} StdVideoH265LevelIdc;
|
||||||
|
|
||||||
typedef enum StdVideoH265SliceType {
|
typedef enum StdVideoH265SliceType {
|
||||||
STD_VIDEO_H265_SLICE_TYPE_B = 0,
|
STD_VIDEO_H265_SLICE_TYPE_B = 0,
|
||||||
@ -94,10 +96,33 @@ typedef enum StdVideoH265PictureType {
|
|||||||
STD_VIDEO_H265_PICTURE_TYPE_INVALID = 0x7FFFFFFF,
|
STD_VIDEO_H265_PICTURE_TYPE_INVALID = 0x7FFFFFFF,
|
||||||
STD_VIDEO_H265_PICTURE_TYPE_MAX_ENUM = 0x7FFFFFFF
|
STD_VIDEO_H265_PICTURE_TYPE_MAX_ENUM = 0x7FFFFFFF
|
||||||
} StdVideoH265PictureType;
|
} StdVideoH265PictureType;
|
||||||
|
|
||||||
|
typedef enum StdVideoH265AspectRatioIdc {
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_UNSPECIFIED = 0,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_SQUARE = 1,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_12_11 = 2,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_10_11 = 3,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_16_11 = 4,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_40_33 = 5,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_24_11 = 6,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_20_11 = 7,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_32_11 = 8,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_80_33 = 9,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_18_11 = 10,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_15_11 = 11,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_64_33 = 12,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_160_99 = 13,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_4_3 = 14,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_3_2 = 15,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_2_1 = 16,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_EXTENDED_SAR = 255,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_INVALID = 0x7FFFFFFF,
|
||||||
|
STD_VIDEO_H265_ASPECT_RATIO_IDC_MAX_ENUM = 0x7FFFFFFF
|
||||||
|
} StdVideoH265AspectRatioIdc;
|
||||||
typedef struct StdVideoH265DecPicBufMgr {
|
typedef struct StdVideoH265DecPicBufMgr {
|
||||||
uint32_t max_latency_increase_plus1[STD_VIDEO_H265_SUBLAYERS_MINUS1_LIST_SIZE];
|
uint32_t max_latency_increase_plus1[STD_VIDEO_H265_SUBLAYERS_LIST_SIZE];
|
||||||
uint8_t max_dec_pic_buffering_minus1[STD_VIDEO_H265_SUBLAYERS_MINUS1_LIST_SIZE];
|
uint8_t max_dec_pic_buffering_minus1[STD_VIDEO_H265_SUBLAYERS_LIST_SIZE];
|
||||||
uint8_t max_num_reorder_pics[STD_VIDEO_H265_SUBLAYERS_MINUS1_LIST_SIZE];
|
uint8_t max_num_reorder_pics[STD_VIDEO_H265_SUBLAYERS_LIST_SIZE];
|
||||||
} StdVideoH265DecPicBufMgr;
|
} StdVideoH265DecPicBufMgr;
|
||||||
|
|
||||||
typedef struct StdVideoH265SubLayerHrdParameters {
|
typedef struct StdVideoH265SubLayerHrdParameters {
|
||||||
@ -119,20 +144,21 @@ typedef struct StdVideoH265HrdFlags {
|
|||||||
} StdVideoH265HrdFlags;
|
} StdVideoH265HrdFlags;
|
||||||
|
|
||||||
typedef struct StdVideoH265HrdParameters {
|
typedef struct StdVideoH265HrdParameters {
|
||||||
uint8_t tick_divisor_minus2;
|
StdVideoH265HrdFlags flags;
|
||||||
uint8_t du_cpb_removal_delay_increment_length_minus1;
|
uint8_t tick_divisor_minus2;
|
||||||
uint8_t dpb_output_delay_du_length_minus1;
|
uint8_t du_cpb_removal_delay_increment_length_minus1;
|
||||||
uint8_t bit_rate_scale;
|
uint8_t dpb_output_delay_du_length_minus1;
|
||||||
uint8_t cpb_size_scale;
|
uint8_t bit_rate_scale;
|
||||||
uint8_t cpb_size_du_scale;
|
uint8_t cpb_size_scale;
|
||||||
uint8_t initial_cpb_removal_delay_length_minus1;
|
uint8_t cpb_size_du_scale;
|
||||||
uint8_t au_cpb_removal_delay_length_minus1;
|
uint8_t initial_cpb_removal_delay_length_minus1;
|
||||||
uint8_t dpb_output_delay_length_minus1;
|
uint8_t au_cpb_removal_delay_length_minus1;
|
||||||
uint8_t cpb_cnt_minus1[STD_VIDEO_H265_SUBLAYERS_MINUS1_LIST_SIZE];
|
uint8_t dpb_output_delay_length_minus1;
|
||||||
uint16_t elemental_duration_in_tc_minus1[STD_VIDEO_H265_SUBLAYERS_MINUS1_LIST_SIZE];
|
uint8_t cpb_cnt_minus1[STD_VIDEO_H265_SUBLAYERS_LIST_SIZE];
|
||||||
StdVideoH265SubLayerHrdParameters* pSubLayerHrdParametersNal[STD_VIDEO_H265_SUBLAYERS_MINUS1_LIST_SIZE];
|
uint16_t elemental_duration_in_tc_minus1[STD_VIDEO_H265_SUBLAYERS_LIST_SIZE];
|
||||||
StdVideoH265SubLayerHrdParameters* pSubLayerHrdParametersVcl[STD_VIDEO_H265_SUBLAYERS_MINUS1_LIST_SIZE];
|
uint16_t reserved[3];
|
||||||
StdVideoH265HrdFlags flags;
|
const StdVideoH265SubLayerHrdParameters* pSubLayerHrdParametersNal;
|
||||||
|
const StdVideoH265SubLayerHrdParameters* pSubLayerHrdParametersVcl;
|
||||||
} StdVideoH265HrdParameters;
|
} StdVideoH265HrdParameters;
|
||||||
|
|
||||||
typedef struct StdVideoH265VpsFlags {
|
typedef struct StdVideoH265VpsFlags {
|
||||||
@ -142,15 +168,33 @@ typedef struct StdVideoH265VpsFlags {
|
|||||||
uint32_t vps_poc_proportional_to_timing_flag : 1;
|
uint32_t vps_poc_proportional_to_timing_flag : 1;
|
||||||
} StdVideoH265VpsFlags;
|
} StdVideoH265VpsFlags;
|
||||||
|
|
||||||
|
typedef struct StdVideoH265ProfileTierLevelFlags {
|
||||||
|
uint32_t general_tier_flag : 1;
|
||||||
|
uint32_t general_progressive_source_flag : 1;
|
||||||
|
uint32_t general_interlaced_source_flag : 1;
|
||||||
|
uint32_t general_non_packed_constraint_flag : 1;
|
||||||
|
uint32_t general_frame_only_constraint_flag : 1;
|
||||||
|
} StdVideoH265ProfileTierLevelFlags;
|
||||||
|
|
||||||
|
typedef struct StdVideoH265ProfileTierLevel {
|
||||||
|
StdVideoH265ProfileTierLevelFlags flags;
|
||||||
|
StdVideoH265ProfileIdc general_profile_idc;
|
||||||
|
StdVideoH265LevelIdc general_level_idc;
|
||||||
|
} StdVideoH265ProfileTierLevel;
|
||||||
|
|
||||||
typedef struct StdVideoH265VideoParameterSet {
|
typedef struct StdVideoH265VideoParameterSet {
|
||||||
uint8_t vps_video_parameter_set_id;
|
StdVideoH265VpsFlags flags;
|
||||||
uint8_t vps_max_sub_layers_minus1;
|
uint8_t vps_video_parameter_set_id;
|
||||||
uint32_t vps_num_units_in_tick;
|
uint8_t vps_max_sub_layers_minus1;
|
||||||
uint32_t vps_time_scale;
|
uint8_t reserved1;
|
||||||
uint32_t vps_num_ticks_poc_diff_one_minus1;
|
uint8_t reserved2;
|
||||||
StdVideoH265DecPicBufMgr* pDecPicBufMgr;
|
uint32_t vps_num_units_in_tick;
|
||||||
StdVideoH265HrdParameters* pHrdParameters;
|
uint32_t vps_time_scale;
|
||||||
StdVideoH265VpsFlags flags;
|
uint32_t vps_num_ticks_poc_diff_one_minus1;
|
||||||
|
uint32_t reserved3;
|
||||||
|
const StdVideoH265DecPicBufMgr* pDecPicBufMgr;
|
||||||
|
const StdVideoH265HrdParameters* pHrdParameters;
|
||||||
|
const StdVideoH265ProfileTierLevel* pProfileTierLevel;
|
||||||
} StdVideoH265VideoParameterSet;
|
} StdVideoH265VideoParameterSet;
|
||||||
|
|
||||||
typedef struct StdVideoH265ScalingLists {
|
typedef struct StdVideoH265ScalingLists {
|
||||||
@ -184,29 +228,32 @@ typedef struct StdVideoH265SpsVuiFlags {
|
|||||||
} StdVideoH265SpsVuiFlags;
|
} StdVideoH265SpsVuiFlags;
|
||||||
|
|
||||||
typedef struct StdVideoH265SequenceParameterSetVui {
|
typedef struct StdVideoH265SequenceParameterSetVui {
|
||||||
uint8_t aspect_ratio_idc;
|
StdVideoH265SpsVuiFlags flags;
|
||||||
uint16_t sar_width;
|
StdVideoH265AspectRatioIdc aspect_ratio_idc;
|
||||||
uint16_t sar_height;
|
uint16_t sar_width;
|
||||||
uint8_t video_format;
|
uint16_t sar_height;
|
||||||
uint8_t colour_primaries;
|
uint8_t video_format;
|
||||||
uint8_t transfer_characteristics;
|
uint8_t colour_primaries;
|
||||||
uint8_t matrix_coeffs;
|
uint8_t transfer_characteristics;
|
||||||
uint8_t chroma_sample_loc_type_top_field;
|
uint8_t matrix_coeffs;
|
||||||
uint8_t chroma_sample_loc_type_bottom_field;
|
uint8_t chroma_sample_loc_type_top_field;
|
||||||
uint16_t def_disp_win_left_offset;
|
uint8_t chroma_sample_loc_type_bottom_field;
|
||||||
uint16_t def_disp_win_right_offset;
|
uint8_t reserved1;
|
||||||
uint16_t def_disp_win_top_offset;
|
uint8_t reserved2;
|
||||||
uint16_t def_disp_win_bottom_offset;
|
uint16_t def_disp_win_left_offset;
|
||||||
uint32_t vui_num_units_in_tick;
|
uint16_t def_disp_win_right_offset;
|
||||||
uint32_t vui_time_scale;
|
uint16_t def_disp_win_top_offset;
|
||||||
uint32_t vui_num_ticks_poc_diff_one_minus1;
|
uint16_t def_disp_win_bottom_offset;
|
||||||
StdVideoH265HrdParameters* pHrdParameters;
|
uint32_t vui_num_units_in_tick;
|
||||||
uint16_t min_spatial_segmentation_idc;
|
uint32_t vui_time_scale;
|
||||||
uint8_t max_bytes_per_pic_denom;
|
uint32_t vui_num_ticks_poc_diff_one_minus1;
|
||||||
uint8_t max_bits_per_min_cu_denom;
|
uint16_t min_spatial_segmentation_idc;
|
||||||
uint8_t log2_max_mv_length_horizontal;
|
uint16_t reserved3;
|
||||||
uint8_t log2_max_mv_length_vertical;
|
uint8_t max_bytes_per_pic_denom;
|
||||||
StdVideoH265SpsVuiFlags flags;
|
uint8_t max_bits_per_min_cu_denom;
|
||||||
|
uint8_t log2_max_mv_length_horizontal;
|
||||||
|
uint8_t log2_max_mv_length_vertical;
|
||||||
|
const StdVideoH265HrdParameters* pHrdParameters;
|
||||||
} StdVideoH265SequenceParameterSetVui;
|
} StdVideoH265SequenceParameterSetVui;
|
||||||
|
|
||||||
typedef struct StdVideoH265PredictorPaletteEntries {
|
typedef struct StdVideoH265PredictorPaletteEntries {
|
||||||
@ -216,6 +263,8 @@ typedef struct StdVideoH265PredictorPaletteEntries {
|
|||||||
typedef struct StdVideoH265SpsFlags {
|
typedef struct StdVideoH265SpsFlags {
|
||||||
uint32_t sps_temporal_id_nesting_flag : 1;
|
uint32_t sps_temporal_id_nesting_flag : 1;
|
||||||
uint32_t separate_colour_plane_flag : 1;
|
uint32_t separate_colour_plane_flag : 1;
|
||||||
|
uint32_t conformance_window_flag : 1;
|
||||||
|
uint32_t sps_sub_layer_ordering_info_present_flag : 1;
|
||||||
uint32_t scaling_list_enabled_flag : 1;
|
uint32_t scaling_list_enabled_flag : 1;
|
||||||
uint32_t sps_scaling_list_data_present_flag : 1;
|
uint32_t sps_scaling_list_data_present_flag : 1;
|
||||||
uint32_t amp_enabled_flag : 1;
|
uint32_t amp_enabled_flag : 1;
|
||||||
@ -237,50 +286,80 @@ typedef struct StdVideoH265SpsFlags {
|
|||||||
uint32_t high_precision_offsets_enabled_flag : 1;
|
uint32_t high_precision_offsets_enabled_flag : 1;
|
||||||
uint32_t persistent_rice_adaptation_enabled_flag : 1;
|
uint32_t persistent_rice_adaptation_enabled_flag : 1;
|
||||||
uint32_t cabac_bypass_alignment_enabled_flag : 1;
|
uint32_t cabac_bypass_alignment_enabled_flag : 1;
|
||||||
|
uint32_t sps_scc_extension_flag : 1;
|
||||||
uint32_t sps_curr_pic_ref_enabled_flag : 1;
|
uint32_t sps_curr_pic_ref_enabled_flag : 1;
|
||||||
uint32_t palette_mode_enabled_flag : 1;
|
uint32_t palette_mode_enabled_flag : 1;
|
||||||
uint32_t sps_palette_predictor_initializer_present_flag : 1;
|
uint32_t sps_palette_predictor_initializers_present_flag : 1;
|
||||||
uint32_t intra_boundary_filtering_disabled_flag : 1;
|
uint32_t intra_boundary_filtering_disabled_flag : 1;
|
||||||
} StdVideoH265SpsFlags;
|
} StdVideoH265SpsFlags;
|
||||||
|
|
||||||
|
typedef struct StdVideoH265ShortTermRefPicSetFlags {
|
||||||
|
uint32_t inter_ref_pic_set_prediction_flag : 1;
|
||||||
|
uint32_t delta_rps_sign : 1;
|
||||||
|
} StdVideoH265ShortTermRefPicSetFlags;
|
||||||
|
|
||||||
|
typedef struct StdVideoH265ShortTermRefPicSet {
|
||||||
|
StdVideoH265ShortTermRefPicSetFlags flags;
|
||||||
|
uint32_t delta_idx_minus1;
|
||||||
|
uint16_t use_delta_flag;
|
||||||
|
uint16_t abs_delta_rps_minus1;
|
||||||
|
uint16_t used_by_curr_pic_flag;
|
||||||
|
uint16_t used_by_curr_pic_s0_flag;
|
||||||
|
uint16_t used_by_curr_pic_s1_flag;
|
||||||
|
uint16_t reserved1;
|
||||||
|
uint8_t reserved2;
|
||||||
|
uint8_t reserved3;
|
||||||
|
uint8_t num_negative_pics;
|
||||||
|
uint8_t num_positive_pics;
|
||||||
|
uint16_t delta_poc_s0_minus1[STD_VIDEO_H265_MAX_DPB_SIZE];
|
||||||
|
uint16_t delta_poc_s1_minus1[STD_VIDEO_H265_MAX_DPB_SIZE];
|
||||||
|
} StdVideoH265ShortTermRefPicSet;
|
||||||
|
|
||||||
|
typedef struct StdVideoH265LongTermRefPicsSps {
|
||||||
|
uint32_t used_by_curr_pic_lt_sps_flag;
|
||||||
|
uint32_t lt_ref_pic_poc_lsb_sps[STD_VIDEO_H265_MAX_LONG_TERM_REF_PICS_SPS];
|
||||||
|
} StdVideoH265LongTermRefPicsSps;
|
||||||
|
|
||||||
typedef struct StdVideoH265SequenceParameterSet {
|
typedef struct StdVideoH265SequenceParameterSet {
|
||||||
StdVideoH265ProfileIdc profile_idc;
|
StdVideoH265SpsFlags flags;
|
||||||
StdVideoH265Level level_idc;
|
StdVideoH265ChromaFormatIdc chroma_format_idc;
|
||||||
uint32_t pic_width_in_luma_samples;
|
uint32_t pic_width_in_luma_samples;
|
||||||
uint32_t pic_height_in_luma_samples;
|
uint32_t pic_height_in_luma_samples;
|
||||||
uint8_t sps_video_parameter_set_id;
|
uint8_t sps_video_parameter_set_id;
|
||||||
uint8_t sps_max_sub_layers_minus1;
|
uint8_t sps_max_sub_layers_minus1;
|
||||||
uint8_t sps_seq_parameter_set_id;
|
uint8_t sps_seq_parameter_set_id;
|
||||||
uint8_t chroma_format_idc;
|
uint8_t bit_depth_luma_minus8;
|
||||||
uint8_t bit_depth_luma_minus8;
|
uint8_t bit_depth_chroma_minus8;
|
||||||
uint8_t bit_depth_chroma_minus8;
|
uint8_t log2_max_pic_order_cnt_lsb_minus4;
|
||||||
uint8_t log2_max_pic_order_cnt_lsb_minus4;
|
uint8_t log2_min_luma_coding_block_size_minus3;
|
||||||
uint8_t sps_max_dec_pic_buffering_minus1;
|
uint8_t log2_diff_max_min_luma_coding_block_size;
|
||||||
uint8_t log2_min_luma_coding_block_size_minus3;
|
uint8_t log2_min_luma_transform_block_size_minus2;
|
||||||
uint8_t log2_diff_max_min_luma_coding_block_size;
|
uint8_t log2_diff_max_min_luma_transform_block_size;
|
||||||
uint8_t log2_min_luma_transform_block_size_minus2;
|
uint8_t max_transform_hierarchy_depth_inter;
|
||||||
uint8_t log2_diff_max_min_luma_transform_block_size;
|
uint8_t max_transform_hierarchy_depth_intra;
|
||||||
uint8_t max_transform_hierarchy_depth_inter;
|
uint8_t num_short_term_ref_pic_sets;
|
||||||
uint8_t max_transform_hierarchy_depth_intra;
|
uint8_t num_long_term_ref_pics_sps;
|
||||||
uint8_t num_short_term_ref_pic_sets;
|
uint8_t pcm_sample_bit_depth_luma_minus1;
|
||||||
uint8_t num_long_term_ref_pics_sps;
|
uint8_t pcm_sample_bit_depth_chroma_minus1;
|
||||||
uint8_t pcm_sample_bit_depth_luma_minus1;
|
uint8_t log2_min_pcm_luma_coding_block_size_minus3;
|
||||||
uint8_t pcm_sample_bit_depth_chroma_minus1;
|
uint8_t log2_diff_max_min_pcm_luma_coding_block_size;
|
||||||
uint8_t log2_min_pcm_luma_coding_block_size_minus3;
|
uint8_t reserved1;
|
||||||
uint8_t log2_diff_max_min_pcm_luma_coding_block_size;
|
uint8_t reserved2;
|
||||||
uint32_t conf_win_left_offset;
|
uint8_t palette_max_size;
|
||||||
uint32_t conf_win_right_offset;
|
uint8_t delta_palette_max_predictor_size;
|
||||||
uint32_t conf_win_top_offset;
|
uint8_t motion_vector_resolution_control_idc;
|
||||||
uint32_t conf_win_bottom_offset;
|
uint8_t sps_num_palette_predictor_initializers_minus1;
|
||||||
StdVideoH265DecPicBufMgr* pDecPicBufMgr;
|
uint32_t conf_win_left_offset;
|
||||||
StdVideoH265SpsFlags flags;
|
uint32_t conf_win_right_offset;
|
||||||
StdVideoH265ScalingLists* pScalingLists;
|
uint32_t conf_win_top_offset;
|
||||||
StdVideoH265SequenceParameterSetVui* pSequenceParameterSetVui;
|
uint32_t conf_win_bottom_offset;
|
||||||
uint8_t palette_max_size;
|
const StdVideoH265ProfileTierLevel* pProfileTierLevel;
|
||||||
uint8_t delta_palette_max_predictor_size;
|
const StdVideoH265DecPicBufMgr* pDecPicBufMgr;
|
||||||
uint8_t motion_vector_resolution_control_idc;
|
const StdVideoH265ScalingLists* pScalingLists;
|
||||||
uint8_t sps_num_palette_predictor_initializer_minus1;
|
const StdVideoH265ShortTermRefPicSet* pShortTermRefPicSet;
|
||||||
StdVideoH265PredictorPaletteEntries* pPredictorPaletteEntries;
|
const StdVideoH265LongTermRefPicsSps* pLongTermRefPicsSps;
|
||||||
|
const StdVideoH265SequenceParameterSetVui* pSequenceParameterSetVui;
|
||||||
|
const StdVideoH265PredictorPaletteEntries* pPredictorPaletteEntries;
|
||||||
} StdVideoH265SequenceParameterSet;
|
} StdVideoH265SequenceParameterSet;
|
||||||
|
|
||||||
typedef struct StdVideoH265PpsFlags {
|
typedef struct StdVideoH265PpsFlags {
|
||||||
@ -312,44 +391,48 @@ typedef struct StdVideoH265PpsFlags {
|
|||||||
uint32_t pps_curr_pic_ref_enabled_flag : 1;
|
uint32_t pps_curr_pic_ref_enabled_flag : 1;
|
||||||
uint32_t residual_adaptive_colour_transform_enabled_flag : 1;
|
uint32_t residual_adaptive_colour_transform_enabled_flag : 1;
|
||||||
uint32_t pps_slice_act_qp_offsets_present_flag : 1;
|
uint32_t pps_slice_act_qp_offsets_present_flag : 1;
|
||||||
uint32_t pps_palette_predictor_initializer_present_flag : 1;
|
uint32_t pps_palette_predictor_initializers_present_flag : 1;
|
||||||
uint32_t monochrome_palette_flag : 1;
|
uint32_t monochrome_palette_flag : 1;
|
||||||
uint32_t pps_range_extension_flag : 1;
|
uint32_t pps_range_extension_flag : 1;
|
||||||
} StdVideoH265PpsFlags;
|
} StdVideoH265PpsFlags;
|
||||||
|
|
||||||
typedef struct StdVideoH265PictureParameterSet {
|
typedef struct StdVideoH265PictureParameterSet {
|
||||||
uint8_t pps_pic_parameter_set_id;
|
StdVideoH265PpsFlags flags;
|
||||||
uint8_t pps_seq_parameter_set_id;
|
uint8_t pps_pic_parameter_set_id;
|
||||||
uint8_t num_extra_slice_header_bits;
|
uint8_t pps_seq_parameter_set_id;
|
||||||
uint8_t num_ref_idx_l0_default_active_minus1;
|
uint8_t sps_video_parameter_set_id;
|
||||||
uint8_t num_ref_idx_l1_default_active_minus1;
|
uint8_t num_extra_slice_header_bits;
|
||||||
int8_t init_qp_minus26;
|
uint8_t num_ref_idx_l0_default_active_minus1;
|
||||||
uint8_t diff_cu_qp_delta_depth;
|
uint8_t num_ref_idx_l1_default_active_minus1;
|
||||||
int8_t pps_cb_qp_offset;
|
int8_t init_qp_minus26;
|
||||||
int8_t pps_cr_qp_offset;
|
uint8_t diff_cu_qp_delta_depth;
|
||||||
uint8_t num_tile_columns_minus1;
|
int8_t pps_cb_qp_offset;
|
||||||
uint8_t num_tile_rows_minus1;
|
int8_t pps_cr_qp_offset;
|
||||||
uint16_t column_width_minus1[STD_VIDEO_H265_CHROMA_QP_OFFSET_TILE_COLS_LIST_SIZE];
|
int8_t pps_beta_offset_div2;
|
||||||
uint16_t row_height_minus1[STD_VIDEO_H265_CHROMA_QP_OFFSET_TILE_ROWS_LIST_SIZE];
|
int8_t pps_tc_offset_div2;
|
||||||
int8_t pps_beta_offset_div2;
|
uint8_t log2_parallel_merge_level_minus2;
|
||||||
int8_t pps_tc_offset_div2;
|
uint8_t log2_max_transform_skip_block_size_minus2;
|
||||||
uint8_t log2_parallel_merge_level_minus2;
|
uint8_t diff_cu_chroma_qp_offset_depth;
|
||||||
StdVideoH265PpsFlags flags;
|
uint8_t chroma_qp_offset_list_len_minus1;
|
||||||
StdVideoH265ScalingLists* pScalingLists;
|
int8_t cb_qp_offset_list[STD_VIDEO_H265_CHROMA_QP_OFFSET_LIST_SIZE];
|
||||||
uint8_t log2_max_transform_skip_block_size_minus2;
|
int8_t cr_qp_offset_list[STD_VIDEO_H265_CHROMA_QP_OFFSET_LIST_SIZE];
|
||||||
uint8_t diff_cu_chroma_qp_offset_depth;
|
uint8_t log2_sao_offset_scale_luma;
|
||||||
uint8_t chroma_qp_offset_list_len_minus1;
|
uint8_t log2_sao_offset_scale_chroma;
|
||||||
int8_t cb_qp_offset_list[STD_VIDEO_H265_CHROMA_QP_OFFSET_LIST_SIZE];
|
int8_t pps_act_y_qp_offset_plus5;
|
||||||
int8_t cr_qp_offset_list[STD_VIDEO_H265_CHROMA_QP_OFFSET_LIST_SIZE];
|
int8_t pps_act_cb_qp_offset_plus5;
|
||||||
uint8_t log2_sao_offset_scale_luma;
|
int8_t pps_act_cr_qp_offset_plus3;
|
||||||
uint8_t log2_sao_offset_scale_chroma;
|
uint8_t pps_num_palette_predictor_initializers;
|
||||||
int8_t pps_act_y_qp_offset_plus5;
|
uint8_t luma_bit_depth_entry_minus8;
|
||||||
int8_t pps_act_cb_qp_offset_plus5;
|
uint8_t chroma_bit_depth_entry_minus8;
|
||||||
int8_t pps_act_cr_qp_offset_plus5;
|
uint8_t num_tile_columns_minus1;
|
||||||
uint8_t pps_num_palette_predictor_initializer;
|
uint8_t num_tile_rows_minus1;
|
||||||
uint8_t luma_bit_depth_entry_minus8;
|
uint8_t reserved1;
|
||||||
uint8_t chroma_bit_depth_entry_minus8;
|
uint8_t reserved2;
|
||||||
StdVideoH265PredictorPaletteEntries* pPredictorPaletteEntries;
|
uint16_t column_width_minus1[STD_VIDEO_H265_CHROMA_QP_OFFSET_TILE_COLS_LIST_SIZE];
|
||||||
|
uint16_t row_height_minus1[STD_VIDEO_H265_CHROMA_QP_OFFSET_TILE_ROWS_LIST_SIZE];
|
||||||
|
uint32_t reserved3;
|
||||||
|
const StdVideoH265ScalingLists* pScalingLists;
|
||||||
|
const StdVideoH265PredictorPaletteEntries* pPredictorPaletteEntries;
|
||||||
} StdVideoH265PictureParameterSet;
|
} StdVideoH265PictureParameterSet;
|
||||||
|
|
||||||
|
|
||||||
|
@ -20,7 +20,12 @@ extern "C" {
|
|||||||
|
|
||||||
|
|
||||||
#define vulkan_video_codec_h265std_decode 1
|
#define vulkan_video_codec_h265std_decode 1
|
||||||
|
// Vulkan 0.9 provisional Vulkan video H.265 decode std specification version number
|
||||||
|
#define VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_API_VERSION_0_9_9 VK_MAKE_VIDEO_STD_VERSION(0, 9, 9) // Patch version should always be set to 0
|
||||||
|
|
||||||
#define STD_VIDEO_DECODE_H265_REF_PIC_SET_LIST_SIZE 8
|
#define STD_VIDEO_DECODE_H265_REF_PIC_SET_LIST_SIZE 8
|
||||||
|
#define VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_API_VERSION_0_9_9
|
||||||
|
#define VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_EXTENSION_NAME "VK_STD_vulkan_video_codec_h265_decode"
|
||||||
typedef struct StdVideoDecodeH265PictureInfoFlags {
|
typedef struct StdVideoDecodeH265PictureInfoFlags {
|
||||||
uint32_t IrapPicFlag : 1;
|
uint32_t IrapPicFlag : 1;
|
||||||
uint32_t IdrPicFlag : 1;
|
uint32_t IdrPicFlag : 1;
|
||||||
@ -29,27 +34,27 @@ typedef struct StdVideoDecodeH265PictureInfoFlags {
|
|||||||
} StdVideoDecodeH265PictureInfoFlags;
|
} StdVideoDecodeH265PictureInfoFlags;
|
||||||
|
|
||||||
typedef struct StdVideoDecodeH265PictureInfo {
|
typedef struct StdVideoDecodeH265PictureInfo {
|
||||||
uint8_t vps_video_parameter_set_id;
|
StdVideoDecodeH265PictureInfoFlags flags;
|
||||||
uint8_t sps_seq_parameter_set_id;
|
uint8_t sps_video_parameter_set_id;
|
||||||
|
uint8_t pps_seq_parameter_set_id;
|
||||||
uint8_t pps_pic_parameter_set_id;
|
uint8_t pps_pic_parameter_set_id;
|
||||||
uint8_t num_short_term_ref_pic_sets;
|
uint8_t NumDeltaPocsOfRefRpsIdx;
|
||||||
int32_t PicOrderCntVal;
|
int32_t PicOrderCntVal;
|
||||||
uint16_t NumBitsForSTRefPicSetInSlice;
|
uint16_t NumBitsForSTRefPicSetInSlice;
|
||||||
uint8_t NumDeltaPocsOfRefRpsIdx;
|
uint16_t reserved;
|
||||||
uint8_t RefPicSetStCurrBefore[STD_VIDEO_DECODE_H265_REF_PIC_SET_LIST_SIZE];
|
uint8_t RefPicSetStCurrBefore[STD_VIDEO_DECODE_H265_REF_PIC_SET_LIST_SIZE];
|
||||||
uint8_t RefPicSetStCurrAfter[STD_VIDEO_DECODE_H265_REF_PIC_SET_LIST_SIZE];
|
uint8_t RefPicSetStCurrAfter[STD_VIDEO_DECODE_H265_REF_PIC_SET_LIST_SIZE];
|
||||||
uint8_t RefPicSetLtCurr[STD_VIDEO_DECODE_H265_REF_PIC_SET_LIST_SIZE];
|
uint8_t RefPicSetLtCurr[STD_VIDEO_DECODE_H265_REF_PIC_SET_LIST_SIZE];
|
||||||
StdVideoDecodeH265PictureInfoFlags flags;
|
|
||||||
} StdVideoDecodeH265PictureInfo;
|
} StdVideoDecodeH265PictureInfo;
|
||||||
|
|
||||||
typedef struct StdVideoDecodeH265ReferenceInfoFlags {
|
typedef struct StdVideoDecodeH265ReferenceInfoFlags {
|
||||||
uint32_t is_long_term : 1;
|
uint32_t used_for_long_term_reference : 1;
|
||||||
uint32_t is_non_existing : 1;
|
uint32_t unused_for_reference : 1;
|
||||||
} StdVideoDecodeH265ReferenceInfoFlags;
|
} StdVideoDecodeH265ReferenceInfoFlags;
|
||||||
|
|
||||||
typedef struct StdVideoDecodeH265ReferenceInfo {
|
typedef struct StdVideoDecodeH265ReferenceInfo {
|
||||||
int32_t PicOrderCntVal;
|
|
||||||
StdVideoDecodeH265ReferenceInfoFlags flags;
|
StdVideoDecodeH265ReferenceInfoFlags flags;
|
||||||
|
int32_t PicOrderCntVal;
|
||||||
} StdVideoDecodeH265ReferenceInfo;
|
} StdVideoDecodeH265ReferenceInfo;
|
||||||
|
|
||||||
|
|
||||||
|
@ -20,13 +20,37 @@ extern "C" {
|
|||||||
|
|
||||||
|
|
||||||
#define vulkan_video_codec_h265std_encode 1
|
#define vulkan_video_codec_h265std_encode 1
|
||||||
#define STD_VIDEO_ENCODE_H265_LUMA_LIST_SIZE 15
|
// Vulkan 0.9 provisional Vulkan video H.265 encode std specification version number
|
||||||
#define STD_VIDEO_ENCODE_H265_CHROMA_LIST_SIZE 15
|
#define VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_API_VERSION_0_9_9 VK_MAKE_VIDEO_STD_VERSION(0, 9, 9) // Patch version should always be set to 0
|
||||||
#define STD_VIDEO_ENCODE_H265_CHROMA_LISTS_NUM 2
|
|
||||||
|
#define VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_API_VERSION_0_9_9
|
||||||
|
#define VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_EXTENSION_NAME "VK_STD_vulkan_video_codec_h265_encode"
|
||||||
|
typedef struct StdVideoEncodeH265WeightTableFlags {
|
||||||
|
uint16_t luma_weight_l0_flag;
|
||||||
|
uint16_t chroma_weight_l0_flag;
|
||||||
|
uint16_t luma_weight_l1_flag;
|
||||||
|
uint16_t chroma_weight_l1_flag;
|
||||||
|
} StdVideoEncodeH265WeightTableFlags;
|
||||||
|
|
||||||
|
typedef struct StdVideoEncodeH265WeightTable {
|
||||||
|
StdVideoEncodeH265WeightTableFlags flags;
|
||||||
|
uint8_t luma_log2_weight_denom;
|
||||||
|
int8_t delta_chroma_log2_weight_denom;
|
||||||
|
int8_t delta_luma_weight_l0[STD_VIDEO_H265_MAX_NUM_LIST_REF];
|
||||||
|
int8_t luma_offset_l0[STD_VIDEO_H265_MAX_NUM_LIST_REF];
|
||||||
|
int8_t delta_chroma_weight_l0[STD_VIDEO_H265_MAX_NUM_LIST_REF][STD_VIDEO_H265_MAX_CHROMA_PLANES];
|
||||||
|
int8_t delta_chroma_offset_l0[STD_VIDEO_H265_MAX_NUM_LIST_REF][STD_VIDEO_H265_MAX_CHROMA_PLANES];
|
||||||
|
int8_t delta_luma_weight_l1[STD_VIDEO_H265_MAX_NUM_LIST_REF];
|
||||||
|
int8_t luma_offset_l1[STD_VIDEO_H265_MAX_NUM_LIST_REF];
|
||||||
|
int8_t delta_chroma_weight_l1[STD_VIDEO_H265_MAX_NUM_LIST_REF][STD_VIDEO_H265_MAX_CHROMA_PLANES];
|
||||||
|
int8_t delta_chroma_offset_l1[STD_VIDEO_H265_MAX_NUM_LIST_REF][STD_VIDEO_H265_MAX_CHROMA_PLANES];
|
||||||
|
} StdVideoEncodeH265WeightTable;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH265SliceSegmentHeaderFlags {
|
typedef struct StdVideoEncodeH265SliceSegmentHeaderFlags {
|
||||||
uint32_t first_slice_segment_in_pic_flag : 1;
|
uint32_t first_slice_segment_in_pic_flag : 1;
|
||||||
uint32_t no_output_of_prior_pics_flag : 1;
|
uint32_t no_output_of_prior_pics_flag : 1;
|
||||||
uint32_t dependent_slice_segment_flag : 1;
|
uint32_t dependent_slice_segment_flag : 1;
|
||||||
|
uint32_t pic_output_flag : 1;
|
||||||
uint32_t short_term_ref_pic_set_sps_flag : 1;
|
uint32_t short_term_ref_pic_set_sps_flag : 1;
|
||||||
uint32_t slice_temporal_mvp_enable_flag : 1;
|
uint32_t slice_temporal_mvp_enable_flag : 1;
|
||||||
uint32_t slice_sao_luma_flag : 1;
|
uint32_t slice_sao_luma_flag : 1;
|
||||||
@ -34,48 +58,42 @@ typedef struct StdVideoEncodeH265SliceSegmentHeaderFlags {
|
|||||||
uint32_t num_ref_idx_active_override_flag : 1;
|
uint32_t num_ref_idx_active_override_flag : 1;
|
||||||
uint32_t mvd_l1_zero_flag : 1;
|
uint32_t mvd_l1_zero_flag : 1;
|
||||||
uint32_t cabac_init_flag : 1;
|
uint32_t cabac_init_flag : 1;
|
||||||
uint32_t slice_deblocking_filter_disable_flag : 1;
|
uint32_t cu_chroma_qp_offset_enabled_flag : 1;
|
||||||
|
uint32_t deblocking_filter_override_flag : 1;
|
||||||
|
uint32_t slice_deblocking_filter_disabled_flag : 1;
|
||||||
uint32_t collocated_from_l0_flag : 1;
|
uint32_t collocated_from_l0_flag : 1;
|
||||||
uint32_t slice_loop_filter_across_slices_enabled_flag : 1;
|
uint32_t slice_loop_filter_across_slices_enabled_flag : 1;
|
||||||
uint32_t bLastSliceInPic : 1;
|
|
||||||
uint32_t reservedBits : 18;
|
|
||||||
uint16_t luma_weight_l0_flag;
|
|
||||||
uint16_t chroma_weight_l0_flag;
|
|
||||||
uint16_t luma_weight_l1_flag;
|
|
||||||
uint16_t chroma_weight_l1_flag;
|
|
||||||
} StdVideoEncodeH265SliceSegmentHeaderFlags;
|
} StdVideoEncodeH265SliceSegmentHeaderFlags;
|
||||||
|
|
||||||
|
typedef struct StdVideoEncodeH265SliceSegmentLongTermRefPics {
|
||||||
|
uint8_t num_long_term_sps;
|
||||||
|
uint8_t num_long_term_pics;
|
||||||
|
uint8_t lt_idx_sps[STD_VIDEO_H265_MAX_LONG_TERM_REF_PICS_SPS];
|
||||||
|
uint8_t poc_lsb_lt[STD_VIDEO_H265_MAX_LONG_TERM_PICS];
|
||||||
|
uint16_t used_by_curr_pic_lt_flag;
|
||||||
|
uint8_t delta_poc_msb_present_flag[STD_VIDEO_H265_MAX_DELTA_POC];
|
||||||
|
uint8_t delta_poc_msb_cycle_lt[STD_VIDEO_H265_MAX_DELTA_POC];
|
||||||
|
} StdVideoEncodeH265SliceSegmentLongTermRefPics;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH265SliceSegmentHeader {
|
typedef struct StdVideoEncodeH265SliceSegmentHeader {
|
||||||
StdVideoH265SliceType slice_type;
|
StdVideoEncodeH265SliceSegmentHeaderFlags flags;
|
||||||
uint8_t slice_pic_parameter_set_id;
|
StdVideoH265SliceType slice_type;
|
||||||
uint8_t num_short_term_ref_pic_sets;
|
uint32_t slice_segment_address;
|
||||||
uint32_t slice_segment_address;
|
uint8_t short_term_ref_pic_set_idx;
|
||||||
uint8_t short_term_ref_pic_set_idx;
|
uint8_t collocated_ref_idx;
|
||||||
uint8_t num_long_term_sps;
|
uint8_t num_ref_idx_l0_active_minus1;
|
||||||
uint8_t num_long_term_pics;
|
uint8_t num_ref_idx_l1_active_minus1;
|
||||||
uint8_t collocated_ref_idx;
|
uint8_t MaxNumMergeCand;
|
||||||
uint8_t num_ref_idx_l0_active_minus1;
|
int8_t slice_cb_qp_offset;
|
||||||
uint8_t num_ref_idx_l1_active_minus1;
|
int8_t slice_cr_qp_offset;
|
||||||
uint8_t luma_log2_weight_denom;
|
int8_t slice_beta_offset_div2;
|
||||||
int8_t delta_chroma_log2_weight_denom;
|
int8_t slice_tc_offset_div2;
|
||||||
int8_t delta_luma_weight_l0[STD_VIDEO_ENCODE_H265_LUMA_LIST_SIZE];
|
int8_t slice_act_y_qp_offset;
|
||||||
int8_t luma_offset_l0[STD_VIDEO_ENCODE_H265_LUMA_LIST_SIZE];
|
int8_t slice_act_cb_qp_offset;
|
||||||
int8_t delta_chroma_weight_l0[STD_VIDEO_ENCODE_H265_CHROMA_LIST_SIZE][STD_VIDEO_ENCODE_H265_CHROMA_LISTS_NUM];
|
int8_t slice_act_cr_qp_offset;
|
||||||
int8_t delta_chroma_offset_l0[STD_VIDEO_ENCODE_H265_CHROMA_LIST_SIZE][STD_VIDEO_ENCODE_H265_CHROMA_LISTS_NUM];
|
const StdVideoH265ShortTermRefPicSet* pShortTermRefPicSet;
|
||||||
int8_t delta_luma_weight_l1[STD_VIDEO_ENCODE_H265_LUMA_LIST_SIZE];
|
const StdVideoEncodeH265SliceSegmentLongTermRefPics* pLongTermRefPics;
|
||||||
int8_t luma_offset_l1[STD_VIDEO_ENCODE_H265_LUMA_LIST_SIZE];
|
const StdVideoEncodeH265WeightTable* pWeightTable;
|
||||||
int8_t delta_chroma_weight_l1[STD_VIDEO_ENCODE_H265_CHROMA_LIST_SIZE][STD_VIDEO_ENCODE_H265_CHROMA_LISTS_NUM];
|
|
||||||
int8_t delta_chroma_offset_l1[STD_VIDEO_ENCODE_H265_CHROMA_LIST_SIZE][STD_VIDEO_ENCODE_H265_CHROMA_LISTS_NUM];
|
|
||||||
uint8_t MaxNumMergeCand;
|
|
||||||
int8_t slice_qp_delta;
|
|
||||||
int8_t slice_cb_qp_offset;
|
|
||||||
int8_t slice_cr_qp_offset;
|
|
||||||
int8_t slice_beta_offset_div2;
|
|
||||||
int8_t slice_tc_offset_div2;
|
|
||||||
int8_t slice_act_y_qp_offset;
|
|
||||||
int8_t slice_act_cb_qp_offset;
|
|
||||||
int8_t slice_act_cr_qp_offset;
|
|
||||||
StdVideoEncodeH265SliceSegmentHeaderFlags flags;
|
|
||||||
} StdVideoEncodeH265SliceSegmentHeader;
|
} StdVideoEncodeH265SliceSegmentHeader;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH265ReferenceModificationFlags {
|
typedef struct StdVideoEncodeH265ReferenceModificationFlags {
|
||||||
@ -86,35 +104,38 @@ typedef struct StdVideoEncodeH265ReferenceModificationFlags {
|
|||||||
typedef struct StdVideoEncodeH265ReferenceModifications {
|
typedef struct StdVideoEncodeH265ReferenceModifications {
|
||||||
StdVideoEncodeH265ReferenceModificationFlags flags;
|
StdVideoEncodeH265ReferenceModificationFlags flags;
|
||||||
uint8_t referenceList0ModificationsCount;
|
uint8_t referenceList0ModificationsCount;
|
||||||
uint8_t* pReferenceList0Modifications;
|
const uint8_t* pReferenceList0Modifications;
|
||||||
uint8_t referenceList1ModificationsCount;
|
uint8_t referenceList1ModificationsCount;
|
||||||
uint8_t* pReferenceList1Modifications;
|
const uint8_t* pReferenceList1Modifications;
|
||||||
} StdVideoEncodeH265ReferenceModifications;
|
} StdVideoEncodeH265ReferenceModifications;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH265PictureInfoFlags {
|
typedef struct StdVideoEncodeH265PictureInfoFlags {
|
||||||
uint32_t is_reference_flag : 1;
|
uint32_t is_reference_flag : 1;
|
||||||
uint32_t IrapPicFlag : 1;
|
uint32_t IrapPicFlag : 1;
|
||||||
uint32_t long_term_flag : 1;
|
uint32_t long_term_flag : 1;
|
||||||
|
uint32_t discardable_flag : 1;
|
||||||
|
uint32_t cross_layer_bla_flag : 1;
|
||||||
} StdVideoEncodeH265PictureInfoFlags;
|
} StdVideoEncodeH265PictureInfoFlags;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH265PictureInfo {
|
typedef struct StdVideoEncodeH265PictureInfo {
|
||||||
|
StdVideoEncodeH265PictureInfoFlags flags;
|
||||||
StdVideoH265PictureType PictureType;
|
StdVideoH265PictureType PictureType;
|
||||||
uint8_t sps_video_parameter_set_id;
|
uint8_t sps_video_parameter_set_id;
|
||||||
uint8_t pps_seq_parameter_set_id;
|
uint8_t pps_seq_parameter_set_id;
|
||||||
|
uint8_t pps_pic_parameter_set_id;
|
||||||
int32_t PicOrderCntVal;
|
int32_t PicOrderCntVal;
|
||||||
uint8_t TemporalId;
|
uint8_t TemporalId;
|
||||||
StdVideoEncodeH265PictureInfoFlags flags;
|
|
||||||
} StdVideoEncodeH265PictureInfo;
|
} StdVideoEncodeH265PictureInfo;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH265ReferenceInfoFlags {
|
typedef struct StdVideoEncodeH265ReferenceInfoFlags {
|
||||||
uint32_t is_long_term : 1;
|
uint32_t used_for_long_term_reference : 1;
|
||||||
uint32_t isUsedFlag : 1;
|
uint32_t unused_for_reference : 1;
|
||||||
} StdVideoEncodeH265ReferenceInfoFlags;
|
} StdVideoEncodeH265ReferenceInfoFlags;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH265ReferenceInfo {
|
typedef struct StdVideoEncodeH265ReferenceInfo {
|
||||||
|
StdVideoEncodeH265ReferenceInfoFlags flags;
|
||||||
int32_t PicOrderCntVal;
|
int32_t PicOrderCntVal;
|
||||||
uint8_t TemporalId;
|
uint8_t TemporalId;
|
||||||
StdVideoEncodeH265ReferenceInfoFlags flags;
|
|
||||||
} StdVideoEncodeH265ReferenceInfo;
|
} StdVideoEncodeH265ReferenceInfo;
|
||||||
|
|
||||||
|
|
||||||
|
1
thirdparty/vulkan/include/vulkan/vulkan.h
vendored
1
thirdparty/vulkan/include/vulkan/vulkan.h
vendored
@ -38,7 +38,6 @@
|
|||||||
|
|
||||||
|
|
||||||
#ifdef VK_USE_PLATFORM_WAYLAND_KHR
|
#ifdef VK_USE_PLATFORM_WAYLAND_KHR
|
||||||
#include <wayland-client.h>
|
|
||||||
#include "vulkan_wayland.h"
|
#include "vulkan_wayland.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
7752
thirdparty/vulkan/include/vulkan/vulkan.hpp
vendored
7752
thirdparty/vulkan/include/vulkan/vulkan.hpp
vendored
File diff suppressed because it is too large
Load Diff
@ -44,7 +44,7 @@ VKAPI_ATTR VkResult VKAPI_CALL vkCreateAndroidSurfaceKHR(
|
|||||||
|
|
||||||
#define VK_ANDROID_external_memory_android_hardware_buffer 1
|
#define VK_ANDROID_external_memory_android_hardware_buffer 1
|
||||||
struct AHardwareBuffer;
|
struct AHardwareBuffer;
|
||||||
#define VK_ANDROID_EXTERNAL_MEMORY_ANDROID_HARDWARE_BUFFER_SPEC_VERSION 4
|
#define VK_ANDROID_EXTERNAL_MEMORY_ANDROID_HARDWARE_BUFFER_SPEC_VERSION 5
|
||||||
#define VK_ANDROID_EXTERNAL_MEMORY_ANDROID_HARDWARE_BUFFER_EXTENSION_NAME "VK_ANDROID_external_memory_android_hardware_buffer"
|
#define VK_ANDROID_EXTERNAL_MEMORY_ANDROID_HARDWARE_BUFFER_EXTENSION_NAME "VK_ANDROID_external_memory_android_hardware_buffer"
|
||||||
typedef struct VkAndroidHardwareBufferUsageANDROID {
|
typedef struct VkAndroidHardwareBufferUsageANDROID {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
|
737
thirdparty/vulkan/include/vulkan/vulkan_beta.h
vendored
737
thirdparty/vulkan/include/vulkan/vulkan_beta.h
vendored
File diff suppressed because it is too large
Load Diff
1959
thirdparty/vulkan/include/vulkan/vulkan_core.h
vendored
1959
thirdparty/vulkan/include/vulkan/vulkan_core.h
vendored
File diff suppressed because it is too large
Load Diff
17362
thirdparty/vulkan/include/vulkan/vulkan_enums.hpp
vendored
17362
thirdparty/vulkan/include/vulkan/vulkan_enums.hpp
vendored
File diff suppressed because it is too large
Load Diff
7357
thirdparty/vulkan/include/vulkan/vulkan_format_traits.hpp
vendored
Normal file
7357
thirdparty/vulkan/include/vulkan/vulkan_format_traits.hpp
vendored
Normal file
File diff suppressed because it is too large
Load Diff
20111
thirdparty/vulkan/include/vulkan/vulkan_funcs.hpp
vendored
20111
thirdparty/vulkan/include/vulkan/vulkan_funcs.hpp
vendored
File diff suppressed because it is too large
Load Diff
9882
thirdparty/vulkan/include/vulkan/vulkan_handles.hpp
vendored
9882
thirdparty/vulkan/include/vulkan/vulkan_handles.hpp
vendored
File diff suppressed because it is too large
Load Diff
5014
thirdparty/vulkan/include/vulkan/vulkan_hash.hpp
vendored
5014
thirdparty/vulkan/include/vulkan/vulkan_hash.hpp
vendored
File diff suppressed because it is too large
Load Diff
141
thirdparty/vulkan/include/vulkan/vulkan_metal.h
vendored
141
thirdparty/vulkan/include/vulkan/vulkan_metal.h
vendored
@ -20,7 +20,6 @@ extern "C" {
|
|||||||
|
|
||||||
|
|
||||||
#define VK_EXT_metal_surface 1
|
#define VK_EXT_metal_surface 1
|
||||||
|
|
||||||
#ifdef __OBJC__
|
#ifdef __OBJC__
|
||||||
@class CAMetalLayer;
|
@class CAMetalLayer;
|
||||||
#else
|
#else
|
||||||
@ -47,6 +46,146 @@ VKAPI_ATTR VkResult VKAPI_CALL vkCreateMetalSurfaceEXT(
|
|||||||
VkSurfaceKHR* pSurface);
|
VkSurfaceKHR* pSurface);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#define VK_EXT_metal_objects 1
|
||||||
|
#ifdef __OBJC__
|
||||||
|
@protocol MTLDevice;
|
||||||
|
typedef id<MTLDevice> MTLDevice_id;
|
||||||
|
#else
|
||||||
|
typedef void* MTLDevice_id;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __OBJC__
|
||||||
|
@protocol MTLCommandQueue;
|
||||||
|
typedef id<MTLCommandQueue> MTLCommandQueue_id;
|
||||||
|
#else
|
||||||
|
typedef void* MTLCommandQueue_id;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __OBJC__
|
||||||
|
@protocol MTLBuffer;
|
||||||
|
typedef id<MTLBuffer> MTLBuffer_id;
|
||||||
|
#else
|
||||||
|
typedef void* MTLBuffer_id;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __OBJC__
|
||||||
|
@protocol MTLTexture;
|
||||||
|
typedef id<MTLTexture> MTLTexture_id;
|
||||||
|
#else
|
||||||
|
typedef void* MTLTexture_id;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct __IOSurface* IOSurfaceRef;
|
||||||
|
#ifdef __OBJC__
|
||||||
|
@protocol MTLSharedEvent;
|
||||||
|
typedef id<MTLSharedEvent> MTLSharedEvent_id;
|
||||||
|
#else
|
||||||
|
typedef void* MTLSharedEvent_id;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define VK_EXT_METAL_OBJECTS_SPEC_VERSION 1
|
||||||
|
#define VK_EXT_METAL_OBJECTS_EXTENSION_NAME "VK_EXT_metal_objects"
|
||||||
|
|
||||||
|
typedef enum VkExportMetalObjectTypeFlagBitsEXT {
|
||||||
|
VK_EXPORT_METAL_OBJECT_TYPE_METAL_DEVICE_BIT_EXT = 0x00000001,
|
||||||
|
VK_EXPORT_METAL_OBJECT_TYPE_METAL_COMMAND_QUEUE_BIT_EXT = 0x00000002,
|
||||||
|
VK_EXPORT_METAL_OBJECT_TYPE_METAL_BUFFER_BIT_EXT = 0x00000004,
|
||||||
|
VK_EXPORT_METAL_OBJECT_TYPE_METAL_TEXTURE_BIT_EXT = 0x00000008,
|
||||||
|
VK_EXPORT_METAL_OBJECT_TYPE_METAL_IOSURFACE_BIT_EXT = 0x00000010,
|
||||||
|
VK_EXPORT_METAL_OBJECT_TYPE_METAL_SHARED_EVENT_BIT_EXT = 0x00000020,
|
||||||
|
VK_EXPORT_METAL_OBJECT_TYPE_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
||||||
|
} VkExportMetalObjectTypeFlagBitsEXT;
|
||||||
|
typedef VkFlags VkExportMetalObjectTypeFlagsEXT;
|
||||||
|
typedef struct VkExportMetalObjectCreateInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkExportMetalObjectTypeFlagBitsEXT exportObjectType;
|
||||||
|
} VkExportMetalObjectCreateInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkExportMetalObjectsInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
} VkExportMetalObjectsInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkExportMetalDeviceInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
MTLDevice_id mtlDevice;
|
||||||
|
} VkExportMetalDeviceInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkExportMetalCommandQueueInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkQueue queue;
|
||||||
|
MTLCommandQueue_id mtlCommandQueue;
|
||||||
|
} VkExportMetalCommandQueueInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkExportMetalBufferInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkDeviceMemory memory;
|
||||||
|
MTLBuffer_id mtlBuffer;
|
||||||
|
} VkExportMetalBufferInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkImportMetalBufferInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
MTLBuffer_id mtlBuffer;
|
||||||
|
} VkImportMetalBufferInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkExportMetalTextureInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkImage image;
|
||||||
|
VkImageView imageView;
|
||||||
|
VkBufferView bufferView;
|
||||||
|
VkImageAspectFlagBits plane;
|
||||||
|
MTLTexture_id mtlTexture;
|
||||||
|
} VkExportMetalTextureInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkImportMetalTextureInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkImageAspectFlagBits plane;
|
||||||
|
MTLTexture_id mtlTexture;
|
||||||
|
} VkImportMetalTextureInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkExportMetalIOSurfaceInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkImage image;
|
||||||
|
IOSurfaceRef ioSurface;
|
||||||
|
} VkExportMetalIOSurfaceInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkImportMetalIOSurfaceInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
IOSurfaceRef ioSurface;
|
||||||
|
} VkImportMetalIOSurfaceInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkExportMetalSharedEventInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkSemaphore semaphore;
|
||||||
|
VkEvent event;
|
||||||
|
MTLSharedEvent_id mtlSharedEvent;
|
||||||
|
} VkExportMetalSharedEventInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkImportMetalSharedEventInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
MTLSharedEvent_id mtlSharedEvent;
|
||||||
|
} VkImportMetalSharedEventInfoEXT;
|
||||||
|
|
||||||
|
typedef void (VKAPI_PTR *PFN_vkExportMetalObjectsEXT)(VkDevice device, VkExportMetalObjectsInfoEXT* pMetalObjectsInfo);
|
||||||
|
|
||||||
|
#ifndef VK_NO_PROTOTYPES
|
||||||
|
VKAPI_ATTR void VKAPI_CALL vkExportMetalObjectsEXT(
|
||||||
|
VkDevice device,
|
||||||
|
VkExportMetalObjectsInfoEXT* pMetalObjectsInfo);
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
16200
thirdparty/vulkan/include/vulkan/vulkan_raii.hpp
vendored
16200
thirdparty/vulkan/include/vulkan/vulkan_raii.hpp
vendored
File diff suppressed because it is too large
Load Diff
6105
thirdparty/vulkan/include/vulkan/vulkan_static_assertions.hpp
vendored
Normal file
6105
thirdparty/vulkan/include/vulkan/vulkan_static_assertions.hpp
vendored
Normal file
File diff suppressed because it is too large
Load Diff
60260
thirdparty/vulkan/include/vulkan/vulkan_structs.hpp
vendored
60260
thirdparty/vulkan/include/vulkan/vulkan_structs.hpp
vendored
File diff suppressed because it is too large
Load Diff
8177
thirdparty/vulkan/include/vulkan/vulkan_to_string.hpp
vendored
Normal file
8177
thirdparty/vulkan/include/vulkan/vulkan_to_string.hpp
vendored
Normal file
File diff suppressed because it is too large
Load Diff
@ -1,8 +1,8 @@
|
|||||||
diff --git a/thirdparty/vulkan/vk_enum_string_helper.h b/thirdparty/vulkan/vk_enum_string_helper.h
|
diff --git a/thirdparty/vulkan/vk_enum_string_helper.h b/thirdparty/vulkan/vk_enum_string_helper.h
|
||||||
index 4c36430341..004a861774 100644
|
index 65b3322c07..e8c61aaf15 100644
|
||||||
--- a/thirdparty/vulkan/vk_enum_string_helper.h
|
--- a/thirdparty/vulkan/vk_enum_string_helper.h
|
||||||
+++ b/thirdparty/vulkan/vk_enum_string_helper.h
|
+++ b/thirdparty/vulkan/vk_enum_string_helper.h
|
||||||
@@ -36,7 +36,11 @@
|
@@ -37,7 +37,11 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
1834
thirdparty/vulkan/vk_enum_string_helper.h
vendored
1834
thirdparty/vulkan/vk_enum_string_helper.h
vendored
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user