Commit 55595987 authored by Alex Hung's avatar Alex Hung Committed by Alex Deucher

drm/amd/display: Pass non-null to dcn20_validate_apply_pipe_split_flags

[WHAT & HOW]
"dcn20_validate_apply_pipe_split_flags" dereferences merge, and thus it
cannot be a null pointer. Let's pass a valid pointer to avoid null
dereference.

This fixes 2 FORWARD_NULL issues reported by Coverity.
Reviewed-by: default avatarRodrigo Siqueira <rodrigo.siqueira@amd.com>
Signed-off-by: default avatarJerry Zuo <jerry.zuo@amd.com>
Signed-off-by: default avatarAlex Hung <alex.hung@amd.com>
Tested-by: default avatarDaniel Wheeler <daniel.wheeler@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 3718a619
...@@ -2040,6 +2040,7 @@ bool dcn20_fast_validate_bw( ...@@ -2040,6 +2040,7 @@ bool dcn20_fast_validate_bw(
{ {
bool out = false; bool out = false;
int split[MAX_PIPES] = { 0 }; int split[MAX_PIPES] = { 0 };
bool merge[MAX_PIPES] = { false };
int pipe_cnt, i, pipe_idx, vlevel; int pipe_cnt, i, pipe_idx, vlevel;
ASSERT(pipes); ASSERT(pipes);
...@@ -2064,7 +2065,7 @@ bool dcn20_fast_validate_bw( ...@@ -2064,7 +2065,7 @@ bool dcn20_fast_validate_bw(
if (vlevel > context->bw_ctx.dml.soc.num_states) if (vlevel > context->bw_ctx.dml.soc.num_states)
goto validate_fail; goto validate_fail;
vlevel = dcn20_validate_apply_pipe_split_flags(dc, context, vlevel, split, NULL); vlevel = dcn20_validate_apply_pipe_split_flags(dc, context, vlevel, split, merge);
/*initialize pipe_just_split_from to invalid idx*/ /*initialize pipe_just_split_from to invalid idx*/
for (i = 0; i < MAX_PIPES; i++) for (i = 0; i < MAX_PIPES; i++)
......
...@@ -774,6 +774,7 @@ bool dcn21_fast_validate_bw(struct dc *dc, ...@@ -774,6 +774,7 @@ bool dcn21_fast_validate_bw(struct dc *dc,
{ {
bool out = false; bool out = false;
int split[MAX_PIPES] = { 0 }; int split[MAX_PIPES] = { 0 };
bool merge[MAX_PIPES] = { false };
int pipe_cnt, i, pipe_idx, vlevel; int pipe_cnt, i, pipe_idx, vlevel;
ASSERT(pipes); ASSERT(pipes);
...@@ -816,7 +817,7 @@ bool dcn21_fast_validate_bw(struct dc *dc, ...@@ -816,7 +817,7 @@ bool dcn21_fast_validate_bw(struct dc *dc,
goto validate_fail; goto validate_fail;
} }
vlevel = dcn20_validate_apply_pipe_split_flags(dc, context, vlevel, split, NULL); vlevel = dcn20_validate_apply_pipe_split_flags(dc, context, vlevel, split, merge);
for (i = 0, pipe_idx = 0; i < dc->res_pool->pipe_count; i++) { for (i = 0, pipe_idx = 0; i < dc->res_pool->pipe_count; i++) {
struct pipe_ctx *pipe = &context->res_ctx.pipe_ctx[i]; struct pipe_ctx *pipe = &context->res_ctx.pipe_ctx[i];
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment