From e49419b0637a357d2e713a0435f0c5ad0c102487 Mon Sep 17 00:00:00 2001 From: ArielG-NV <159081215+ArielG-NV@users.noreply.github.com> Date: Fri, 28 Jun 2024 04:07:12 -0400 Subject: Implement HLSL resource bindings and default type `float4` to `SubpassInput` (#4462) * Add case to `emitVectorReshape` for `vector<>` type, `scalar` value 1. Add new case 2. Add test * fix warning * fix warning * Implement HLSL resource bindings and default type `float4` to `SubpassInput` fixes: #4440 1. Removed GLSLInputAttachmentIndexLayout modifier and the somewhat 'hacky' binding model 'Input Attachment' previously relied upon. This was changed to work with the slang-type-layout rules system. This change allows Slang automatic bindings, HLSL bindings, GLSL bindings, and translation of GLSL to and from HLSL bindings to work. 2. Added default argument `float4` to SubpassInput. 3. Merged glsl.meta and hlsl.meta SubpassInput logic. * fix InputAttachment attribute checks fix InputAttachment attribute checks for HLSL and GLSL syntax * remove unused var * validate attribute correctly Attributes do not have type information. We must check the type expression to validate attribute usage. * remove hacky validation type based validation before types are fully resolved is quite hacky and unstable to changes and wrapped types * fix warning * remove redundant `!= nullptr` * remove extra `!= nullptr` * fix some warnings/errors * subpass capability to limit to dxc & remove default values in some functions * revert logic to previous logic revert logic to return if we have a binding regardless of if a VarDecl is given the binding --- .../input-attachment-index-use-error.slang | 11 -------- .../subpass-input/subpass-input-hlsl.slang | 32 ++++++++++++++++++++++ 2 files changed, 32 insertions(+), 11 deletions(-) delete mode 100644 tests/glsl-intrinsic/subpass-input/input-attachment-index-use-error.slang create mode 100644 tests/glsl-intrinsic/subpass-input/subpass-input-hlsl.slang (limited to 'tests') diff --git a/tests/glsl-intrinsic/subpass-input/input-attachment-index-use-error.slang b/tests/glsl-intrinsic/subpass-input/input-attachment-index-use-error.slang deleted file mode 100644 index 889a4e205..000000000 --- a/tests/glsl-intrinsic/subpass-input/input-attachment-index-use-error.slang +++ /dev/null @@ -1,11 +0,0 @@ -//TEST:SIMPLE(filecheck=CHECK): -target glsl -stage fragment -entry main -allow-glsl -#version 450 - -// CHECK: error 31207 -layout (input_attachment_index = 1, set = 0, binding = 1) uniform vec3 image; - -layout (location = 0) out vec4 outColor; - -void main() { - outColor = vec4(0); -} \ No newline at end of file diff --git a/tests/glsl-intrinsic/subpass-input/subpass-input-hlsl.slang b/tests/glsl-intrinsic/subpass-input/subpass-input-hlsl.slang new file mode 100644 index 000000000..0b8e4896f --- /dev/null +++ b/tests/glsl-intrinsic/subpass-input/subpass-input-hlsl.slang @@ -0,0 +1,32 @@ +//TEST:SIMPLE(filecheck=CHECK_GLSL): -target glsl -stage fragment -entry main -allow-glsl +//TEST:SIMPLE(filecheck=CHECK_SPV): -target spirv -emit-spirv-directly -stage fragment -entry main -allow-glsl +//TEST:SIMPLE(filecheck=CHECK_HLSL): -target hlsl -stage fragment -entry main -allow-glsl + +// CHECK_SPV-DAG: OpEntryPoint +// CHECK_SPV-DAG: InputAttachmentIndex 3 +// CHECK_SPV-DAG: InputAttachmentIndex + +// CHECK_GLSL-DAG: void main() +// CHECK_GLSL-DAG: input_attachment_index = 3 +// CHECK_GLSL-DAG: input_attachment_index + +// CHECK_HLSL-DAG: main() +// CHECK_HLSL-DAG: [vk::input_attachment_index(3)] +// CHECK_HLSL-DAG: vk::input_attachment_index +[[vk::input_attachment_index(3)]] SubpassInput subpassHLSL1; +SubpassInput subpassHLSL2; + +RWTexture2D t; + +layout (location = 0) out vec4 outColor; + +void main() { +// CHECK_SPV-COUNT-2: OpImageRead +// CHECK_GLSL-COUNT-2: subpassLoad +// CHECK_HLSL-COUNT-2: SubpassLoad + outColor = vec4(true + && subpassHLSL1.SubpassLoad() == vec4(1) + && subpassHLSL2.SubpassLoad() == vec4(1) + && t.Load(int2(0,0)) != float4(0,0,0,0) + ); +} \ No newline at end of file -- cgit v1.2.3