diff options
author | Bartosz Tomczyk <[email protected]> | 2017-01-30 14:07:45 +0100 |
---|---|---|
committer | Nicolai Hähnle <[email protected]> | 2017-01-30 15:30:03 +0100 |
commit | a41f2527ae8ae5432b99c88863fbdf2f0b5f04ad (patch) | |
tree | 01cedcd5a71253b80ab3963e01abad1dfea3a65f /src/gallium/drivers/r600 | |
parent | e2c15ea0925542bd3557a5b5872a679ebbcefacd (diff) |
r600: Fix stack overflow
Commit 7b5878ee0491e7a93914389a8369cd6752b9757d increased number of
outputs to 64, but left output array intact. This caused stack overflow
when number of outputs is bigger then 32. Found by ASAN.
Cc: "12.0 13.0 17.0" <[email protected]>
Reviewed-by: Nicolai Hähnle <[email protected]>
Diffstat (limited to 'src/gallium/drivers/r600')
-rw-r--r-- | src/gallium/drivers/r600/r600_shader.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/src/gallium/drivers/r600/r600_shader.c b/src/gallium/drivers/r600/r600_shader.c index b692e7f4a17..b80a3f8b629 100644 --- a/src/gallium/drivers/r600/r600_shader.c +++ b/src/gallium/drivers/r600/r600_shader.c @@ -2924,7 +2924,7 @@ static int r600_shader_from_tgsi(struct r600_context *rctx, struct pipe_stream_output_info so = pipeshader->selector->so; struct tgsi_full_immediate *immediate; struct r600_shader_ctx ctx; - struct r600_bytecode_output output[32]; + struct r600_bytecode_output output[ARRAY_SIZE(shader->output)]; unsigned output_done, noutput; unsigned opcode; int i, j, k, r = 0; |