/* * Copyright 2015 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 __DC_HW_SEQUENCER_H__ #define __DC_HW_SEQUENCER_H__ #include "dc_types.h" #include "inc/clock_source.h" #include "inc/hw/timing_generator.h" #include "inc/hw/opp.h" #include "inc/hw/link_encoder.h" #include "inc/core_status.h" #include "inc/hw/hw_shared.h" #include "dsc/dsc.h" struct pipe_ctx; struct dc_state; struct dc_stream_status; struct dc_writeback_info; struct dchub_init_data; struct dc_static_screen_params; struct resource_pool; struct dc_phy_addr_space_config; struct dc_virtual_addr_space_config; struct dpp; struct dce_hwseq; struct link_resource; struct dc_dmub_cmd; struct pg_block_update; struct drr_params; struct dc_underflow_debug_data; struct dsc_optc_config; struct vm_system_aperture_param; struct subvp_pipe_control_lock_fast_params { struct dc *dc; bool lock; bool subvp_immediate_flip; }; struct pipe_control_lock_params { struct dc *dc; struct pipe_ctx *pipe_ctx; bool lock; }; struct set_flip_control_gsl_params { struct hubp *hubp; bool flip_immediate; }; struct program_triplebuffer_params { const struct dc *dc; struct pipe_ctx *pipe_ctx; bool enableTripleBuffer; }; struct update_plane_addr_params { struct dc *dc; struct pipe_ctx *pipe_ctx; }; struct set_input_transfer_func_params { struct dc *dc; struct pipe_ctx *pipe_ctx; struct dc_plane_state *plane_state; }; struct program_gamut_remap_params { struct pipe_ctx *pipe_ctx; }; struct program_manual_trigger_params { struct pipe_ctx *pipe_ctx; }; struct send_dmcub_cmd_params { struct dc_context *ctx; union dmub_rb_cmd *cmd; enum dm_dmub_wait_type wait_type; }; struct setup_dpp_params { struct pipe_ctx *pipe_ctx; }; struct program_bias_and_scale_params { struct pipe_ctx *pipe_ctx; }; struct set_output_transfer_func_params { struct dc *dc; struct pipe_ctx *pipe_ctx; const struct dc_stream_state *stream; }; struct update_visual_confirm_params { struct dc *dc; struct pipe_ctx *pipe_ctx; int mpcc_id; }; struct power_on_mpc_mem_pwr_params { struct mpc *mpc; int mpcc_id; bool power_on; }; struct set_output_csc_params { struct mpc *mpc; int opp_id; const uint16_t *regval; enum mpc_output_csc_mode ocsc_mode; }; struct set_ocsc_default_params { struct mpc *mpc; int opp_id; enum dc_color_space color_space; enum mpc_output_csc_mode ocsc_mode; }; struct subvp_save_surf_addr { struct dc_dmub_srv *dc_dmub_srv; const struct dc_plane_address *addr; uint8_t subvp_index; }; struct wait_for_dcc_meta_propagation_params { const struct dc *dc; const struct pipe_ctx *top_pipe_to_program; }; struct dmub_hw_control_lock_fast_params { struct dc *dc; bool is_required; bool lock; }; struct program_surface_config_params { struct hubp *hubp; enum surface_pixel_format format; struct dc_tiling_info *tiling_info; struct plane_size plane_size; enum dc_rotation_angle rotation; struct dc_plane_dcc_param *dcc; bool horizontal_mirror; int compat_level; }; struct program_mcache_id_and_split_coordinate { struct hubp *hubp; struct dml2_hubp_pipe_mcache_regs *mcache_regs; }; struct program_cursor_update_now_params { struct dc *dc; struct pipe_ctx *pipe_ctx; }; struct hubp_wait_pipe_read_start_params { struct hubp *hubp; }; struct apply_update_flags_for_phantom_params { struct pipe_ctx *pipe_ctx; }; struct update_phantom_vp_position_params { struct dc *dc; struct pipe_ctx *pipe_ctx; struct dc_state *context; }; struct set_odm_combine_params { struct timing_generator *tg; int opp_inst[MAX_PIPES]; int opp_head_count; int odm_slice_width; int last_odm_slice_width; }; struct set_odm_bypass_params { struct timing_generator *tg; const struct dc_crtc_timing *timing; }; struct opp_pipe_clock_control_params { struct output_pixel_processor *opp; bool enable; }; struct opp_program_left_edge_extra_pixel_params { struct output_pixel_processor *opp; enum dc_pixel_encoding pixel_encoding; bool is_otg_master; }; struct dccg_set_dto_dscclk_params { struct dccg *dccg; int inst; int num_slices_h; }; struct dsc_set_config_params { struct display_stream_compressor *dsc; struct dsc_config *dsc_cfg; struct dsc_optc_config *dsc_optc_cfg; }; struct dsc_enable_params { struct display_stream_compressor *dsc; int opp_inst; }; struct tg_set_dsc_config_params { struct timing_generator *tg; struct dsc_optc_config *dsc_optc_cfg; bool enable; }; struct dsc_disconnect_params { struct display_stream_compressor *dsc; }; struct dsc_read_state_params { struct display_stream_compressor *dsc; struct dcn_dsc_state *dsc_state; }; struct dsc_calculate_and_set_config_params { struct pipe_ctx *pipe_ctx; struct dsc_optc_config dsc_optc_cfg; bool enable; int opp_cnt; }; struct dsc_enable_with_opp_params { struct pipe_ctx *pipe_ctx; }; struct program_tg_params { struct dc *dc; struct pipe_ctx *pipe_ctx; struct dc_state *context; }; struct tg_program_global_sync_params { struct timing_generator *tg; int vready_offset; unsigned int vstartup_lines; unsigned int vupdate_offset_pixels; unsigned int vupdate_vupdate_width_pixels; unsigned int pstate_keepout_start_lines; }; struct tg_wait_for_state_params { struct timing_generator *tg; enum crtc_state state; }; struct tg_set_vtg_params_params { struct timing_generator *tg; struct dc_crtc_timing *timing; bool program_fp2; }; struct tg_set_gsl_params { struct timing_generator *tg; struct gsl_params gsl; }; struct tg_set_gsl_source_select_params { struct timing_generator *tg; int group_idx; uint32_t gsl_ready_signal; }; struct setup_vupdate_interrupt_params { struct dc *dc; struct pipe_ctx *pipe_ctx; }; struct tg_setup_vertical_interrupt2_params { struct timing_generator *tg; int start_line; }; struct dpp_set_hdr_multiplier_params { struct dpp *dpp; uint32_t hw_mult; }; struct program_det_size_params { struct hubbub *hubbub; unsigned int hubp_inst; unsigned int det_buffer_size_kb; }; struct program_det_segments_params { struct hubbub *hubbub; unsigned int hubp_inst; unsigned int det_size; }; struct update_dchubp_dpp_params { struct dc *dc; struct pipe_ctx *pipe_ctx; struct dc_state *context; }; struct opp_set_dyn_expansion_params { struct output_pixel_processor *opp; enum dc_color_space color_space; enum dc_color_depth color_depth; enum signal_type signal; }; struct opp_program_fmt_params { struct output_pixel_processor *opp; struct bit_depth_reduction_params *fmt_bit_depth; struct clamping_and_pixel_encoding_params *clamping; }; struct opp_program_bit_depth_reduction_params { struct output_pixel_processor *opp; bool use_default_params; struct pipe_ctx *pipe_ctx; }; struct opp_set_disp_pattern_generator_params { struct output_pixel_processor *opp; enum controller_dp_test_pattern test_pattern; enum controller_dp_color_space color_space; enum dc_color_depth color_depth; struct tg_color solid_color; bool use_solid_color; int width; int height; int offset; }; struct set_abm_pipe_params { struct dc *dc; struct pipe_ctx *pipe_ctx; }; struct set_abm_level_params { struct abm *abm; unsigned int abm_level; }; struct set_abm_immediate_disable_params { struct dc *dc; struct pipe_ctx *pipe_ctx; }; struct set_disp_pattern_generator_params { struct dc *dc; struct pipe_ctx *pipe_ctx; enum controller_dp_test_pattern test_pattern; enum controller_dp_color_space color_space; enum dc_color_depth color_depth; const struct tg_color *solid_color; int width; int height; int offset; }; struct mpc_update_blending_params { struct mpc *mpc; struct mpcc_blnd_cfg blnd_cfg; int mpcc_id; }; struct mpc_assert_idle_mpcc_params { struct mpc *mpc; int mpcc_id; }; struct mpc_insert_plane_params { struct mpc *mpc; struct mpc_tree *mpc_tree_params; struct mpcc_blnd_cfg blnd_cfg; struct mpcc_sm_cfg *sm_cfg; struct mpcc *insert_above_mpcc; int dpp_id; int mpcc_id; }; struct mpc_remove_mpcc_params { struct mpc *mpc; struct mpc_tree *mpc_tree_params; struct mpcc *mpcc_to_remove; }; struct opp_set_mpcc_disconnect_pending_params { struct output_pixel_processor *opp; int mpcc_inst; bool pending; }; struct dc_set_optimized_required_params { struct dc *dc; bool optimized_required; }; struct hubp_disconnect_params { struct hubp *hubp; }; struct hubbub_force_pstate_change_control_params { struct hubbub *hubbub; bool enable; bool wait; }; struct tg_enable_crtc_params { struct timing_generator *tg; }; struct hubp_wait_flip_pending_params { struct hubp *hubp; unsigned int timeout_us; unsigned int polling_interval_us; }; struct tg_wait_double_buffer_pending_params { struct timing_generator *tg; unsigned int timeout_us; unsigned int polling_interval_us; }; struct update_force_pstate_params { struct dc *dc; struct dc_state *context; }; struct hubbub_apply_dedcn21_147_wa_params { struct hubbub *hubbub; }; struct hubbub_allow_self_refresh_control_params { struct hubbub *hubbub; bool allow; bool *disallow_self_refresh_applied; }; struct tg_get_frame_count_params { struct timing_generator *tg; unsigned int *frame_count; }; struct mpc_set_dwb_mux_params { struct mpc *mpc; int dwb_id; int mpcc_id; }; struct mpc_disable_dwb_mux_params { struct mpc *mpc; unsigned int dwb_id; }; struct mcif_wb_config_buf_params { struct mcif_wb *mcif_wb; struct mcif_buf_params *mcif_buf_params; unsigned int dest_height; }; struct mcif_wb_config_arb_params { struct mcif_wb *mcif_wb; struct mcif_arb_params *mcif_arb_params; }; struct mcif_wb_enable_params { struct mcif_wb *mcif_wb; }; struct mcif_wb_disable_params { struct mcif_wb *mcif_wb; }; struct dwbc_enable_params { struct dwbc *dwb; struct dc_dwb_params *dwb_params; }; struct dwbc_disable_params { struct dwbc *dwb; }; struct dwbc_update_params { struct dwbc *dwb; struct dc_dwb_params *dwb_params; }; struct hubp_update_mall_sel_params { struct hubp *hubp; uint32_t mall_sel; bool cache_cursor; }; struct hubp_prepare_subvp_buffering_params { struct hubp *hubp; bool enable; }; struct hubp_set_blank_en_params { struct hubp *hubp; bool enable; }; struct hubp_disable_control_params { struct hubp *hubp; bool disable; }; struct hubbub_soft_reset_params { struct hubbub *hubbub; void (*hubbub_soft_reset)(struct hubbub *hubbub, bool reset); bool reset; }; struct hubp_clk_cntl_params { struct hubp *hubp; bool enable; }; struct hubp_init_params { struct hubp *hubp; }; struct hubp_set_vm_system_aperture_settings_params { struct hubp *hubp; //struct vm_system_aperture_param apt; PHYSICAL_ADDRESS_LOC sys_default; PHYSICAL_ADDRESS_LOC sys_low; PHYSICAL_ADDRESS_LOC sys_high; }; struct hubp_set_flip_int_params { struct hubp *hubp; }; struct dpp_dppclk_control_params { struct dpp *dpp; bool dppclk_div; bool enable; }; struct disable_phantom_crtc_params { struct timing_generator *tg; }; struct dpp_pg_control_params { struct dce_hwseq *hws; unsigned int dpp_inst; bool power_on; }; struct hubp_pg_control_params { struct dce_hwseq *hws; unsigned int hubp_inst; bool power_on; }; struct hubp_reset_params { struct hubp *hubp; }; struct dpp_reset_params { struct dpp *dpp; }; struct dpp_root_clock_control_params { struct dce_hwseq *hws; unsigned int dpp_inst; bool clock_on; }; struct dc_ip_request_cntl_params { struct dc *dc; bool enable; }; struct dsc_pg_status_params { struct dce_hwseq *hws; int dsc_inst; bool is_ungated; }; struct dsc_wait_disconnect_pending_clear_params { struct display_stream_compressor *dsc; bool *is_ungated; }; struct dsc_disable_params { struct display_stream_compressor *dsc; bool *is_ungated; }; struct dccg_set_ref_dscclk_params { struct dccg *dccg; int dsc_inst; bool *is_ungated; }; struct dccg_update_dpp_dto_params { struct dccg *dccg; int dpp_inst; int dppclk_khz; }; struct hubp_vtg_sel_params { struct hubp *hubp; uint32_t otg_inst; }; struct hubp_setup2_params { struct hubp *hubp; struct dml2_dchub_per_pipe_register_set *hubp_regs; union dml2_global_sync_programming *global_sync; struct dc_crtc_timing *timing; }; struct hubp_setup_params { struct hubp *hubp; struct _vcs_dpi_display_dlg_regs_st *dlg_regs; struct _vcs_dpi_display_ttu_regs_st *ttu_regs; struct _vcs_dpi_display_rq_regs_st *rq_regs; struct _vcs_dpi_display_pipe_dest_params_st *pipe_dest; }; struct hubp_set_unbounded_requesting_params { struct hubp *hubp; bool unbounded_req; }; struct hubp_setup_interdependent2_params { struct hubp *hubp; struct dml2_dchub_per_pipe_register_set *hubp_regs; }; struct hubp_setup_interdependent_params { struct hubp *hubp; struct _vcs_dpi_display_dlg_regs_st *dlg_regs; struct _vcs_dpi_display_ttu_regs_st *ttu_regs; }; struct dpp_set_cursor_matrix_params { struct dpp *dpp; enum dc_color_space color_space; struct dc_csc_transform *cursor_csc_color_matrix; }; struct mpc_update_mpcc_params { struct dc *dc; struct pipe_ctx *pipe_ctx; }; struct dpp_set_scaler_params { struct dpp *dpp; const struct scaler_data *scl_data; }; struct hubp_mem_program_viewport_params { struct hubp *hubp; const struct rect *viewport; const struct rect *viewport_c; }; struct hubp_program_mcache_id_and_split_coordinate_params { struct hubp *hubp; struct mcache_regs_struct *mcache_regs; }; struct abort_cursor_offload_update_params { struct dc *dc; struct pipe_ctx *pipe_ctx; }; struct set_cursor_attribute_params { struct dc *dc; struct pipe_ctx *pipe_ctx; }; struct set_cursor_position_params { struct dc *dc; struct pipe_ctx *pipe_ctx; }; struct set_cursor_sdr_white_level_params { struct dc *dc; struct pipe_ctx *pipe_ctx; }; struct program_output_csc_params { struct dc *dc; struct pipe_ctx *pipe_ctx; enum dc_color_space colorspace; uint16_t *matrix; int opp_id; }; struct hubp_set_blank_params { struct hubp *hubp; bool blank; }; struct phantom_hubp_post_enable_params { struct hubp *hubp; }; union block_sequence_params { struct update_plane_addr_params update_plane_addr_params; struct subvp_pipe_control_lock_fast_params subvp_pipe_control_lock_fast_params; struct pipe_control_lock_params pipe_control_lock_params; struct set_flip_control_gsl_params set_flip_control_gsl_params; struct program_triplebuffer_params program_triplebuffer_params; struct set_input_transfer_func_params set_input_transfer_func_params; struct program_gamut_remap_params program_gamut_remap_params; struct program_manual_trigger_params program_manual_trigger_params; struct send_dmcub_cmd_params send_dmcub_cmd_params; struct setup_dpp_params setup_dpp_params; struct program_bias_and_scale_params program_bias_and_scale_params; struct set_output_transfer_func_params set_output_transfer_func_params; struct update_visual_confirm_params update_visual_confirm_params; struct power_on_mpc_mem_pwr_params power_on_mpc_mem_pwr_params; struct set_output_csc_params set_output_csc_params; struct set_ocsc_default_params set_ocsc_default_params; struct subvp_save_surf_addr subvp_save_surf_addr; struct wait_for_dcc_meta_propagation_params wait_for_dcc_meta_propagation_params; struct dmub_hw_control_lock_fast_params dmub_hw_control_lock_fast_params; struct program_surface_config_params program_surface_config_params; struct program_mcache_id_and_split_coordinate program_mcache_id_and_split_coordinate; struct program_cursor_update_now_params program_cursor_update_now_params; struct hubp_wait_pipe_read_start_params hubp_wait_pipe_read_start_params; struct apply_update_flags_for_phantom_params apply_update_flags_for_phantom_params; struct update_phantom_vp_position_params update_phantom_vp_position_params; struct set_odm_combine_params set_odm_combine_params; struct set_odm_bypass_params set_odm_bypass_params; struct opp_pipe_clock_control_params opp_pipe_clock_control_params; struct opp_program_left_edge_extra_pixel_params opp_program_left_edge_extra_pixel_params; struct dccg_set_dto_dscclk_params dccg_set_dto_dscclk_params; struct dsc_set_config_params dsc_set_config_params; struct dsc_enable_params dsc_enable_params; struct tg_set_dsc_config_params tg_set_dsc_config_params; struct dsc_disconnect_params dsc_disconnect_params; struct dsc_read_state_params dsc_read_state_params; struct dsc_calculate_and_set_config_params dsc_calculate_and_set_config_params; struct dsc_enable_with_opp_params dsc_enable_with_opp_params; struct program_tg_params program_tg_params; struct tg_program_global_sync_params tg_program_global_sync_params; struct tg_wait_for_state_params tg_wait_for_state_params; struct tg_set_vtg_params_params tg_set_vtg_params_params; struct tg_setup_vertical_interrupt2_params tg_setup_vertical_interrupt2_params; struct dpp_set_hdr_multiplier_params dpp_set_hdr_multiplier_params; struct tg_set_gsl_params tg_set_gsl_params; struct tg_set_gsl_source_select_params tg_set_gsl_source_select_params; struct setup_vupdate_interrupt_params setup_vupdate_interrupt_params; struct program_det_size_params program_det_size_params; struct program_det_segments_params program_det_segments_params; struct update_dchubp_dpp_params update_dchubp_dpp_params; struct opp_set_dyn_expansion_params opp_set_dyn_expansion_params; struct opp_program_fmt_params opp_program_fmt_params; struct opp_program_bit_depth_reduction_params opp_program_bit_depth_reduction_params; struct opp_set_disp_pattern_generator_params opp_set_disp_pattern_generator_params; struct set_abm_pipe_params set_abm_pipe_params; struct set_abm_level_params set_abm_level_params; struct set_abm_immediate_disable_params set_abm_immediate_disable_params; struct set_disp_pattern_generator_params set_disp_pattern_generator_params; struct mpc_remove_mpcc_params mpc_remove_mpcc_params; struct opp_set_mpcc_disconnect_pending_params opp_set_mpcc_disconnect_pending_params; struct dc_set_optimized_required_params dc_set_optimized_required_params; struct hubp_disconnect_params hubp_disconnect_params; struct hubbub_force_pstate_change_control_params hubbub_force_pstate_change_control_params; struct tg_enable_crtc_params tg_enable_crtc_params; struct hubp_wait_flip_pending_params hubp_wait_flip_pending_params; struct tg_wait_double_buffer_pending_params tg_wait_double_buffer_pending_params; struct update_force_pstate_params update_force_pstate_params; struct hubbub_apply_dedcn21_147_wa_params hubbub_apply_dedcn21_147_wa_params; struct hubbub_allow_self_refresh_control_params hubbub_allow_self_refresh_control_params; struct tg_get_frame_count_params tg_get_frame_count_params; struct mpc_set_dwb_mux_params mpc_set_dwb_mux_params; struct mpc_disable_dwb_mux_params mpc_disable_dwb_mux_params; struct mcif_wb_config_buf_params mcif_wb_config_buf_params; struct mcif_wb_config_arb_params mcif_wb_config_arb_params; struct mcif_wb_enable_params mcif_wb_enable_params; struct mcif_wb_disable_params mcif_wb_disable_params; struct dwbc_enable_params dwbc_enable_params; struct dwbc_disable_params dwbc_disable_params; struct dwbc_update_params dwbc_update_params; struct hubp_update_mall_sel_params hubp_update_mall_sel_params; struct hubp_prepare_subvp_buffering_params hubp_prepare_subvp_buffering_params; struct hubp_set_blank_en_params hubp_set_blank_en_params; struct hubp_disable_control_params hubp_disable_control_params; struct hubbub_soft_reset_params hubbub_soft_reset_params; struct hubp_clk_cntl_params hubp_clk_cntl_params; struct hubp_init_params hubp_init_params; struct hubp_set_vm_system_aperture_settings_params hubp_set_vm_system_aperture_settings_params; struct hubp_set_flip_int_params hubp_set_flip_int_params; struct dpp_dppclk_control_params dpp_dppclk_control_params; struct disable_phantom_crtc_params disable_phantom_crtc_params; struct dpp_pg_control_params dpp_pg_control_params; struct hubp_pg_control_params hubp_pg_control_params; struct hubp_reset_params hubp_reset_params; struct dpp_reset_params dpp_reset_params; struct dpp_root_clock_control_params dpp_root_clock_control_params; struct dc_ip_request_cntl_params dc_ip_request_cntl_params; struct dsc_pg_status_params dsc_pg_status_params; struct dsc_wait_disconnect_pending_clear_params dsc_wait_disconnect_pending_clear_params; struct dsc_disable_params dsc_disable_params; struct dccg_set_ref_dscclk_params dccg_set_ref_dscclk_params; struct dccg_update_dpp_dto_params dccg_update_dpp_dto_params; struct hubp_vtg_sel_params hubp_vtg_sel_params; struct hubp_setup2_params hubp_setup2_params; struct hubp_setup_params hubp_setup_params; struct hubp_set_unbounded_requesting_params hubp_set_unbounded_requesting_params; struct hubp_setup_interdependent2_params hubp_setup_interdependent2_params; struct hubp_setup_interdependent_params hubp_setup_interdependent_params; struct dpp_set_cursor_matrix_params dpp_set_cursor_matrix_params; struct mpc_update_mpcc_params mpc_update_mpcc_params; struct mpc_update_blending_params mpc_update_blending_params; struct mpc_assert_idle_mpcc_params mpc_assert_idle_mpcc_params; struct mpc_insert_plane_params mpc_insert_plane_params; struct dpp_set_scaler_params dpp_set_scaler_params; struct hubp_mem_program_viewport_params hubp_mem_program_viewport_params; struct abort_cursor_offload_update_params abort_cursor_offload_update_params; struct set_cursor_attribute_params set_cursor_attribute_params; struct set_cursor_position_params set_cursor_position_params; struct set_cursor_sdr_white_level_params set_cursor_sdr_white_level_params; struct program_output_csc_params program_output_csc_params; struct hubp_set_blank_params hubp_set_blank_params; struct phantom_hubp_post_enable_params phantom_hubp_post_enable_params; }; enum block_sequence_func { DMUB_SUBVP_PIPE_CONTROL_LOCK_FAST = 0, OPTC_PIPE_CONTROL_LOCK, HUBP_SET_FLIP_CONTROL_GSL, HUBP_PROGRAM_TRIPLEBUFFER, HUBP_UPDATE_PLANE_ADDR, DPP_SET_INPUT_TRANSFER_FUNC, DPP_PROGRAM_GAMUT_REMAP, OPTC_PROGRAM_MANUAL_TRIGGER, DMUB_SEND_DMCUB_CMD, DPP_SETUP_DPP, DPP_PROGRAM_BIAS_AND_SCALE, DPP_SET_OUTPUT_TRANSFER_FUNC, DPP_SET_HDR_MULTIPLIER, MPC_UPDATE_VISUAL_CONFIRM, MPC_POWER_ON_MPC_MEM_PWR, MPC_SET_OUTPUT_CSC, MPC_SET_OCSC_DEFAULT, DMUB_SUBVP_SAVE_SURF_ADDR, HUBP_WAIT_FOR_DCC_META_PROP, DMUB_HW_CONTROL_LOCK_FAST, HUBP_PROGRAM_SURFACE_CONFIG, HUBP_PROGRAM_MCACHE_ID, PROGRAM_CURSOR_UPDATE_NOW, HUBP_WAIT_PIPE_READ_START, HWS_APPLY_UPDATE_FLAGS_FOR_PHANTOM, HWS_UPDATE_PHANTOM_VP_POSITION, OPTC_SET_ODM_COMBINE, OPTC_SET_ODM_BYPASS, OPP_PIPE_CLOCK_CONTROL, OPP_PROGRAM_LEFT_EDGE_EXTRA_PIXEL, DCCG_SET_DTO_DSCCLK, DSC_SET_CONFIG, DSC_ENABLE, TG_SET_DSC_CONFIG, DSC_DISCONNECT, DSC_READ_STATE, DSC_CALCULATE_AND_SET_CONFIG, DSC_ENABLE_WITH_OPP, TG_PROGRAM_GLOBAL_SYNC, TG_WAIT_FOR_STATE, TG_SET_VTG_PARAMS, TG_SETUP_VERTICAL_INTERRUPT2, HUBP_PROGRAM_DET_SIZE, HUBP_PROGRAM_DET_SEGMENTS, OPP_SET_DYN_EXPANSION, OPP_PROGRAM_FMT, OPP_PROGRAM_BIT_DEPTH_REDUCTION, OPP_SET_DISP_PATTERN_GENERATOR, ABM_SET_PIPE, ABM_SET_LEVEL, ABM_SET_IMMEDIATE_DISABLE, MPC_REMOVE_MPCC, OPP_SET_MPCC_DISCONNECT_PENDING, DC_SET_OPTIMIZED_REQUIRED, HUBP_DISCONNECT, HUBBUB_FORCE_PSTATE_CHANGE_CONTROL, TG_ENABLE_CRTC, TG_SET_GSL, TG_SET_GSL_SOURCE_SELECT, HUBP_WAIT_FLIP_PENDING, TG_WAIT_DOUBLE_BUFFER_PENDING, UPDATE_FORCE_PSTATE, PROGRAM_MALL_PIPE_CONFIG, HUBBUB_APPLY_DEDCN21_147_WA, HUBBUB_ALLOW_SELF_REFRESH_CONTROL, TG_GET_FRAME_COUNT, MPC_SET_DWB_MUX, MPC_DISABLE_DWB_MUX, MCIF_WB_CONFIG_BUF, MCIF_WB_CONFIG_ARB, MCIF_WB_ENABLE, MCIF_WB_DISABLE, DWBC_ENABLE, DWBC_DISABLE, DWBC_UPDATE, HUBP_UPDATE_MALL_SEL, HUBP_PREPARE_SUBVP_BUFFERING, HUBP_SET_BLANK_EN, HUBP_DISABLE_CONTROL, HUBBUB_SOFT_RESET, HUBP_CLK_CNTL, HUBP_INIT, HUBP_SET_VM_SYSTEM_APERTURE_SETTINGS, HUBP_SET_FLIP_INT, DPP_DPPCLK_CONTROL, DISABLE_PHANTOM_CRTC, DSC_PG_STATUS, DSC_WAIT_DISCONNECT_PENDING_CLEAR, DSC_DISABLE, DCCG_SET_REF_DSCCLK, DPP_PG_CONTROL, HUBP_PG_CONTROL, HUBP_RESET, DPP_RESET, DPP_ROOT_CLOCK_CONTROL, DC_IP_REQUEST_CNTL, DCCG_UPDATE_DPP_DTO, HUBP_VTG_SEL, HUBP_SETUP2, HUBP_SETUP, HUBP_SET_UNBOUNDED_REQUESTING, HUBP_SETUP_INTERDEPENDENT2, HUBP_SETUP_INTERDEPENDENT, DPP_SET_CURSOR_MATRIX, MPC_UPDATE_BLENDING, MPC_ASSERT_IDLE_MPCC, MPC_INSERT_PLANE, DPP_SET_SCALER, HUBP_MEM_PROGRAM_VIEWPORT, ABORT_CURSOR_OFFLOAD_UPDATE, SET_CURSOR_ATTRIBUTE, SET_CURSOR_POSITION, SET_CURSOR_SDR_WHITE_LEVEL, PROGRAM_OUTPUT_CSC, HUBP_SET_LEGACY_TILING_COMPAT_LEVEL, HUBP_SET_BLANK, PHANTOM_HUBP_POST_ENABLE, /* This must be the last value in this enum, add new ones above */ HWSS_BLOCK_SEQUENCE_FUNC_COUNT }; struct block_sequence { union block_sequence_params params; enum block_sequence_func func; }; struct block_sequence_state { struct block_sequence *steps; unsigned int *num_steps; }; #define MAX_HWSS_BLOCK_SEQUENCE_SIZE (HWSS_BLOCK_SEQUENCE_FUNC_COUNT * MAX_PIPES) struct hw_sequencer_funcs { void (*hardware_release)(struct dc *dc); /* Embedded Display Related */ void (*edp_power_control)(struct dc_link *link, bool enable); void (*edp_wait_for_hpd_ready)(struct dc_link *link, bool power_up); void (*edp_wait_for_T12)(struct dc_link *link); /* Pipe Programming Related */ void (*init_hw)(struct dc *dc); void (*power_down_on_boot)(struct dc *dc); void (*enable_accelerated_mode)(struct dc *dc, struct dc_state *context); enum dc_status (*apply_ctx_to_hw)(struct dc *dc, struct dc_state *context); void (*disable_plane)(struct dc *dc, struct dc_state *state, struct pipe_ctx *pipe_ctx); void (*disable_plane_sequence)(struct dc *dc, struct dc_state *state, struct pipe_ctx *pipe_ctx, struct block_sequence_state *seq_state); void (*disable_pixel_data)(struct dc *dc, struct pipe_ctx *pipe_ctx, bool blank); void (*apply_ctx_for_surface)(struct dc *dc, const struct dc_stream_state *stream, int num_planes, struct dc_state *context); void (*program_front_end_for_ctx)(struct dc *dc, struct dc_state *context); void (*wait_for_pending_cleared)(struct dc *dc, struct dc_state *context); void (*post_unlock_program_front_end)(struct dc *dc, struct dc_state *context); void (*update_plane_addr)(const struct dc *dc, struct pipe_ctx *pipe_ctx); void (*update_dchub)(struct dce_hwseq *hws, struct dchub_init_data *dh_data); void (*wait_for_mpcc_disconnect)(struct dc *dc, struct resource_pool *res_pool, struct pipe_ctx *pipe_ctx); void (*wait_for_mpcc_disconnect_sequence)(struct dc *dc, struct resource_pool *res_pool, struct pipe_ctx *pipe_ctx, struct block_sequence_state *seq_state); void (*edp_backlight_control)( struct dc_link *link, bool enable); void (*program_triplebuffer)(const struct dc *dc, struct pipe_ctx *pipe_ctx, bool enableTripleBuffer); void (*update_pending_status)(struct pipe_ctx *pipe_ctx); void (*update_dsc_pg)(struct dc *dc, struct dc_state *context, bool safe_to_disable); void (*clear_surface_dcc_and_tiling)(struct pipe_ctx *pipe_ctx, struct dc_plane_state *plane_state, bool clear_tiling); /* Pipe Lock Related */ void (*pipe_control_lock)(struct dc *dc, struct pipe_ctx *pipe, bool lock); void (*interdependent_update_lock)(struct dc *dc, struct dc_state *context, bool lock); void (*set_flip_control_gsl)(struct pipe_ctx *pipe_ctx, bool flip_immediate); void (*cursor_lock)(struct dc *dc, struct pipe_ctx *pipe, bool lock); /* Timing Related */ void (*get_position)(struct pipe_ctx **pipe_ctx, int num_pipes, struct crtc_position *position); int (*get_vupdate_offset_from_vsync)(struct pipe_ctx *pipe_ctx); void (*calc_vupdate_position)( struct dc *dc, struct pipe_ctx *pipe_ctx, uint32_t *start_line, uint32_t *end_line); void (*enable_per_frame_crtc_position_reset)(struct dc *dc, int group_size, struct pipe_ctx *grouped_pipes[]); void (*enable_timing_synchronization)(struct dc *dc, struct dc_state *state, int group_index, int group_size, struct pipe_ctx *grouped_pipes[]); void (*enable_vblanks_synchronization)(struct dc *dc, int group_index, int group_size, struct pipe_ctx *grouped_pipes[]); void (*setup_periodic_interrupt)(struct dc *dc, struct pipe_ctx *pipe_ctx); void (*set_drr)(struct pipe_ctx **pipe_ctx, int num_pipes, struct dc_crtc_timing_adjust adjust); void (*set_static_screen_control)(struct pipe_ctx **pipe_ctx, int num_pipes, const struct dc_static_screen_params *events); /* Stream Related */ void (*enable_stream)(struct pipe_ctx *pipe_ctx); void (*disable_stream)(struct pipe_ctx *pipe_ctx); void (*blank_stream)(struct pipe_ctx *pipe_ctx); void (*unblank_stream)(struct pipe_ctx *pipe_ctx, struct dc_link_settings *link_settings); /* Bandwidth Related */ void (*prepare_bandwidth)(struct dc *dc, struct dc_state *context); bool (*update_bandwidth)(struct dc *dc, struct dc_state *context); void (*optimize_bandwidth)(struct dc *dc, struct dc_state *context); /* Infopacket Related */ void (*set_avmute)(struct pipe_ctx *pipe_ctx, bool enable); void (*send_immediate_sdp_message)( struct pipe_ctx *pipe_ctx, const uint8_t *custom_sdp_message, unsigned int sdp_message_size); void (*update_info_frame)(struct pipe_ctx *pipe_ctx); void (*set_dmdata_attributes)(struct pipe_ctx *pipe); void (*program_dmdata_engine)(struct pipe_ctx *pipe_ctx); bool (*dmdata_status_done)(struct pipe_ctx *pipe_ctx); /* Cursor Related */ void (*set_cursor_position)(struct pipe_ctx *pipe); void (*set_cursor_attribute)(struct pipe_ctx *pipe); void (*set_cursor_sdr_white_level)(struct pipe_ctx *pipe); void (*abort_cursor_offload_update)(struct dc *dc, const struct pipe_ctx *pipe); void (*begin_cursor_offload_update)(struct dc *dc, const struct pipe_ctx *pipe); void (*commit_cursor_offload_update)(struct dc *dc, const struct pipe_ctx *pipe); void (*update_cursor_offload_pipe)(struct dc *dc, const struct pipe_ctx *pipe); void (*notify_cursor_offload_drr_update)(struct dc *dc, struct dc_state *context, const struct dc_stream_state *stream); void (*program_cursor_offload_now)(struct dc *dc, const struct pipe_ctx *pipe); /* Colour Related */ void (*program_gamut_remap)(struct pipe_ctx *pipe_ctx); void (*program_output_csc)(struct dc *dc, struct pipe_ctx *pipe_ctx, enum dc_color_space colorspace, uint16_t *matrix, int opp_id); void (*trigger_3dlut_dma_load)(struct dc *dc, struct pipe_ctx *pipe_ctx); /* VM Related */ int (*init_sys_ctx)(struct dce_hwseq *hws, struct dc *dc, struct dc_phy_addr_space_config *pa_config); void (*init_vm_ctx)(struct dce_hwseq *hws, struct dc *dc, struct dc_virtual_addr_space_config *va_config, int vmid); /* Writeback Related */ void (*update_writeback)(struct dc *dc, struct dc_writeback_info *wb_info, struct dc_state *context); void (*enable_writeback)(struct dc *dc, struct dc_writeback_info *wb_info, struct dc_state *context); void (*disable_writeback)(struct dc *dc, unsigned int dwb_pipe_inst); /* Clock Related */ enum dc_status (*set_clock)(struct dc *dc, enum dc_clock_type clock_type, uint32_t clk_khz, uint32_t stepping); void (*get_clock)(struct dc *dc, enum dc_clock_type clock_type, struct dc_clock_config *clock_cfg); void (*optimize_pwr_state)(const struct dc *dc, struct dc_state *context); void (*exit_optimized_pwr_state)(const struct dc *dc, struct dc_state *context); void (*calculate_pix_rate_divider)(struct dc *dc, struct dc_state *context, const struct dc_stream_state *stream); /* Audio Related */ void (*enable_audio_stream)(struct pipe_ctx *pipe_ctx); void (*disable_audio_stream)(struct pipe_ctx *pipe_ctx); /* Stereo 3D Related */ void (*setup_stereo)(struct pipe_ctx *pipe_ctx, struct dc *dc); /* HW State Logging Related */ void (*log_hw_state)(struct dc *dc, struct dc_log_buffer_ctx *log_ctx); void (*log_color_state)(struct dc *dc, struct dc_log_buffer_ctx *log_ctx); void (*get_hw_state)(struct dc *dc, char *pBuf, unsigned int bufSize, unsigned int mask); void (*clear_status_bits)(struct dc *dc, unsigned int mask); bool (*set_backlight_level)(struct pipe_ctx *pipe_ctx, struct set_backlight_level_params *params); void (*set_abm_immediate_disable)(struct pipe_ctx *pipe_ctx); void (*set_pipe)(struct pipe_ctx *pipe_ctx); void (*enable_dp_link_output)(struct dc_link *link, const struct link_resource *link_res, enum signal_type signal, enum clock_source_id clock_source, const struct dc_link_settings *link_settings); void (*enable_tmds_link_output)(struct dc_link *link, const struct link_resource *link_res, enum signal_type signal, enum clock_source_id clock_source, enum dc_color_depth color_depth, uint32_t pixel_clock); void (*enable_lvds_link_output)(struct dc_link *link, const struct link_resource *link_res, enum clock_source_id clock_source, uint32_t pixel_clock); void (*disable_link_output)(struct dc_link *link, const struct link_resource *link_res, enum signal_type signal); void (*get_dcc_en_bits)(struct dc *dc, int *dcc_en_bits); /* Idle Optimization Related */ bool (*apply_idle_power_optimizations)(struct dc *dc, bool enable); bool (*does_plane_fit_in_mall)(struct dc *dc, unsigned int pitch, unsigned int height, enum surface_pixel_format format, struct dc_cursor_attributes *cursor_attr); void (*commit_subvp_config)(struct dc *dc, struct dc_state *context); void (*enable_phantom_streams)(struct dc *dc, struct dc_state *context); void (*disable_phantom_streams)(struct dc *dc, struct dc_state *context); void (*subvp_pipe_control_lock)(struct dc *dc, struct dc_state *context, bool lock, bool should_lock_all_pipes, struct pipe_ctx *top_pipe_to_program, bool subvp_prev_use); void (*subvp_pipe_control_lock_fast)(union block_sequence_params *params); void (*z10_restore)(const struct dc *dc); void (*z10_save_init)(struct dc *dc); bool (*is_abm_supported)(struct dc *dc, struct dc_state *context, struct dc_stream_state *stream); void (*set_disp_pattern_generator)(const struct dc *dc, struct pipe_ctx *pipe_ctx, enum controller_dp_test_pattern test_pattern, enum controller_dp_color_space color_space, enum dc_color_depth color_depth, const struct tg_color *solid_color, int width, int height, int offset); void (*blank_phantom)(struct dc *dc, struct timing_generator *tg, int width, int height); void (*update_visual_confirm_color)(struct dc *dc, struct pipe_ctx *pipe_ctx, int mpcc_id); void (*update_phantom_vp_position)(struct dc *dc, struct dc_state *context, struct pipe_ctx *phantom_pipe); void (*apply_update_flags_for_phantom)(struct pipe_ctx *phantom_pipe); void (*calc_blocks_to_gate)(struct dc *dc, struct dc_state *context, struct pg_block_update *update_state); void (*calc_blocks_to_ungate)(struct dc *dc, struct dc_state *context, struct pg_block_update *update_state); void (*hw_block_power_up)(struct dc *dc, struct pg_block_update *update_state); void (*hw_block_power_down)(struct dc *dc, struct pg_block_update *update_state); void (*root_clock_control)(struct dc *dc, struct pg_block_update *update_state, bool power_on); bool (*is_pipe_topology_transition_seamless)(struct dc *dc, const struct dc_state *cur_ctx, const struct dc_state *new_ctx); void (*wait_for_dcc_meta_propagation)(const struct dc *dc, const struct pipe_ctx *top_pipe_to_program); void (*dmub_hw_control_lock)(struct dc *dc, struct dc_state *context, bool lock); void (*fams2_update_config)(struct dc *dc, struct dc_state *context, bool enable); void (*dmub_hw_control_lock_fast)(union block_sequence_params *params); void (*set_long_vtotal)(struct pipe_ctx **pipe_ctx, int num_pipes, uint32_t v_total_min, uint32_t v_total_max); void (*program_outstanding_updates)(struct dc *dc, struct dc_state *context); void (*setup_hpo_hw_control)(const struct dce_hwseq *hws, bool enable); void (*wait_for_all_pending_updates)(const struct pipe_ctx *pipe_ctx); void (*detect_pipe_changes)(struct dc_state *old_state, struct dc_state *new_state, struct pipe_ctx *old_pipe, struct pipe_ctx *new_pipe); void (*enable_plane)(struct dc *dc, struct pipe_ctx *pipe_ctx, struct dc_state *context); void (*enable_plane_sequence)(struct dc *dc, struct pipe_ctx *pipe_ctx, struct dc_state *context, struct block_sequence_state *seq_state); void (*update_dchubp_dpp)(struct dc *dc, struct pipe_ctx *pipe_ctx, struct dc_state *context); void (*update_dchubp_dpp_sequence)(struct dc *dc, struct pipe_ctx *pipe_ctx, struct dc_state *context, struct block_sequence_state *seq_state); void (*post_unlock_reset_opp)(struct dc *dc, struct pipe_ctx *opp_head); void (*post_unlock_reset_opp_sequence)( struct dc *dc, struct pipe_ctx *opp_head, struct block_sequence_state *seq_state); void (*get_underflow_debug_data)(const struct dc *dc, struct timing_generator *tg, struct dc_underflow_debug_data *out_data); }; void color_space_to_black_color( const struct dc *dc, enum dc_color_space colorspace, struct tg_color *black_color); bool hwss_wait_for_blank_complete( struct timing_generator *tg); const uint16_t *find_color_matrix( enum dc_color_space color_space, uint32_t *array_size); void get_surface_tile_visual_confirm_color( struct pipe_ctx *pipe_ctx, struct tg_color *color); void get_surface_visual_confirm_color( const struct pipe_ctx *pipe_ctx, struct tg_color *color); void get_hdr_visual_confirm_color( struct pipe_ctx *pipe_ctx, struct tg_color *color); void get_mpctree_visual_confirm_color( struct pipe_ctx *pipe_ctx, struct tg_color *color); void get_smartmux_visual_confirm_color( struct dc *dc, struct tg_color *color); void get_vabc_visual_confirm_color( struct pipe_ctx *pipe_ctx, struct tg_color *color); void get_subvp_visual_confirm_color( struct pipe_ctx *pipe_ctx, struct tg_color *color); void get_fams2_visual_confirm_color( struct dc *dc, struct dc_state *context, struct pipe_ctx *pipe_ctx, struct tg_color *color); void get_mclk_switch_visual_confirm_color( struct pipe_ctx *pipe_ctx, struct tg_color *color); void get_cursor_visual_confirm_color( struct pipe_ctx *pipe_ctx, struct tg_color *color); void get_dcc_visual_confirm_color( struct dc *dc, struct pipe_ctx *pipe_ctx, struct tg_color *color); void set_p_state_switch_method( struct dc *dc, struct dc_state *context, struct pipe_ctx *pipe_ctx); void set_drr_and_clear_adjust_pending( struct pipe_ctx *pipe_ctx, struct dc_stream_state *stream, struct drr_params *params); void hwss_execute_sequence(struct dc *dc, struct block_sequence block_sequence[MAX_HWSS_BLOCK_SEQUENCE_SIZE], int num_steps); void hwss_build_fast_sequence(struct dc *dc, struct dc_dmub_cmd *dc_dmub_cmd, unsigned int dmub_cmd_count, struct block_sequence block_sequence[MAX_HWSS_BLOCK_SEQUENCE_SIZE], unsigned int *num_steps, struct pipe_ctx *pipe_ctx, struct dc_stream_status *stream_status, struct dc_state *context); void hwss_wait_for_all_blank_complete(struct dc *dc, struct dc_state *context); void hwss_wait_for_odm_update_pending_complete(struct dc *dc, struct dc_state *context); void hwss_wait_for_no_pipes_pending(struct dc *dc, struct dc_state *context); void hwss_wait_for_outstanding_hw_updates(struct dc *dc, struct dc_state *dc_context); void hwss_process_outstanding_hw_updates(struct dc *dc, struct dc_state *dc_context); void hwss_send_dmcub_cmd(union block_sequence_params *params); void hwss_program_manual_trigger(union block_sequence_params *params); void hwss_setup_dpp(union block_sequence_params *params); void hwss_program_bias_and_scale(union block_sequence_params *params); void hwss_power_on_mpc_mem_pwr(union block_sequence_params *params); void hwss_set_output_csc(union block_sequence_params *params); void hwss_set_ocsc_default(union block_sequence_params *params); void hwss_subvp_save_surf_addr(union block_sequence_params *params); void hwss_program_surface_config(union block_sequence_params *params); void hwss_program_mcache_id_and_split_coordinate(union block_sequence_params *params); void hwss_set_odm_combine(union block_sequence_params *params); void hwss_set_odm_bypass(union block_sequence_params *params); void hwss_opp_pipe_clock_control(union block_sequence_params *params); void hwss_opp_program_left_edge_extra_pixel(union block_sequence_params *params); void hwss_blank_pixel_data(union block_sequence_params *params); void hwss_dccg_set_dto_dscclk(union block_sequence_params *params); void hwss_dsc_set_config(union block_sequence_params *params); void hwss_dsc_enable(union block_sequence_params *params); void hwss_tg_set_dsc_config(union block_sequence_params *params); void hwss_dsc_disconnect(union block_sequence_params *params); void hwss_dsc_read_state(union block_sequence_params *params); void hwss_dsc_calculate_and_set_config(union block_sequence_params *params); void hwss_dsc_enable_with_opp(union block_sequence_params *params); void hwss_program_tg(union block_sequence_params *params); void hwss_tg_program_global_sync(union block_sequence_params *params); void hwss_tg_wait_for_state(union block_sequence_params *params); void hwss_tg_set_vtg_params(union block_sequence_params *params); void hwss_tg_setup_vertical_interrupt2(union block_sequence_params *params); void hwss_dpp_set_hdr_multiplier(union block_sequence_params *params); void hwss_program_det_size(union block_sequence_params *params); void hwss_program_det_segments(union block_sequence_params *params); void hwss_opp_set_dyn_expansion(union block_sequence_params *params); void hwss_opp_program_fmt(union block_sequence_params *params); void hwss_opp_program_bit_depth_reduction(union block_sequence_params *params); void hwss_opp_set_disp_pattern_generator(union block_sequence_params *params); void hwss_set_abm_pipe(union block_sequence_params *params); void hwss_set_abm_level(union block_sequence_params *params); void hwss_set_abm_immediate_disable(union block_sequence_params *params); void hwss_mpc_remove_mpcc(union block_sequence_params *params); void hwss_opp_set_mpcc_disconnect_pending(union block_sequence_params *params); void hwss_dc_set_optimized_required(union block_sequence_params *params); void hwss_hubp_disconnect(union block_sequence_params *params); void hwss_hubbub_force_pstate_change_control(union block_sequence_params *params); void hwss_tg_enable_crtc(union block_sequence_params *params); void hwss_tg_set_gsl(union block_sequence_params *params); void hwss_tg_set_gsl_source_select(union block_sequence_params *params); void hwss_hubp_wait_flip_pending(union block_sequence_params *params); void hwss_tg_wait_double_buffer_pending(union block_sequence_params *params); void hwss_update_force_pstate(union block_sequence_params *params); void hwss_hubbub_apply_dedcn21_147_wa(union block_sequence_params *params); void hwss_hubbub_allow_self_refresh_control(union block_sequence_params *params); void hwss_tg_get_frame_count(union block_sequence_params *params); void hwss_mpc_set_dwb_mux(union block_sequence_params *params); void hwss_mpc_disable_dwb_mux(union block_sequence_params *params); void hwss_mcif_wb_config_buf(union block_sequence_params *params); void hwss_mcif_wb_config_arb(union block_sequence_params *params); void hwss_mcif_wb_enable(union block_sequence_params *params); void hwss_mcif_wb_disable(union block_sequence_params *params); void hwss_dwbc_enable(union block_sequence_params *params); void hwss_dwbc_disable(union block_sequence_params *params); void hwss_dwbc_update(union block_sequence_params *params); void hwss_hubp_update_mall_sel(union block_sequence_params *params); void hwss_hubp_prepare_subvp_buffering(union block_sequence_params *params); void hwss_hubp_set_blank_en(union block_sequence_params *params); void hwss_hubp_disable_control(union block_sequence_params *params); void hwss_hubbub_soft_reset(union block_sequence_params *params); void hwss_hubp_clk_cntl(union block_sequence_params *params); void hwss_hubp_init(union block_sequence_params *params); void hwss_hubp_set_vm_system_aperture_settings(union block_sequence_params *params); void hwss_hubp_set_flip_int(union block_sequence_params *params); void hwss_dpp_dppclk_control(union block_sequence_params *params); void hwss_disable_phantom_crtc(union block_sequence_params *params); void hwss_dsc_pg_status(union block_sequence_params *params); void hwss_dsc_wait_disconnect_pending_clear(union block_sequence_params *params); void hwss_dsc_disable(union block_sequence_params *params); void hwss_dccg_set_ref_dscclk(union block_sequence_params *params); void hwss_dpp_pg_control(union block_sequence_params *params); void hwss_hubp_pg_control(union block_sequence_params *params); void hwss_hubp_reset(union block_sequence_params *params); void hwss_dpp_reset(union block_sequence_params *params); void hwss_dpp_root_clock_control(union block_sequence_params *params); void hwss_dc_ip_request_cntl(union block_sequence_params *params); void hwss_dccg_update_dpp_dto(union block_sequence_params *params); void hwss_hubp_vtg_sel(union block_sequence_params *params); void hwss_hubp_setup2(union block_sequence_params *params); void hwss_hubp_setup(union block_sequence_params *params); void hwss_hubp_set_unbounded_requesting(union block_sequence_params *params); void hwss_hubp_setup_interdependent2(union block_sequence_params *params); void hwss_hubp_setup_interdependent(union block_sequence_params *params); void hwss_dpp_set_cursor_matrix(union block_sequence_params *params); void hwss_mpc_update_mpcc(union block_sequence_params *params); void hwss_mpc_update_blending(union block_sequence_params *params); void hwss_mpc_assert_idle_mpcc(union block_sequence_params *params); void hwss_mpc_insert_plane(union block_sequence_params *params); void hwss_dpp_set_scaler(union block_sequence_params *params); void hwss_hubp_mem_program_viewport(union block_sequence_params *params); void hwss_abort_cursor_offload_update(union block_sequence_params *params); void hwss_set_cursor_attribute(union block_sequence_params *params); void hwss_set_cursor_position(union block_sequence_params *params); void hwss_set_cursor_sdr_white_level(union block_sequence_params *params); void hwss_program_output_csc(union block_sequence_params *params); void hwss_hubp_set_legacy_tiling_compat_level(union block_sequence_params *params); void hwss_hubp_set_blank(union block_sequence_params *params); void hwss_phantom_hubp_post_enable(union block_sequence_params *params); void hwss_add_optc_pipe_control_lock(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *pipe_ctx, bool lock); void hwss_add_hubp_set_flip_control_gsl(struct block_sequence_state *seq_state, struct hubp *hubp, bool flip_immediate); void hwss_add_hubp_program_triplebuffer(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *pipe_ctx, bool enableTripleBuffer); void hwss_add_hubp_update_plane_addr(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *pipe_ctx); void hwss_add_dpp_set_input_transfer_func(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *pipe_ctx, struct dc_plane_state *plane_state); void hwss_add_dpp_program_gamut_remap(struct block_sequence_state *seq_state, struct pipe_ctx *pipe_ctx); void hwss_add_dpp_program_bias_and_scale(struct block_sequence_state *seq_state, struct pipe_ctx *pipe_ctx); void hwss_add_optc_program_manual_trigger(struct block_sequence_state *seq_state, struct pipe_ctx *pipe_ctx); void hwss_add_dpp_set_output_transfer_func(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *pipe_ctx, struct dc_stream_state *stream); void hwss_add_mpc_update_visual_confirm(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *pipe_ctx, int mpcc_id); void hwss_add_mpc_power_on_mpc_mem_pwr(struct block_sequence_state *seq_state, struct mpc *mpc, int mpcc_id, bool power_on); void hwss_add_mpc_set_output_csc(struct block_sequence_state *seq_state, struct mpc *mpc, int opp_id, const uint16_t *regval, enum mpc_output_csc_mode ocsc_mode); void hwss_add_mpc_set_ocsc_default(struct block_sequence_state *seq_state, struct mpc *mpc, int opp_id, enum dc_color_space colorspace, enum mpc_output_csc_mode ocsc_mode); void hwss_add_dmub_send_dmcub_cmd(struct block_sequence_state *seq_state, struct dc_context *ctx, union dmub_rb_cmd *cmd, enum dm_dmub_wait_type wait_type); void hwss_add_dmub_subvp_save_surf_addr(struct block_sequence_state *seq_state, struct dc_dmub_srv *dc_dmub_srv, struct dc_plane_address *addr, uint8_t subvp_index); void hwss_add_hubp_wait_for_dcc_meta_prop(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *top_pipe_to_program); void hwss_add_hubp_wait_pipe_read_start(struct block_sequence_state *seq_state, struct hubp *hubp); void hwss_add_hws_apply_update_flags_for_phantom(struct block_sequence_state *seq_state, struct pipe_ctx *pipe_ctx); void hwss_add_hws_update_phantom_vp_position(struct block_sequence_state *seq_state, struct dc *dc, struct dc_state *context, struct pipe_ctx *pipe_ctx); void hwss_add_optc_set_odm_combine(struct block_sequence_state *seq_state, struct timing_generator *tg, int opp_inst[MAX_PIPES], int opp_head_count, int odm_slice_width, int last_odm_slice_width); void hwss_add_optc_set_odm_bypass(struct block_sequence_state *seq_state, struct timing_generator *optc, struct dc_crtc_timing *timing); void hwss_add_tg_program_global_sync(struct block_sequence_state *seq_state, struct timing_generator *tg, int vready_offset, unsigned int vstartup_lines, unsigned int vupdate_offset_pixels, unsigned int vupdate_vupdate_width_pixels, unsigned int pstate_keepout_start_lines); void hwss_add_tg_wait_for_state(struct block_sequence_state *seq_state, struct timing_generator *tg, enum crtc_state state); void hwss_add_tg_set_vtg_params(struct block_sequence_state *seq_state, struct timing_generator *tg, struct dc_crtc_timing *dc_crtc_timing, bool program_fp2); void hwss_add_tg_setup_vertical_interrupt2(struct block_sequence_state *seq_state, struct timing_generator *tg, int start_line); void hwss_add_dpp_set_hdr_multiplier(struct block_sequence_state *seq_state, struct dpp *dpp, uint32_t hw_mult); void hwss_add_hubp_program_det_size(struct block_sequence_state *seq_state, struct hubbub *hubbub, unsigned int hubp_inst, unsigned int det_buffer_size_kb); void hwss_add_hubp_program_mcache_id(struct block_sequence_state *seq_state, struct hubp *hubp, struct dml2_hubp_pipe_mcache_regs *mcache_regs); void hwss_add_hubbub_force_pstate_change_control(struct block_sequence_state *seq_state, struct hubbub *hubbub, bool enable, bool wait); void hwss_add_hubp_program_det_segments(struct block_sequence_state *seq_state, struct hubbub *hubbub, unsigned int hubp_inst, unsigned int det_size); void hwss_add_opp_set_dyn_expansion(struct block_sequence_state *seq_state, struct output_pixel_processor *opp, enum dc_color_space color_sp, enum dc_color_depth color_dpth, enum signal_type signal); void hwss_add_opp_program_fmt(struct block_sequence_state *seq_state, struct output_pixel_processor *opp, struct bit_depth_reduction_params *fmt_bit_depth, struct clamping_and_pixel_encoding_params *clamping); void hwss_add_abm_set_pipe(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *pipe_ctx); void hwss_add_abm_set_level(struct block_sequence_state *seq_state, struct abm *abm, uint32_t abm_level); void hwss_add_tg_enable_crtc(struct block_sequence_state *seq_state, struct timing_generator *tg); void hwss_add_hubp_wait_flip_pending(struct block_sequence_state *seq_state, struct hubp *hubp, unsigned int timeout_us, unsigned int polling_interval_us); void hwss_add_tg_wait_double_buffer_pending(struct block_sequence_state *seq_state, struct timing_generator *tg, unsigned int timeout_us, unsigned int polling_interval_us); void hwss_add_dccg_set_dto_dscclk(struct block_sequence_state *seq_state, struct dccg *dccg, int inst, int num_slices_h); void hwss_add_dsc_calculate_and_set_config(struct block_sequence_state *seq_state, struct pipe_ctx *pipe_ctx, bool enable, int opp_cnt); void hwss_add_mpc_remove_mpcc(struct block_sequence_state *seq_state, struct mpc *mpc, struct mpc_tree *mpc_tree_params, struct mpcc *mpcc_to_remove); void hwss_add_opp_set_mpcc_disconnect_pending(struct block_sequence_state *seq_state, struct output_pixel_processor *opp, int mpcc_inst, bool pending); void hwss_add_hubp_disconnect(struct block_sequence_state *seq_state, struct hubp *hubp); void hwss_add_dsc_enable_with_opp(struct block_sequence_state *seq_state, struct pipe_ctx *pipe_ctx); void hwss_add_dsc_disconnect(struct block_sequence_state *seq_state, struct display_stream_compressor *dsc); void hwss_add_dc_set_optimized_required(struct block_sequence_state *seq_state, struct dc *dc, bool optimized_required); void hwss_add_abm_set_immediate_disable(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *pipe_ctx); void hwss_add_opp_set_disp_pattern_generator(struct block_sequence_state *seq_state, struct output_pixel_processor *opp, enum controller_dp_test_pattern test_pattern, enum controller_dp_color_space color_space, enum dc_color_depth color_depth, struct tg_color solid_color, bool use_solid_color, int width, int height, int offset); void hwss_add_opp_program_bit_depth_reduction(struct block_sequence_state *seq_state, struct output_pixel_processor *opp, bool use_default_params, struct pipe_ctx *pipe_ctx); void hwss_add_dc_ip_request_cntl(struct block_sequence_state *seq_state, struct dc *dc, bool enable); void hwss_add_dwbc_update(struct block_sequence_state *seq_state, struct dwbc *dwb, struct dc_dwb_params *dwb_params); void hwss_add_mcif_wb_config_buf(struct block_sequence_state *seq_state, struct mcif_wb *mcif_wb, struct mcif_buf_params *mcif_buf_params, unsigned int dest_height); void hwss_add_mcif_wb_config_arb(struct block_sequence_state *seq_state, struct mcif_wb *mcif_wb, struct mcif_arb_params *mcif_arb_params); void hwss_add_mcif_wb_enable(struct block_sequence_state *seq_state, struct mcif_wb *mcif_wb); void hwss_add_mcif_wb_disable(struct block_sequence_state *seq_state, struct mcif_wb *mcif_wb); void hwss_add_mpc_set_dwb_mux(struct block_sequence_state *seq_state, struct mpc *mpc, int dwb_id, int mpcc_id); void hwss_add_mpc_disable_dwb_mux(struct block_sequence_state *seq_state, struct mpc *mpc, unsigned int dwb_id); void hwss_add_dwbc_enable(struct block_sequence_state *seq_state, struct dwbc *dwb, struct dc_dwb_params *dwb_params); void hwss_add_dwbc_disable(struct block_sequence_state *seq_state, struct dwbc *dwb); void hwss_add_tg_set_gsl(struct block_sequence_state *seq_state, struct timing_generator *tg, struct gsl_params gsl); void hwss_add_tg_set_gsl_source_select(struct block_sequence_state *seq_state, struct timing_generator *tg, int group_idx, uint32_t gsl_ready_signal); void hwss_add_hubp_update_mall_sel(struct block_sequence_state *seq_state, struct hubp *hubp, uint32_t mall_sel, bool cache_cursor); void hwss_add_hubp_prepare_subvp_buffering(struct block_sequence_state *seq_state, struct hubp *hubp, bool enable); void hwss_add_hubp_set_blank_en(struct block_sequence_state *seq_state, struct hubp *hubp, bool enable); void hwss_add_hubp_disable_control(struct block_sequence_state *seq_state, struct hubp *hubp, bool disable); void hwss_add_hubbub_soft_reset(struct block_sequence_state *seq_state, struct hubbub *hubbub, void (*hubbub_soft_reset)(struct hubbub *hubbub, bool reset), bool reset); void hwss_add_hubp_clk_cntl(struct block_sequence_state *seq_state, struct hubp *hubp, bool enable); void hwss_add_dpp_dppclk_control(struct block_sequence_state *seq_state, struct dpp *dpp, bool dppclk_div, bool enable); void hwss_add_disable_phantom_crtc(struct block_sequence_state *seq_state, struct timing_generator *tg); void hwss_add_dsc_pg_status(struct block_sequence_state *seq_state, struct dce_hwseq *hws, int dsc_inst, bool is_ungated); void hwss_add_dsc_wait_disconnect_pending_clear(struct block_sequence_state *seq_state, struct display_stream_compressor *dsc, bool *is_ungated); void hwss_add_dsc_disable(struct block_sequence_state *seq_state, struct display_stream_compressor *dsc, bool *is_ungated); void hwss_add_dccg_set_ref_dscclk(struct block_sequence_state *seq_state, struct dccg *dccg, int dsc_inst, bool *is_ungated); void hwss_add_dpp_root_clock_control(struct block_sequence_state *seq_state, struct dce_hwseq *hws, unsigned int dpp_inst, bool clock_on); void hwss_add_dpp_pg_control(struct block_sequence_state *seq_state, struct dce_hwseq *hws, unsigned int dpp_inst, bool power_on); void hwss_add_hubp_pg_control(struct block_sequence_state *seq_state, struct dce_hwseq *hws, unsigned int hubp_inst, bool power_on); void hwss_add_hubp_set_blank(struct block_sequence_state *seq_state, struct hubp *hubp, bool blank); void hwss_add_hubp_init(struct block_sequence_state *seq_state, struct hubp *hubp); void hwss_add_hubp_reset(struct block_sequence_state *seq_state, struct hubp *hubp); void hwss_add_dpp_reset(struct block_sequence_state *seq_state, struct dpp *dpp); void hwss_add_opp_pipe_clock_control(struct block_sequence_state *seq_state, struct output_pixel_processor *opp, bool enable); void hwss_add_hubp_set_vm_system_aperture_settings(struct block_sequence_state *seq_state, struct hubp *hubp, uint64_t sys_default, uint64_t sys_low, uint64_t sys_high); void hwss_add_hubp_set_flip_int(struct block_sequence_state *seq_state, struct hubp *hubp); void hwss_add_dccg_update_dpp_dto(struct block_sequence_state *seq_state, struct dccg *dccg, int dpp_inst, int dppclk_khz); void hwss_add_hubp_vtg_sel(struct block_sequence_state *seq_state, struct hubp *hubp, uint32_t otg_inst); void hwss_add_hubp_setup2(struct block_sequence_state *seq_state, struct hubp *hubp, struct dml2_dchub_per_pipe_register_set *hubp_regs, union dml2_global_sync_programming *global_sync, struct dc_crtc_timing *timing); void hwss_add_hubp_setup(struct block_sequence_state *seq_state, struct hubp *hubp, struct _vcs_dpi_display_dlg_regs_st *dlg_regs, struct _vcs_dpi_display_ttu_regs_st *ttu_regs, struct _vcs_dpi_display_rq_regs_st *rq_regs, struct _vcs_dpi_display_pipe_dest_params_st *pipe_dest); void hwss_add_hubp_set_unbounded_requesting(struct block_sequence_state *seq_state, struct hubp *hubp, bool unbounded_req); void hwss_add_hubp_setup_interdependent2(struct block_sequence_state *seq_state, struct hubp *hubp, struct dml2_dchub_per_pipe_register_set *hubp_regs); void hwss_add_hubp_setup_interdependent(struct block_sequence_state *seq_state, struct hubp *hubp, struct _vcs_dpi_display_dlg_regs_st *dlg_regs, struct _vcs_dpi_display_ttu_regs_st *ttu_regs); void hwss_add_hubp_program_surface_config(struct block_sequence_state *seq_state, struct hubp *hubp, enum surface_pixel_format format, struct dc_tiling_info *tiling_info, struct plane_size plane_size, enum dc_rotation_angle rotation, struct dc_plane_dcc_param *dcc, bool horizontal_mirror, int compat_level); void hwss_add_dpp_setup_dpp(struct block_sequence_state *seq_state, struct pipe_ctx *pipe_ctx); void hwss_add_dpp_set_cursor_matrix(struct block_sequence_state *seq_state, struct dpp *dpp, enum dc_color_space color_space, struct dc_csc_transform *cursor_csc_color_matrix); void hwss_add_mpc_update_blending(struct block_sequence_state *seq_state, struct mpc *mpc, struct mpcc_blnd_cfg blnd_cfg, int mpcc_id); void hwss_add_mpc_assert_idle_mpcc(struct block_sequence_state *seq_state, struct mpc *mpc, int mpcc_id); void hwss_add_mpc_insert_plane(struct block_sequence_state *seq_state, struct mpc *mpc, struct mpc_tree *mpc_tree_params, struct mpcc_blnd_cfg blnd_cfg, struct mpcc_sm_cfg *sm_cfg, struct mpcc *insert_above_mpcc, int dpp_id, int mpcc_id); void hwss_add_dpp_set_scaler(struct block_sequence_state *seq_state, struct dpp *dpp, const struct scaler_data *scl_data); void hwss_add_hubp_mem_program_viewport(struct block_sequence_state *seq_state, struct hubp *hubp, const struct rect *viewport, const struct rect *viewport_c); void hwss_add_abort_cursor_offload_update(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *pipe_ctx); void hwss_add_set_cursor_attribute(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *pipe_ctx); void hwss_add_set_cursor_position(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *pipe_ctx); void hwss_add_set_cursor_sdr_white_level(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *pipe_ctx); void hwss_add_program_output_csc(struct block_sequence_state *seq_state, struct dc *dc, struct pipe_ctx *pipe_ctx, enum dc_color_space colorspace, uint16_t *matrix, int opp_id); void hwss_add_phantom_hubp_post_enable(struct block_sequence_state *seq_state, struct hubp *hubp); void hwss_add_update_force_pstate(struct block_sequence_state *seq_state, struct dc *dc, struct dc_state *context); void hwss_add_hubbub_apply_dedcn21_147_wa(struct block_sequence_state *seq_state, struct hubbub *hubbub); void hwss_add_hubbub_allow_self_refresh_control(struct block_sequence_state *seq_state, struct hubbub *hubbub, bool allow, bool *disallow_self_refresh_applied); void hwss_add_tg_get_frame_count(struct block_sequence_state *seq_state, struct timing_generator *tg, unsigned int *frame_count); void hwss_add_tg_set_dsc_config(struct block_sequence_state *seq_state, struct timing_generator *tg, struct dsc_optc_config *dsc_optc_cfg, bool enable); void hwss_add_opp_program_left_edge_extra_pixel(struct block_sequence_state *seq_state, struct output_pixel_processor *opp, enum dc_pixel_encoding pixel_encoding, bool is_otg_master); #endif /* __DC_HW_SEQUENCER_H__ */