diff options
author | Nicolai Hähnle <[email protected]> | 2016-11-21 10:36:50 +0100 |
---|---|---|
committer | Nicolai Hähnle <[email protected]> | 2016-11-30 09:09:59 +0100 |
commit | 0a58b258caf67aa85c49bb4160b48a61b535e2be (patch) | |
tree | 43be04d742426e57f2a5c4c03e90f48971a4a5d3 /src/mesa/state_tracker | |
parent | 611166b8ed08ce39f835385b8e08e37754edcf7b (diff) |
st/glsl_to_tgsi: swizzle PROGRAM_OUTPUTs correctly in src_register translation
This is required for reading directly from fragment shader stencil and depth
outputs.
Reviewed-by: Marek Olšák <[email protected]>
Diffstat (limited to 'src/mesa/state_tracker')
-rw-r--r-- | src/mesa/state_tracker/st_glsl_to_tgsi.cpp | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/src/mesa/state_tracker/st_glsl_to_tgsi.cpp b/src/mesa/state_tracker/st_glsl_to_tgsi.cpp index 978dc46401b..8a247ea68d7 100644 --- a/src/mesa/state_tracker/st_glsl_to_tgsi.cpp +++ b/src/mesa/state_tracker/st_glsl_to_tgsi.cpp @@ -5383,9 +5383,19 @@ src_register(struct st_translate *t, const st_src_reg *reg) case PROGRAM_TEMPORARY: case PROGRAM_ARRAY: - case PROGRAM_OUTPUT: return ureg_src(dst_register(t, reg->file, reg->index, reg->array_id)); + case PROGRAM_OUTPUT: { + struct ureg_dst dst = dst_register(t, reg->file, reg->index, reg->array_id); + assert(dst.WriteMask != 0); + unsigned shift = ffs(dst.WriteMask) - 1; + return ureg_swizzle(ureg_src(dst), + shift, + MIN2(shift + 1, 3), + MIN2(shift + 2, 3), + MIN2(shift + 3, 3)); + } + case PROGRAM_UNIFORM: assert(reg->index >= 0); return reg->index < t->num_constants ? |