drm/amd/display: Call DMUB for eDP power control
[Why] If DMUB is used, LVTMA VBIOS call can be used to control eDP instead of tranditional transmitter control. Interface is agreed with VBIOS for eDP to use this new path to program LVTMA registers. [How] Create DAL interface to send DMUB command for LVTMA as currently implemented in VBIOS. Signed-off-by: Chris Park <Chris.Park@amd.com> Reviewed-by: Nicholas Kazlauskas <Nicholas.Kazlauskas@amd.com> Acked-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
1ffe92021e
commit
8a0e210c04
|
@ -1108,6 +1108,18 @@ static enum bp_result bios_parser_enable_disp_power_gating(
|
||||||
action);
|
action);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static enum bp_result bios_parser_enable_lvtma_control(
|
||||||
|
struct dc_bios *dcb,
|
||||||
|
uint8_t uc_pwr_on)
|
||||||
|
{
|
||||||
|
struct bios_parser *bp = BP_FROM_DCB(dcb);
|
||||||
|
|
||||||
|
if (!bp->cmd_tbl.enable_lvtma_control)
|
||||||
|
return BP_RESULT_FAILURE;
|
||||||
|
|
||||||
|
return bp->cmd_tbl.enable_lvtma_control(bp, uc_pwr_on);
|
||||||
|
}
|
||||||
|
|
||||||
static bool bios_parser_is_accelerated_mode(
|
static bool bios_parser_is_accelerated_mode(
|
||||||
struct dc_bios *dcb)
|
struct dc_bios *dcb)
|
||||||
{
|
{
|
||||||
|
@ -2208,7 +2220,9 @@ static const struct dc_vbios_funcs vbios_funcs = {
|
||||||
.get_board_layout_info = bios_get_board_layout_info,
|
.get_board_layout_info = bios_get_board_layout_info,
|
||||||
.pack_data_tables = bios_parser_pack_data_tables,
|
.pack_data_tables = bios_parser_pack_data_tables,
|
||||||
|
|
||||||
.get_atom_dc_golden_table = bios_get_atom_dc_golden_table
|
.get_atom_dc_golden_table = bios_get_atom_dc_golden_table,
|
||||||
|
|
||||||
|
.enable_lvtma_control = bios_parser_enable_lvtma_control
|
||||||
};
|
};
|
||||||
|
|
||||||
static bool bios_parser2_construct(
|
static bool bios_parser2_construct(
|
||||||
|
|
|
@ -901,6 +901,33 @@ static unsigned int get_smu_clock_info_v3_1(struct bios_parser *bp, uint8_t id)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
******************************************************************************
|
||||||
|
**
|
||||||
|
** LVTMA CONTROL
|
||||||
|
**
|
||||||
|
******************************************************************************
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
static enum bp_result enable_lvtma_control(
|
||||||
|
struct bios_parser *bp,
|
||||||
|
uint8_t uc_pwr_on);
|
||||||
|
|
||||||
|
static void init_enable_lvtma_control(struct bios_parser *bp)
|
||||||
|
{
|
||||||
|
/* TODO add switch for table vrsion */
|
||||||
|
bp->cmd_tbl.enable_lvtma_control = enable_lvtma_control;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static enum bp_result enable_lvtma_control(
|
||||||
|
struct bios_parser *bp,
|
||||||
|
uint8_t uc_pwr_on)
|
||||||
|
{
|
||||||
|
enum bp_result result = BP_RESULT_FAILURE;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
void dal_firmware_parser_init_cmd_tbl(struct bios_parser *bp)
|
void dal_firmware_parser_init_cmd_tbl(struct bios_parser *bp)
|
||||||
{
|
{
|
||||||
init_dig_encoder_control(bp);
|
init_dig_encoder_control(bp);
|
||||||
|
@ -916,4 +943,5 @@ void dal_firmware_parser_init_cmd_tbl(struct bios_parser *bp)
|
||||||
init_set_dce_clock(bp);
|
init_set_dce_clock(bp);
|
||||||
init_get_smu_clock_info(bp);
|
init_get_smu_clock_info(bp);
|
||||||
|
|
||||||
|
init_enable_lvtma_control(bp);
|
||||||
}
|
}
|
||||||
|
|
|
@ -94,7 +94,8 @@ struct cmd_tbl {
|
||||||
struct bp_set_dce_clock_parameters *bp_params);
|
struct bp_set_dce_clock_parameters *bp_params);
|
||||||
unsigned int (*get_smu_clock_info)(
|
unsigned int (*get_smu_clock_info)(
|
||||||
struct bios_parser *bp, uint8_t id);
|
struct bios_parser *bp, uint8_t id);
|
||||||
|
enum bp_result (*enable_lvtma_control)(struct bios_parser *bp,
|
||||||
|
uint8_t uc_pwr_on);
|
||||||
};
|
};
|
||||||
|
|
||||||
void dal_firmware_parser_init_cmd_tbl(struct bios_parser *bp);
|
void dal_firmware_parser_init_cmd_tbl(struct bios_parser *bp);
|
||||||
|
|
|
@ -136,6 +136,10 @@ struct dc_vbios_funcs {
|
||||||
|
|
||||||
enum bp_result (*get_atom_dc_golden_table)(
|
enum bp_result (*get_atom_dc_golden_table)(
|
||||||
struct dc_bios *dcb);
|
struct dc_bios *dcb);
|
||||||
|
|
||||||
|
enum bp_result (*enable_lvtma_control)(
|
||||||
|
struct dc_bios *bios,
|
||||||
|
uint8_t uc_pwr_on);
|
||||||
};
|
};
|
||||||
|
|
||||||
struct bios_registers {
|
struct bios_registers {
|
||||||
|
|
|
@ -842,6 +842,17 @@ void dce110_edp_power_control(
|
||||||
cntl.coherent = false;
|
cntl.coherent = false;
|
||||||
cntl.lanes_number = LANE_COUNT_FOUR;
|
cntl.lanes_number = LANE_COUNT_FOUR;
|
||||||
cntl.hpd_sel = link->link_enc->hpd_source;
|
cntl.hpd_sel = link->link_enc->hpd_source;
|
||||||
|
|
||||||
|
if (ctx->dc->ctx->dmub_srv &&
|
||||||
|
ctx->dc->debug.dmub_command_table) {
|
||||||
|
if (cntl.action == TRANSMITTER_CONTROL_POWER_ON)
|
||||||
|
bp_result = ctx->dc_bios->funcs->enable_lvtma_control(ctx->dc_bios,
|
||||||
|
LVTMA_CONTROL_POWER_ON);
|
||||||
|
else
|
||||||
|
bp_result = ctx->dc_bios->funcs->enable_lvtma_control(ctx->dc_bios,
|
||||||
|
LVTMA_CONTROL_POWER_OFF);
|
||||||
|
}
|
||||||
|
|
||||||
bp_result = link_transmitter_control(ctx->dc_bios, &cntl);
|
bp_result = link_transmitter_control(ctx->dc_bios, &cntl);
|
||||||
|
|
||||||
if (!power_up)
|
if (!power_up)
|
||||||
|
@ -919,8 +930,21 @@ void dce110_edp_backlight_control(
|
||||||
/*edp 1.2*/
|
/*edp 1.2*/
|
||||||
if (cntl.action == TRANSMITTER_CONTROL_BACKLIGHT_ON)
|
if (cntl.action == TRANSMITTER_CONTROL_BACKLIGHT_ON)
|
||||||
edp_receiver_ready_T7(link);
|
edp_receiver_ready_T7(link);
|
||||||
|
|
||||||
|
if (ctx->dc->ctx->dmub_srv &&
|
||||||
|
ctx->dc->debug.dmub_command_table) {
|
||||||
|
if (cntl.action == TRANSMITTER_CONTROL_BACKLIGHT_ON)
|
||||||
|
ctx->dc_bios->funcs->enable_lvtma_control(ctx->dc_bios,
|
||||||
|
LVTMA_CONTROL_LCD_BLON);
|
||||||
|
else
|
||||||
|
ctx->dc_bios->funcs->enable_lvtma_control(ctx->dc_bios,
|
||||||
|
LVTMA_CONTROL_LCD_BLOFF);
|
||||||
|
}
|
||||||
|
|
||||||
link_transmitter_control(ctx->dc_bios, &cntl);
|
link_transmitter_control(ctx->dc_bios, &cntl);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (enable && link->dpcd_sink_ext_caps.bits.oled)
|
if (enable && link->dpcd_sink_ext_caps.bits.oled)
|
||||||
msleep(OLED_POST_T7_DELAY);
|
msleep(OLED_POST_T7_DELAY);
|
||||||
|
|
||||||
|
|
|
@ -101,6 +101,13 @@ enum bp_pipe_control_action {
|
||||||
ASIC_PIPE_INIT
|
ASIC_PIPE_INIT
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum bp_lvtma_control_action {
|
||||||
|
LVTMA_CONTROL_LCD_BLOFF = 2,
|
||||||
|
LVTMA_CONTROL_LCD_BLON = 3,
|
||||||
|
LVTMA_CONTROL_POWER_ON = 12,
|
||||||
|
LVTMA_CONTROL_POWER_OFF = 13
|
||||||
|
};
|
||||||
|
|
||||||
struct bp_encoder_control {
|
struct bp_encoder_control {
|
||||||
enum bp_encoder_control_action action;
|
enum bp_encoder_control_action action;
|
||||||
enum engine_id engine_id;
|
enum engine_id engine_id;
|
||||||
|
|
Loading…
Reference in New Issue