SpvTools.h 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. //
  2. // Copyright (C) 2014-2016 LunarG, Inc.
  3. // Copyright (C) 2018 Google, Inc.
  4. //
  5. // All rights reserved.
  6. //
  7. // Redistribution and use in source and binary forms, with or without
  8. // modification, are permitted provided that the following conditions
  9. // are met:
  10. //
  11. // Redistributions of source code must retain the above copyright
  12. // notice, this list of conditions and the following disclaimer.
  13. //
  14. // Redistributions in binary form must reproduce the above
  15. // copyright notice, this list of conditions and the following
  16. // disclaimer in the documentation and/or other materials provided
  17. // with the distribution.
  18. //
  19. // Neither the name of 3Dlabs Inc. Ltd. nor the names of its
  20. // contributors may be used to endorse or promote products derived
  21. // from this software without specific prior written permission.
  22. //
  23. // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  24. // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  25. // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  26. // FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
  27. // COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
  28. // INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
  29. // BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  30. // LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  31. // CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  32. // LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
  33. // ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  34. // POSSIBILITY OF SUCH DAMAGE.
  35. //
  36. // Call into SPIRV-Tools to disassemble, validate, and optimize.
  37. //
  38. #pragma once
  39. #ifndef GLSLANG_SPV_TOOLS_H
  40. #define GLSLANG_SPV_TOOLS_H
  41. #if ENABLE_OPT
  42. #include <vector>
  43. #include <ostream>
  44. #include <unordered_set>
  45. #include "spirv-tools/libspirv.h"
  46. #endif
  47. #include "glslang/MachineIndependent/Versions.h"
  48. #include "glslang/Include/visibility.h"
  49. #include "GlslangToSpv.h"
  50. #include "Logger.h"
  51. namespace glslang {
  52. #if ENABLE_OPT
  53. class TIntermediate;
  54. // Translate glslang's view of target versioning to what SPIRV-Tools uses.
  55. GLSLANG_EXPORT spv_target_env MapToSpirvToolsEnv(const SpvVersion& spvVersion, spv::SpvBuildLogger* logger);
  56. GLSLANG_EXPORT spv_target_env MapToSpirvToolsEnv(const glslang::TIntermediate& intermediate, spv::SpvBuildLogger* logger);
  57. // Use the SPIRV-Tools disassembler to print SPIR-V using a SPV_ENV_UNIVERSAL_1_3 environment.
  58. GLSLANG_EXPORT void SpirvToolsDisassemble(std::ostream& out, const std::vector<unsigned int>& spirv);
  59. // Use the SPIRV-Tools disassembler to print SPIR-V with a provided SPIR-V environment.
  60. GLSLANG_EXPORT void SpirvToolsDisassemble(std::ostream& out, const std::vector<unsigned int>& spirv,
  61. spv_target_env requested_context);
  62. // Apply the SPIRV-Tools validator to generated SPIR-V.
  63. GLSLANG_EXPORT void SpirvToolsValidate(const glslang::TIntermediate& intermediate, std::vector<unsigned int>& spirv,
  64. spv::SpvBuildLogger*, bool prelegalization);
  65. // Apply the SPIRV-Tools optimizer to generated SPIR-V. HLSL SPIR-V is legalized in the process.
  66. GLSLANG_EXPORT void SpirvToolsTransform(const glslang::TIntermediate& intermediate, std::vector<unsigned int>& spirv,
  67. spv::SpvBuildLogger*, const SpvOptions*);
  68. // Apply the SPIRV-Tools EliminateDeadInputComponents pass to generated SPIR-V. Put result in |spirv|.
  69. GLSLANG_EXPORT void SpirvToolsEliminateDeadInputComponents(spv_target_env target_env, std::vector<unsigned int>& spirv,
  70. spv::SpvBuildLogger*);
  71. // Apply the SPIRV-Tools AnalyzeDeadOutputStores pass to generated SPIR-V. Put result in |live_locs|.
  72. // Return true if the result is valid.
  73. GLSLANG_EXPORT bool SpirvToolsAnalyzeDeadOutputStores(spv_target_env target_env, std::vector<unsigned int>& spirv,
  74. std::unordered_set<uint32_t>* live_locs,
  75. std::unordered_set<uint32_t>* live_builtins,
  76. spv::SpvBuildLogger*);
  77. // Apply the SPIRV-Tools EliminateDeadOutputStores and AggressiveDeadCodeElimination passes to generated SPIR-V using
  78. // |live_locs|. Put result in |spirv|.
  79. GLSLANG_EXPORT void SpirvToolsEliminateDeadOutputStores(spv_target_env target_env, std::vector<unsigned int>& spirv,
  80. std::unordered_set<uint32_t>* live_locs,
  81. std::unordered_set<uint32_t>* live_builtins,
  82. spv::SpvBuildLogger*);
  83. // Apply the SPIRV-Tools optimizer to strip debug info from SPIR-V. This is implicitly done by
  84. // SpirvToolsTransform if spvOptions->stripDebugInfo is set, but can be called separately if
  85. // optimization is disabled.
  86. GLSLANG_EXPORT void SpirvToolsStripDebugInfo(const glslang::TIntermediate& intermediate,
  87. std::vector<unsigned int>& spirv, spv::SpvBuildLogger*);
  88. #endif
  89. } // end namespace glslang
  90. #endif // GLSLANG_SPV_TOOLS_H