diff options
| author | jsmall-nvidia <jsmall@nvidia.com> | 2018-10-09 15:09:32 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-10-09 15:09:32 -0400 |
| commit | 60a91d63afab47a172690974c8b566af74072932 (patch) | |
| tree | a5d2d3592618deecbf55f91cca8824600fb12036 /source/slang/slang.cpp | |
| parent | 7ea9ff03f4fc766f21d5896aea220d17f236dd70 (diff) | |
Added -serial-ir command line option (#664)
* Added -serial-ir option, to make generateIR always serialize in and out before further processing. Testing out serialization, and adding a kind of 'firewall' between compiler front end and backend.
* Reduce peak memory usage, by discarding IR when stored in serialized form.
Typo fix.
Diffstat (limited to 'source/slang/slang.cpp')
| -rw-r--r-- | source/slang/slang.cpp | 28 |
1 files changed, 27 insertions, 1 deletions
diff --git a/source/slang/slang.cpp b/source/slang/slang.cpp index 7c06a11e7..e3b675cd7 100644 --- a/source/slang/slang.cpp +++ b/source/slang/slang.cpp @@ -9,6 +9,8 @@ #include "syntax-visitors.h" #include "../slang/type-layout.h" +#include "ir-serialize.h" + // Used to print exception type names in internal-compiler-error messages #include <typeinfo> @@ -484,7 +486,31 @@ void CompileRequest::generateIR() // in isolation. for( auto& translationUnit : translationUnits ) { - translationUnit->irModule = generateIRForTranslationUnit(translationUnit); + if (useSerialIRBottleneck) + { + IRSerialData serialData; + { + /// Generate IR for translation unit + RefPtr<IRModule> irModule(generateIRForTranslationUnit(translationUnit)); + + // Write IR out to serialData - copying over SourceLoc information directly + IRSerialWriter writer; + writer.write(irModule, sourceManager, IRSerialWriter::OptionFlag::RawSourceLocation, &serialData); + } + RefPtr<IRModule> irReadModule; + { + // Read IR back from serialData + IRSerialReader reader; + reader.read(serialData, mSession, irReadModule); + } + + // Use the serialized irModule + translationUnit->irModule = irReadModule; + } + else + { + translationUnit->irModule = generateIRForTranslationUnit(translationUnit); + } } } |
