From 9f786fdf71e90339e20979ef3ba8f073657f5a98 Mon Sep 17 00:00:00 2001 From: kaizhangNV <149626564+kaizhangNV@users.noreply.github.com> Date: Fri, 17 May 2024 11:43:08 -0500 Subject: capture/relay: Add capture interface classes (#4177) * capture/relay: Add capture interface classes Add `ModuleCapture` class for capturing `IModule` - The `IModule` can only be created from -- `ISession::loadModule` -- `ISession::loadModuleFromIRBlob` -- `ISession::loadModuleFromSource` -- `ISession::loadModuleFromSourceString` so, we create the `ModuleCapture` at those methods in `SessionCapture` class. We use a hash map to store a map from `IModule` to `ModuleCapture` to avoid creating new `ModuleCapture` when there is already an old one. - In `SessionCapture::getLoadedModule`, we will assert on not finding a `ModuleCapture` instance. Add `EntryPointCapture` class for capturing `IEntryPoint`. - The `IEntryPoint` can only be created from: -- `IModule::findEntryPointByName` -- `IModule::findAndCheckEntryPoint` so, we create the `EntryPointCapture` at those methods in `ModuleCapture`. Similarly, we use a hash map to store a map from `IEntryPoint` to `EntryPointCapture`. - In `IModule::getDefinedEntryPoint`, we will assert on not finding a `EntryPointCapture` instance. Add `CompositeComponentTypeCapture` class for capturing CompositeComponentType, but since user is only exposed to `IComponentType`, so `CompositeComponentTypeCapture` just inherits from `IComponentType`. - `CompositeComponentType` can only be created from: -- ISession::createCompositeComponentType so create it here. Add `TypeConformanceCapture` class for capturing `ITypeConformance`. - The `ITypeConformance` can only be created from: -- `ISession::createTypeConformanceComponentType` so create it here. In addition, because `EntryPointCapture` and `ModuleCapture` share a some base class `IComponentType`, we generate the COM GUID for those two classes to differentiate them. * Fix the build issue * Add nullptr check for output parameter * define the SLANG_CAPTURE_ASSERT macro used in both debug and release build --- source/slang/slang-compiler.h | 17 ++++++++++++++++- source/slang/slang.cpp | 6 ++++++ 2 files changed, 22 insertions(+), 1 deletion(-) (limited to 'source/slang') diff --git a/source/slang/slang-compiler.h b/source/slang/slang-compiler.h index fc97a2f47..770449de7 100755 --- a/source/slang/slang-compiler.h +++ b/source/slang/slang-compiler.h @@ -1335,6 +1335,11 @@ namespace Slang char const* name, slang::IEntryPoint** outEntryPoint) SLANG_OVERRIDE { + if (outEntryPoint == nullptr) + { + return SLANG_E_INVALID_ARG; + } + ComPtr entryPoint(findEntryPointByName(UnownedStringSlice(name))); if((!entryPoint)) return SLANG_FAIL; @@ -1349,6 +1354,11 @@ namespace Slang slang::IEntryPoint** outEntryPoint, ISlangBlob** outDiagnostics) override { + if (outEntryPoint == nullptr) + { + return SLANG_E_INVALID_ARG; + } + ComPtr entryPoint(findAndCheckEntryPoint(UnownedStringSlice(name), stage, outDiagnostics)); if ((!entryPoint)) return SLANG_FAIL; @@ -1367,6 +1377,11 @@ namespace Slang if (index < 0 || index >= m_entryPoints.getCount()) return SLANG_E_INVALID_ARG; + if (outEntryPoint == nullptr) + { + return SLANG_E_INVALID_ARG; + } + ComPtr entryPoint(m_entryPoints[index].Ptr()); *outEntryPoint = entryPoint.detach(); return SLANG_OK; @@ -1541,7 +1556,7 @@ namespace Slang // List of source files this module depends on FileDependencyList m_fileDependencyList; - // Entry points that were defined in thsi module + // Entry points that were defined in this module // // Note: the entry point defined in the module are *not* // part of the memory image/layout of the module when diff --git a/source/slang/slang.cpp b/source/slang/slang.cpp index 4d83823d2..c6af8b34d 100644 --- a/source/slang/slang.cpp +++ b/source/slang/slang.cpp @@ -1266,6 +1266,9 @@ SLANG_NO_THROW SlangResult SLANG_MCALL Linkage::createCompositeComponentType( slang::IComponentType** outCompositeComponentType, ISlangBlob** outDiagnostics) { + if (outCompositeComponentType == nullptr) + return SLANG_E_INVALID_ARG; + SLANG_AST_BUILDER_RAII(getASTBuilder()); // Attempting to create a "composite" of just one component type should @@ -1491,6 +1494,9 @@ SLANG_NO_THROW SlangResult SLANG_MCALL Linkage::createTypeConformanceComponentTy SlangInt conformanceIdOverride, ISlangBlob** outDiagnostics) { + if (outConformanceComponentType == nullptr) + return SLANG_E_INVALID_ARG; + SLANG_AST_BUILDER_RAII(getASTBuilder()); RefPtr result; -- cgit v1.2.3