diff options
| author | liamwhite <liamwhite@users.noreply.github.com> | 2022-11-11 08:03:40 -0500 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-11-11 08:03:40 -0500 |
| commit | c973029374a731e13f2de240820c818fa2899c2b (patch) | |
| tree | ab20b418b3c6465e4e9b9503d8d3744f3560ad4b /src/shader_recompiler/backend/spirv/emit_spirv_context_get_set.cpp | |
| parent | 5eb30c7827959075cd240f39c6ab57d2c2a8197e (diff) | |
| parent | a4472b55260ed1ccbad0d191d11abd2330145140 (diff) | |
Merge pull request #9167 from vonchenplus/tess
video_core: Fix few issues in Tess stage
Diffstat (limited to 'src/shader_recompiler/backend/spirv/emit_spirv_context_get_set.cpp')
| -rw-r--r-- | src/shader_recompiler/backend/spirv/emit_spirv_context_get_set.cpp | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/src/shader_recompiler/backend/spirv/emit_spirv_context_get_set.cpp b/src/shader_recompiler/backend/spirv/emit_spirv_context_get_set.cpp index a4751b42d..5b3b5d1f3 100644 --- a/src/shader_recompiler/backend/spirv/emit_spirv_context_get_set.cpp +++ b/src/shader_recompiler/backend/spirv/emit_spirv_context_get_set.cpp @@ -512,6 +512,18 @@ Id EmitInvocationId(EmitContext& ctx) { return ctx.OpLoad(ctx.U32[1], ctx.invocation_id); } +Id EmitInvocationInfo(EmitContext& ctx) { + switch (ctx.stage) { + case Stage::TessellationControl: + case Stage::TessellationEval: + return ctx.OpShiftLeftLogical(ctx.U32[1], ctx.OpLoad(ctx.U32[1], ctx.patch_vertices_in), + ctx.Const(16u)); + default: + LOG_WARNING(Shader, "(STUBBED) called"); + return ctx.Const(0x00ff0000u); + } +} + Id EmitSampleId(EmitContext& ctx) { return ctx.OpLoad(ctx.U32[1], ctx.sample_id); } |
