mirror of
https://github.com/KhronosGroup/SPIRV-Tools
synced 2024-11-24 12:30:13 +00:00
e70b009b0f
Add support for SPV_KHR_non_semantic_info This entails a couple of changes: - Allowing unknown OpExtInstImport that begin with the prefix `NonSemantic.` - Allowing OpExtInst that reference any of those sets to contain unknown ext inst instruction numbers, and assume the format is always a series of IDs as guaranteed by the extension. - Allowing those OpExtInst to appear in the types/variables/constants section. - Not stripping OpString in the --strip-debug pass, since it may be referenced by these non-semantic OpExtInsts. - Stripping them instead in the --strip-reflect pass. * Add adjacency validation of non-semantic OpExtInst - We validate and test that OpExtInst cannot appear before or between OpPhi instructions, or before/between OpFunctionParameter instructions. * Change non-semantic extinst type to single value * Add helper function spvExtInstIsNonSemantic() which will check if the extinst set is non-semantic or not, either the unknown generic value or any future recognised non-semantic set. * Add test of a complex non-semantic extinst * Use DefUseManager in StripDebugInfoPass to strip some OpStrings * Any OpString used by a non-semantic instruction cannot be stripped, all others can so we search for uses to see if each string can be removed. * We only do this if the non-semantic debug info extension is enabled, otherwise all strings can be trivially removed. * Silence -Winconsistent-missing-override in protobufs
44 lines
1.9 KiB
C
44 lines
1.9 KiB
C
// Copyright (c) 2015-2016 The Khronos Group Inc.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
#ifndef SOURCE_EXT_INST_H_
|
|
#define SOURCE_EXT_INST_H_
|
|
|
|
#include "source/table.h"
|
|
#include "spirv-tools/libspirv.h"
|
|
|
|
// Gets the type of the extended instruction set with the specified name.
|
|
spv_ext_inst_type_t spvExtInstImportTypeGet(const char* name);
|
|
|
|
// Returns true if the extended instruction set is non-semantic
|
|
bool spvExtInstIsNonSemantic(const spv_ext_inst_type_t type);
|
|
|
|
// Finds the named extented instruction of the given type in the given extended
|
|
// instruction table. On success, returns SPV_SUCCESS and writes a handle of
|
|
// the instruction entry into *entry.
|
|
spv_result_t spvExtInstTableNameLookup(const spv_ext_inst_table table,
|
|
const spv_ext_inst_type_t type,
|
|
const char* name,
|
|
spv_ext_inst_desc* entry);
|
|
|
|
// Finds the extented instruction of the given type in the given extended
|
|
// instruction table by value. On success, returns SPV_SUCCESS and writes a
|
|
// handle of the instruction entry into *entry.
|
|
spv_result_t spvExtInstTableValueLookup(const spv_ext_inst_table table,
|
|
const spv_ext_inst_type_t type,
|
|
const uint32_t value,
|
|
spv_ext_inst_desc* pEntry);
|
|
|
|
#endif // SOURCE_EXT_INST_H_
|