diff options
| author | Sai Praveen Bangaru <31557731+saipraveenb25@users.noreply.github.com> | 2025-01-17 17:08:03 -0500 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-01-17 14:08:03 -0800 |
| commit | 3ff257816fc8f376d9bee76378a690757f8b5377 (patch) | |
| tree | 310ad9b184eb14be314254ba5a84919f8a21c502 | |
| parent | f68d493d55eddd03d5eb5faad05c4628a2af2d91 (diff) | |
Fix interface requirement lowering for generic accessors (#6123)
| -rw-r--r-- | source/slang/slang-lower-to-ir.cpp | 10 | ||||
| -rw-r--r-- | tests/autodiff/generic-accessors.slang | 32 |
2 files changed, 42 insertions, 0 deletions
diff --git a/source/slang/slang-lower-to-ir.cpp b/source/slang/slang-lower-to-ir.cpp index 086345719..54540a3f8 100644 --- a/source/slang/slang-lower-to-ir.cpp +++ b/source/slang/slang-lower-to-ir.cpp @@ -8633,6 +8633,9 @@ struct DeclLoweringVisitor : DeclVisitor<DeclLoweringVisitor, LoweredValInfo> UInt operandCount = 0; for (auto requirementDecl : decl->members) { + if (as<GenericDecl>(requirementDecl)) + requirementDecl = getInner(requirementDecl); + if (as<SubscriptDecl>(requirementDecl) || as<PropertyDecl>(requirementDecl)) { for (auto accessorDecl : as<ContainerDecl>(requirementDecl)->members) @@ -8782,6 +8785,13 @@ struct DeclLoweringVisitor : DeclVisitor<DeclLoweringVisitor, LoweredValInfo> auto requirementKey = getInterfaceRequirementKey(requirementDecl); if (!requirementKey) { + if (auto genericDecl = as<GenericDecl>(requirementDecl)) + { + // We need to form a declref into the inner decls in case of a generic + // requirement. + requirementDecl = getInner(genericDecl); + } + if (as<PropertyDecl>(requirementDecl) || as<SubscriptDecl>(requirementDecl)) { for (auto member : as<ContainerDecl>(requirementDecl)->members) diff --git a/tests/autodiff/generic-accessors.slang b/tests/autodiff/generic-accessors.slang new file mode 100644 index 000000000..2b179f256 --- /dev/null +++ b/tests/autodiff/generic-accessors.slang @@ -0,0 +1,32 @@ +//TEST:COMPARE_COMPUTE(filecheck-buffer=CHK): -output-using-type + +interface ITest +{ + __generic<I : IInteger> + __subscript(I i) -> float + { + [BackwardDifferentiable] get; + } +} +struct Test : ITest +{ + __generic<I : IInteger> + __subscript(I i) -> float + { + [BackwardDifferentiable] get { return 5.0f * i.toInt(); } + } +} +[Differentiable] +float test(ITest arg) +{ + return arg[1]; +} +//TEST_INPUT:set output = out ubuffer(data=[0 0 0 0], stride=4) +RWStructuredBuffer<float> output; +[numthreads(1,1,1)] +void computeMain() +{ + Test t = {}; + output[0] = test(t); + // CHK: 5.0 +}
\ No newline at end of file |
