Commit 8a31820b authored by Martin Leung's avatar Martin Leung Committed by Alex Deucher

drm/amd/display: Make init_hw and init_pipes generic for seamless boot

[Why]
For seamless boot the init_hw sequence must be split into
actual hardware vs pipes, in order to defer pipe initialization to set mode
and skip of pipe-destructive sequences

[How]
made dcn10_init_hw and dcn10_init_pipes generic for future dcns to inherit
deleted dcn20 specific versions. This is part 1 of a 2 partimplementation
of seamless boot
Signed-off-by: default avatarMartin Leung <martin.leung@amd.com>
Reviewed-by: default avatarJun Lei <Jun.Lei@amd.com>
Acked-by: default avatarLeo Li <sunpeng.li@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 61e29b21
...@@ -731,7 +731,7 @@ static enum bp_result link_transmitter_control( ...@@ -731,7 +731,7 @@ static enum bp_result link_transmitter_control(
* @brief * @brief
* eDP only. * eDP only.
*/ */
void hwss_edp_wait_for_hpd_ready( void dce110_edp_wait_for_hpd_ready(
struct dc_link *link, struct dc_link *link,
bool power_up) bool power_up)
{ {
...@@ -799,7 +799,7 @@ void hwss_edp_wait_for_hpd_ready( ...@@ -799,7 +799,7 @@ void hwss_edp_wait_for_hpd_ready(
} }
} }
void hwss_edp_power_control( void dce110_edp_power_control(
struct dc_link *link, struct dc_link *link,
bool power_up) bool power_up)
{ {
...@@ -881,7 +881,7 @@ void hwss_edp_power_control( ...@@ -881,7 +881,7 @@ void hwss_edp_power_control(
* @brief * @brief
* eDP only. Control the backlight of the eDP panel * eDP only. Control the backlight of the eDP panel
*/ */
void hwss_edp_backlight_control( void dce110_edp_backlight_control(
struct dc_link *link, struct dc_link *link,
bool enable) bool enable)
{ {
...@@ -2758,9 +2758,9 @@ static const struct hw_sequencer_funcs dce110_funcs = { ...@@ -2758,9 +2758,9 @@ static const struct hw_sequencer_funcs dce110_funcs = {
.setup_stereo = NULL, .setup_stereo = NULL,
.set_avmute = dce110_set_avmute, .set_avmute = dce110_set_avmute,
.wait_for_mpcc_disconnect = dce110_wait_for_mpcc_disconnect, .wait_for_mpcc_disconnect = dce110_wait_for_mpcc_disconnect,
.edp_backlight_control = hwss_edp_backlight_control, .edp_backlight_control = dce110_edp_backlight_control,
.edp_power_control = hwss_edp_power_control, .edp_power_control = dce110_edp_power_control,
.edp_wait_for_hpd_ready = hwss_edp_wait_for_hpd_ready, .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
.set_cursor_position = dce110_set_cursor_position, .set_cursor_position = dce110_set_cursor_position,
.set_cursor_attribute = dce110_set_cursor_attribute .set_cursor_attribute = dce110_set_cursor_attribute
}; };
......
...@@ -73,15 +73,15 @@ void dce110_optimize_bandwidth( ...@@ -73,15 +73,15 @@ void dce110_optimize_bandwidth(
void dp_receiver_power_ctrl(struct dc_link *link, bool on); void dp_receiver_power_ctrl(struct dc_link *link, bool on);
void hwss_edp_power_control( void dce110_edp_power_control(
struct dc_link *link, struct dc_link *link,
bool power_up); bool power_up);
void hwss_edp_backlight_control( void dce110_edp_backlight_control(
struct dc_link *link, struct dc_link *link,
bool enable); bool enable);
void hwss_edp_wait_for_hpd_ready( void dce110_edp_wait_for_hpd_ready(
struct dc_link *link, struct dc_link *link,
bool power_up); bool power_up);
......
...@@ -104,7 +104,7 @@ void hubbub1_allow_self_refresh_control(struct hubbub *hubbub, bool allow) ...@@ -104,7 +104,7 @@ void hubbub1_allow_self_refresh_control(struct hubbub *hubbub, bool allow)
DCHUBBUB_ARB_ALLOW_SELF_REFRESH_FORCE_ENABLE, !allow); DCHUBBUB_ARB_ALLOW_SELF_REFRESH_FORCE_ENABLE, !allow);
} }
bool hububu1_is_allow_self_refresh_enabled(struct hubbub *hubbub) bool hubbub1_is_allow_self_refresh_enabled(struct hubbub *hubbub)
{ {
struct dcn10_hubbub *hubbub1 = TO_DCN10_HUBBUB(hubbub); struct dcn10_hubbub *hubbub1 = TO_DCN10_HUBBUB(hubbub);
uint32_t enable = 0; uint32_t enable = 0;
...@@ -945,6 +945,8 @@ static const struct hubbub_funcs hubbub1_funcs = { ...@@ -945,6 +945,8 @@ static const struct hubbub_funcs hubbub1_funcs = {
.get_dcc_compression_cap = hubbub1_get_dcc_compression_cap, .get_dcc_compression_cap = hubbub1_get_dcc_compression_cap,
.wm_read_state = hubbub1_wm_read_state, .wm_read_state = hubbub1_wm_read_state,
.program_watermarks = hubbub1_program_watermarks, .program_watermarks = hubbub1_program_watermarks,
.is_allow_self_refresh_enabled = hubbub1_is_allow_self_refresh_enabled,
.allow_self_refresh_control = hubbub1_allow_self_refresh_control,
}; };
void hubbub1_construct(struct hubbub *hubbub, void hubbub1_construct(struct hubbub *hubbub,
......
...@@ -247,7 +247,7 @@ void hubbub1_program_watermarks( ...@@ -247,7 +247,7 @@ void hubbub1_program_watermarks(
void hubbub1_allow_self_refresh_control(struct hubbub *hubbub, bool allow); void hubbub1_allow_self_refresh_control(struct hubbub *hubbub, bool allow);
bool hububu1_is_allow_self_refresh_enabled(struct hubbub *hubub); bool hubbub1_is_allow_self_refresh_enabled(struct hubbub *hubub);
void hubbub1_toggle_watermark_change_req( void hubbub1_toggle_watermark_change_req(
struct hubbub *hubbub); struct hubbub *hubbub);
......
...@@ -582,7 +582,7 @@ static const struct hubbub_funcs hubbub2_funcs = { ...@@ -582,7 +582,7 @@ static const struct hubbub_funcs hubbub2_funcs = {
.get_dcc_compression_cap = hubbub2_get_dcc_compression_cap, .get_dcc_compression_cap = hubbub2_get_dcc_compression_cap,
.wm_read_state = hubbub2_wm_read_state, .wm_read_state = hubbub2_wm_read_state,
.get_dchub_ref_freq = hubbub2_get_dchub_ref_freq, .get_dchub_ref_freq = hubbub2_get_dchub_ref_freq,
.program_watermarks = hubbub2_program_watermarks, .program_watermarks = hubbub2_program_watermarks
}; };
void hubbub2_construct(struct dcn20_hubbub *hubbub, void hubbub2_construct(struct dcn20_hubbub *hubbub,
......
...@@ -141,6 +141,10 @@ struct hubbub_funcs { ...@@ -141,6 +141,10 @@ struct hubbub_funcs {
struct dcn_watermark_set *watermarks, struct dcn_watermark_set *watermarks,
unsigned int refclk_mhz, unsigned int refclk_mhz,
bool safe_to_lower); bool safe_to_lower);
bool (*is_allow_self_refresh_enabled)(struct hubbub *hubbub);
void (*allow_self_refresh_control)(struct hubbub *hubbub, bool allow);
}; };
struct hubbub { struct hubbub {
......
...@@ -78,6 +78,8 @@ struct stream_resource; ...@@ -78,6 +78,8 @@ struct stream_resource;
struct dc_phy_addr_space_config; struct dc_phy_addr_space_config;
struct dc_virtual_addr_space_config; struct dc_virtual_addr_space_config;
#endif #endif
struct hubp;
struct dpp;
struct hw_sequencer_funcs { struct hw_sequencer_funcs {
...@@ -280,6 +282,36 @@ struct hw_sequencer_funcs { ...@@ -280,6 +282,36 @@ struct hw_sequencer_funcs {
void (*setup_vupdate_interrupt)(struct pipe_ctx *pipe_ctx); void (*setup_vupdate_interrupt)(struct pipe_ctx *pipe_ctx);
bool (*did_underflow_occur)(struct dc *dc, struct pipe_ctx *pipe_ctx); bool (*did_underflow_occur)(struct dc *dc, struct pipe_ctx *pipe_ctx);
void (*init_blank)(struct dc *dc, struct timing_generator *tg);
void (*disable_vga)(struct dce_hwseq *hws);
void (*bios_golden_init)(struct dc *dc);
void (*plane_atomic_power_down)(struct dc *dc,
struct dpp *dpp,
struct hubp *hubp);
void (*plane_atomic_disable)(
struct dc *dc, struct pipe_ctx *pipe_ctx);
void (*enable_power_gating_plane)(
struct dce_hwseq *hws,
bool enable);
void (*dpp_pg_control)(
struct dce_hwseq *hws,
unsigned int dpp_inst,
bool power_on);
void (*hubp_pg_control)(
struct dce_hwseq *hws,
unsigned int hubp_inst,
bool power_on);
void (*dsc_pg_control)(
struct dce_hwseq *hws,
unsigned int dsc_inst,
bool power_on);
#if defined(CONFIG_DRM_AMD_DC_DCN2_0) #if defined(CONFIG_DRM_AMD_DC_DCN2_0)
void (*update_odm)(struct dc *dc, struct dc_state *context, struct pipe_ctx *pipe_ctx); void (*update_odm)(struct dc *dc, struct dc_state *context, struct pipe_ctx *pipe_ctx);
void (*program_all_writeback_pipes_in_tree)( void (*program_all_writeback_pipes_in_tree)(
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment