drm/amd/display: DML changes for DCN32/321
DML is required for display configuration modelling for things like bandwidth management and validation. Signed-off-by: Aurabindo Pillai <aurabindo.pillai@amd.com> Acked-by: Alex Deucher <alexander.deucher@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
58efeea32d
commit
dda4fb85e4
@ -72,6 +72,9 @@ CFLAGS_$(AMDDALPATH)/dc/dml/dcn30/display_rq_dlg_calc_30.o := $(dml_ccflags)
|
||||
CFLAGS_$(AMDDALPATH)/dc/dml/dcn31/display_mode_vba_31.o := $(dml_ccflags) $(frame_warn_flag)
|
||||
CFLAGS_$(AMDDALPATH)/dc/dml/dcn31/display_rq_dlg_calc_31.o := $(dml_ccflags)
|
||||
CFLAGS_$(AMDDALPATH)/dc/dml/dcn30/dcn30_fpu.o := $(dml_ccflags)
|
||||
CFLAGS_$(AMDDALPATH)/dc/dml/dcn32/display_mode_vba_32.o := $(dml_ccflags) $(frame_warn_flag)
|
||||
CFLAGS_$(AMDDALPATH)/dc/dml/dcn32/display_rq_dlg_calc_32.o := $(dml_ccflags)
|
||||
CFLAGS_$(AMDDALPATH)/dc/dml/dcn32/display_mode_vba_util_32.o := $(dml_ccflags)
|
||||
CFLAGS_$(AMDDALPATH)/dc/dml/dcn31/dcn31_fpu.o := $(dml_ccflags)
|
||||
CFLAGS_$(AMDDALPATH)/dc/dml/dcn301/dcn301_fpu.o := $(dml_ccflags)
|
||||
CFLAGS_$(AMDDALPATH)/dc/dml/dcn302/dcn302_fpu.o := $(dml_ccflags)
|
||||
@ -93,6 +96,9 @@ CFLAGS_REMOVE_$(AMDDALPATH)/dc/dml/dcn30/display_mode_vba_30.o := $(dml_rcflags)
|
||||
CFLAGS_REMOVE_$(AMDDALPATH)/dc/dml/dcn30/display_rq_dlg_calc_30.o := $(dml_rcflags)
|
||||
CFLAGS_REMOVE_$(AMDDALPATH)/dc/dml/dcn31/display_mode_vba_31.o := $(dml_rcflags)
|
||||
CFLAGS_REMOVE_$(AMDDALPATH)/dc/dml/dcn31/display_rq_dlg_calc_31.o := $(dml_rcflags)
|
||||
CFLAGS_REMOVE_$(AMDDALPATH)/dc/dml/dcn32/display_mode_vba_32.o := $(dml_rcflags)
|
||||
CFLAGS_REMOVE_$(AMDDALPATH)/dc/dml/dcn32/display_rq_dlg_calc_32.o := $(dml_rcflags)
|
||||
CFLAGS_REMOVE_$(AMDDALPATH)/dc/dml/dcn32/display_mode_vba_util_32.o := $(dml_rcflags)
|
||||
CFLAGS_REMOVE_$(AMDDALPATH)/dc/dml/dcn301/dcn301_fpu.o := $(dml_rcflags)
|
||||
CFLAGS_REMOVE_$(AMDDALPATH)/dc/dml/display_mode_lib.o := $(dml_rcflags)
|
||||
CFLAGS_REMOVE_$(AMDDALPATH)/dc/dml/dsc/rc_calc_fpu.o := $(dml_rcflags)
|
||||
@ -116,6 +122,7 @@ DML += dcn20/display_rq_dlg_calc_20v2.o dcn20/display_mode_vba_20v2.o
|
||||
DML += dcn21/display_rq_dlg_calc_21.o dcn21/display_mode_vba_21.o
|
||||
DML += dcn30/dcn30_fpu.o dcn30/display_mode_vba_30.o dcn30/display_rq_dlg_calc_30.o
|
||||
DML += dcn31/display_mode_vba_31.o dcn31/display_rq_dlg_calc_31.o
|
||||
DML += dcn32/display_mode_vba_32.o dcn32/display_rq_dlg_calc_32.o dcn32/display_mode_vba_util_32.o
|
||||
DML += dcn31/dcn31_fpu.o
|
||||
DML += dcn301/dcn301_fpu.o
|
||||
DML += dcn302/dcn302_fpu.o
|
||||
|
@ -438,8 +438,8 @@ static void UseMinimumDCFCLK(
|
||||
int dpte_group_bytes[],
|
||||
double PrefetchLinesY[][2][DC__NUM_DPP__MAX],
|
||||
double PrefetchLinesC[][2][DC__NUM_DPP__MAX],
|
||||
int swath_width_luma_ub_all_states[][2][DC__NUM_DPP__MAX],
|
||||
int swath_width_chroma_ub_all_states[][2][DC__NUM_DPP__MAX],
|
||||
unsigned int swath_width_luma_ub_all_states[][2][DC__NUM_DPP__MAX],
|
||||
unsigned int swath_width_chroma_ub_all_states[][2][DC__NUM_DPP__MAX],
|
||||
int BytePerPixelY[],
|
||||
int BytePerPixelC[],
|
||||
int HTotal[],
|
||||
@ -6696,8 +6696,8 @@ static void UseMinimumDCFCLK(
|
||||
int dpte_group_bytes[],
|
||||
double PrefetchLinesY[][2][DC__NUM_DPP__MAX],
|
||||
double PrefetchLinesC[][2][DC__NUM_DPP__MAX],
|
||||
int swath_width_luma_ub_all_states[][2][DC__NUM_DPP__MAX],
|
||||
int swath_width_chroma_ub_all_states[][2][DC__NUM_DPP__MAX],
|
||||
unsigned int swath_width_luma_ub_all_states[][2][DC__NUM_DPP__MAX],
|
||||
unsigned int swath_width_chroma_ub_all_states[][2][DC__NUM_DPP__MAX],
|
||||
int BytePerPixelY[],
|
||||
int BytePerPixelC[],
|
||||
int HTotal[],
|
||||
|
@ -2996,7 +2996,7 @@ static void DISPCLKDPPCLKDCFCLKDeepSleepPrefetchParametersWatermarksAndPerforman
|
||||
v->ImmediateFlipSupported)) ? true : false;
|
||||
#ifdef __DML_VBA_DEBUG__
|
||||
dml_print("DML::%s: PrefetchModeSupported %d\n", __func__, v->PrefetchModeSupported);
|
||||
dml_print("DML::%s: ImmediateFlipRequirement %d\n", __func__, v->ImmediateFlipRequirement == dm_immediate_flip_required);
|
||||
dml_print("DML::%s: ImmediateFlipRequirement[0] %d\n", __func__, v->ImmediateFlipRequirement[0] == dm_immediate_flip_required);
|
||||
dml_print("DML::%s: ImmediateFlipSupported %d\n", __func__, v->ImmediateFlipSupported);
|
||||
dml_print("DML::%s: ImmediateFlipSupport %d\n", __func__, v->ImmediateFlipSupport);
|
||||
dml_print("DML::%s: HostVMEnable %d\n", __func__, v->HostVMEnable);
|
||||
|
3835
drivers/gpu/drm/amd/display/dc/dml/dcn32/display_mode_vba_32.c
Normal file
3835
drivers/gpu/drm/amd/display/dc/dml/dcn32/display_mode_vba_32.c
Normal file
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,57 @@
|
||||
/*
|
||||
* Copyright 2022 Advanced Micro Devices, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
* Authors: AMD
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef __DML32_DISPLAY_MODE_VBA_H__
|
||||
#define __DML32_DISPLAY_MODE_VBA_H__
|
||||
|
||||
#include "../display_mode_enums.h"
|
||||
|
||||
// To enable a lot of debug msg
|
||||
//#define __DML_VBA_DEBUG__
|
||||
// For DML-C changes that hasn't been propagated to VBA yet
|
||||
//#define __DML_VBA_ALLOW_DELTA__
|
||||
|
||||
// Move these to ip parameters/constant
|
||||
// At which vstartup the DML start to try if the mode can be supported
|
||||
#define __DML_VBA_MIN_VSTARTUP__ 9
|
||||
|
||||
// Delay in DCFCLK from ARB to DET (1st num is ARB to SDPIF, 2nd number is SDPIF to DET)
|
||||
#define __DML_ARB_TO_RET_DELAY__ 7 + 95
|
||||
|
||||
// fudge factor for min dcfclk calclation
|
||||
#define __DML_MIN_DCFCLK_FACTOR__ 1.15
|
||||
|
||||
// Prefetch schedule max vratio
|
||||
#define __DML_MAX_VRATIO_PRE__ 4.0
|
||||
|
||||
#define BPP_INVALID 0
|
||||
#define BPP_BLENDED_PIPE 0xffffffff
|
||||
|
||||
struct display_mode_lib;
|
||||
|
||||
void dml32_ModeSupportAndSystemConfigurationFull(struct display_mode_lib *mode_lib);
|
||||
void dml32_recalculate(struct display_mode_lib *mode_lib);
|
||||
|
||||
#endif
|
6254
drivers/gpu/drm/amd/display/dc/dml/dcn32/display_mode_vba_util_32.c
Normal file
6254
drivers/gpu/drm/amd/display/dc/dml/dcn32/display_mode_vba_util_32.c
Normal file
File diff suppressed because it is too large
Load Diff
1175
drivers/gpu/drm/amd/display/dc/dml/dcn32/display_mode_vba_util_32.h
Normal file
1175
drivers/gpu/drm/amd/display/dc/dml/dcn32/display_mode_vba_util_32.h
Normal file
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,616 @@
|
||||
/*
|
||||
* Copyright 2022 Advanced Micro Devices, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
* Authors: AMD
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
#include "../display_mode_lib.h"
|
||||
#include "../display_mode_vba.h"
|
||||
#include "../dml_inline_defs.h"
|
||||
#include "display_rq_dlg_calc_32.h"
|
||||
|
||||
static bool is_dual_plane(enum source_format_class source_format)
|
||||
{
|
||||
bool ret_val = 0;
|
||||
|
||||
if ((source_format == dm_420_12) || (source_format == dm_420_8) || (source_format == dm_420_10)
|
||||
|| (source_format == dm_rgbe_alpha))
|
||||
ret_val = 1;
|
||||
|
||||
return ret_val;
|
||||
}
|
||||
|
||||
void dml32_rq_dlg_get_rq_reg(display_rq_regs_st *rq_regs,
|
||||
struct display_mode_lib *mode_lib,
|
||||
const display_e2e_pipe_params_st *e2e_pipe_param,
|
||||
const unsigned int num_pipes,
|
||||
const unsigned int pipe_idx)
|
||||
{
|
||||
const display_pipe_source_params_st *src = &e2e_pipe_param[pipe_idx].pipe.src;
|
||||
bool dual_plane = is_dual_plane((enum source_format_class) (src->source_format));
|
||||
double stored_swath_l_bytes;
|
||||
double stored_swath_c_bytes;
|
||||
bool is_phantom_pipe;
|
||||
uint32_t pixel_chunk_bytes = 0;
|
||||
uint32_t min_pixel_chunk_bytes = 0;
|
||||
uint32_t meta_chunk_bytes = 0;
|
||||
uint32_t min_meta_chunk_bytes = 0;
|
||||
uint32_t dpte_group_bytes = 0;
|
||||
uint32_t mpte_group_bytes = 0;
|
||||
|
||||
uint32_t p1_pixel_chunk_bytes = 0;
|
||||
uint32_t p1_min_pixel_chunk_bytes = 0;
|
||||
uint32_t p1_meta_chunk_bytes = 0;
|
||||
uint32_t p1_min_meta_chunk_bytes = 0;
|
||||
uint32_t p1_dpte_group_bytes = 0;
|
||||
uint32_t p1_mpte_group_bytes = 0;
|
||||
|
||||
unsigned int detile_buf_size_in_bytes;
|
||||
unsigned int detile_buf_plane1_addr;
|
||||
unsigned int pte_row_height_linear;
|
||||
|
||||
memset(rq_regs, 0, sizeof(*rq_regs));
|
||||
|
||||
dml_print("DML_DLG::%s: Calculation for pipe[%d] start, num_pipes=%d\n", __func__, pipe_idx, num_pipes);
|
||||
|
||||
pixel_chunk_bytes = get_pixel_chunk_size_in_kbyte(mode_lib, e2e_pipe_param, num_pipes) * 1024; // From VBA
|
||||
min_pixel_chunk_bytes = get_min_pixel_chunk_size_in_byte(mode_lib, e2e_pipe_param, num_pipes); // From VBA
|
||||
|
||||
if (pixel_chunk_bytes == 64 * 1024)
|
||||
min_pixel_chunk_bytes = 0;
|
||||
|
||||
meta_chunk_bytes = get_meta_chunk_size_in_kbyte(mode_lib, e2e_pipe_param, num_pipes) * 1024; // From VBA
|
||||
min_meta_chunk_bytes = get_min_meta_chunk_size_in_byte(mode_lib, e2e_pipe_param, num_pipes); // From VBA
|
||||
|
||||
dpte_group_bytes = get_dpte_group_size_in_bytes(mode_lib, e2e_pipe_param, num_pipes, pipe_idx); // From VBA
|
||||
mpte_group_bytes = get_vm_group_size_in_bytes(mode_lib, e2e_pipe_param, num_pipes, pipe_idx); // From VBA
|
||||
|
||||
p1_pixel_chunk_bytes = pixel_chunk_bytes;
|
||||
p1_min_pixel_chunk_bytes = min_pixel_chunk_bytes;
|
||||
p1_meta_chunk_bytes = meta_chunk_bytes;
|
||||
p1_min_meta_chunk_bytes = min_meta_chunk_bytes;
|
||||
p1_dpte_group_bytes = dpte_group_bytes;
|
||||
p1_mpte_group_bytes = mpte_group_bytes;
|
||||
|
||||
if ((enum source_format_class) src->source_format == dm_rgbe_alpha)
|
||||
p1_pixel_chunk_bytes = get_alpha_pixel_chunk_size_in_kbyte(mode_lib, e2e_pipe_param, num_pipes) * 1024;
|
||||
|
||||
rq_regs->rq_regs_l.chunk_size = dml_log2(pixel_chunk_bytes) - 10;
|
||||
rq_regs->rq_regs_c.chunk_size = dml_log2(p1_pixel_chunk_bytes) - 10;
|
||||
|
||||
if (min_pixel_chunk_bytes == 0)
|
||||
rq_regs->rq_regs_l.min_chunk_size = 0;
|
||||
else
|
||||
rq_regs->rq_regs_l.min_chunk_size = dml_log2(min_pixel_chunk_bytes) - 8 + 1;
|
||||
|
||||
if (p1_min_pixel_chunk_bytes == 0)
|
||||
rq_regs->rq_regs_c.min_chunk_size = 0;
|
||||
else
|
||||
rq_regs->rq_regs_c.min_chunk_size = dml_log2(p1_min_pixel_chunk_bytes) - 8 + 1;
|
||||
|
||||
rq_regs->rq_regs_l.meta_chunk_size = dml_log2(meta_chunk_bytes) - 10;
|
||||
rq_regs->rq_regs_c.meta_chunk_size = dml_log2(p1_meta_chunk_bytes) - 10;
|
||||
|
||||
if (min_meta_chunk_bytes == 0)
|
||||
rq_regs->rq_regs_l.min_meta_chunk_size = 0;
|
||||
else
|
||||
rq_regs->rq_regs_l.min_meta_chunk_size = dml_log2(min_meta_chunk_bytes) - 6 + 1;
|
||||
|
||||
if (min_meta_chunk_bytes == 0)
|
||||
rq_regs->rq_regs_c.min_meta_chunk_size = 0;
|
||||
else
|
||||
rq_regs->rq_regs_c.min_meta_chunk_size = dml_log2(p1_min_meta_chunk_bytes) - 6 + 1;
|
||||
|
||||
rq_regs->rq_regs_l.dpte_group_size = dml_log2(dpte_group_bytes) - 6;
|
||||
rq_regs->rq_regs_l.mpte_group_size = dml_log2(mpte_group_bytes) - 6;
|
||||
rq_regs->rq_regs_c.dpte_group_size = dml_log2(p1_dpte_group_bytes) - 6;
|
||||
rq_regs->rq_regs_c.mpte_group_size = dml_log2(p1_mpte_group_bytes) - 6;
|
||||
|
||||
detile_buf_size_in_bytes = get_det_buffer_size_kbytes(mode_lib, e2e_pipe_param, num_pipes, pipe_idx) * 1024;
|
||||
detile_buf_plane1_addr = 0;
|
||||
pte_row_height_linear = get_dpte_row_height_linear_l(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx);
|
||||
|
||||
if (src->sw_mode == dm_sw_linear)
|
||||
ASSERT(pte_row_height_linear >= 8);
|
||||
|
||||
rq_regs->rq_regs_l.pte_row_height_linear = dml_floor(dml_log2(pte_row_height_linear), 1) - 3;
|
||||
|
||||
if (dual_plane) {
|
||||
unsigned int p1_pte_row_height_linear = get_dpte_row_height_linear_c(mode_lib, e2e_pipe_param,
|
||||
num_pipes, pipe_idx);
|
||||
;
|
||||
if (src->sw_mode == dm_sw_linear)
|
||||
ASSERT(p1_pte_row_height_linear >= 8);
|
||||
|
||||
rq_regs->rq_regs_c.pte_row_height_linear = dml_floor(dml_log2(p1_pte_row_height_linear), 1) - 3;
|
||||
}
|
||||
|
||||
rq_regs->rq_regs_l.swath_height = dml_log2(get_swath_height_l(mode_lib, e2e_pipe_param, num_pipes, pipe_idx));
|
||||
rq_regs->rq_regs_c.swath_height = dml_log2(get_swath_height_c(mode_lib, e2e_pipe_param, num_pipes, pipe_idx));
|
||||
|
||||
// FIXME: take the max between luma, chroma chunk size?
|
||||
// okay for now, as we are setting pixel_chunk_bytes to 8kb anyways
|
||||
if (pixel_chunk_bytes >= 32 * 1024 || (dual_plane && p1_pixel_chunk_bytes >= 32 * 1024)) { //32kb
|
||||
rq_regs->drq_expansion_mode = 0;
|
||||
} else {
|
||||
rq_regs->drq_expansion_mode = 2;
|
||||
}
|
||||
rq_regs->prq_expansion_mode = 1;
|
||||
rq_regs->mrq_expansion_mode = 1;
|
||||
rq_regs->crq_expansion_mode = 1;
|
||||
|
||||
stored_swath_l_bytes = get_det_stored_buffer_size_l_bytes(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx);
|
||||
stored_swath_c_bytes = get_det_stored_buffer_size_c_bytes(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx);
|
||||
is_phantom_pipe = get_is_phantom_pipe(mode_lib, e2e_pipe_param, num_pipes, pipe_idx);
|
||||
|
||||
// Note: detile_buf_plane1_addr is in unit of 1KB
|
||||
if (dual_plane) {
|
||||
if (is_phantom_pipe) {
|
||||
detile_buf_plane1_addr = ((1024.0 * 1024.0) / 2.0 / 1024.0); // half to chroma
|
||||
} else {
|
||||
if (stored_swath_l_bytes / stored_swath_c_bytes <= 1.5) {
|
||||
detile_buf_plane1_addr = (detile_buf_size_in_bytes / 2.0 / 1024.0); // half to chroma
|
||||
#ifdef __DML_RQ_DLG_CALC_DEBUG__
|
||||
dml_print("DML_DLG: %s: detile_buf_plane1_addr = %d (1/2 to chroma)\n",
|
||||
__func__, detile_buf_plane1_addr);
|
||||
#endif
|
||||
} else {
|
||||
detile_buf_plane1_addr =
|
||||
dml_round_to_multiple(
|
||||
(unsigned int) ((2.0 * detile_buf_size_in_bytes) / 3.0),
|
||||
1024, 0) / 1024.0; // 2/3 to luma
|
||||
#ifdef __DML_RQ_DLG_CALC_DEBUG__
|
||||
dml_print("DML_DLG: %s: detile_buf_plane1_addr = %d (1/3 chroma)\n",
|
||||
__func__, detile_buf_plane1_addr);
|
||||
#endif
|
||||
}
|
||||
}
|
||||
}
|
||||
rq_regs->plane1_base_address = detile_buf_plane1_addr;
|
||||
|
||||
#ifdef __DML_RQ_DLG_CALC_DEBUG__
|
||||
dml_print("DML_DLG: %s: is_phantom_pipe = %d\n", __func__, is_phantom_pipe);
|
||||
dml_print("DML_DLG: %s: stored_swath_l_bytes = %f\n", __func__, stored_swath_l_bytes);
|
||||
dml_print("DML_DLG: %s: stored_swath_c_bytes = %f\n", __func__, stored_swath_c_bytes);
|
||||
dml_print("DML_DLG: %s: detile_buf_size_in_bytes = %d\n", __func__, detile_buf_size_in_bytes);
|
||||
dml_print("DML_DLG: %s: detile_buf_plane1_addr = %d\n", __func__, detile_buf_plane1_addr);
|
||||
dml_print("DML_DLG: %s: plane1_base_address = %d\n", __func__, rq_regs->plane1_base_address);
|
||||
#endif
|
||||
print__rq_regs_st(mode_lib, rq_regs);
|
||||
dml_print("DML_DLG::%s: Calculation for pipe[%d] done, num_pipes=%d\n", __func__, pipe_idx, num_pipes);
|
||||
}
|
||||
|
||||
void dml32_rq_dlg_get_dlg_reg(struct display_mode_lib *mode_lib,
|
||||
display_dlg_regs_st *dlg_regs,
|
||||
display_ttu_regs_st *ttu_regs,
|
||||
display_e2e_pipe_params_st *e2e_pipe_param,
|
||||
const unsigned int num_pipes,
|
||||
const unsigned int pipe_idx)
|
||||
{
|
||||
const display_pipe_source_params_st *src = &e2e_pipe_param[pipe_idx].pipe.src;
|
||||
const display_pipe_dest_params_st *dst = &e2e_pipe_param[pipe_idx].pipe.dest;
|
||||
const display_clocks_and_cfg_st *clks = &e2e_pipe_param[pipe_idx].clks_cfg;
|
||||
double refcyc_per_req_delivery_pre_cur0 = 0.;
|
||||
double refcyc_per_req_delivery_cur0 = 0.;
|
||||
double refcyc_per_req_delivery_pre_c = 0.;
|
||||
double refcyc_per_req_delivery_c = 0.;
|
||||
double refcyc_per_req_delivery_pre_l;
|
||||
double refcyc_per_req_delivery_l;
|
||||
double refcyc_per_line_delivery_pre_c = 0.;
|
||||
double refcyc_per_line_delivery_c = 0.;
|
||||
double refcyc_per_line_delivery_pre_l;
|
||||
double refcyc_per_line_delivery_l;
|
||||
double min_ttu_vblank;
|
||||
double vratio_pre_l;
|
||||
double vratio_pre_c;
|
||||
unsigned int min_dst_y_next_start;
|
||||
unsigned int htotal = dst->htotal;
|
||||
unsigned int hblank_end = dst->hblank_end;
|
||||
unsigned int vblank_end = dst->vblank_end;
|
||||
bool interlaced = dst->interlaced;
|
||||
double pclk_freq_in_mhz = dst->pixel_rate_mhz;
|
||||
unsigned int vready_after_vcount0;
|
||||
double refclk_freq_in_mhz = clks->refclk_mhz;
|
||||
double ref_freq_to_pix_freq = refclk_freq_in_mhz / pclk_freq_in_mhz;
|
||||
bool dual_plane = 0;
|
||||
unsigned int pipe_index_in_combine[DC__NUM_PIPES__MAX];
|
||||
int unsigned dst_x_after_scaler;
|
||||
int unsigned dst_y_after_scaler;
|
||||
double dst_y_prefetch;
|
||||
double dst_y_per_vm_vblank;
|
||||
double dst_y_per_row_vblank;
|
||||
double dst_y_per_vm_flip;
|
||||
double dst_y_per_row_flip;
|
||||
double max_dst_y_per_vm_vblank = 32.0;
|
||||
double max_dst_y_per_row_vblank = 16.0;
|
||||
|
||||
double dst_y_per_pte_row_nom_l;
|
||||
double dst_y_per_pte_row_nom_c;
|
||||
double dst_y_per_meta_row_nom_l;
|
||||
double dst_y_per_meta_row_nom_c;
|
||||
double refcyc_per_pte_group_nom_l;
|
||||
double refcyc_per_pte_group_nom_c;
|
||||
double refcyc_per_pte_group_vblank_l;
|
||||
double refcyc_per_pte_group_vblank_c;
|
||||
double refcyc_per_pte_group_flip_l;
|
||||
double refcyc_per_pte_group_flip_c;
|
||||
double refcyc_per_meta_chunk_nom_l;
|
||||
double refcyc_per_meta_chunk_nom_c;
|
||||
double refcyc_per_meta_chunk_vblank_l;
|
||||
double refcyc_per_meta_chunk_vblank_c;
|
||||
double refcyc_per_meta_chunk_flip_l;
|
||||
double refcyc_per_meta_chunk_flip_c;
|
||||
|
||||
memset(dlg_regs, 0, sizeof(*dlg_regs));
|
||||
memset(ttu_regs, 0, sizeof(*ttu_regs));
|
||||
dml_print("DML_DLG::%s: Calculation for pipe[%d] starts, num_pipes=%d\n", __func__, pipe_idx, num_pipes);
|
||||
dml_print("DML_DLG: %s: refclk_freq_in_mhz = %3.2f\n", __func__, refclk_freq_in_mhz);
|
||||
dml_print("DML_DLG: %s: pclk_freq_in_mhz = %3.2f\n", __func__, pclk_freq_in_mhz);
|
||||
dml_print("DML_DLG: %s: ref_freq_to_pix_freq = %3.2f\n", __func__, ref_freq_to_pix_freq);
|
||||
dml_print("DML_DLG: %s: interlaced = %d\n", __func__, interlaced);
|
||||
ASSERT(ref_freq_to_pix_freq < 4.0);
|
||||
|
||||
dlg_regs->ref_freq_to_pix_freq = (unsigned int) (ref_freq_to_pix_freq * dml_pow(2, 19));
|
||||
dlg_regs->refcyc_per_htotal = (unsigned int) (ref_freq_to_pix_freq * (double) htotal * dml_pow(2, 8));
|
||||
dlg_regs->dlg_vblank_end = interlaced ? (vblank_end / 2) : vblank_end; // 15 bits
|
||||
|
||||
min_ttu_vblank = get_min_ttu_vblank_in_us(mode_lib, e2e_pipe_param, num_pipes, pipe_idx); // From VBA
|
||||
min_dst_y_next_start = get_min_dst_y_next_start(mode_lib, e2e_pipe_param, num_pipes, pipe_idx);
|
||||
|
||||
dml_print("DML_DLG: %s: min_ttu_vblank (us) = %3.2f\n", __func__, min_ttu_vblank);
|
||||
dml_print("DML_DLG: %s: min_dst_y_next_start = %d\n", __func__, min_dst_y_next_start);
|
||||
dml_print("DML_DLG: %s: ref_freq_to_pix_freq = %3.2f\n", __func__, ref_freq_to_pix_freq);
|
||||
|
||||
dual_plane = is_dual_plane((enum source_format_class) (src->source_format));
|
||||
|
||||
vready_after_vcount0 = get_vready_at_or_after_vsync(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx); // From VBA
|
||||
dlg_regs->vready_after_vcount0 = vready_after_vcount0;
|
||||
|
||||
dml_print("DML_DLG: %s: vready_after_vcount0 = %d\n", __func__, dlg_regs->vready_after_vcount0);
|
||||
|
||||
dst_x_after_scaler = get_dst_x_after_scaler(mode_lib, e2e_pipe_param, num_pipes, pipe_idx);
|
||||
dst_y_after_scaler = get_dst_y_after_scaler(mode_lib, e2e_pipe_param, num_pipes, pipe_idx);
|
||||
|
||||
// do some adjustment on the dst_after scaler to account for odm combine mode
|
||||
dml_print("DML_DLG: %s: input dst_x_after_scaler = %d\n", __func__, dst_x_after_scaler);
|
||||
dml_print("DML_DLG: %s: input dst_y_after_scaler = %d\n", __func__, dst_y_after_scaler);
|
||||
|
||||
// need to figure out which side of odm combine we're in
|
||||
if (dst->odm_combine == dm_odm_combine_mode_2to1 || dst->odm_combine == dm_odm_combine_mode_4to1) {
|
||||
// figure out which pipes go together
|
||||
bool visited[DC__NUM_PIPES__MAX];
|
||||
unsigned int i, j, k;
|
||||
|
||||
for (k = 0; k < num_pipes; ++k) {
|
||||
visited[k] = false;
|
||||
pipe_index_in_combine[k] = 0;
|
||||
}
|
||||
|
||||
for (i = 0; i < num_pipes; i++) {
|
||||
if (e2e_pipe_param[i].pipe.src.is_hsplit && !visited[i]) {
|
||||
|
||||
unsigned int grp = e2e_pipe_param[i].pipe.src.hsplit_grp;
|
||||
unsigned int grp_idx = 0;
|
||||
|
||||
for (j = i; j < num_pipes; j++) {
|
||||
if (e2e_pipe_param[j].pipe.src.hsplit_grp == grp
|
||||
&& e2e_pipe_param[j].pipe.src.is_hsplit && !visited[j]) {
|
||||
pipe_index_in_combine[j] = grp_idx;
|
||||
dml_print("DML_DLG: %s: pipe[%d] is in grp %d idx %d\n",
|
||||
__func__, j, grp, grp_idx);
|
||||
grp_idx++;
|
||||
visited[j] = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (dst->odm_combine == dm_odm_combine_mode_disabled) {
|
||||
// FIXME how about ODM split??
|
||||
dlg_regs->refcyc_h_blank_end = (unsigned int) ((double) hblank_end * ref_freq_to_pix_freq);
|
||||
} else {
|
||||
if (dst->odm_combine == dm_odm_combine_mode_2to1 || dst->odm_combine == dm_odm_combine_mode_4to1) {
|
||||
// TODO: We should really check that 4to1 is supported before setting it to 4
|
||||
unsigned int odm_combine_factor = (dst->odm_combine == dm_odm_combine_mode_2to1 ? 2 : 4);
|
||||
unsigned int odm_pipe_index = pipe_index_in_combine[pipe_idx];
|
||||
|
||||
dlg_regs->refcyc_h_blank_end = (unsigned int) (((double) hblank_end
|
||||
+ odm_pipe_index * (double) dst->hactive / odm_combine_factor) * ref_freq_to_pix_freq);
|
||||
}
|
||||
}
|
||||
ASSERT(dlg_regs->refcyc_h_blank_end < (unsigned int)dml_pow(2, 13));
|
||||
|
||||
dml_print("DML_DLG: %s: htotal= %d\n", __func__, htotal);
|
||||
dml_print("DML_DLG: %s: dst_x_after_scaler[%d]= %d\n", __func__, pipe_idx, dst_x_after_scaler);
|
||||
dml_print("DML_DLG: %s: dst_y_after_scaler[%d] = %d\n", __func__, pipe_idx, dst_y_after_scaler);
|
||||
|
||||
dst_y_prefetch = get_dst_y_prefetch(mode_lib, e2e_pipe_param, num_pipes, pipe_idx); // From VBA
|
||||
// From VBA
|
||||
dst_y_per_vm_vblank = get_dst_y_per_vm_vblank(mode_lib, e2e_pipe_param, num_pipes, pipe_idx);
|
||||
// From VBA
|
||||
dst_y_per_row_vblank = get_dst_y_per_row_vblank(mode_lib, e2e_pipe_param, num_pipes, pipe_idx);
|
||||
dst_y_per_vm_flip = get_dst_y_per_vm_flip(mode_lib, e2e_pipe_param, num_pipes, pipe_idx); // From VBA
|
||||
dst_y_per_row_flip = get_dst_y_per_row_flip(mode_lib, e2e_pipe_param, num_pipes, pipe_idx); // From VBA
|
||||
|
||||
// magic!
|
||||
if (htotal <= 75) {
|
||||
max_dst_y_per_vm_vblank = 100.0;
|
||||
max_dst_y_per_row_vblank = 100.0;
|
||||
}
|
||||
|
||||
dml_print("DML_DLG: %s: dst_y_prefetch (after rnd) = %3.2f\n", __func__, dst_y_prefetch);
|
||||
dml_print("DML_DLG: %s: dst_y_per_vm_flip = %3.2f\n", __func__, dst_y_per_vm_flip);
|
||||
dml_print("DML_DLG: %s: dst_y_per_row_flip = %3.2f\n", __func__, dst_y_per_row_flip);
|
||||
dml_print("DML_DLG: %s: dst_y_per_vm_vblank = %3.2f\n", __func__, dst_y_per_vm_vblank);
|
||||
dml_print("DML_DLG: %s: dst_y_per_row_vblank = %3.2f\n", __func__, dst_y_per_row_vblank);
|
||||
|
||||
ASSERT(dst_y_per_vm_vblank < max_dst_y_per_vm_vblank);
|
||||
ASSERT(dst_y_per_row_vblank < max_dst_y_per_row_vblank);
|
||||
ASSERT(dst_y_prefetch > (dst_y_per_vm_vblank + dst_y_per_row_vblank));
|
||||
|
||||
vratio_pre_l = get_vratio_prefetch_l(mode_lib, e2e_pipe_param, num_pipes, pipe_idx); // From VBA
|
||||
vratio_pre_c = get_vratio_prefetch_c(mode_lib, e2e_pipe_param, num_pipes, pipe_idx); // From VBA
|
||||
|
||||
dml_print("DML_DLG: %s: vratio_pre_l = %3.2f\n", __func__, vratio_pre_l);
|
||||
dml_print("DML_DLG: %s: vratio_pre_c = %3.2f\n", __func__, vratio_pre_c);
|
||||
|
||||
// Active
|
||||
refcyc_per_line_delivery_pre_l = get_refcyc_per_line_delivery_pre_l_in_us(mode_lib, e2e_pipe_param, num_pipes, pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_line_delivery_l = get_refcyc_per_line_delivery_l_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
|
||||
dml_print("DML_DLG: %s: refcyc_per_line_delivery_pre_l = %3.2f\n", __func__, refcyc_per_line_delivery_pre_l);
|
||||
dml_print("DML_DLG: %s: refcyc_per_line_delivery_l = %3.2f\n", __func__, refcyc_per_line_delivery_l);
|
||||
|
||||
if (dual_plane) {
|
||||
refcyc_per_line_delivery_pre_c = get_refcyc_per_line_delivery_pre_c_in_us(mode_lib, e2e_pipe_param,
|
||||
num_pipes, pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_line_delivery_c = get_refcyc_per_line_delivery_c_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
|
||||
dml_print("DML_DLG: %s: refcyc_per_line_delivery_pre_c = %3.2f\n",
|
||||
__func__, refcyc_per_line_delivery_pre_c);
|
||||
dml_print("DML_DLG: %s: refcyc_per_line_delivery_c = %3.2f\n",
|
||||
__func__, refcyc_per_line_delivery_c);
|
||||
}
|
||||
|
||||
if (src->dynamic_metadata_enable && src->gpuvm)
|
||||
dlg_regs->refcyc_per_vm_dmdata = get_refcyc_per_vm_dmdata_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
|
||||
dlg_regs->dmdata_dl_delta = get_dmdata_dl_delta_in_us(mode_lib, e2e_pipe_param, num_pipes, pipe_idx)
|
||||
* refclk_freq_in_mhz; // From VBA
|
||||
|
||||
refcyc_per_req_delivery_pre_l = get_refcyc_per_req_delivery_pre_l_in_us(mode_lib, e2e_pipe_param, num_pipes, pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_req_delivery_l = get_refcyc_per_req_delivery_l_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
|
||||
dml_print("DML_DLG: %s: refcyc_per_req_delivery_pre_l = %3.2f\n", __func__, refcyc_per_req_delivery_pre_l);
|
||||
dml_print("DML_DLG: %s: refcyc_per_req_delivery_l = %3.2f\n", __func__, refcyc_per_req_delivery_l);
|
||||
|
||||
if (dual_plane) {
|
||||
refcyc_per_req_delivery_pre_c = get_refcyc_per_req_delivery_pre_c_in_us(mode_lib, e2e_pipe_param,
|
||||
num_pipes, pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_req_delivery_c = get_refcyc_per_req_delivery_c_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
|
||||
dml_print("DML_DLG: %s: refcyc_per_req_delivery_pre_c = %3.2f\n",
|
||||
__func__, refcyc_per_req_delivery_pre_c);
|
||||
dml_print("DML_DLG: %s: refcyc_per_req_delivery_c = %3.2f\n", __func__, refcyc_per_req_delivery_c);
|
||||
}
|
||||
|
||||
// TTU - Cursor
|
||||
ASSERT(src->num_cursors <= 1);
|
||||
if (src->num_cursors > 0) {
|
||||
refcyc_per_req_delivery_pre_cur0 = get_refcyc_per_cursor_req_delivery_pre_in_us(mode_lib,
|
||||
e2e_pipe_param, num_pipes, pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_req_delivery_cur0 = get_refcyc_per_cursor_req_delivery_in_us(mode_lib, e2e_pipe_param,
|
||||
num_pipes, pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
|
||||
dml_print("DML_DLG: %s: refcyc_per_req_delivery_pre_cur0 = %3.2f\n",
|
||||
__func__, refcyc_per_req_delivery_pre_cur0);
|
||||
dml_print("DML_DLG: %s: refcyc_per_req_delivery_cur0 = %3.2f\n",
|
||||
__func__, refcyc_per_req_delivery_cur0);
|
||||
}
|
||||
|
||||
// Assign to register structures
|
||||
dlg_regs->min_dst_y_next_start = min_dst_y_next_start * dml_pow(2, 2);
|
||||
ASSERT(dlg_regs->min_dst_y_next_start < (unsigned int)dml_pow(2, 18));
|
||||
|
||||
dlg_regs->dst_y_after_scaler = dst_y_after_scaler; // in terms of line
|
||||
dlg_regs->refcyc_x_after_scaler = dst_x_after_scaler * ref_freq_to_pix_freq; // in terms of refclk
|
||||
dlg_regs->dst_y_prefetch = (unsigned int) (dst_y_prefetch * dml_pow(2, 2));
|
||||
dlg_regs->dst_y_per_vm_vblank = (unsigned int) (dst_y_per_vm_vblank * dml_pow(2, 2));
|
||||
dlg_regs->dst_y_per_row_vblank = (unsigned int) (dst_y_per_row_vblank * dml_pow(2, 2));
|
||||
dlg_regs->dst_y_per_vm_flip = (unsigned int) (dst_y_per_vm_flip * dml_pow(2, 2));
|
||||
dlg_regs->dst_y_per_row_flip = (unsigned int) (dst_y_per_row_flip * dml_pow(2, 2));
|
||||
|
||||
dlg_regs->vratio_prefetch = (unsigned int) (vratio_pre_l * dml_pow(2, 19));
|
||||
dlg_regs->vratio_prefetch_c = (unsigned int) (vratio_pre_c * dml_pow(2, 19));
|
||||
|
||||
dml_print("DML_DLG: %s: dlg_regs->dst_y_per_vm_vblank = 0x%x\n", __func__, dlg_regs->dst_y_per_vm_vblank);
|
||||
dml_print("DML_DLG: %s: dlg_regs->dst_y_per_row_vblank = 0x%x\n", __func__, dlg_regs->dst_y_per_row_vblank);
|
||||
dml_print("DML_DLG: %s: dlg_regs->dst_y_per_vm_flip = 0x%x\n", __func__, dlg_regs->dst_y_per_vm_flip);
|
||||
dml_print("DML_DLG: %s: dlg_regs->dst_y_per_row_flip = 0x%x\n", __func__, dlg_regs->dst_y_per_row_flip);
|
||||
|
||||
dlg_regs->refcyc_per_vm_group_vblank = get_refcyc_per_vm_group_vblank_in_us(mode_lib, e2e_pipe_param,
|
||||
num_pipes, pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
dlg_regs->refcyc_per_vm_group_flip = get_refcyc_per_vm_group_flip_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
dlg_regs->refcyc_per_vm_req_vblank = get_refcyc_per_vm_req_vblank_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz * dml_pow(2, 10); // From VBA
|
||||
dlg_regs->refcyc_per_vm_req_flip = get_refcyc_per_vm_req_flip_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz * dml_pow(2, 10); // From VBA
|
||||
|
||||
// From VBA
|
||||
dst_y_per_pte_row_nom_l = get_dst_y_per_pte_row_nom_l(mode_lib, e2e_pipe_param, num_pipes, pipe_idx);
|
||||
// From VBA
|
||||
dst_y_per_pte_row_nom_c = get_dst_y_per_pte_row_nom_c(mode_lib, e2e_pipe_param, num_pipes, pipe_idx);
|
||||
// From VBA
|
||||
dst_y_per_meta_row_nom_l = get_dst_y_per_meta_row_nom_l(mode_lib, e2e_pipe_param, num_pipes, pipe_idx);
|
||||
// From VBA
|
||||
dst_y_per_meta_row_nom_c = get_dst_y_per_meta_row_nom_c(mode_lib, e2e_pipe_param, num_pipes, pipe_idx);
|
||||
|
||||
refcyc_per_pte_group_nom_l = get_refcyc_per_pte_group_nom_l_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_pte_group_nom_c = get_refcyc_per_pte_group_nom_c_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_pte_group_vblank_l = get_refcyc_per_pte_group_vblank_l_in_us(mode_lib, e2e_pipe_param,
|
||||
num_pipes, pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_pte_group_vblank_c = get_refcyc_per_pte_group_vblank_c_in_us(mode_lib, e2e_pipe_param,
|
||||
num_pipes, pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_pte_group_flip_l = get_refcyc_per_pte_group_flip_l_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_pte_group_flip_c = get_refcyc_per_pte_group_flip_c_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
|
||||
refcyc_per_meta_chunk_nom_l = get_refcyc_per_meta_chunk_nom_l_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_meta_chunk_nom_c = get_refcyc_per_meta_chunk_nom_c_in_us(mode_lib, e2e_pipe_param, num_pipes,
|
||||
pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_meta_chunk_vblank_l = get_refcyc_per_meta_chunk_vblank_l_in_us(mode_lib, e2e_pipe_param,
|
||||
num_pipes, pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_meta_chunk_vblank_c = get_refcyc_per_meta_chunk_vblank_c_in_us(mode_lib, e2e_pipe_param,
|
||||
num_pipes, pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_meta_chunk_flip_l = get_refcyc_per_meta_chunk_flip_l_in_us(mode_lib, e2e_pipe_param,
|
||||
num_pipes, pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
refcyc_per_meta_chunk_flip_c = get_refcyc_per_meta_chunk_flip_c_in_us(mode_lib, e2e_pipe_param,
|
||||
num_pipes, pipe_idx) * refclk_freq_in_mhz; // From VBA
|
||||
|
||||
dlg_regs->dst_y_per_pte_row_nom_l = dst_y_per_pte_row_nom_l * dml_pow(2, 2);
|
||||
dlg_regs->dst_y_per_pte_row_nom_c = dst_y_per_pte_row_nom_c * dml_pow(2, 2);
|
||||
dlg_regs->dst_y_per_meta_row_nom_l = dst_y_per_meta_row_nom_l * dml_pow(2, 2);
|
||||
dlg_regs->dst_y_per_meta_row_nom_c = dst_y_per_meta_row_nom_c * dml_pow(2, 2);
|
||||
dlg_regs->refcyc_per_pte_group_nom_l = refcyc_per_pte_group_nom_l;
|
||||
dlg_regs->refcyc_per_pte_group_nom_c = refcyc_per_pte_group_nom_c;
|
||||
dlg_regs->refcyc_per_pte_group_vblank_l = refcyc_per_pte_group_vblank_l;
|
||||
dlg_regs->refcyc_per_pte_group_vblank_c = refcyc_per_pte_group_vblank_c;
|
||||
dlg_regs->refcyc_per_pte_group_flip_l = refcyc_per_pte_group_flip_l;
|
||||
dlg_regs->refcyc_per_pte_group_flip_c = refcyc_per_pte_group_flip_c;
|
||||
dlg_regs->refcyc_per_meta_chunk_nom_l = refcyc_per_meta_chunk_nom_l;
|
||||
dlg_regs->refcyc_per_meta_chunk_nom_c = refcyc_per_meta_chunk_nom_c;
|
||||
dlg_regs->refcyc_per_meta_chunk_vblank_l = refcyc_per_meta_chunk_vblank_l;
|
||||
dlg_regs->refcyc_per_meta_chunk_vblank_c = refcyc_per_meta_chunk_vblank_c;
|
||||
dlg_regs->refcyc_per_meta_chunk_flip_l = refcyc_per_meta_chunk_flip_l;
|
||||
dlg_regs->refcyc_per_meta_chunk_flip_c = refcyc_per_meta_chunk_flip_c;
|
||||
dlg_regs->refcyc_per_line_delivery_pre_l = (unsigned int) dml_floor(refcyc_per_line_delivery_pre_l, 1);
|
||||
dlg_regs->refcyc_per_line_delivery_l = (unsigned int) dml_floor(refcyc_per_line_delivery_l, 1);
|
||||
dlg_regs->refcyc_per_line_delivery_pre_c = (unsigned int) dml_floor(refcyc_per_line_delivery_pre_c, 1);
|
||||
dlg_regs->refcyc_per_line_delivery_c = (unsigned int) dml_floor(refcyc_per_line_delivery_c, 1);
|
||||
|
||||
dlg_regs->chunk_hdl_adjust_cur0 = 3;
|
||||
dlg_regs->dst_y_offset_cur0 = 0;
|
||||
dlg_regs->chunk_hdl_adjust_cur1 = 3;
|
||||
dlg_regs->dst_y_offset_cur1 = 0;
|
||||
|
||||
dlg_regs->dst_y_delta_drq_limit = 0x7fff; // off
|
||||
|
||||
ttu_regs->refcyc_per_req_delivery_pre_l = (unsigned int) (refcyc_per_req_delivery_pre_l * dml_pow(2, 10));
|
||||
ttu_regs->refcyc_per_req_delivery_l = (unsigned int) (refcyc_per_req_delivery_l * dml_pow(2, 10));
|
||||
ttu_regs->refcyc_per_req_delivery_pre_c = (unsigned int) (refcyc_per_req_delivery_pre_c * dml_pow(2, 10));
|
||||
ttu_regs->refcyc_per_req_delivery_c = (unsigned int) (refcyc_per_req_delivery_c * dml_pow(2, 10));
|
||||
ttu_regs->refcyc_per_req_delivery_pre_cur0 =
|
||||
(unsigned int) (refcyc_per_req_delivery_pre_cur0 * dml_pow(2, 10));
|
||||
ttu_regs->refcyc_per_req_delivery_cur0 = (unsigned int) (refcyc_per_req_delivery_cur0 * dml_pow(2, 10));
|
||||
ttu_regs->refcyc_per_req_delivery_pre_cur1 = 0;
|
||||
ttu_regs->refcyc_per_req_delivery_cur1 = 0;
|
||||
ttu_regs->qos_level_low_wm = 0;
|
||||
|
||||
ttu_regs->qos_level_high_wm = (unsigned int) (4.0 * (double) htotal * ref_freq_to_pix_freq);
|
||||
|
||||
ttu_regs->qos_level_flip = 14;
|
||||
ttu_regs->qos_level_fixed_l = 8;
|
||||
ttu_regs->qos_level_fixed_c = 8;
|
||||
ttu_regs->qos_level_fixed_cur0 = 8;
|
||||
ttu_regs->qos_ramp_disable_l = 0;
|
||||
ttu_regs->qos_ramp_disable_c = 0;
|
||||
ttu_regs->qos_ramp_disable_cur0 = 0;
|
||||
ttu_regs->min_ttu_vblank = min_ttu_vblank * refclk_freq_in_mhz;
|
||||
|
||||
// CHECK for HW registers' range, assert or clamp
|
||||
ASSERT(refcyc_per_req_delivery_pre_l < dml_pow(2, 13));
|
||||
ASSERT(refcyc_per_req_delivery_l < dml_pow(2, 13));
|
||||
ASSERT(refcyc_per_req_delivery_pre_c < dml_pow(2, 13));
|
||||
ASSERT(refcyc_per_req_delivery_c < dml_pow(2, 13));
|
||||
if (dlg_regs->refcyc_per_vm_group_vblank >= (unsigned int) dml_pow(2, 23))
|
||||
dlg_regs->refcyc_per_vm_group_vblank = dml_pow(2, 23) - 1;
|
||||
|
||||
if (dlg_regs->refcyc_per_vm_group_flip >= (unsigned int) dml_pow(2, 23))
|
||||
dlg_regs->refcyc_per_vm_group_flip = dml_pow(2, 23) - 1;
|
||||
|
||||
if (dlg_regs->refcyc_per_vm_req_vblank >= (unsigned int) dml_pow(2, 23))
|
||||
dlg_regs->refcyc_per_vm_req_vblank = dml_pow(2, 23) - 1;
|
||||
|
||||
if (dlg_regs->refcyc_per_vm_req_flip >= (unsigned int) dml_pow(2, 23))
|
||||
dlg_regs->refcyc_per_vm_req_flip = dml_pow(2, 23) - 1;
|
||||
|
||||
ASSERT(dlg_regs->dst_y_after_scaler < (unsigned int) 8);
|
||||
ASSERT(dlg_regs->refcyc_x_after_scaler < (unsigned int)dml_pow(2, 13));
|
||||
ASSERT(dlg_regs->dst_y_per_pte_row_nom_l < (unsigned int)dml_pow(2, 17));
|
||||
if (dual_plane) {
|
||||
if (dlg_regs->dst_y_per_pte_row_nom_c >= (unsigned int) dml_pow(2, 17)) {
|
||||
// FIXME what so special about chroma, can we just assert?
|
||||
dml_print("DML_DLG: %s: Warning dst_y_per_pte_row_nom_c %u > register max U15.2 %u\n",
|
||||
__func__, dlg_regs->dst_y_per_pte_row_nom_c, (unsigned int)dml_pow(2, 17) - 1);
|
||||
}
|
||||
}
|
||||
ASSERT(dlg_regs->dst_y_per_meta_row_nom_l < (unsigned int)dml_pow(2, 17));
|
||||
ASSERT(dlg_regs->dst_y_per_meta_row_nom_c < (unsigned int)dml_pow(2, 17));
|
||||
|
||||
if (dlg_regs->refcyc_per_pte_group_nom_l >= (unsigned int) dml_pow(2, 23))
|
||||
dlg_regs->refcyc_per_pte_group_nom_l = dml_pow(2, 23) - 1;
|
||||
if (dual_plane) {
|
||||
if (dlg_regs->refcyc_per_pte_group_nom_c >= (unsigned int) dml_pow(2, 23))
|
||||
dlg_regs->refcyc_per_pte_group_nom_c = dml_pow(2, 23) - 1;
|
||||
}
|
||||
ASSERT(dlg_regs->refcyc_per_pte_group_vblank_l < (unsigned int)dml_pow(2, 13));
|
||||
if (dual_plane) {
|
||||
ASSERT(dlg_regs->refcyc_per_pte_group_vblank_c < (unsigned int)dml_pow(2, 13));
|
||||
}
|
||||
|
||||
if (dlg_regs->refcyc_per_meta_chunk_nom_l >= (unsigned int) dml_pow(2, 23))
|
||||
dlg_regs->refcyc_per_meta_chunk_nom_l = dml_pow(2, 23) - 1;
|
||||
if (dual_plane) {
|
||||
if (dlg_regs->refcyc_per_meta_chunk_nom_c >= (unsigned int) dml_pow(2, 23))
|
||||
dlg_regs->refcyc_per_meta_chunk_nom_c = dml_pow(2, 23) - 1;
|
||||
}
|
||||
ASSERT(dlg_regs->refcyc_per_meta_chunk_vblank_l < (unsigned int)dml_pow(2, 13));
|
||||
ASSERT(dlg_regs->refcyc_per_meta_chunk_vblank_c < (unsigned int)dml_pow(2, 13));
|
||||
ASSERT(dlg_regs->refcyc_per_line_delivery_pre_l < (unsigned int)dml_pow(2, 13));
|
||||
ASSERT(dlg_regs->refcyc_per_line_delivery_l < (unsigned int)dml_pow(2, 13));
|
||||
ASSERT(dlg_regs->refcyc_per_line_delivery_pre_c < (unsigned int)dml_pow(2, 13));
|
||||
ASSERT(dlg_regs->refcyc_per_line_delivery_c < (unsigned int)dml_pow(2, 13));
|
||||
ASSERT(ttu_regs->qos_level_low_wm < dml_pow(2, 14));
|
||||
ASSERT(ttu_regs->qos_level_high_wm < dml_pow(2, 14));
|
||||
ASSERT(ttu_regs->min_ttu_vblank < dml_pow(2, 24));
|
||||
|
||||
print__ttu_regs_st(mode_lib, ttu_regs);
|
||||
print__dlg_regs_st(mode_lib, dlg_regs);
|
||||
dml_print("DML_DLG::%s: Calculation for pipe[%d] done, num_pipes=%d\n", __func__, pipe_idx, num_pipes);
|
||||
}
|
||||
|
@ -0,0 +1,70 @@
|
||||
/*
|
||||
* Copyright 2022 Advanced Micro Devices, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
* Authors: AMD
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef __DML32_DISPLAY_RQ_DLG_CALC_H__
|
||||
#define __DML32_DISPLAY_RQ_DLG_CALC_H__
|
||||
|
||||
#include "../display_rq_dlg_helpers.h"
|
||||
|
||||
struct display_mode_lib;
|
||||
|
||||
/*
|
||||
* Function: dml_rq_dlg_get_rq_reg
|
||||
* Main entry point for test to get the register values out of this DML class.
|
||||
* This function calls <get_rq_param> and <extract_rq_regs> functions to calculate
|
||||
* and then populate the rq_regs struct
|
||||
* Input:
|
||||
* pipe_param - pipe source configuration (e.g. vp, pitch, scaling, dest, etc.)
|
||||
* Output:
|
||||
* rq_regs - struct that holds all the RQ registers field value.
|
||||
* See also: <display_rq_regs_st>
|
||||
*/
|
||||
void dml32_rq_dlg_get_rq_reg(display_rq_regs_st *rq_regs,
|
||||
struct display_mode_lib *mode_lib,
|
||||
const display_e2e_pipe_params_st *e2e_pipe_param,
|
||||
const unsigned int num_pipes,
|
||||
const unsigned int pipe_idx);
|
||||
|
||||
/*
|
||||
* Function: dml_rq_dlg_get_dlg_reg
|
||||
* Calculate and return DLG and TTU register struct given the system setting
|
||||
* Output:
|
||||
* dlg_regs - output DLG register struct
|
||||
* ttu_regs - output DLG TTU register struct
|
||||
* Input:
|
||||
* e2e_pipe_param - "compacted" array of e2e pipe param struct
|
||||
* num_pipes - num of active "pipe" or "route"
|
||||
* pipe_idx - index that identifies the e2e_pipe_param that corresponding to this dlg
|
||||
* cstate - 0: when calculate min_ttu_vblank it is assumed cstate is not required. 1: Normal mode, cstate is considered.
|
||||
* Added for legacy or unrealistic timing tests.
|
||||
*/
|
||||
void dml32_rq_dlg_get_dlg_reg(struct display_mode_lib *mode_lib,
|
||||
display_dlg_regs_st *dlg_regs,
|
||||
display_ttu_regs_st *ttu_regs,
|
||||
display_e2e_pipe_params_st *e2e_pipe_param,
|
||||
const unsigned int num_pipes,
|
||||
const unsigned int pipe_idx);
|
||||
|
||||
#endif
|
@ -26,7 +26,11 @@
|
||||
#define __DISPLAY_MODE_ENUMS_H__
|
||||
|
||||
enum output_encoder_class {
|
||||
dm_dp = 0, dm_hdmi = 1, dm_wb = 2, dm_edp
|
||||
dm_dp = 0,
|
||||
dm_hdmi = 1,
|
||||
dm_wb = 2,
|
||||
dm_edp = 3,
|
||||
dm_dp2p0 = 5,
|
||||
};
|
||||
enum output_format_class {
|
||||
dm_444 = 0, dm_420 = 1, dm_n422, dm_s422
|
||||
@ -105,6 +109,10 @@ enum clock_change_support {
|
||||
dm_dram_clock_change_uninitialized = 0,
|
||||
dm_dram_clock_change_vactive,
|
||||
dm_dram_clock_change_vblank,
|
||||
dm_dram_clock_change_vactive_w_mall_full_frame,
|
||||
dm_dram_clock_change_vactive_w_mall_sub_vp,
|
||||
dm_dram_clock_change_vblank_w_mall_full_frame,
|
||||
dm_dram_clock_change_vblank_w_mall_sub_vp,
|
||||
dm_dram_clock_change_unsupported
|
||||
};
|
||||
|
||||
@ -169,6 +177,9 @@ enum odm_combine_mode {
|
||||
dm_odm_combine_mode_disabled,
|
||||
dm_odm_combine_mode_2to1,
|
||||
dm_odm_combine_mode_4to1,
|
||||
dm_odm_split_mode_1to2,
|
||||
dm_odm_mode_mso_1to2,
|
||||
dm_odm_mode_mso_1to4
|
||||
};
|
||||
|
||||
enum odm_combine_policy {
|
||||
@ -176,11 +187,15 @@ enum odm_combine_policy {
|
||||
dm_odm_combine_policy_none,
|
||||
dm_odm_combine_policy_2to1,
|
||||
dm_odm_combine_policy_4to1,
|
||||
dm_odm_split_policy_1to2,
|
||||
dm_odm_mso_policy_1to2,
|
||||
dm_odm_mso_policy_1to4,
|
||||
};
|
||||
|
||||
enum immediate_flip_requirement {
|
||||
dm_immediate_flip_not_required,
|
||||
dm_immediate_flip_required,
|
||||
dm_immediate_flip_opportunistic,
|
||||
};
|
||||
|
||||
enum unbounded_requesting_policy {
|
||||
@ -189,4 +204,75 @@ enum unbounded_requesting_policy {
|
||||
dm_unbounded_requesting_disable
|
||||
};
|
||||
|
||||
enum dm_rotation_angle {
|
||||
dm_rotation_0,
|
||||
dm_rotation_90,
|
||||
dm_rotation_180,
|
||||
dm_rotation_270,
|
||||
dm_rotation_0m,
|
||||
dm_rotation_90m,
|
||||
dm_rotation_180m,
|
||||
dm_rotation_270m,
|
||||
};
|
||||
|
||||
enum dm_use_mall_for_pstate_change_mode {
|
||||
dm_use_mall_pstate_change_disable,
|
||||
dm_use_mall_pstate_change_full_frame,
|
||||
dm_use_mall_pstate_change_sub_viewport,
|
||||
dm_use_mall_pstate_change_phantom_pipe
|
||||
};
|
||||
|
||||
enum dm_use_mall_for_static_screen_mode {
|
||||
dm_use_mall_static_screen_disable,
|
||||
dm_use_mall_static_screen_optimize,
|
||||
dm_use_mall_static_screen_enable,
|
||||
};
|
||||
|
||||
enum dm_output_link_dp_rate {
|
||||
dm_dp_rate_na,
|
||||
dm_dp_rate_hbr,
|
||||
dm_dp_rate_hbr2,
|
||||
dm_dp_rate_hbr3,
|
||||
dm_dp_rate_uhbr10,
|
||||
dm_dp_rate_uhbr13p5,
|
||||
dm_dp_rate_uhbr20,
|
||||
};
|
||||
|
||||
enum dm_fclock_change_support {
|
||||
dm_fclock_change_vactive,
|
||||
dm_fclock_change_vblank,
|
||||
dm_fclock_change_unsupported,
|
||||
};
|
||||
|
||||
enum dm_prefetch_modes {
|
||||
dm_prefetch_support_uclk_fclk_and_stutter_if_possible,
|
||||
dm_prefetch_support_uclk_fclk_and_stutter,
|
||||
dm_prefetch_support_fclk_and_stutter,
|
||||
dm_prefetch_support_stutter,
|
||||
dm_prefetch_support_none,
|
||||
};
|
||||
enum dm_output_type {
|
||||
dm_output_type_unknown,
|
||||
dm_output_type_dp,
|
||||
dm_output_type_edp,
|
||||
dm_output_type_dp2p0,
|
||||
dm_output_type_hdmi,
|
||||
dm_output_type_hdmifrl,
|
||||
};
|
||||
|
||||
enum dm_output_rate {
|
||||
dm_output_rate_unknown,
|
||||
dm_output_rate_dp_rate_hbr,
|
||||
dm_output_rate_dp_rate_hbr2,
|
||||
dm_output_rate_dp_rate_hbr3,
|
||||
dm_output_rate_dp_rate_uhbr10,
|
||||
dm_output_rate_dp_rate_uhbr13p5,
|
||||
dm_output_rate_dp_rate_uhbr20,
|
||||
dm_output_rate_hdmi_rate_3x3,
|
||||
dm_output_rate_hdmi_rate_6x3,
|
||||
dm_output_rate_hdmi_rate_6x4,
|
||||
dm_output_rate_hdmi_rate_8x4,
|
||||
dm_output_rate_hdmi_rate_10x4,
|
||||
dm_output_rate_hdmi_rate_12x4,
|
||||
};
|
||||
#endif
|
||||
|
@ -35,6 +35,8 @@
|
||||
#include "dcn30/display_rq_dlg_calc_30.h"
|
||||
#include "dcn31/display_mode_vba_31.h"
|
||||
#include "dcn31/display_rq_dlg_calc_31.h"
|
||||
#include "dcn32/display_mode_vba_32.h"
|
||||
#include "dcn32/display_rq_dlg_calc_32.h"
|
||||
#include "dml_logger.h"
|
||||
|
||||
const struct dml_funcs dml20_funcs = {
|
||||
@ -72,6 +74,13 @@ const struct dml_funcs dml31_funcs = {
|
||||
.rq_dlg_get_rq_reg = dml31_rq_dlg_get_rq_reg
|
||||
};
|
||||
|
||||
const struct dml_funcs dml32_funcs = {
|
||||
.validate = dml32_ModeSupportAndSystemConfigurationFull,
|
||||
.recalculate = dml32_recalculate,
|
||||
.rq_dlg_get_dlg_reg_v2 = dml32_rq_dlg_get_dlg_reg,
|
||||
.rq_dlg_get_rq_reg_v2 = dml32_rq_dlg_get_rq_reg
|
||||
};
|
||||
|
||||
void dml_init_instance(struct display_mode_lib *lib,
|
||||
const struct _vcs_dpi_soc_bounding_box_st *soc_bb,
|
||||
const struct _vcs_dpi_ip_params_st *ip_params,
|
||||
@ -98,6 +107,9 @@ void dml_init_instance(struct display_mode_lib *lib,
|
||||
case DML_PROJECT_DCN31_FPGA:
|
||||
lib->funcs = dml31_funcs;
|
||||
break;
|
||||
case DML_PROJECT_DCN32:
|
||||
lib->funcs = dml32_funcs;
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
|
@ -41,6 +41,7 @@ enum dml_project {
|
||||
DML_PROJECT_DCN30,
|
||||
DML_PROJECT_DCN31,
|
||||
DML_PROJECT_DCN31_FPGA,
|
||||
DML_PROJECT_DCN32,
|
||||
};
|
||||
|
||||
struct display_mode_lib;
|
||||
@ -62,6 +63,20 @@ struct dml_funcs {
|
||||
struct display_mode_lib *mode_lib,
|
||||
display_rq_regs_st *rq_regs,
|
||||
const display_pipe_params_st *pipe_param);
|
||||
// DLG interfaces have different function parameters in DCN32.
|
||||
// Create new function pointers to address the changes
|
||||
void (*rq_dlg_get_dlg_reg_v2)(
|
||||
struct display_mode_lib *mode_lib,
|
||||
display_dlg_regs_st *dlg_regs,
|
||||
display_ttu_regs_st *ttu_regs,
|
||||
display_e2e_pipe_params_st *e2e_pipe_param,
|
||||
const unsigned int num_pipes,
|
||||
const unsigned int pipe_idx);
|
||||
void (*rq_dlg_get_rq_reg_v2)(display_rq_regs_st *rq_regs,
|
||||
struct display_mode_lib *mode_lib,
|
||||
const display_e2e_pipe_params_st *e2e_pipe_param,
|
||||
const unsigned int num_pipes,
|
||||
const unsigned int pipe_idx);
|
||||
void (*recalculate)(struct display_mode_lib *mode_lib);
|
||||
void (*validate)(struct display_mode_lib *mode_lib);
|
||||
};
|
||||
|
@ -54,12 +54,102 @@ typedef struct _vcs_dpi_display_rq_regs_st display_rq_regs_st;
|
||||
typedef struct _vcs_dpi_display_dlg_sys_params_st display_dlg_sys_params_st;
|
||||
typedef struct _vcs_dpi_display_arb_params_st display_arb_params_st;
|
||||
|
||||
typedef struct {
|
||||
double UrgentWatermark;
|
||||
double WritebackUrgentWatermark;
|
||||
double DRAMClockChangeWatermark;
|
||||
double FCLKChangeWatermark;
|
||||
double WritebackDRAMClockChangeWatermark;
|
||||
double WritebackFCLKChangeWatermark;
|
||||
double StutterExitWatermark;
|
||||
double StutterEnterPlusExitWatermark;
|
||||
double Z8StutterExitWatermark;
|
||||
double Z8StutterEnterPlusExitWatermark;
|
||||
double USRRetrainingWatermark;
|
||||
} Watermarks;
|
||||
|
||||
typedef struct {
|
||||
double UrgentLatency;
|
||||
double ExtraLatency;
|
||||
double WritebackLatency;
|
||||
double DRAMClockChangeLatency;
|
||||
double FCLKChangeLatency;
|
||||
double SRExitTime;
|
||||
double SREnterPlusExitTime;
|
||||
double SRExitZ8Time;
|
||||
double SREnterPlusExitZ8Time;
|
||||
double USRRetrainingLatencyPlusSMNLatency;
|
||||
} Latencies;
|
||||
|
||||
typedef struct {
|
||||
double Dppclk;
|
||||
double Dispclk;
|
||||
double PixelClock;
|
||||
double DCFClkDeepSleep;
|
||||
unsigned int DPPPerSurface;
|
||||
bool ScalerEnabled;
|
||||
enum dm_rotation_angle SourceRotation;
|
||||
unsigned int ViewportHeight;
|
||||
unsigned int ViewportHeightChroma;
|
||||
unsigned int BlockWidth256BytesY;
|
||||
unsigned int BlockHeight256BytesY;
|
||||
unsigned int BlockWidth256BytesC;
|
||||
unsigned int BlockHeight256BytesC;
|
||||
unsigned int BlockWidthY;
|
||||
unsigned int BlockHeightY;
|
||||
unsigned int BlockWidthC;
|
||||
unsigned int BlockHeightC;
|
||||
unsigned int InterlaceEnable;
|
||||
unsigned int NumberOfCursors;
|
||||
unsigned int VBlank;
|
||||
unsigned int HTotal;
|
||||
unsigned int HActive;
|
||||
bool DCCEnable;
|
||||
enum odm_combine_mode ODMMode;
|
||||
enum source_format_class SourcePixelFormat;
|
||||
enum dm_swizzle_mode SurfaceTiling;
|
||||
unsigned int BytePerPixelY;
|
||||
unsigned int BytePerPixelC;
|
||||
bool ProgressiveToInterlaceUnitInOPP;
|
||||
double VRatio;
|
||||
double VRatioChroma;
|
||||
unsigned int VTaps;
|
||||
unsigned int VTapsChroma;
|
||||
unsigned int PitchY;
|
||||
unsigned int DCCMetaPitchY;
|
||||
unsigned int PitchC;
|
||||
unsigned int DCCMetaPitchC;
|
||||
bool ViewportStationary;
|
||||
unsigned int ViewportXStart;
|
||||
unsigned int ViewportYStart;
|
||||
unsigned int ViewportXStartC;
|
||||
unsigned int ViewportYStartC;
|
||||
bool FORCE_ONE_ROW_FOR_FRAME;
|
||||
unsigned int SwathHeightY;
|
||||
unsigned int SwathHeightC;
|
||||
} DmlPipe;
|
||||
|
||||
typedef struct {
|
||||
double UrgentLatency;
|
||||
double ExtraLatency;
|
||||
double WritebackLatency;
|
||||
double DRAMClockChangeLatency;
|
||||
double FCLKChangeLatency;
|
||||
double SRExitTime;
|
||||
double SREnterPlusExitTime;
|
||||
double SRExitZ8Time;
|
||||
double SREnterPlusExitZ8Time;
|
||||
double USRRetrainingLatency;
|
||||
double SMNLatency;
|
||||
} SOCParametersList;
|
||||
|
||||
struct _vcs_dpi_voltage_scaling_st {
|
||||
int state;
|
||||
double dscclk_mhz;
|
||||
double dcfclk_mhz;
|
||||
double socclk_mhz;
|
||||
double phyclk_d18_mhz;
|
||||
double phyclk_d32_mhz;
|
||||
double dram_speed_mts;
|
||||
double fabricclk_mhz;
|
||||
double dispclk_mhz;
|
||||
@ -80,6 +170,15 @@ struct _vcs_dpi_soc_bounding_box_st {
|
||||
double urgent_latency_pixel_data_only_us;
|
||||
double urgent_latency_pixel_mixed_with_vm_data_us;
|
||||
double urgent_latency_vm_data_only_us;
|
||||
double usr_retraining_latency_us;
|
||||
double smn_latency_us;
|
||||
double fclk_change_latency_us;
|
||||
double mall_allocated_for_dcn_mbytes;
|
||||
double pct_ideal_fabric_bw_after_urgent;
|
||||
double pct_ideal_dram_bw_after_urgent_strobe;
|
||||
double max_avg_fabric_bw_use_normal_percent;
|
||||
double max_avg_dram_bw_use_normal_strobe_percent;
|
||||
enum dm_prefetch_modes allow_for_pstate_or_stutter_in_vblank_final;
|
||||
double writeback_latency_us;
|
||||
double ideal_dram_bw_after_urgent_percent;
|
||||
double pct_ideal_dram_sdp_bw_after_urgent_pixel_only; // PercentOfIdealDRAMFabricAndSDPPortBWReceivedAfterUrgLatencyPixelDataOnly
|
||||
@ -148,6 +247,9 @@ struct _vcs_dpi_ip_params_st {
|
||||
unsigned int dpp_output_buffer_pixels;
|
||||
unsigned int opp_output_buffer_lines;
|
||||
unsigned int pixel_chunk_size_kbytes;
|
||||
unsigned int alpha_pixel_chunk_size_kbytes;
|
||||
unsigned int min_pixel_chunk_size_bytes;
|
||||
unsigned int dcc_meta_buffer_size_bytes;
|
||||
unsigned char pte_enable;
|
||||
unsigned int pte_chunk_size_kbytes;
|
||||
unsigned int meta_chunk_size_kbytes;
|
||||
@ -168,6 +270,7 @@ struct _vcs_dpi_ip_params_st {
|
||||
double writeback_min_hscl_ratio;
|
||||
double writeback_min_vscl_ratio;
|
||||
unsigned int maximum_dsc_bits_per_component;
|
||||
unsigned int maximum_pixels_per_line_per_dsc_unit;
|
||||
unsigned int writeback_max_hscl_taps;
|
||||
unsigned int writeback_max_vscl_taps;
|
||||
unsigned int writeback_line_buffer_luma_buffer_size;
|
||||
@ -224,6 +327,8 @@ struct _vcs_dpi_ip_params_st {
|
||||
unsigned int can_vstartup_lines_exceed_vsync_plus_back_porch_lines_minus_one;
|
||||
unsigned int bug_forcing_LC_req_same_size_fixed;
|
||||
unsigned int number_of_cursors;
|
||||
unsigned int max_num_dp2p0_outputs;
|
||||
unsigned int max_num_dp2p0_streams;
|
||||
};
|
||||
|
||||
struct _vcs_dpi_display_xfc_params_st {
|
||||
@ -250,6 +355,7 @@ struct _vcs_dpi_display_pipe_source_params_st {
|
||||
bool hostvm_levels_force_en;
|
||||
unsigned int hostvm_levels_force;
|
||||
int source_scan;
|
||||
int source_rotation; // new in dml32
|
||||
int sw_mode;
|
||||
int macro_tile_size;
|
||||
unsigned int surface_width_y;
|
||||
@ -264,6 +370,15 @@ struct _vcs_dpi_display_pipe_source_params_st {
|
||||
unsigned int viewport_height_c;
|
||||
unsigned int viewport_width_max;
|
||||
unsigned int viewport_height_max;
|
||||
unsigned int viewport_x_y;
|
||||
unsigned int viewport_x_c;
|
||||
bool viewport_stationary;
|
||||
unsigned int dcc_rate_luma;
|
||||
unsigned int gpuvm_min_page_size_kbytes;
|
||||
unsigned int use_mall_for_pstate_change;
|
||||
unsigned int use_mall_for_static_screen;
|
||||
bool force_one_row_for_frame;
|
||||
bool pte_buffer_mode;
|
||||
unsigned int data_pitch;
|
||||
unsigned int data_pitch_c;
|
||||
unsigned int meta_pitch;
|
||||
@ -296,10 +411,17 @@ struct writeback_st {
|
||||
int wb_vtaps_luma;
|
||||
int wb_htaps_chroma;
|
||||
int wb_vtaps_chroma;
|
||||
unsigned int wb_htaps;
|
||||
unsigned int wb_vtaps;
|
||||
double wb_hratio;
|
||||
double wb_vratio;
|
||||
};
|
||||
|
||||
struct display_audio_params_st {
|
||||
unsigned int audio_sample_rate_khz;
|
||||
int audio_sample_layout;
|
||||
};
|
||||
|
||||
struct _vcs_dpi_display_output_params_st {
|
||||
int dp_lanes;
|
||||
double output_bpp;
|
||||
@ -313,6 +435,11 @@ struct _vcs_dpi_display_output_params_st {
|
||||
int dsc_slices;
|
||||
int max_audio_sample_rate;
|
||||
struct writeback_st wb;
|
||||
struct display_audio_params_st audio;
|
||||
unsigned int output_bpc;
|
||||
int dp_rate;
|
||||
unsigned int dp_multistream_id;
|
||||
bool dp_multistream_en;
|
||||
};
|
||||
|
||||
struct _vcs_dpi_scaler_ratio_depth_st {
|
||||
@ -361,6 +488,8 @@ struct _vcs_dpi_display_pipe_dest_params_st {
|
||||
unsigned char use_maximum_vstartup;
|
||||
unsigned int vtotal_max;
|
||||
unsigned int vtotal_min;
|
||||
unsigned int refresh_rate;
|
||||
bool synchronize_timings;
|
||||
};
|
||||
|
||||
struct _vcs_dpi_display_pipe_params_st {
|
||||
@ -558,6 +687,9 @@ struct _vcs_dpi_display_arb_params_st {
|
||||
int max_req_outstanding;
|
||||
int min_req_outstanding;
|
||||
int sat_level_us;
|
||||
int hvm_min_req_outstand_commit_threshold;
|
||||
int hvm_max_qos_commit_threshold;
|
||||
int compbuf_reserved_space_kbytes;
|
||||
};
|
||||
|
||||
#endif /*__DISPLAY_MODE_STRUCTS_H__*/
|
||||
|
@ -110,6 +110,15 @@ dml_get_attr_func(return_bw, mode_lib->vba.ReturnBW);
|
||||
dml_get_attr_func(tcalc, mode_lib->vba.TCalc);
|
||||
dml_get_attr_func(fraction_of_urgent_bandwidth, mode_lib->vba.FractionOfUrgentBandwidth);
|
||||
dml_get_attr_func(fraction_of_urgent_bandwidth_imm_flip, mode_lib->vba.FractionOfUrgentBandwidthImmediateFlip);
|
||||
dml_get_attr_func(cstate_max_cap_mode, mode_lib->vba.DCHUBBUB_ARB_CSTATE_MAX_CAP_MODE);
|
||||
dml_get_attr_func(comp_buffer_size_kbytes, mode_lib->vba.CompressedBufferSizeInkByte);
|
||||
dml_get_attr_func(pixel_chunk_size_in_kbyte, mode_lib->vba.PixelChunkSizeInKByte);
|
||||
dml_get_attr_func(alpha_pixel_chunk_size_in_kbyte, mode_lib->vba.AlphaPixelChunkSizeInKByte);
|
||||
dml_get_attr_func(meta_chunk_size_in_kbyte, mode_lib->vba.MetaChunkSize);
|
||||
dml_get_attr_func(min_pixel_chunk_size_in_byte, mode_lib->vba.MinPixelChunkSizeBytes);
|
||||
dml_get_attr_func(min_meta_chunk_size_in_byte, mode_lib->vba.MinMetaChunkSizeBytes);
|
||||
dml_get_attr_func(fclk_watermark, mode_lib->vba.Watermark.FCLKChangeWatermark);
|
||||
dml_get_attr_func(usr_retraining_watermark, mode_lib->vba.Watermark.USRRetrainingWatermark);
|
||||
|
||||
#define dml_get_pipe_attr_func(attr, var) double get_##attr(struct display_mode_lib *mode_lib, const display_e2e_pipe_params_st *pipes, unsigned int num_pipes, unsigned int which_pipe) \
|
||||
{\
|
||||
@ -165,6 +174,27 @@ dml_get_pipe_attr_func(vupdate_width, mode_lib->vba.VUpdateWidthPix);
|
||||
dml_get_pipe_attr_func(vready_offset, mode_lib->vba.VReadyOffsetPix);
|
||||
dml_get_pipe_attr_func(vready_at_or_after_vsync, mode_lib->vba.VREADY_AT_OR_AFTER_VSYNC);
|
||||
dml_get_pipe_attr_func(min_dst_y_next_start, mode_lib->vba.MIN_DST_Y_NEXT_START);
|
||||
dml_get_pipe_attr_func(dst_y_per_pte_row_nom_l, mode_lib->vba.DST_Y_PER_PTE_ROW_NOM_L);
|
||||
dml_get_pipe_attr_func(dst_y_per_pte_row_nom_c, mode_lib->vba.DST_Y_PER_PTE_ROW_NOM_C);
|
||||
dml_get_pipe_attr_func(dst_y_per_meta_row_nom_l, mode_lib->vba.DST_Y_PER_META_ROW_NOM_L);
|
||||
dml_get_pipe_attr_func(dst_y_per_meta_row_nom_c, mode_lib->vba.DST_Y_PER_META_ROW_NOM_C);
|
||||
dml_get_pipe_attr_func(refcyc_per_pte_group_nom_l_in_us, mode_lib->vba.time_per_pte_group_nom_luma);
|
||||
dml_get_pipe_attr_func(refcyc_per_pte_group_nom_c_in_us, mode_lib->vba.time_per_pte_group_nom_chroma);
|
||||
dml_get_pipe_attr_func(refcyc_per_pte_group_vblank_l_in_us, mode_lib->vba.time_per_pte_group_vblank_luma);
|
||||
dml_get_pipe_attr_func(refcyc_per_pte_group_vblank_c_in_us, mode_lib->vba.time_per_pte_group_vblank_chroma);
|
||||
dml_get_pipe_attr_func(refcyc_per_pte_group_flip_l_in_us, mode_lib->vba.time_per_pte_group_flip_luma);
|
||||
dml_get_pipe_attr_func(refcyc_per_pte_group_flip_c_in_us, mode_lib->vba.time_per_pte_group_flip_chroma);
|
||||
dml_get_pipe_attr_func(vstartup_calculated, mode_lib->vba.VStartup);
|
||||
dml_get_pipe_attr_func(dpte_row_height_linear_c, mode_lib->vba.dpte_row_height_linear_chroma);
|
||||
dml_get_pipe_attr_func(swath_height_l, mode_lib->vba.SwathHeightY);
|
||||
dml_get_pipe_attr_func(swath_height_c, mode_lib->vba.SwathHeightC);
|
||||
dml_get_pipe_attr_func(det_stored_buffer_size_l_bytes, mode_lib->vba.DETBufferSizeY);
|
||||
dml_get_pipe_attr_func(det_stored_buffer_size_c_bytes, mode_lib->vba.DETBufferSizeC);
|
||||
dml_get_pipe_attr_func(dpte_group_size_in_bytes, mode_lib->vba.dpte_group_bytes);
|
||||
dml_get_pipe_attr_func(vm_group_size_in_bytes, mode_lib->vba.vm_group_bytes);
|
||||
dml_get_pipe_attr_func(dpte_row_height_linear_l, mode_lib->vba.dpte_row_height_linear);
|
||||
dml_get_pipe_attr_func(pte_buffer_mode, mode_lib->vba.PTE_BUFFER_MODE);
|
||||
dml_get_pipe_attr_func(subviewport_lines_needed_in_mall, mode_lib->vba.SubViewportLinesNeededInMALL);
|
||||
|
||||
double get_total_immediate_flip_bytes(
|
||||
struct display_mode_lib *mode_lib,
|
||||
@ -202,6 +232,67 @@ double get_total_prefetch_bw(
|
||||
return total_prefetch_bw;
|
||||
}
|
||||
|
||||
unsigned int get_total_surface_size_in_mall_bytes(
|
||||
struct display_mode_lib *mode_lib,
|
||||
const display_e2e_pipe_params_st *pipes,
|
||||
unsigned int num_pipes)
|
||||
{
|
||||
unsigned int k;
|
||||
unsigned int size = 0.0;
|
||||
recalculate_params(mode_lib, pipes, num_pipes);
|
||||
for (k = 0; k < mode_lib->vba.NumberOfActiveSurfaces; ++k)
|
||||
size += mode_lib->vba.SurfaceSizeInMALL[k];
|
||||
return size;
|
||||
}
|
||||
|
||||
unsigned int get_pipe_idx(struct display_mode_lib *mode_lib, unsigned int plane_idx)
|
||||
{
|
||||
int pipe_idx = -1;
|
||||
int i;
|
||||
|
||||
ASSERT(plane_idx < DC__NUM_DPP__MAX);
|
||||
|
||||
for (i = 0; i < DC__NUM_DPP__MAX ; i++) {
|
||||
if (plane_idx == mode_lib->vba.pipe_plane[i]) {
|
||||
pipe_idx = i;
|
||||
break;
|
||||
}
|
||||
}
|
||||
ASSERT(pipe_idx >= 0);
|
||||
|
||||
return pipe_idx;
|
||||
}
|
||||
|
||||
|
||||
double get_det_buffer_size_kbytes(struct display_mode_lib *mode_lib, const display_e2e_pipe_params_st *pipes,
|
||||
unsigned int num_pipes, unsigned int pipe_idx)
|
||||
{
|
||||
unsigned int plane_idx;
|
||||
double det_buf_size_kbytes;
|
||||
|
||||
recalculate_params(mode_lib, pipes, num_pipes);
|
||||
plane_idx = mode_lib->vba.pipe_plane[pipe_idx];
|
||||
|
||||
dml_print("DML::%s: num_pipes=%d pipe_idx=%d plane_idx=%0d\n", __func__, num_pipes, pipe_idx, plane_idx);
|
||||
det_buf_size_kbytes = mode_lib->vba.DETBufferSizeInKByte[plane_idx]; // per hubp DET buffer size
|
||||
|
||||
dml_print("DML::%s: det_buf_size_kbytes=%3.2f\n", __func__, det_buf_size_kbytes);
|
||||
|
||||
return det_buf_size_kbytes;
|
||||
}
|
||||
|
||||
bool get_is_phantom_pipe(struct display_mode_lib *mode_lib, const display_e2e_pipe_params_st *pipes,
|
||||
unsigned int num_pipes, unsigned int pipe_idx)
|
||||
{
|
||||
unsigned int plane_idx;
|
||||
|
||||
recalculate_params(mode_lib, pipes, num_pipes);
|
||||
plane_idx = mode_lib->vba.pipe_plane[pipe_idx];
|
||||
dml_print("DML::%s: num_pipes=%d pipe_idx=%d UseMALLForPStateChange=%0d\n", __func__, num_pipes, pipe_idx,
|
||||
mode_lib->vba.UsesMALLForPStateChange[plane_idx]);
|
||||
return (mode_lib->vba.UsesMALLForPStateChange[plane_idx] == dm_use_mall_pstate_change_phantom_pipe);
|
||||
}
|
||||
|
||||
static void fetch_socbb_params(struct display_mode_lib *mode_lib)
|
||||
{
|
||||
soc_bounding_box_st *soc = &mode_lib->vba.soc;
|
||||
@ -241,6 +332,22 @@ static void fetch_socbb_params(struct display_mode_lib *mode_lib)
|
||||
soc->max_avg_sdp_bw_use_normal_percent;
|
||||
mode_lib->vba.SRExitZ8Time = soc->sr_exit_z8_time_us;
|
||||
mode_lib->vba.SREnterPlusExitZ8Time = soc->sr_enter_plus_exit_z8_time_us;
|
||||
mode_lib->vba.FCLKChangeLatency = soc->fclk_change_latency_us;
|
||||
mode_lib->vba.USRRetrainingLatency = soc->usr_retraining_latency_us;
|
||||
mode_lib->vba.SMNLatency = soc->smn_latency_us;
|
||||
mode_lib->vba.MALLAllocatedForDCNFinal = soc->mall_allocated_for_dcn_mbytes;
|
||||
|
||||
mode_lib->vba.PercentOfIdealDRAMBWReceivedAfterUrgLatencySTROBE = soc->pct_ideal_dram_bw_after_urgent_strobe;
|
||||
mode_lib->vba.MaxAveragePercentOfIdealFabricBWDisplayCanUseInNormalSystemOperation =
|
||||
soc->max_avg_fabric_bw_use_normal_percent;
|
||||
mode_lib->vba.MaxAveragePercentOfIdealDRAMBWDisplayCanUseInNormalSystemOperationSTROBE =
|
||||
soc->max_avg_dram_bw_use_normal_strobe_percent;
|
||||
|
||||
mode_lib->vba.DRAMClockChangeRequirementFinal = 1;
|
||||
mode_lib->vba.FCLKChangeRequirementFinal = 1;
|
||||
mode_lib->vba.USRRetrainingRequiredFinal = 1;
|
||||
mode_lib->vba.ConfigurableDETSizeEnFinal = 0;
|
||||
mode_lib->vba.AllowForPStateChangeOrStutterInVBlankFinal = soc->allow_for_pstate_or_stutter_in_vblank_final;
|
||||
mode_lib->vba.DRAMClockChangeLatency = soc->dram_clock_change_latency_us;
|
||||
mode_lib->vba.DummyPStateCheck = soc->dram_clock_change_latency_us == soc->dummy_pstate_latency_us;
|
||||
mode_lib->vba.DRAMClockChangeSupportsVActive = !soc->disable_dram_clock_change_vactive_support ||
|
||||
@ -283,6 +390,7 @@ static void fetch_socbb_params(struct display_mode_lib *mode_lib)
|
||||
mode_lib->vba.SOCCLKPerState[i] = soc->clock_limits[i].socclk_mhz;
|
||||
mode_lib->vba.PHYCLKPerState[i] = soc->clock_limits[i].phyclk_mhz;
|
||||
mode_lib->vba.PHYCLKD18PerState[i] = soc->clock_limits[i].phyclk_d18_mhz;
|
||||
mode_lib->vba.PHYCLKD32PerState[i] = soc->clock_limits[i].phyclk_d32_mhz;
|
||||
mode_lib->vba.MaxDppclk[i] = soc->clock_limits[i].dppclk_mhz;
|
||||
mode_lib->vba.MaxDSCCLK[i] = soc->clock_limits[i].dscclk_mhz;
|
||||
mode_lib->vba.DRAMSpeedPerState[i] = soc->clock_limits[i].dram_speed_mts;
|
||||
@ -325,6 +433,18 @@ static void fetch_ip_params(struct display_mode_lib *mode_lib)
|
||||
mode_lib->vba.COMPBUF_RESERVED_SPACE_ZS = ip->compbuf_reserved_space_zs;
|
||||
mode_lib->vba.MaximumDSCBitsPerComponent = ip->maximum_dsc_bits_per_component;
|
||||
mode_lib->vba.DSC422NativeSupport = ip->dsc422_native_support;
|
||||
/* In DCN3.2, nomDETInKByte should be initialized correctly. */
|
||||
mode_lib->vba.nomDETInKByte = ip->det_buffer_size_kbytes;
|
||||
mode_lib->vba.CompbufReservedSpace64B = ip->compbuf_reserved_space_64b;
|
||||
mode_lib->vba.CompbufReservedSpaceZs = ip->compbuf_reserved_space_zs;
|
||||
mode_lib->vba.CompressedBufferSegmentSizeInkByteFinal = ip->compressed_buffer_segment_size_in_kbytes;
|
||||
mode_lib->vba.LineBufferSizeFinal = ip->line_buffer_size_bits;
|
||||
mode_lib->vba.AlphaPixelChunkSizeInKByte = ip->alpha_pixel_chunk_size_kbytes; // not ysed
|
||||
mode_lib->vba.MinPixelChunkSizeBytes = ip->min_pixel_chunk_size_bytes; // not used
|
||||
mode_lib->vba.MaximumPixelsPerLinePerDSCUnit = ip->maximum_pixels_per_line_per_dsc_unit;
|
||||
mode_lib->vba.MaxNumDP2p0Outputs = ip->max_num_dp2p0_outputs;
|
||||
mode_lib->vba.MaxNumDP2p0Streams = ip->max_num_dp2p0_streams;
|
||||
mode_lib->vba.DCCMetaBufferSizeBytes = ip->dcc_meta_buffer_size_bytes;
|
||||
|
||||
mode_lib->vba.PixelChunkSizeInKByte = ip->pixel_chunk_size_kbytes;
|
||||
mode_lib->vba.MetaChunkSize = ip->meta_chunk_size_kbytes;
|
||||
@ -399,6 +519,7 @@ static void fetch_pipe_params(struct display_mode_lib *mode_lib)
|
||||
visited[k] = false;
|
||||
|
||||
mode_lib->vba.NumberOfActivePlanes = 0;
|
||||
mode_lib->vba.NumberOfActiveSurfaces = 0;
|
||||
mode_lib->vba.ImmediateFlipSupport = false;
|
||||
for (j = 0; j < mode_lib->vba.cache_num_pipes; ++j) {
|
||||
display_pipe_source_params_st *src = &pipes[j].pipe.src;
|
||||
@ -429,6 +550,21 @@ static void fetch_pipe_params(struct display_mode_lib *mode_lib)
|
||||
src->viewport_y_y;
|
||||
mode_lib->vba.ViewportYStartC[mode_lib->vba.NumberOfActivePlanes] =
|
||||
src->viewport_y_c;
|
||||
mode_lib->vba.SourceRotation[mode_lib->vba.NumberOfActiveSurfaces] = src->source_rotation;
|
||||
mode_lib->vba.ViewportXStartY[mode_lib->vba.NumberOfActiveSurfaces] = src->viewport_x_y;
|
||||
mode_lib->vba.ViewportXStartC[mode_lib->vba.NumberOfActiveSurfaces] = src->viewport_x_c;
|
||||
// TODO: Assign correct value to viewport_stationary
|
||||
mode_lib->vba.ViewportStationary[mode_lib->vba.NumberOfActivePlanes] =
|
||||
src->viewport_stationary;
|
||||
mode_lib->vba.UsesMALLForPStateChange[mode_lib->vba.NumberOfActivePlanes] = src->use_mall_for_pstate_change;
|
||||
mode_lib->vba.UseMALLForStaticScreen[mode_lib->vba.NumberOfActivePlanes] = src->use_mall_for_static_screen;
|
||||
mode_lib->vba.GPUVMMinPageSizeKBytes[mode_lib->vba.NumberOfActivePlanes] = src->gpuvm_min_page_size_kbytes;
|
||||
mode_lib->vba.RefreshRate[mode_lib->vba.NumberOfActivePlanes] = dst->refresh_rate; //todo remove this
|
||||
mode_lib->vba.OutputLinkDPRate[mode_lib->vba.NumberOfActivePlanes] = dout->dp_rate;
|
||||
mode_lib->vba.ODMUse[mode_lib->vba.NumberOfActivePlanes] = dst->odm_combine;
|
||||
//TODO: Need to assign correct values to dp_multistream vars
|
||||
mode_lib->vba.OutputMultistreamEn[mode_lib->vba.NumberOfActiveSurfaces] = dout->dp_multistream_en;
|
||||
mode_lib->vba.OutputMultistreamId[mode_lib->vba.NumberOfActiveSurfaces] = dout->dp_multistream_id;
|
||||
mode_lib->vba.PitchY[mode_lib->vba.NumberOfActivePlanes] = src->data_pitch;
|
||||
mode_lib->vba.SurfaceWidthY[mode_lib->vba.NumberOfActivePlanes] = src->surface_width_y;
|
||||
mode_lib->vba.SurfaceHeightY[mode_lib->vba.NumberOfActivePlanes] = src->surface_height_y;
|
||||
@ -677,6 +813,7 @@ static void fetch_pipe_params(struct display_mode_lib *mode_lib)
|
||||
}
|
||||
|
||||
mode_lib->vba.NumberOfActivePlanes++;
|
||||
mode_lib->vba.NumberOfActiveSurfaces++;
|
||||
}
|
||||
|
||||
// handle overlays through BlendingAndTiming
|
||||
@ -702,6 +839,8 @@ static void fetch_pipe_params(struct display_mode_lib *mode_lib)
|
||||
}
|
||||
}
|
||||
|
||||
mode_lib->vba.SynchronizeTimingsFinal = pipes[0].pipe.dest.synchronize_timings;
|
||||
mode_lib->vba.DCCProgrammingAssumesScanDirectionUnknownFinal = false;
|
||||
mode_lib->vba.UseUnboundedRequesting = dm_unbounded_requesting;
|
||||
for (k = 0; k < mode_lib->vba.cache_num_pipes; ++k) {
|
||||
if (pipes[k].pipe.src.unbounded_req_mode == 0)
|
||||
@ -745,6 +884,32 @@ static void fetch_pipe_params(struct display_mode_lib *mode_lib)
|
||||
|
||||
mode_lib->vba.GPUVMEnable = mode_lib->vba.GPUVMEnable && !!ip->gpuvm_enable;
|
||||
mode_lib->vba.HostVMEnable = mode_lib->vba.HostVMEnable && !!ip->hostvm_enable;
|
||||
|
||||
for (k = 0; k < mode_lib->vba.cache_num_pipes; ++k) {
|
||||
mode_lib->vba.ForceOneRowForFrame[k] = pipes[k].pipe.src.force_one_row_for_frame;
|
||||
mode_lib->vba.PteBufferMode[k] = pipes[k].pipe.src.pte_buffer_mode;
|
||||
|
||||
if (mode_lib->vba.PteBufferMode[k] == 0 && mode_lib->vba.GPUVMEnable) {
|
||||
if (mode_lib->vba.ForceOneRowForFrame[k] ||
|
||||
(mode_lib->vba.GPUVMMinPageSizeKBytes[k] > 64*1024) ||
|
||||
(mode_lib->vba.UsesMALLForPStateChange[k] != dm_use_mall_pstate_change_disable) ||
|
||||
(mode_lib->vba.UseMALLForStaticScreen[k] != dm_use_mall_static_screen_disable)) {
|
||||
#ifdef __DML_VBA_DEBUG__
|
||||
dml_print("DML::%s: ERROR: Invalid PteBufferMode=%d for plane %0d!\n",
|
||||
__func__, mode_lib->vba.PteBufferMode[k], k);
|
||||
dml_print("DML::%s: - ForceOneRowForFrame = %d\n",
|
||||
__func__, mode_lib->vba.ForceOneRowForFrame[k]);
|
||||
dml_print("DML::%s: - GPUVMMinPageSizeKBytes = %d\n",
|
||||
__func__, mode_lib->vba.GPUVMMinPageSizeKBytes[k]);
|
||||
dml_print("DML::%s: - UseMALLForPStateChange = %d\n",
|
||||
__func__, (int) mode_lib->vba.UsesMALLForPStateChange[k]);
|
||||
dml_print("DML::%s: - UseMALLForStaticScreen = %d\n",
|
||||
__func__, (int) mode_lib->vba.UseMALLForStaticScreen[k]);
|
||||
#endif
|
||||
ASSERT(0);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -896,6 +1061,7 @@ void ModeSupportAndSystemConfiguration(struct display_mode_lib *mode_lib)
|
||||
soc_bounding_box_st *soc = &mode_lib->vba.soc;
|
||||
unsigned int k;
|
||||
unsigned int total_pipes = 0;
|
||||
unsigned int pipe_idx = 0;
|
||||
|
||||
mode_lib->vba.VoltageLevel = mode_lib->vba.cache_pipes[0].clks_cfg.voltage;
|
||||
mode_lib->vba.ReturnBW = mode_lib->vba.ReturnBWPerState[mode_lib->vba.VoltageLevel][mode_lib->vba.maxMpcComb];
|
||||
@ -917,6 +1083,11 @@ void ModeSupportAndSystemConfiguration(struct display_mode_lib *mode_lib)
|
||||
// Total Available Pipes Support Check
|
||||
for (k = 0; k < mode_lib->vba.NumberOfActivePlanes; ++k) {
|
||||
total_pipes += mode_lib->vba.DPPPerPlane[k];
|
||||
pipe_idx = get_pipe_idx(mode_lib, k);
|
||||
if (mode_lib->vba.cache_pipes[pipe_idx].clks_cfg.dppclk_mhz > 0.0)
|
||||
mode_lib->vba.DPPCLK[k] = mode_lib->vba.cache_pipes[pipe_idx].clks_cfg.dppclk_mhz;
|
||||
else
|
||||
mode_lib->vba.DPPCLK[k] = soc->clock_limits[mode_lib->vba.VoltageLevel].dppclk_mhz;
|
||||
}
|
||||
ASSERT(total_pipes <= DC__NUM_DPP__MAX);
|
||||
}
|
||||
|
@ -58,6 +58,15 @@ dml_get_attr_decl(return_bw);
|
||||
dml_get_attr_decl(tcalc);
|
||||
dml_get_attr_decl(fraction_of_urgent_bandwidth);
|
||||
dml_get_attr_decl(fraction_of_urgent_bandwidth_imm_flip);
|
||||
dml_get_attr_decl(cstate_max_cap_mode);
|
||||
dml_get_attr_decl(comp_buffer_size_kbytes);
|
||||
dml_get_attr_decl(pixel_chunk_size_in_kbyte);
|
||||
dml_get_attr_decl(alpha_pixel_chunk_size_in_kbyte);
|
||||
dml_get_attr_decl(meta_chunk_size_in_kbyte);
|
||||
dml_get_attr_decl(min_pixel_chunk_size_in_byte);
|
||||
dml_get_attr_decl(min_meta_chunk_size_in_byte);
|
||||
dml_get_attr_decl(fclk_watermark);
|
||||
dml_get_attr_decl(usr_retraining_watermark);
|
||||
|
||||
#define dml_get_pipe_attr_decl(attr) double get_##attr(struct display_mode_lib *mode_lib, const display_e2e_pipe_params_st *pipes, unsigned int num_pipes, unsigned int which_pipe)
|
||||
|
||||
@ -75,6 +84,26 @@ dml_get_pipe_attr_decl(dst_y_per_row_vblank);
|
||||
dml_get_pipe_attr_decl(dst_y_prefetch);
|
||||
dml_get_pipe_attr_decl(dst_y_per_vm_flip);
|
||||
dml_get_pipe_attr_decl(dst_y_per_row_flip);
|
||||
dml_get_pipe_attr_decl(dst_y_per_pte_row_nom_l);
|
||||
dml_get_pipe_attr_decl(dst_y_per_pte_row_nom_c);
|
||||
dml_get_pipe_attr_decl(dst_y_per_meta_row_nom_l);
|
||||
dml_get_pipe_attr_decl(dst_y_per_meta_row_nom_c);
|
||||
dml_get_pipe_attr_decl(dpte_row_height_linear_c);
|
||||
dml_get_pipe_attr_decl(swath_height_l);
|
||||
dml_get_pipe_attr_decl(swath_height_c);
|
||||
dml_get_pipe_attr_decl(det_stored_buffer_size_l_bytes);
|
||||
dml_get_pipe_attr_decl(det_stored_buffer_size_c_bytes);
|
||||
dml_get_pipe_attr_decl(dpte_group_size_in_bytes);
|
||||
dml_get_pipe_attr_decl(vm_group_size_in_bytes);
|
||||
dml_get_pipe_attr_decl(det_buffer_size_kbytes);
|
||||
dml_get_pipe_attr_decl(dpte_row_height_linear_l);
|
||||
dml_get_pipe_attr_decl(refcyc_per_pte_group_nom_l_in_us);
|
||||
dml_get_pipe_attr_decl(refcyc_per_pte_group_nom_c_in_us);
|
||||
dml_get_pipe_attr_decl(refcyc_per_pte_group_vblank_l_in_us);
|
||||
dml_get_pipe_attr_decl(refcyc_per_pte_group_vblank_c_in_us);
|
||||
dml_get_pipe_attr_decl(refcyc_per_pte_group_flip_l_in_us);
|
||||
dml_get_pipe_attr_decl(refcyc_per_pte_group_flip_c_in_us);
|
||||
dml_get_pipe_attr_decl(pte_buffer_mode);
|
||||
dml_get_pipe_attr_decl(refcyc_per_vm_group_vblank);
|
||||
dml_get_pipe_attr_decl(refcyc_per_vm_group_flip);
|
||||
dml_get_pipe_attr_decl(refcyc_per_vm_req_vblank);
|
||||
@ -108,6 +137,8 @@ dml_get_pipe_attr_decl(vupdate_width);
|
||||
dml_get_pipe_attr_decl(vready_offset);
|
||||
dml_get_pipe_attr_decl(vready_at_or_after_vsync);
|
||||
dml_get_pipe_attr_decl(min_dst_y_next_start);
|
||||
dml_get_pipe_attr_decl(vstartup_calculated);
|
||||
dml_get_pipe_attr_decl(subviewport_lines_needed_in_mall);
|
||||
|
||||
double get_total_immediate_flip_bytes(
|
||||
struct display_mode_lib *mode_lib,
|
||||
@ -126,6 +157,16 @@ unsigned int dml_get_voltage_level(
|
||||
const display_e2e_pipe_params_st *pipes,
|
||||
unsigned int num_pipes);
|
||||
|
||||
unsigned int get_total_surface_size_in_mall_bytes(
|
||||
struct display_mode_lib *mode_lib,
|
||||
const display_e2e_pipe_params_st *pipes,
|
||||
unsigned int num_pipes);
|
||||
unsigned int get_pipe_idx(struct display_mode_lib *mode_lib, unsigned int plane_idx);
|
||||
|
||||
bool get_is_phantom_pipe(struct display_mode_lib *mode_lib,
|
||||
const display_e2e_pipe_params_st *pipes,
|
||||
unsigned int num_pipes,
|
||||
unsigned int pipe_idx);
|
||||
void PixelClockAdjustmentForProgressiveToInterlaceUnit(struct display_mode_lib *mode_lib);
|
||||
|
||||
bool Calculate256BBlockSizes(
|
||||
@ -138,6 +179,39 @@ bool Calculate256BBlockSizes(
|
||||
unsigned int *BlockWidth256BytesY,
|
||||
unsigned int *BlockWidth256BytesC);
|
||||
|
||||
struct DISPCLKDPPCLKDCFCLKDeepSleepPrefetchParametersWatermarksAndPerformanceCalculation {
|
||||
unsigned int dummy_integer_array[2][DC__NUM_DPP__MAX];
|
||||
double dummy_single_array[2][DC__NUM_DPP__MAX];
|
||||
unsigned int dummy_long_array[2][DC__NUM_DPP__MAX];
|
||||
double dummy_double_array[2][DC__NUM_DPP__MAX];
|
||||
bool dummy_boolean_array[DC__NUM_DPP__MAX];
|
||||
bool dummy_boolean;
|
||||
bool dummy_boolean2;
|
||||
enum output_encoder_class dummy_output_encoder_array[DC__NUM_DPP__MAX];
|
||||
DmlPipe SurfaceParameters[DC__NUM_DPP__MAX];
|
||||
bool dummy_boolean_array2[2][DC__NUM_DPP__MAX];
|
||||
unsigned int ReorderBytes;
|
||||
unsigned int VMDataOnlyReturnBW;
|
||||
double HostVMInefficiencyFactor;
|
||||
};
|
||||
|
||||
struct dml32_ModeSupportAndSystemConfigurationFull {
|
||||
unsigned int dummy_integer_array[8][DC__NUM_DPP__MAX];
|
||||
double dummy_double_array[2][DC__NUM_DPP__MAX];
|
||||
DmlPipe SurfParameters[DC__NUM_DPP__MAX];
|
||||
double dummy_single[5];
|
||||
double dummy_single2[5];
|
||||
SOCParametersList mSOCParameters;
|
||||
unsigned int MaximumSwathWidthSupportLuma;
|
||||
unsigned int MaximumSwathWidthSupportChroma;
|
||||
};
|
||||
|
||||
struct dummy_vars {
|
||||
struct DISPCLKDPPCLKDCFCLKDeepSleepPrefetchParametersWatermarksAndPerformanceCalculation
|
||||
DISPCLKDPPCLKDCFCLKDeepSleepPrefetchParametersWatermarksAndPerformanceCalculation;
|
||||
struct dml32_ModeSupportAndSystemConfigurationFull dml32_ModeSupportAndSystemConfigurationFull;
|
||||
};
|
||||
|
||||
struct vba_vars_st {
|
||||
ip_params_st ip;
|
||||
soc_bounding_box_st soc;
|
||||
@ -154,6 +228,7 @@ struct vba_vars_st {
|
||||
double DISPCLKWithRampingRoundedToDFSGranularity;
|
||||
double DISPCLKWithoutRampingRoundedToDFSGranularity;
|
||||
double MaxDispclkRoundedToDFSGranularity;
|
||||
double MaxDppclkRoundedToDFSGranularity;
|
||||
bool DCCEnabledAnyPlane;
|
||||
double ReturnBandwidthToDCN;
|
||||
unsigned int TotalActiveDPP;
|
||||
@ -169,6 +244,8 @@ struct vba_vars_st {
|
||||
double NextMaxVStartup;
|
||||
double VBlankTime;
|
||||
double SmallestVBlank;
|
||||
enum dm_prefetch_modes AllowForPStateChangeOrStutterInVBlankFinal; // Mode Support only
|
||||
double DCFCLKDeepSleepPerSurface[DC__NUM_DPP__MAX];
|
||||
double DCFCLKDeepSleepPerPlane[DC__NUM_DPP__MAX];
|
||||
double EffectiveDETPlusLBLinesLuma;
|
||||
double EffectiveDETPlusLBLinesChroma;
|
||||
@ -212,6 +289,14 @@ struct vba_vars_st {
|
||||
double UrgentLatencyPixelMixedWithVMData;
|
||||
double UrgentLatencyVMDataOnly;
|
||||
double UrgentLatency; // max of the above three
|
||||
double USRRetrainingLatency;
|
||||
double SMNLatency;
|
||||
double FCLKChangeLatency;
|
||||
unsigned int MALLAllocatedForDCNFinal;
|
||||
double DefaultGPUVMMinPageSizeKBytes; // Default for the project
|
||||
double MaxAveragePercentOfIdealFabricBWDisplayCanUseInNormalSystemOperation;
|
||||
double MaxAveragePercentOfIdealDRAMBWDisplayCanUseInNormalSystemOperationSTROBE;
|
||||
double PercentOfIdealDRAMBWReceivedAfterUrgLatencySTROBE;
|
||||
double WritebackLatency;
|
||||
double PercentOfIdealDRAMFabricAndSDPPortBWReceivedAfterUrgLatencyPixelDataOnly; // Mode Support
|
||||
double PercentOfIdealDRAMFabricAndSDPPortBWReceivedAfterUrgLatencyPixelMixedWithVMData; // Mode Support
|
||||
@ -284,6 +369,14 @@ struct vba_vars_st {
|
||||
double DPPCLKDelayCNVCCursor;
|
||||
double DISPCLKDelaySubtotal;
|
||||
bool ProgressiveToInterlaceUnitInOPP;
|
||||
unsigned int CompressedBufferSegmentSizeInkByteFinal;
|
||||
unsigned int CompbufReservedSpace64B;
|
||||
unsigned int CompbufReservedSpaceZs;
|
||||
unsigned int LineBufferSizeFinal;
|
||||
unsigned int MaximumPixelsPerLinePerDSCUnit;
|
||||
unsigned int AlphaPixelChunkSizeInKByte;
|
||||
double MinPixelChunkSizeBytes;
|
||||
unsigned int DCCMetaBufferSizeBytes;
|
||||
// Pipe/Plane Parameters
|
||||
int VoltageLevel;
|
||||
double FabricClock;
|
||||
@ -291,6 +384,23 @@ struct vba_vars_st {
|
||||
double DISPCLK;
|
||||
double SOCCLK;
|
||||
double DCFCLK;
|
||||
unsigned int MaxTotalDETInKByte;
|
||||
unsigned int MinCompressedBufferSizeInKByte;
|
||||
unsigned int NumberOfActiveSurfaces;
|
||||
bool ViewportStationary[DC__NUM_DPP__MAX];
|
||||
unsigned int RefreshRate[DC__NUM_DPP__MAX];
|
||||
double OutputBPP[DC__NUM_DPP__MAX];
|
||||
unsigned int GPUVMMinPageSizeKBytes[DC__NUM_DPP__MAX];
|
||||
bool SynchronizeTimingsFinal;
|
||||
bool SynchronizeDRRDisplaysForUCLKPStateChangeFinal;
|
||||
bool ForceOneRowForFrame[DC__NUM_DPP__MAX];
|
||||
unsigned int ViewportXStartY[DC__NUM_DPP__MAX];
|
||||
unsigned int ViewportXStartC[DC__NUM_DPP__MAX];
|
||||
enum dm_rotation_angle SourceRotation[DC__NUM_DPP__MAX];
|
||||
bool DRRDisplay[DC__NUM_DPP__MAX];
|
||||
bool PteBufferMode[DC__NUM_DPP__MAX];
|
||||
enum dm_output_type OutputType[DC__NUM_DPP__MAX];
|
||||
enum dm_output_rate OutputRate[DC__NUM_DPP__MAX];
|
||||
|
||||
unsigned int NumberOfActivePlanes;
|
||||
unsigned int NumberOfDSCSlices[DC__NUM_DPP__MAX];
|
||||
@ -392,6 +502,12 @@ struct vba_vars_st {
|
||||
double StutterEfficiencyNotIncludingVBlank;
|
||||
double NonUrgentLatencyTolerance;
|
||||
double MinActiveDRAMClockChangeLatencySupported;
|
||||
double Z8StutterEfficiencyBestCase;
|
||||
unsigned int Z8NumberOfStutterBurstsPerFrameBestCase;
|
||||
double Z8StutterEfficiencyNotIncludingVBlankBestCase;
|
||||
double StutterPeriodBestCase;
|
||||
Watermarks Watermark;
|
||||
bool DCHUBBUB_ARB_CSTATE_MAX_CAP_MODE;
|
||||
|
||||
// These are the clocks calcuated by the library but they are not actually
|
||||
// used explicitly. They are fetched by tests and then possibly used. The
|
||||
@ -399,6 +515,10 @@ struct vba_vars_st {
|
||||
double DISPCLK_calculated;
|
||||
double DPPCLK_calculated[DC__NUM_DPP__MAX];
|
||||
|
||||
bool ImmediateFlipSupportedSurface[DC__NUM_DPP__MAX];
|
||||
|
||||
bool Use_One_Row_For_Frame[DC__NUM_DPP__MAX];
|
||||
bool Use_One_Row_For_Frame_Flip[DC__NUM_DPP__MAX];
|
||||
unsigned int VUpdateOffsetPix[DC__NUM_DPP__MAX];
|
||||
double VUpdateWidthPix[DC__NUM_DPP__MAX];
|
||||
double VReadyOffsetPix[DC__NUM_DPP__MAX];
|
||||
@ -429,6 +549,7 @@ struct vba_vars_st {
|
||||
double DRAMSpeedPerState[DC__VOLTAGE_STATES];
|
||||
double MaxDispclk[DC__VOLTAGE_STATES];
|
||||
int VoltageOverrideLevel;
|
||||
double PHYCLKD32PerState[DC__VOLTAGE_STATES];
|
||||
|
||||
/*outputs*/
|
||||
bool ScaleRatioAndTapsSupport;
|
||||
@ -452,6 +573,51 @@ struct vba_vars_st {
|
||||
bool PitchSupport;
|
||||
enum dm_validation_status ValidationStatus[DC__VOLTAGE_STATES];
|
||||
|
||||
/* Mode Support Reason */
|
||||
bool P2IWith420;
|
||||
bool DSCOnlyIfNecessaryWithBPP;
|
||||
bool DSC422NativeNotSupported;
|
||||
bool LinkRateDoesNotMatchDPVersion;
|
||||
bool LinkRateForMultistreamNotIndicated;
|
||||
bool BPPForMultistreamNotIndicated;
|
||||
bool MultistreamWithHDMIOreDP;
|
||||
bool MSOOrODMSplitWithNonDPLink;
|
||||
bool NotEnoughLanesForMSO;
|
||||
bool ViewportExceedsSurface;
|
||||
|
||||
bool ImmediateFlipRequiredButTheRequirementForEachSurfaceIsNotSpecified;
|
||||
bool ImmediateFlipOrHostVMAndPStateWithMALLFullFrameOrPhantomPipe;
|
||||
bool InvalidCombinationOfMALLUseForPStateAndStaticScreen;
|
||||
bool InvalidCombinationOfMALLUseForPState;
|
||||
|
||||
enum dm_output_link_dp_rate OutputLinkDPRate[DC__NUM_DPP__MAX];
|
||||
double PrefetchLinesYThisState[DC__NUM_DPP__MAX];
|
||||
double PrefetchLinesCThisState[DC__NUM_DPP__MAX];
|
||||
double meta_row_bandwidth_this_state[DC__NUM_DPP__MAX];
|
||||
double dpte_row_bandwidth_this_state[DC__NUM_DPP__MAX];
|
||||
double DPTEBytesPerRowThisState[DC__NUM_DPP__MAX];
|
||||
double PDEAndMetaPTEBytesPerFrameThisState[DC__NUM_DPP__MAX];
|
||||
double MetaRowBytesThisState[DC__NUM_DPP__MAX];
|
||||
bool use_one_row_for_frame[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
|
||||
bool use_one_row_for_frame_flip[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
|
||||
bool use_one_row_for_frame_this_state[DC__NUM_DPP__MAX];
|
||||
bool use_one_row_for_frame_flip_this_state[DC__NUM_DPP__MAX];
|
||||
|
||||
unsigned int OutputTypeAndRatePerState[DC__VOLTAGE_STATES][DC__NUM_DPP__MAX];
|
||||
double RequiredDISPCLKPerSurface[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
|
||||
unsigned int MicroTileHeightY[DC__NUM_DPP__MAX];
|
||||
unsigned int MicroTileHeightC[DC__NUM_DPP__MAX];
|
||||
unsigned int MicroTileWidthY[DC__NUM_DPP__MAX];
|
||||
unsigned int MicroTileWidthC[DC__NUM_DPP__MAX];
|
||||
bool ImmediateFlipRequiredFinal;
|
||||
bool DCCProgrammingAssumesScanDirectionUnknownFinal;
|
||||
bool EnoughWritebackUnits;
|
||||
bool ODMCombine2To1SupportCheckOK[DC__VOLTAGE_STATES];
|
||||
bool NumberOfDP2p0Support;
|
||||
unsigned int MaxNumDP2p0Streams;
|
||||
unsigned int MaxNumDP2p0Outputs;
|
||||
enum dm_output_type OutputTypePerState[DC__VOLTAGE_STATES][DC__NUM_DPP__MAX];
|
||||
enum dm_output_rate OutputRatePerState[DC__VOLTAGE_STATES][DC__NUM_DPP__MAX];
|
||||
double WritebackLineBufferLumaBufferSize;
|
||||
double WritebackLineBufferChromaBufferSize;
|
||||
double WritebackMinHSCLRatio;
|
||||
@ -647,6 +813,7 @@ struct vba_vars_st {
|
||||
double dummy7[DC__NUM_DPP__MAX];
|
||||
double dummy8[DC__NUM_DPP__MAX];
|
||||
double dummy13[DC__NUM_DPP__MAX];
|
||||
double dummy_double_array[2][DC__NUM_DPP__MAX];
|
||||
unsigned int dummyinteger1ms[DC__NUM_DPP__MAX];
|
||||
double dummyinteger2ms[DC__NUM_DPP__MAX];
|
||||
unsigned int dummyinteger3[DC__NUM_DPP__MAX];
|
||||
@ -666,6 +833,9 @@ struct vba_vars_st {
|
||||
unsigned int dummyintegerarr2[DC__NUM_DPP__MAX];
|
||||
unsigned int dummyintegerarr3[DC__NUM_DPP__MAX];
|
||||
unsigned int dummyintegerarr4[DC__NUM_DPP__MAX];
|
||||
unsigned int dummy_integer_array[8][DC__NUM_DPP__MAX];
|
||||
unsigned int dummy_integer_array22[22][DC__NUM_DPP__MAX];
|
||||
|
||||
bool dummysinglestring;
|
||||
bool SingleDPPViewportSizeSupportPerPlane[DC__NUM_DPP__MAX];
|
||||
double PlaneRequiredDISPCLKWithODMCombine2To1;
|
||||
@ -896,8 +1066,8 @@ struct vba_vars_st {
|
||||
double meta_row_bandwidth[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
|
||||
double DETBufferSizeYAllStates[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
|
||||
double DETBufferSizeCAllStates[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
|
||||
int swath_width_luma_ub_all_states[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
|
||||
int swath_width_chroma_ub_all_states[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
|
||||
unsigned int swath_width_luma_ub_all_states[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
|
||||
unsigned int swath_width_chroma_ub_all_states[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
|
||||
bool NotUrgentLatencyHiding[DC__VOLTAGE_STATES][2];
|
||||
unsigned int SwathHeightYAllStates[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
|
||||
unsigned int SwathHeightCAllStates[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
|
||||
@ -972,6 +1142,74 @@ struct vba_vars_st {
|
||||
int Z8NumberOfStutterBurstsPerFrame;
|
||||
unsigned int MaximumDSCBitsPerComponent;
|
||||
unsigned int NotEnoughUrgentLatencyHidingA[DC__VOLTAGE_STATES][2];
|
||||
double UrgentLatencyWithUSRRetraining;
|
||||
double UrgLatencyWithUSRRetraining[DC__VOLTAGE_STATES];
|
||||
double ReadBandwidthSurfaceLuma[DC__NUM_DPP__MAX];
|
||||
double ReadBandwidthSurfaceChroma[DC__NUM_DPP__MAX];
|
||||
double SurfaceRequiredDISPCLKWithoutODMCombine;
|
||||
double SurfaceRequiredDISPCLK;
|
||||
double SurfaceRequiredDISPCLKWithODMCombine2To1;
|
||||
double SurfaceRequiredDISPCLKWithODMCombine4To1;
|
||||
double MinActiveFCLKChangeLatencySupported;
|
||||
double dummy14;
|
||||
double dummy15;
|
||||
int MinVoltageLevel;
|
||||
int MaxVoltageLevel;
|
||||
unsigned int TotalNumberOfSingleDPPSurfaces[DC__VOLTAGE_STATES][2];
|
||||
unsigned int CompressedBufferSizeInkByteAllStates[DC__VOLTAGE_STATES][2];
|
||||
unsigned int DETBufferSizeInKByteAllStates[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
|
||||
unsigned int DETBufferSizeInKByteThisState[DC__NUM_DPP__MAX];
|
||||
unsigned int SurfaceSizeInMALL[DC__NUM_DPP__MAX];
|
||||
bool ExceededMALLSize;
|
||||
bool PTE_BUFFER_MODE[DC__NUM_DPP__MAX];
|
||||
unsigned int BIGK_FRAGMENT_SIZE[DC__NUM_DPP__MAX];
|
||||
unsigned int dummyinteger33;
|
||||
unsigned int CompressedBufferSizeInkByteThisState;
|
||||
enum dm_fclock_change_support FCLKChangeSupport[DC__VOLTAGE_STATES][2];
|
||||
Latencies myLatency;
|
||||
Latencies mLatency;
|
||||
Watermarks DummyWatermark;
|
||||
bool USRRetrainingSupport[DC__VOLTAGE_STATES][2];
|
||||
bool dummyBooleanvector1[DC__NUM_DPP__MAX];
|
||||
bool dummyBooleanvector2[DC__NUM_DPP__MAX];
|
||||
enum dm_use_mall_for_pstate_change_mode UsesMALLForPStateChange[DC__NUM_DPP__MAX];
|
||||
bool NotEnoughUrgentLatencyHiding_dml32[DC__VOLTAGE_STATES][2];
|
||||
bool UnboundedRequestEnabledAllStates[DC__VOLTAGE_STATES][2];
|
||||
bool SingleDPPViewportSizeSupportPerSurface[DC__NUM_DPP__MAX];
|
||||
enum dm_use_mall_for_static_screen_mode UseMALLForStaticScreen[DC__NUM_DPP__MAX];
|
||||
bool UnboundedRequestEnabledThisState;
|
||||
bool DRAMClockChangeRequirementFinal;
|
||||
bool FCLKChangeRequirementFinal;
|
||||
bool USRRetrainingRequiredFinal;
|
||||
bool MALLUseFinal;
|
||||
bool ConfigurableDETSizeEnFinal;
|
||||
bool dummyboolean;
|
||||
unsigned int DETSizeOverride[DC__NUM_DPP__MAX];
|
||||
unsigned int nomDETInKByte;
|
||||
enum mpc_combine_affinity MPCCombineUse[DC__NUM_DPP__MAX];
|
||||
bool MPCCombineMethodIncompatible;
|
||||
unsigned int RequiredSlots[DC__VOLTAGE_STATES][DC__NUM_DPP__MAX];
|
||||
bool ExceededMultistreamSlots[DC__VOLTAGE_STATES];
|
||||
enum odm_combine_policy ODMUse[DC__NUM_DPP__MAX];
|
||||
unsigned int OutputMultistreamId[DC__NUM_DPP__MAX];
|
||||
bool OutputMultistreamEn[DC__NUM_DPP__MAX];
|
||||
bool UsesMALLForStaticScreen[DC__NUM_DPP__MAX];
|
||||
double MaxActiveDRAMClockChangeLatencySupported[DC__NUM_DPP__MAX];
|
||||
double WritebackAllowFCLKChangeEndPosition[DC__NUM_DPP__MAX];
|
||||
bool PTEBufferSizeNotExceededPerState[DC__NUM_DPP__MAX]; // new in DML32
|
||||
bool DCCMetaBufferSizeNotExceededPerState[DC__NUM_DPP__MAX]; // new in DML32
|
||||
bool NotEnoughDSCSlices[DC__VOLTAGE_STATES];
|
||||
bool PixelsPerLinePerDSCUnitSupport[DC__VOLTAGE_STATES];
|
||||
bool DCCMetaBufferSizeNotExceeded[DC__VOLTAGE_STATES][2];
|
||||
unsigned int dpte_row_height_linear[DC__NUM_DPP__MAX];
|
||||
unsigned int dpte_row_height_linear_chroma[DC__NUM_DPP__MAX];
|
||||
unsigned int BlockHeightY[DC__NUM_DPP__MAX];
|
||||
unsigned int BlockHeightC[DC__NUM_DPP__MAX];
|
||||
unsigned int BlockWidthY[DC__NUM_DPP__MAX];
|
||||
unsigned int BlockWidthC[DC__NUM_DPP__MAX];
|
||||
unsigned int SubViewportLinesNeededInMALL[DC__NUM_DPP__MAX];
|
||||
bool VActiveBandwithSupport[DC__VOLTAGE_STATES][2];
|
||||
struct dummy_vars dummy_vars;
|
||||
};
|
||||
|
||||
bool CalculateMinAndMaxPrefetchMode(
|
||||
|
@ -23,7 +23,6 @@
|
||||
*
|
||||
*/
|
||||
|
||||
#include "dml_wrapper.h"
|
||||
#include "resource.h"
|
||||
#include "core_types.h"
|
||||
#include "dsc.h"
|
||||
@ -86,25 +85,6 @@ static void get_pixel_clock_parameters(
|
||||
|
||||
}
|
||||
|
||||
static enum dc_status build_pipe_hw_param(struct pipe_ctx *pipe_ctx)
|
||||
{
|
||||
get_pixel_clock_parameters(pipe_ctx, &pipe_ctx->stream_res.pix_clk_params);
|
||||
|
||||
if (pipe_ctx->clock_source)
|
||||
pipe_ctx->clock_source->funcs->get_pix_clk_dividers(
|
||||
pipe_ctx->clock_source,
|
||||
&pipe_ctx->stream_res.pix_clk_params,
|
||||
&pipe_ctx->pll_settings);
|
||||
|
||||
pipe_ctx->stream->clamping.pixel_encoding = pipe_ctx->stream->timing.pixel_encoding;
|
||||
|
||||
resource_build_bit_depth_reduction_params(pipe_ctx->stream,
|
||||
&pipe_ctx->stream->bit_depth_params);
|
||||
build_clamping_params(pipe_ctx->stream);
|
||||
|
||||
return DC_OK;
|
||||
}
|
||||
|
||||
static void resource_build_bit_depth_reduction_params(struct dc_stream_state *stream,
|
||||
struct bit_depth_reduction_params *fmt_bit_depth)
|
||||
{
|
||||
@ -231,6 +211,30 @@ static void resource_build_bit_depth_reduction_params(struct dc_stream_state *st
|
||||
fmt_bit_depth->pixel_encoding = pixel_encoding;
|
||||
}
|
||||
|
||||
/* Move this after the above function as VS complains about
|
||||
* declaration issues for resource_build_bit_depth_reduction_params.
|
||||
*/
|
||||
|
||||
static enum dc_status build_pipe_hw_param(struct pipe_ctx *pipe_ctx)
|
||||
{
|
||||
|
||||
get_pixel_clock_parameters(pipe_ctx, &pipe_ctx->stream_res.pix_clk_params);
|
||||
|
||||
if (pipe_ctx->clock_source)
|
||||
pipe_ctx->clock_source->funcs->get_pix_clk_dividers(
|
||||
pipe_ctx->clock_source,
|
||||
&pipe_ctx->stream_res.pix_clk_params,
|
||||
&pipe_ctx->pll_settings);
|
||||
|
||||
pipe_ctx->stream->clamping.pixel_encoding = pipe_ctx->stream->timing.pixel_encoding;
|
||||
|
||||
resource_build_bit_depth_reduction_params(pipe_ctx->stream,
|
||||
&pipe_ctx->stream->bit_depth_params);
|
||||
build_clamping_params(pipe_ctx->stream);
|
||||
|
||||
return DC_OK;
|
||||
}
|
||||
|
||||
bool dml_validate_dsc(struct dc *dc, struct dc_state *new_ctx)
|
||||
{
|
||||
int i;
|
||||
@ -1130,7 +1134,7 @@ static int dml_populate_dml_pipes_from_context(
|
||||
{
|
||||
int i, pipe_cnt;
|
||||
struct resource_context *res_ctx = &context->res_ctx;
|
||||
struct pipe_ctx *pipe;
|
||||
struct pipe_ctx *pipe = NULL; // Fix potentially uninitialized error from VS
|
||||
|
||||
populate_dml_pipes_from_context_base(dc, context, pipes, fast_validate);
|
||||
|
||||
@ -1296,6 +1300,7 @@ static void dml_update_soc_for_wm_a(struct dc *dc, struct dc_state *context)
|
||||
context->bw_ctx.dml.soc.dram_clock_change_latency_us = dc->clk_mgr->bw_params->wm_table.nv_entries[WM_A].dml_input.pstate_latency_us;
|
||||
context->bw_ctx.dml.soc.sr_enter_plus_exit_time_us = dc->clk_mgr->bw_params->wm_table.nv_entries[WM_A].dml_input.sr_enter_plus_exit_time_us;
|
||||
context->bw_ctx.dml.soc.sr_exit_time_us = dc->clk_mgr->bw_params->wm_table.nv_entries[WM_A].dml_input.sr_exit_time_us;
|
||||
context->bw_ctx.dml.soc.fclk_change_latency_us = dc->clk_mgr->bw_params->wm_table.nv_entries[WM_A].dml_input.fclk_change_latency_us;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1593,11 +1598,8 @@ static void dml_calculate_dlg_params(
|
||||
context->bw_ctx.bw.dcn.clk.z9_support = DCN_Z9_SUPPORT_ALLOW;
|
||||
*/
|
||||
context->bw_ctx.bw.dcn.clk.dtbclk_en = is_dtbclk_required(dc, context);
|
||||
/* TODO : Uncomment the below line and make changes
|
||||
* as per DML nomenclature once it is available.
|
||||
* context->bw_ctx.bw.dcn.clk.fclk_p_state_change_support = context->bw_ctx.dml.vba.fclk_pstate_support;
|
||||
*/
|
||||
|
||||
context->bw_ctx.bw.dcn.clk.fclk_p_state_change_support =
|
||||
context->bw_ctx.dml.vba.FCLKChangeSupport[vlevel][context->bw_ctx.dml.vba.maxMpcComb];
|
||||
if (context->bw_ctx.bw.dcn.clk.dispclk_khz < dc->debug.min_disp_clk_khz)
|
||||
context->bw_ctx.bw.dcn.clk.dispclk_khz = dc->debug.min_disp_clk_khz;
|
||||
|
||||
@ -1699,12 +1701,11 @@ static void dml_calculate_wm_and_dlg(
|
||||
context->bw_ctx.bw.dcn.watermarks.b.frac_urg_bw_nom = get_fraction_of_urgent_bandwidth(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
context->bw_ctx.bw.dcn.watermarks.b.frac_urg_bw_flip = get_fraction_of_urgent_bandwidth_imm_flip(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
context->bw_ctx.bw.dcn.watermarks.b.urgent_latency_ns = get_urgent_latency(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
//context->bw_ctx.bw.dcn.watermarks.b.cstate_pstate.fclk_pstate_change_ns = get_wm_fclk_pstate(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
context->bw_ctx.bw.dcn.watermarks.b.cstate_pstate.fclk_pstate_change_ns = get_fclk_watermark(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
//context->bw_ctx.bw.dcn.watermarks.b.usr_retraining_ns = get_wm_usr_retraining(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
|
||||
/* Temporary, to have some fclk_pstate_change_ns and usr_retraining_ns wm values until DML is implemented */
|
||||
context->bw_ctx.bw.dcn.watermarks.b.cstate_pstate.fclk_pstate_change_ns = context->bw_ctx.bw.dcn.watermarks.b.cstate_pstate.pstate_change_ns / 4;
|
||||
context->bw_ctx.bw.dcn.watermarks.b.usr_retraining_ns = context->bw_ctx.bw.dcn.watermarks.b.cstate_pstate.pstate_change_ns / 8;
|
||||
//context->bw_ctx.bw.dcn.watermarks.b.usr_retraining = context->bw_ctx.bw.dcn.watermarks.b.cstate_pstate.pstate_change_ns / 8;
|
||||
|
||||
/* Set D:
|
||||
* All clocks min.
|
||||
@ -1736,13 +1737,11 @@ static void dml_calculate_wm_and_dlg(
|
||||
context->bw_ctx.bw.dcn.watermarks.d.frac_urg_bw_nom = get_fraction_of_urgent_bandwidth(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
context->bw_ctx.bw.dcn.watermarks.d.frac_urg_bw_flip = get_fraction_of_urgent_bandwidth_imm_flip(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
context->bw_ctx.bw.dcn.watermarks.d.urgent_latency_ns = get_urgent_latency(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
//context->bw_ctx.bw.dcn.watermarks.d.cstate_pstate.fclk_pstate_change_ns = get_wm_fclk_pstate(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
context->bw_ctx.bw.dcn.watermarks.d.cstate_pstate.fclk_pstate_change_ns = get_fclk_watermark(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
//context->bw_ctx.bw.dcn.watermarks.d.usr_retraining_ns = get_wm_usr_retraining(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
|
||||
/* Temporary, to have some fclk_pstate_change_ns and usr_retraining_ns wm values until DML is implemented */
|
||||
context->bw_ctx.bw.dcn.watermarks.d.cstate_pstate.fclk_pstate_change_ns = context->bw_ctx.bw.dcn.watermarks.d.cstate_pstate.pstate_change_ns / 4;
|
||||
context->bw_ctx.bw.dcn.watermarks.d.usr_retraining_ns = context->bw_ctx.bw.dcn.watermarks.d.cstate_pstate.pstate_change_ns / 8;
|
||||
|
||||
//context->bw_ctx.bw.dcn.watermarks.d.usr_retraining = context->bw_ctx.bw.dcn.watermarks.d.cstate_pstate.pstate_change_ns / 8;
|
||||
/* Set C, for Dummy P-State:
|
||||
* All clocks min.
|
||||
* DCFCLK: Min, as reported by PM FW, when available
|
||||
@ -1773,13 +1772,11 @@ static void dml_calculate_wm_and_dlg(
|
||||
context->bw_ctx.bw.dcn.watermarks.c.frac_urg_bw_nom = get_fraction_of_urgent_bandwidth(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
context->bw_ctx.bw.dcn.watermarks.c.frac_urg_bw_flip = get_fraction_of_urgent_bandwidth_imm_flip(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
context->bw_ctx.bw.dcn.watermarks.c.urgent_latency_ns = get_urgent_latency(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
//context->bw_ctx.bw.dcn.watermarks.c.cstate_pstate.fclk_pstate_change_ns = get_wm_fclk_pstate(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
context->bw_ctx.bw.dcn.watermarks.c.cstate_pstate.fclk_pstate_change_ns = get_fclk_watermark(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
//context->bw_ctx.bw.dcn.watermarks.c.usr_retraining_ns = get_wm_usr_retraining(&context->bw_ctx.dml, pipes, pipe_cnt) * 1000;
|
||||
|
||||
/* Temporary, to have some fclk_pstate_change_ns and usr_retraining_ns wm values until DML is implemented */
|
||||
context->bw_ctx.bw.dcn.watermarks.c.cstate_pstate.fclk_pstate_change_ns = context->bw_ctx.bw.dcn.watermarks.c.cstate_pstate.pstate_change_ns / 4;
|
||||
context->bw_ctx.bw.dcn.watermarks.c.usr_retraining_ns = context->bw_ctx.bw.dcn.watermarks.c.cstate_pstate.pstate_change_ns / 8;
|
||||
|
||||
//context->bw_ctx.bw.dcn.watermarks.c.usr_retraining = context->bw_ctx.bw.dcn.watermarks.c.cstate_pstate.pstate_change_ns / 8;
|
||||
if ((!pstate_en) && (dc->clk_mgr->bw_params->wm_table.nv_entries[WM_C].valid)) {
|
||||
/* The only difference between A and C is p-state latency, if p-state is not supported
|
||||
* with full p-state latency we want to calculate DLG based on dummy p-state latency,
|
||||
|
Loading…
x
Reference in New Issue
Block a user