diff options
| author | T. Foley <tfoleyNV@users.noreply.github.com> | 2021-05-27 13:40:17 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-05-27 13:40:17 -0700 |
| commit | 63dcc7acf4784d95407866730a70f5d37d391b88 (patch) | |
| tree | 58cf716422ba5842a5a06230509a5d83eb370f4f /source/slang/slang-emit.cpp | |
| parent | 15f5cffc3026a5faed7046ae7d75ec6b56cf4a4c (diff) | |
Fix a bug in struct inheritance (#1861)
During lowering from AST to IR, the Slang compiler translates code that uses `struct` inheritance:
```hlsl
struct Base { int a; }
struct Derived : Base {}
```
into code where the inheritance relationship is "witnessed" by a simple field:
```hlsl
struct Base { int a; }
struct Derived { Base __anonymous_field__; }
```
The underlying bug here is that the `__anonymous_field__` that the compiler generated during IR lowering was not being given any linkage decorations (no mangled name). As a result, if multiple separately-compiled modules all access that field they could disagree on its identity as an IR instruction. This could lead to output code being generated where the declaration of `__anonymous_field__` uses one IR instruction, but accesses use another.
This change includes a fix for the issue, and a test that serves as a reproducer for the original problem.
Diffstat (limited to 'source/slang/slang-emit.cpp')
| -rw-r--r-- | source/slang/slang-emit.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/source/slang/slang-emit.cpp b/source/slang/slang-emit.cpp index 74b11079d..16164b957 100644 --- a/source/slang/slang-emit.cpp +++ b/source/slang/slang-emit.cpp @@ -698,6 +698,15 @@ Result linkAndOptimizeIR( // bit_cast on basic types. lowerBitCast(targetRequest, irModule); eliminateDeadCode(irModule); + + + // We include one final step to (optionally) dump the IR and validate + // it after all of the optimization passes are complete. This should + // reflect the IR that code is generated from as closely as possible. + // +#if 0 + dumpIRIfEnabled(compileRequest, irModule, "OPTIMIZED"); +#endif validateIRModuleIfEnabled(compileRequest, irModule); return SLANG_OK; |
