summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYong He <yonghe@outlook.com>2025-01-28 01:30:08 -0800
committerGitHub <noreply@github.com>2025-01-28 01:30:08 -0800
commit4b9a34249d560a86d1333420f6cd06f6fe502c9d (patch)
tree4fe93071aaf3468812b226af690b0341bec2a4d3
parentcd27fbd1d3822f6da4d539ad467b9af2ad159526 (diff)
Fix geometry shader related modifier lowering. (#6197)
* Fix geometry shader related modifier lowering. * Cleanup. * Delete obselete test. * Enable geometryShader test on windows only. * Fix test.
-rw-r--r--source/slang/slang-lower-to-ir.cpp68
-rw-r--r--tools/slang-unit-test/unit-test-geometry-shader.cpp93
2 files changed, 117 insertions, 44 deletions
diff --git a/source/slang/slang-lower-to-ir.cpp b/source/slang/slang-lower-to-ir.cpp
index 7281b55be..76b8e38e9 100644
--- a/source/slang/slang-lower-to-ir.cpp
+++ b/source/slang/slang-lower-to-ir.cpp
@@ -2333,6 +2333,30 @@ void addVarDecorations(IRGenContext* context, IRInst* inst, Decl* decl)
inst,
IRIntegerValue(collection->getMemoryQualifierBit()));
}
+ else if (auto geometryModifier = as<HLSLGeometryShaderInputPrimitiveTypeModifier>(mod))
+ {
+ IROp op = kIROp_Invalid;
+ switch (geometryModifier->astNodeType)
+ {
+ case ASTNodeType::HLSLTriangleModifier:
+ op = kIROp_TriangleInputPrimitiveTypeDecoration;
+ break;
+ case ASTNodeType::HLSLPointModifier:
+ op = kIROp_PointInputPrimitiveTypeDecoration;
+ break;
+ case ASTNodeType::HLSLLineModifier:
+ op = kIROp_LineInputPrimitiveTypeDecoration;
+ break;
+ case ASTNodeType::HLSLLineAdjModifier:
+ op = kIROp_LineAdjInputPrimitiveTypeDecoration;
+ break;
+ case ASTNodeType::HLSLTriangleAdjModifier:
+ op = kIROp_TriangleAdjInputPrimitiveTypeDecoration;
+ break;
+ }
+ if (op != kIROp_Invalid)
+ builder->addDecoration(inst, op);
+ }
// TODO: what are other modifiers we need to propagate through?
}
if (auto t =
@@ -11180,50 +11204,6 @@ static void lowerFrontEndEntryPointToIR(
entryPointName->text.getUnownedSlice(),
moduleName.getUnownedSlice());
}
-
- // Go through the entry point parameters creating decorations from layout as appropriate
- // But only if this is a definition not a declaration
- if (isDefinition(instToDecorate))
- {
- FilteredMemberList<ParamDecl> params = entryPointFuncDecl->getParameters();
-
- IRGlobalValueWithParams* valueWithParams = as<IRGlobalValueWithParams>(instToDecorate);
- if (valueWithParams)
- {
- IRParam* irParam = valueWithParams->getFirstParam();
-
- for (auto param : params)
- {
- if (auto modifier =
- param->findModifier<HLSLGeometryShaderInputPrimitiveTypeModifier>())
- {
- IROp op = kIROp_Invalid;
-
- if (as<HLSLTriangleModifier>(modifier))
- op = kIROp_TriangleInputPrimitiveTypeDecoration;
- else if (as<HLSLPointModifier>(modifier))
- op = kIROp_PointInputPrimitiveTypeDecoration;
- else if (as<HLSLLineModifier>(modifier))
- op = kIROp_LineInputPrimitiveTypeDecoration;
- else if (as<HLSLLineAdjModifier>(modifier))
- op = kIROp_LineAdjInputPrimitiveTypeDecoration;
- else if (as<HLSLTriangleAdjModifier>(modifier))
- op = kIROp_TriangleAdjInputPrimitiveTypeDecoration;
-
- if (op != kIROp_Invalid)
- {
- builder->addDecoration(irParam, op);
- }
- else
- {
- SLANG_UNEXPECTED("unhandled primitive type");
- }
- }
-
- irParam = irParam->getNextParam();
- }
- }
- }
}
static void lowerProgramEntryPointToIR(
diff --git a/tools/slang-unit-test/unit-test-geometry-shader.cpp b/tools/slang-unit-test/unit-test-geometry-shader.cpp
new file mode 100644
index 000000000..e1126673e
--- /dev/null
+++ b/tools/slang-unit-test/unit-test-geometry-shader.cpp
@@ -0,0 +1,93 @@
+// unit-test-geometry-shader.cpp
+
+#include "../../source/core/slang-io.h"
+#include "../../source/core/slang-process.h"
+#include "slang-com-ptr.h"
+#include "slang.h"
+#include "unit-test/slang-unit-test.h"
+
+#include <stdio.h>
+#include <stdlib.h>
+
+using namespace Slang;
+
+// Test the compilation API for compiling geometry shaders to DXIL.
+
+#if SLANG_WINDOWS_FAMILY
+
+SLANG_UNIT_TEST(geometryShader)
+{
+ const char* userSourceBody = R"(
+ struct GS_INPUT
+ {
+ float4 PosSS : TEXTURE0; // [Screen Space] Position
+ };
+
+ struct PS_INPUT
+ {
+ float4 PosSS : SV_POSITION; // [Screen Space] Position
+ };
+
+ [maxvertexcount(3)]
+ void main(triangle GS_INPUT input[3], inout TriangleStream<PS_INPUT> outStream)
+ {
+ PS_INPUT output;
+
+ output.PosSS = input[0].PosSS;
+ outStream.Append(output);
+
+ output.PosSS = input[1].PosSS;
+ outStream.Append(output);
+
+ output.PosSS = input[2].PosSS;
+ outStream.Append(output);
+
+ outStream.RestartStrip();
+ }
+ )";
+ ComPtr<slang::IGlobalSession> globalSession;
+ SlangGlobalSessionDesc globalDesc = {};
+ globalDesc.enableGLSL = true;
+ SLANG_CHECK(slang_createGlobalSession2(&globalDesc, globalSession.writeRef()) == SLANG_OK);
+ slang::TargetDesc targetDesc = {};
+ targetDesc.format = SLANG_DXIL;
+ targetDesc.profile = globalSession->findProfile("sm_6_0");
+ slang::SessionDesc sessionDesc = {};
+ sessionDesc.targetCount = 1;
+ sessionDesc.targets = &targetDesc;
+ ComPtr<slang::ISession> session;
+ SLANG_CHECK(globalSession->createSession(sessionDesc, session.writeRef()) == SLANG_OK);
+
+ ComPtr<slang::IBlob> diagnosticBlob;
+ auto module = session->loadModuleFromSourceString(
+ "m",
+ "m.slang",
+ userSourceBody,
+ diagnosticBlob.writeRef());
+ SLANG_CHECK(module != nullptr);
+
+ ComPtr<slang::IEntryPoint> entryPoint;
+ module->findAndCheckEntryPoint(
+ "main",
+ SLANG_STAGE_GEOMETRY,
+ entryPoint.writeRef(),
+ diagnosticBlob.writeRef());
+
+ slang::IComponentType* componentTypes[2] = {module, entryPoint.get()};
+ ComPtr<slang::IComponentType> composedProgram;
+ session->createCompositeComponentType(
+ componentTypes,
+ 2,
+ composedProgram.writeRef(),
+ diagnosticBlob.writeRef());
+
+ ComPtr<slang::IComponentType> linkedProgram;
+ composedProgram->link(linkedProgram.writeRef(), diagnosticBlob.writeRef());
+
+ ComPtr<slang::IBlob> code;
+ linkedProgram->getEntryPointCode(0, 0, code.writeRef(), diagnosticBlob.writeRef());
+
+ SLANG_CHECK(code != nullptr);
+}
+
+#endif