SpirvModule.cpp 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. //===--- SpirvModule.cpp - SPIR-V Module Implementation ----------*- C++ -*-==//
  2. //
  3. // The LLVM Compiler Infrastructure
  4. //
  5. // This file is distributed under the University of Illinois Open Source
  6. // License. See LICENSE.TXT for details.
  7. //
  8. //===----------------------------------------------------------------------===//
  9. #include "clang/SPIRV/SpirvModule.h"
  10. #include "clang/SPIRV/SpirvVisitor.h"
  11. namespace clang {
  12. namespace spirv {
  13. SpirvModule::SpirvModule()
  14. : capabilities({}), extensions({}), extInstSets({}), memoryModel(nullptr),
  15. entryPoints({}), executionModes({}), debugSource(nullptr),
  16. moduleProcesses({}), decorations({}), constants({}), variables({}),
  17. functions({}) {}
  18. bool SpirvModule::invokeVisitor(Visitor *visitor) {
  19. if (!visitor->visit(this, Visitor::Phase::Init))
  20. return false;
  21. for (auto *cap : capabilities)
  22. if (!cap->invokeVisitor(visitor))
  23. return false;
  24. for (auto ext : extensions)
  25. if (!ext->invokeVisitor(visitor))
  26. return false;
  27. for (auto extInstSet : extInstSets)
  28. if (!extInstSet->invokeVisitor(visitor))
  29. return false;
  30. if (!memoryModel->invokeVisitor(visitor))
  31. return false;
  32. for (auto entryPoint : entryPoints)
  33. if (!entryPoint->invokeVisitor(visitor))
  34. return false;
  35. for (auto execMode : executionModes)
  36. if (!execMode->invokeVisitor(visitor))
  37. return false;
  38. if (debugSource)
  39. if (!debugSource->invokeVisitor(visitor))
  40. return false;
  41. for (auto moduleProcess : moduleProcesses)
  42. if (!moduleProcess->invokeVisitor(visitor))
  43. return false;
  44. for (auto decoration : decorations)
  45. if (!decoration->invokeVisitor(visitor))
  46. return false;
  47. for (auto constant : constants)
  48. constant->invokeVisitor(visitor);
  49. for (auto var : variables)
  50. if (!var->invokeVisitor(visitor))
  51. return false;
  52. for (auto fn : functions)
  53. if (!fn->invokeVisitor(visitor))
  54. return false;
  55. if (!visitor->visit(this, Visitor::Phase::Done))
  56. return false;
  57. return true;
  58. }
  59. void SpirvModule::addFunction(SpirvFunction *fn) {
  60. assert(fn && "cannot add null function to the module");
  61. functions.insert(fn);
  62. }
  63. void SpirvModule::addCapability(SpirvCapability *cap) {
  64. assert(cap && "cannot add null capability to the module");
  65. capabilities.push_back(cap);
  66. }
  67. void SpirvModule::setMemoryModel(SpirvMemoryModel *model) {
  68. assert(model && "cannot set a null memory model");
  69. memoryModel = model;
  70. }
  71. void SpirvModule::addEntryPoint(SpirvEntryPoint *ep) {
  72. assert(ep && "cannot add null as an entry point");
  73. entryPoints.push_back(ep);
  74. }
  75. void SpirvModule::addExecutionMode(SpirvExecutionMode *em) {
  76. assert(em && "cannot add null execution mode");
  77. executionModes.push_back(em);
  78. }
  79. void SpirvModule::addExtension(SpirvExtension *ext) {
  80. assert(ext && "cannot add null extension");
  81. extensions.push_back(ext);
  82. }
  83. void SpirvModule::addExtInstSet(SpirvExtInstImport *set) {
  84. assert(set && "cannot add null extended instruction set");
  85. extInstSets.push_back(set);
  86. }
  87. SpirvExtInstImport *SpirvModule::getGLSLExtInstSet() {
  88. // We expect very few (usually 1) extended instruction sets to exist in the
  89. // module, so this is not expensive.
  90. auto found =
  91. std::find_if(extInstSets.begin(), extInstSets.end(),
  92. [](const SpirvExtInstImport *set) {
  93. return set->getExtendedInstSetName() == "GLSL.std.450";
  94. });
  95. if (found != extInstSets.end())
  96. return *found;
  97. return nullptr;
  98. }
  99. void SpirvModule::addVariable(SpirvVariable *var) {
  100. assert(var && "cannot add null variable to the module");
  101. variables.push_back(var);
  102. }
  103. void SpirvModule::addDecoration(SpirvDecoration *decor) {
  104. assert(decor && "cannot add null decoration to the module");
  105. decorations.push_back(decor);
  106. }
  107. void SpirvModule::addConstant(SpirvConstant *constant) {
  108. assert(constant);
  109. constants.push_back(constant);
  110. }
  111. void SpirvModule::addDebugSource(SpirvSource *src) {
  112. assert(src);
  113. debugSource = src;
  114. }
  115. void SpirvModule::addModuleProcessed(SpirvModuleProcessed *p) {
  116. assert(p);
  117. moduleProcesses.push_back(p);
  118. }
  119. } // end namespace spirv
  120. } // end namespace clang