Mesa (main): v3dv: assert job->cmd_buffer is valid
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Mon Jul 26 07:43:08 UTC 2021
Module: Mesa
Branch: main
Commit: 4eb0475b5a0047e368129550e4c07a450a233a74
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=4eb0475b5a0047e368129550e4c07a450a233a74
Author: Juan A. Suarez Romero <jasuarez at igalia.com>
Date: Wed Jul 21 19:29:49 2021 +0200
v3dv: assert job->cmd_buffer is valid
In v3dv_write_uniforms_wg_offsets() function, the job's cmd_buffer is a
valid command buffer, so there is no reason to check if its NULL or not.
This fixes CID#1487441 ("Dereference after null check") error.
v1:
- `job->cmd_buffer` is the same as `cmd_buffer` (Alejandro)
v2:
- Use `cmd_buffer` instead of `job->cmd_buffer` (Iago)
Fixes: 31a786c80ad ("v3dv: handle QUNIFORM_FB_LAYERS")
Reviewed-by: Iago Toral Quiroga <itoral at igalia.com>
Signed-off-by: Juan A. Suarez Romero <jasuarez at igalia.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/11999>
---
src/broadcom/vulkan/v3dv_uniforms.c | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/src/broadcom/vulkan/v3dv_uniforms.c b/src/broadcom/vulkan/v3dv_uniforms.c
index 7b1f3ed01c2..d97d3b263c1 100644
--- a/src/broadcom/vulkan/v3dv_uniforms.c
+++ b/src/broadcom/vulkan/v3dv_uniforms.c
@@ -401,6 +401,7 @@ v3dv_write_uniforms_wg_offsets(struct v3dv_cmd_buffer *cmd_buffer,
struct v3dv_job *job = cmd_buffer->state.job;
assert(job);
+ assert(job->cmd_buffer == cmd_buffer);
struct texture_bo_list tex_bos = { 0 };
struct state_bo_list state_bos = { 0 };
@@ -510,11 +511,10 @@ v3dv_write_uniforms_wg_offsets(struct v3dv_cmd_buffer *cmd_buffer,
uint32_t num_layers;
if (job->frame_tiling.layers != 0) {
num_layers = job->frame_tiling.layers;
- } else if (job->cmd_buffer &&
- job->cmd_buffer->state.framebuffer) {
- num_layers = job->cmd_buffer->state.framebuffer->layers;
+ } else if (cmd_buffer->state.framebuffer) {
+ num_layers = cmd_buffer->state.framebuffer->layers;
} else {
- assert(job->cmd_buffer->level == VK_COMMAND_BUFFER_LEVEL_SECONDARY);
+ assert(cmd_buffer->level == VK_COMMAND_BUFFER_LEVEL_SECONDARY);
num_layers = 2048;
#if DEBUG
fprintf(stderr, "Skipping gl_LayerID shader sanity check for "
More information about the mesa-commit
mailing list