mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
drm/amd/display: Limit array index according to architecture
[WHY & HOW] ctx->architecture determine array sizes of ODMMode and DPPPerSurface arrays to __DML2_WRAPPER_MAX_STREAMS_PLANES__ or __DML_NUM_PLANES__, and these array index should be checked before used This fixes 2 OVERRUN issues reported by Coverity. Reviewed-by: Harry Wentland <harry.wentland@amd.com> Acked-by: Tom Chung <chiahsuan.chung@amd.com> Signed-off-by: Alex Hung <alex.hung@amd.com> Tested-by: Daniel Wheeler <daniel.wheeler@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
ae13c8a5cf
commit
55ec7679e6
@ -1031,6 +1031,7 @@ bool dml2_map_dc_pipes(struct dml2_context *ctx, struct dc_state *state, const s
|
|||||||
|
|
||||||
unsigned int stream_disp_cfg_index;
|
unsigned int stream_disp_cfg_index;
|
||||||
unsigned int plane_disp_cfg_index;
|
unsigned int plane_disp_cfg_index;
|
||||||
|
unsigned int disp_cfg_index_max;
|
||||||
|
|
||||||
unsigned int plane_id;
|
unsigned int plane_id;
|
||||||
unsigned int stream_id;
|
unsigned int stream_id;
|
||||||
@ -1060,6 +1061,7 @@ bool dml2_map_dc_pipes(struct dml2_context *ctx, struct dc_state *state, const s
|
|||||||
} else {
|
} else {
|
||||||
ODMMode = (unsigned int *)disp_cfg->hw.ODMMode;
|
ODMMode = (unsigned int *)disp_cfg->hw.ODMMode;
|
||||||
DPPPerSurface = disp_cfg->hw.DPPPerSurface;
|
DPPPerSurface = disp_cfg->hw.DPPPerSurface;
|
||||||
|
disp_cfg_index_max = __DML_NUM_PLANES__;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (stream_index = 0; stream_index < state->stream_count; stream_index++) {
|
for (stream_index = 0; stream_index < state->stream_count; stream_index++) {
|
||||||
@ -1067,6 +1069,8 @@ bool dml2_map_dc_pipes(struct dml2_context *ctx, struct dc_state *state, const s
|
|||||||
|
|
||||||
stream_id = state->streams[stream_index]->stream_id;
|
stream_id = state->streams[stream_index]->stream_id;
|
||||||
stream_disp_cfg_index = find_disp_cfg_idx_by_stream_id(mapping, stream_id);
|
stream_disp_cfg_index = find_disp_cfg_idx_by_stream_id(mapping, stream_id);
|
||||||
|
if (stream_disp_cfg_index >= disp_cfg_index_max)
|
||||||
|
continue;
|
||||||
|
|
||||||
if (ODMMode[stream_disp_cfg_index] == dml_odm_mode_bypass) {
|
if (ODMMode[stream_disp_cfg_index] == dml_odm_mode_bypass) {
|
||||||
scratch.odm_info.odm_factor = 1;
|
scratch.odm_info.odm_factor = 1;
|
||||||
@ -1110,7 +1114,7 @@ bool dml2_map_dc_pipes(struct dml2_context *ctx, struct dc_state *state, const s
|
|||||||
|
|
||||||
// Setup mpc_info for this plane
|
// Setup mpc_info for this plane
|
||||||
scratch.mpc_info.prev_odm_pipe = NULL;
|
scratch.mpc_info.prev_odm_pipe = NULL;
|
||||||
if (scratch.odm_info.odm_factor == 1) {
|
if (scratch.odm_info.odm_factor == 1 && plane_disp_cfg_index < disp_cfg_index_max) {
|
||||||
// If ODM combine is not inuse, then the number of pipes
|
// If ODM combine is not inuse, then the number of pipes
|
||||||
// per plane is determined by MPC combine factor
|
// per plane is determined by MPC combine factor
|
||||||
scratch.mpc_info.mpc_factor = DPPPerSurface[plane_disp_cfg_index];
|
scratch.mpc_info.mpc_factor = DPPPerSurface[plane_disp_cfg_index];
|
||||||
|
Loading…
Reference in New Issue
Block a user