summaryrefslogtreecommitdiff
path: root/source/slang/slang-ir-insts-stable-names.cpp
diff options
context:
space:
mode:
authorEllie Hermaszewska <ellieh@nvidia.com>2025-07-09 14:41:19 +0800
committerGitHub <noreply@github.com>2025-07-09 06:41:19 +0000
commit00746bf09047cdf01c19dac513a532bcf3ed3ea3 (patch)
tree3424872a629307fc9fb4dc04ea5e9a0a787a6523 /source/slang/slang-ir-insts-stable-names.cpp
parent4f54cccf0e0e06be38312e2ee97c2b50b82d7c10 (diff)
Stable names and backwards compat for serialized IR modules (#7644)
* stable names * tests, options and ci for stable names * Add back compat design document * fix warnings * formatting * comment * neaten * regenerate command line reference * consolidate ci scripts * faster ci * remove libreadline * Move new function to end of interface --------- Co-authored-by: slangbot <186143334+slangbot@users.noreply.github.com>
Diffstat (limited to 'source/slang/slang-ir-insts-stable-names.cpp')
-rw-r--r--source/slang/slang-ir-insts-stable-names.cpp61
1 files changed, 61 insertions, 0 deletions
diff --git a/source/slang/slang-ir-insts-stable-names.cpp b/source/slang/slang-ir-insts-stable-names.cpp
new file mode 100644
index 000000000..2ac205faf
--- /dev/null
+++ b/source/slang/slang-ir-insts-stable-names.cpp
@@ -0,0 +1,61 @@
+#include "slang-ir-insts-stable-names.h"
+
+namespace Slang
+{
+
+static const UInt kOpcodeToStableName[] = {
+#if 0 // FIDDLE TEMPLATE:
+% local insts = require("source/slang/slang-ir-insts.lua")
+% insts.traverse(function(inst)
+% if inst.is_leaf then
+% if inst.stable_name == nil then
+% error("Instruction is missing stable name: " .. tostring(inst.struct_name))
+% end
+% local stable_name = tostring(inst.stable_name)
+ $stable_name,
+% end
+% end)
+#else // FIDDLE OUTPUT:
+#define FIDDLE_GENERATED_OUTPUT_ID 0
+#include "slang-ir-insts-stable-names.cpp.fiddle"
+#endif // FIDDLE END
+};
+
+static const IROp kStableNameToOpcode[] = {
+#if 0 // FIDDLE TEMPLATE:
+% local insts = require("source/slang/slang-ir-insts.lua")
+% for i = 0, insts.max_stable_name do
+% inst = insts.stable_name_to_inst[i]
+% if inst then
+% local struct_name = inst.struct_name
+ kIROp_$struct_name,
+% else
+ kIROp_Invalid,
+% end
+% end
+#else // FIDDLE OUTPUT:
+#define FIDDLE_GENERATED_OUTPUT_ID 1
+#include "slang-ir-insts-stable-names.cpp.fiddle"
+#endif // FIDDLE END
+};
+
+UInt getOpcodeStableName(IROp op)
+{
+ // Check if the opcode is within valid range
+ if (op >= SLANG_COUNT_OF(kOpcodeToStableName))
+ {
+ return kInvalidStableName;
+ }
+ return kOpcodeToStableName[op];
+}
+
+IROp getStableNameOpcode(UInt stableName)
+{
+ // Check if the stable name is within valid range
+ if (stableName >= SLANG_COUNT_OF(kStableNameToOpcode))
+ {
+ return kIROp_Invalid;
+ }
+ return kStableNameToOpcode[stableName];
+}
+} // namespace Slang