summaryrefslogtreecommitdiffstats
path: root/source/slang
diff options
context:
space:
mode:
authorkaizhangNV <149626564+kaizhangNV@users.noreply.github.com>2024-07-23 10:45:26 -0500
committerGitHub <noreply@github.com>2024-07-23 08:45:26 -0700
commit986256ffb92ab7c8fc7cf9f2c424919a439a824f (patch)
tree260e37bd439275e3398d16fe238b20cd00d08cb7 /source/slang
parentc28d8b6aec721fa3350fc52647f1572a353f6151 (diff)
Feature/capture (#4625)
* Add decoder * Add a replay executable to consume the decoded content Add file-processor.cpp/h where we implement the logic to process the captured file block by block. Each block is: function header + parameter buffer + function tailer + function output[optional]. After reading one block, the block of data is sent to decoder module to dispatch the corresponding API. Add slang-decoder.cpp/h where we implement the logic to dispatch the slang API according to the input block data. - Rename api_callId.h to capture-format.h - Renmae capture_utility.cpp to capture-utility.cpp - Renmae capture_utility.h to capture-utility.h - Change the #include file name accordingly. * Reorganize source files structure Move all the capture logic code into `capture` directory. - the capture code will be build with slang dll. Move all the replay logic code into `relay` directoy. - the replay code is not part of slang dll, it will be built as a stand alone binary and link against slang dll. Change the #include file names accordingly. Add tools/slang-replay/main.cpp for the slang-replay stand alone binary place holder. Will implement it later. Update premake5.lua accordingly. * Update cmake files Update cmake files to change the build process for capture and relay system. - capture component should be build with slang dll, so we should not include replay component. - replay component should be a separate executable tool, which should not include capture component. - In order to easy use our current cmake infrastructure, move the shared files to a `util` folder - change the header include path * Redesgin the interfaces of consumers Fix some issues in capture Finish implementing all slang-decoder functions * Fix the AppleClang build issue * Address few comments - Fix the weird indent issues. - Correct the function name for CreateGlobalSession() - Rename file-processor to captureFile-processor to be more specific. - Use Slang::List instead of std::vector * record/replay: name refactor change Refactor the naming. Change the name "encoder/capture" to "record".
Diffstat (limited to 'source/slang')
-rw-r--r--source/slang/CMakeLists.txt11
-rw-r--r--source/slang/slang-api.cpp12
2 files changed, 12 insertions, 11 deletions
diff --git a/source/slang/CMakeLists.txt b/source/slang/CMakeLists.txt
index 27019f41a..fd20bbe22 100644
--- a/source/slang/CMakeLists.txt
+++ b/source/slang/CMakeLists.txt
@@ -161,6 +161,11 @@ set(SLANG_LOOKUP_GENERATOR_OUTPUT_DIR
set(SLANG_LOOKUP_GENERATED_SOURCE
"${SLANG_LOOKUP_GENERATOR_OUTPUT_DIR}/slang-lookup-GLSLstd450.cpp"
)
+set(SLANG_RECORD_REPLAY_SYSTEM
+ "${slang_SOURCE_DIR}/source/slang-record-replay/record"
+ "${slang_SOURCE_DIR}/source/slang-record-replay/util"
+)
+
add_custom_command(
OUTPUT ${SLANG_LOOKUP_GENERATED_SOURCE}
COMMAND
@@ -201,10 +206,6 @@ slang_add_target(
FOLDER generated
)
-set(SLANG_CAPTURE_REPLAY_SYSTEM
- "${slang_SOURCE_DIR}/source/slang-capture-replay"
-)
-
#
# Generate an embeddable stdlib
#
@@ -243,7 +244,7 @@ configure_file(${slang_SOURCE_DIR}/slang-tag-version.h.in slang-version-header/s
#
set(slang_common_args
- EXTRA_SOURCE_DIRS ${SLANG_CAPTURE_REPLAY_SYSTEM}
+ EXTRA_SOURCE_DIRS ${SLANG_RECORD_REPLAY_SYSTEM}
USE_EXTRA_WARNINGS
LINK_WITH_PRIVATE
core
diff --git a/source/slang/slang-api.cpp b/source/slang/slang-api.cpp
index 250b9edf3..c4f668fb2 100644
--- a/source/slang/slang-api.cpp
+++ b/source/slang/slang-api.cpp
@@ -5,8 +5,8 @@
#include "slang-repro.h"
#include "../core/slang-shared-library.h"
-#include "../slang-capture-replay/slang-global-session.h"
-#include "../slang-capture-replay/capture_utility.h"
+#include "../slang-record-replay/record/slang-global-session.h"
+#include "../slang-record-replay/util/record-utility.h"
// implementation of C interface
@@ -119,11 +119,11 @@ SLANG_API SlangResult slang_createGlobalSession(
}
// Check if the SLANG_CAPTURE_ENABLE_ENV is enabled
- if (SlangCapture::isCaptureLayerEnabled())
+ if (SlangRecord::isRecordLayerEnabled())
{
- SlangCapture::GlobalSessionCapture* globalSessionCapture =
- new SlangCapture::GlobalSessionCapture(globalSession.detach());
- Slang::ComPtr<SlangCapture::GlobalSessionCapture> result(globalSessionCapture);
+ SlangRecord::GlobalSessionRecorder* globalSessionRecorder =
+ new SlangRecord::GlobalSessionRecorder(globalSession.detach());
+ Slang::ComPtr<SlangRecord::GlobalSessionRecorder> result(globalSessionRecorder);
*outGlobalSession = result.detach();
}
else