xref: /linux/drivers/gpu/drm/amd/display/dc/hwss/hw_sequencer.h (revision 3f1c07fc21c68bd3bd2df9d2c9441f6485e934d9)
1 /*
2  * Copyright 2015 Advanced Micro Devices, Inc.
3  *
4  * Permission is hereby granted, free of charge, to any person obtaining a
5  * copy of this software and associated documentation files (the "Software"),
6  * to deal in the Software without restriction, including without limitation
7  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8  * and/or sell copies of the Software, and to permit persons to whom the
9  * Software is furnished to do so, subject to the following conditions:
10  *
11  * The above copyright notice and this permission notice shall be included in
12  * all copies or substantial portions of the Software.
13  *
14  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
17  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20  * OTHER DEALINGS IN THE SOFTWARE.
21  *
22  * Authors: AMD
23  *
24  */
25 
26 #ifndef __DC_HW_SEQUENCER_H__
27 #define __DC_HW_SEQUENCER_H__
28 #include "dc_types.h"
29 #include "inc/clock_source.h"
30 #include "inc/hw/timing_generator.h"
31 #include "inc/hw/opp.h"
32 #include "inc/hw/link_encoder.h"
33 #include "inc/core_status.h"
34 #include "inc/hw/hw_shared.h"
35 #include "dsc/dsc.h"
36 
37 struct pipe_ctx;
38 struct dc_state;
39 struct dc_stream_status;
40 struct dc_writeback_info;
41 struct dchub_init_data;
42 struct dc_static_screen_params;
43 struct resource_pool;
44 struct dc_phy_addr_space_config;
45 struct dc_virtual_addr_space_config;
46 struct dpp;
47 struct dce_hwseq;
48 struct link_resource;
49 struct dc_dmub_cmd;
50 struct pg_block_update;
51 struct drr_params;
52 struct dc_underflow_debug_data;
53 struct dsc_optc_config;
54 struct vm_system_aperture_param;
55 
56 struct subvp_pipe_control_lock_fast_params {
57 	struct dc *dc;
58 	bool lock;
59 	bool subvp_immediate_flip;
60 };
61 
62 struct pipe_control_lock_params {
63 	struct dc *dc;
64 	struct pipe_ctx *pipe_ctx;
65 	bool lock;
66 };
67 
68 struct set_flip_control_gsl_params {
69 	struct hubp *hubp;
70 	bool flip_immediate;
71 };
72 
73 struct program_triplebuffer_params {
74 	const struct dc *dc;
75 	struct pipe_ctx *pipe_ctx;
76 	bool enableTripleBuffer;
77 };
78 
79 struct update_plane_addr_params {
80 	struct dc *dc;
81 	struct pipe_ctx *pipe_ctx;
82 };
83 
84 struct set_input_transfer_func_params {
85 	struct dc *dc;
86 	struct pipe_ctx *pipe_ctx;
87 	struct dc_plane_state *plane_state;
88 };
89 
90 struct program_gamut_remap_params {
91 	struct pipe_ctx *pipe_ctx;
92 };
93 
94 struct program_manual_trigger_params {
95 	struct pipe_ctx *pipe_ctx;
96 };
97 
98 struct send_dmcub_cmd_params {
99 	struct dc_context *ctx;
100 	union dmub_rb_cmd *cmd;
101 	enum dm_dmub_wait_type wait_type;
102 };
103 
104 struct setup_dpp_params {
105 	struct pipe_ctx *pipe_ctx;
106 };
107 
108 struct program_bias_and_scale_params {
109 	struct pipe_ctx *pipe_ctx;
110 };
111 
112 struct set_output_transfer_func_params {
113 	struct dc *dc;
114 	struct pipe_ctx *pipe_ctx;
115 	const struct dc_stream_state *stream;
116 };
117 
118 struct update_visual_confirm_params {
119 	struct dc *dc;
120 	struct pipe_ctx *pipe_ctx;
121 	int mpcc_id;
122 };
123 
124 struct power_on_mpc_mem_pwr_params {
125 	struct mpc *mpc;
126 	int mpcc_id;
127 	bool power_on;
128 };
129 
130 struct set_output_csc_params {
131 	struct mpc *mpc;
132 	int opp_id;
133 	const uint16_t *regval;
134 	enum mpc_output_csc_mode ocsc_mode;
135 };
136 
137 struct set_ocsc_default_params {
138 	struct mpc *mpc;
139 	int opp_id;
140 	enum dc_color_space color_space;
141 	enum mpc_output_csc_mode ocsc_mode;
142 };
143 
144 struct subvp_save_surf_addr {
145 	struct dc_dmub_srv *dc_dmub_srv;
146 	const struct dc_plane_address *addr;
147 	uint8_t subvp_index;
148 };
149 
150 struct wait_for_dcc_meta_propagation_params {
151 	const struct dc *dc;
152 	const struct pipe_ctx *top_pipe_to_program;
153 };
154 
155 struct dmub_hw_control_lock_fast_params {
156 	struct dc *dc;
157 	bool is_required;
158 	bool lock;
159 };
160 
161 struct program_surface_config_params {
162 	struct hubp *hubp;
163 	enum surface_pixel_format format;
164 	struct dc_tiling_info *tiling_info;
165 	struct plane_size plane_size;
166 	enum dc_rotation_angle rotation;
167 	struct dc_plane_dcc_param *dcc;
168 	bool horizontal_mirror;
169 	int compat_level;
170 };
171 
172 struct program_mcache_id_and_split_coordinate {
173 	struct hubp *hubp;
174 	struct dml2_hubp_pipe_mcache_regs *mcache_regs;
175 };
176 
177 struct program_cursor_update_now_params {
178 	struct dc *dc;
179 	struct pipe_ctx *pipe_ctx;
180 };
181 
182 struct hubp_wait_pipe_read_start_params {
183 	struct hubp *hubp;
184 };
185 
186 struct apply_update_flags_for_phantom_params {
187 	struct pipe_ctx *pipe_ctx;
188 };
189 
190 struct update_phantom_vp_position_params {
191 	struct dc *dc;
192 	struct pipe_ctx *pipe_ctx;
193 	struct dc_state *context;
194 };
195 
196 struct set_odm_combine_params {
197 	struct timing_generator *tg;
198 	int opp_inst[MAX_PIPES];
199 	int opp_head_count;
200 	int odm_slice_width;
201 	int last_odm_slice_width;
202 };
203 
204 struct set_odm_bypass_params {
205 	struct timing_generator *tg;
206 	const struct dc_crtc_timing *timing;
207 };
208 
209 struct opp_pipe_clock_control_params {
210 	struct output_pixel_processor *opp;
211 	bool enable;
212 };
213 
214 struct opp_program_left_edge_extra_pixel_params {
215 	struct output_pixel_processor *opp;
216 	enum dc_pixel_encoding pixel_encoding;
217 	bool is_otg_master;
218 };
219 
220 struct dccg_set_dto_dscclk_params {
221 	struct dccg *dccg;
222 	int inst;
223 	int num_slices_h;
224 };
225 
226 struct dsc_set_config_params {
227 	struct display_stream_compressor *dsc;
228 	struct dsc_config *dsc_cfg;
229 	struct dsc_optc_config *dsc_optc_cfg;
230 };
231 
232 struct dsc_enable_params {
233 	struct display_stream_compressor *dsc;
234 	int opp_inst;
235 };
236 
237 struct tg_set_dsc_config_params {
238 	struct timing_generator *tg;
239 	struct dsc_optc_config *dsc_optc_cfg;
240 	bool enable;
241 };
242 
243 struct dsc_disconnect_params {
244 	struct display_stream_compressor *dsc;
245 };
246 
247 struct dsc_read_state_params {
248 	struct display_stream_compressor *dsc;
249 	struct dcn_dsc_state *dsc_state;
250 };
251 
252 struct dsc_calculate_and_set_config_params {
253 	struct pipe_ctx *pipe_ctx;
254 	struct dsc_optc_config dsc_optc_cfg;
255 	bool enable;
256 	int opp_cnt;
257 };
258 
259 struct dsc_enable_with_opp_params {
260 	struct pipe_ctx *pipe_ctx;
261 };
262 
263 struct program_tg_params {
264 	struct dc *dc;
265 	struct pipe_ctx *pipe_ctx;
266 	struct dc_state *context;
267 };
268 
269 struct tg_program_global_sync_params {
270 	struct timing_generator *tg;
271 	int vready_offset;
272 	unsigned int vstartup_lines;
273 	unsigned int vupdate_offset_pixels;
274 	unsigned int vupdate_vupdate_width_pixels;
275 	unsigned int pstate_keepout_start_lines;
276 };
277 
278 struct tg_wait_for_state_params {
279 	struct timing_generator *tg;
280 	enum crtc_state state;
281 };
282 
283 struct tg_set_vtg_params_params {
284 	struct timing_generator *tg;
285 	struct dc_crtc_timing *timing;
286 	bool program_fp2;
287 };
288 
289 struct tg_set_gsl_params {
290 	struct timing_generator *tg;
291 	struct gsl_params gsl;
292 };
293 
294 struct tg_set_gsl_source_select_params {
295 	struct timing_generator *tg;
296 	int group_idx;
297 	uint32_t gsl_ready_signal;
298 };
299 
300 struct setup_vupdate_interrupt_params {
301 	struct dc *dc;
302 	struct pipe_ctx *pipe_ctx;
303 };
304 
305 struct tg_setup_vertical_interrupt2_params {
306 	struct timing_generator *tg;
307 	int start_line;
308 };
309 
310 struct dpp_set_hdr_multiplier_params {
311 	struct dpp *dpp;
312 	uint32_t hw_mult;
313 };
314 
315 struct program_det_size_params {
316 	struct hubbub *hubbub;
317 	unsigned int hubp_inst;
318 	unsigned int det_buffer_size_kb;
319 };
320 
321 struct program_det_segments_params {
322 	struct hubbub *hubbub;
323 	unsigned int hubp_inst;
324 	unsigned int det_size;
325 };
326 
327 struct update_dchubp_dpp_params {
328 	struct dc *dc;
329 	struct pipe_ctx *pipe_ctx;
330 	struct dc_state *context;
331 };
332 
333 struct opp_set_dyn_expansion_params {
334 	struct output_pixel_processor *opp;
335 	enum dc_color_space color_space;
336 	enum dc_color_depth color_depth;
337 	enum signal_type signal;
338 };
339 
340 struct opp_program_fmt_params {
341 	struct output_pixel_processor *opp;
342 	struct bit_depth_reduction_params *fmt_bit_depth;
343 	struct clamping_and_pixel_encoding_params *clamping;
344 };
345 
346 struct opp_program_bit_depth_reduction_params {
347 	struct output_pixel_processor *opp;
348 	bool use_default_params;
349 	struct pipe_ctx *pipe_ctx;
350 };
351 
352 struct opp_set_disp_pattern_generator_params {
353 	struct output_pixel_processor *opp;
354 	enum controller_dp_test_pattern test_pattern;
355 	enum controller_dp_color_space color_space;
356 	enum dc_color_depth color_depth;
357 	struct tg_color solid_color;
358 	bool use_solid_color;
359 	int width;
360 	int height;
361 	int offset;
362 };
363 
364 struct set_abm_pipe_params {
365 	struct dc *dc;
366 	struct pipe_ctx *pipe_ctx;
367 };
368 
369 struct set_abm_level_params {
370 	struct abm *abm;
371 	unsigned int abm_level;
372 };
373 
374 struct set_abm_immediate_disable_params {
375 	struct dc *dc;
376 	struct pipe_ctx *pipe_ctx;
377 };
378 
379 struct set_disp_pattern_generator_params {
380 	struct dc *dc;
381 	struct pipe_ctx *pipe_ctx;
382 	enum controller_dp_test_pattern test_pattern;
383 	enum controller_dp_color_space color_space;
384 	enum dc_color_depth color_depth;
385 	const struct tg_color *solid_color;
386 	int width;
387 	int height;
388 	int offset;
389 };
390 
391 struct mpc_update_blending_params {
392 	struct mpc *mpc;
393 	struct mpcc_blnd_cfg blnd_cfg;
394 	int mpcc_id;
395 };
396 
397 struct mpc_assert_idle_mpcc_params {
398 	struct mpc *mpc;
399 	int mpcc_id;
400 };
401 
402 struct mpc_insert_plane_params {
403 	struct mpc *mpc;
404 	struct mpc_tree *mpc_tree_params;
405 	struct mpcc_blnd_cfg blnd_cfg;
406 	struct mpcc_sm_cfg *sm_cfg;
407 	struct mpcc *insert_above_mpcc;
408 	int dpp_id;
409 	int mpcc_id;
410 };
411 
412 struct mpc_remove_mpcc_params {
413 	struct mpc *mpc;
414 	struct mpc_tree *mpc_tree_params;
415 	struct mpcc *mpcc_to_remove;
416 };
417 
418 struct opp_set_mpcc_disconnect_pending_params {
419 	struct output_pixel_processor *opp;
420 	int mpcc_inst;
421 	bool pending;
422 };
423 
424 struct dc_set_optimized_required_params {
425 	struct dc *dc;
426 	bool optimized_required;
427 };
428 
429 struct hubp_disconnect_params {
430 	struct hubp *hubp;
431 };
432 
433 struct hubbub_force_pstate_change_control_params {
434 	struct hubbub *hubbub;
435 	bool enable;
436 	bool wait;
437 };
438 
439 struct tg_enable_crtc_params {
440 	struct timing_generator *tg;
441 };
442 
443 struct hubp_wait_flip_pending_params {
444 	struct hubp *hubp;
445 	unsigned int timeout_us;
446 	unsigned int polling_interval_us;
447 };
448 
449 struct tg_wait_double_buffer_pending_params {
450 	struct timing_generator *tg;
451 	unsigned int timeout_us;
452 	unsigned int polling_interval_us;
453 };
454 
455 struct update_force_pstate_params {
456 	struct dc *dc;
457 	struct dc_state *context;
458 };
459 
460 struct hubbub_apply_dedcn21_147_wa_params {
461 	struct hubbub *hubbub;
462 };
463 
464 struct hubbub_allow_self_refresh_control_params {
465 	struct hubbub *hubbub;
466 	bool allow;
467 	bool *disallow_self_refresh_applied;
468 };
469 
470 struct tg_get_frame_count_params {
471 	struct timing_generator *tg;
472 	unsigned int *frame_count;
473 };
474 
475 struct mpc_set_dwb_mux_params {
476 	struct mpc *mpc;
477 	int dwb_id;
478 	int mpcc_id;
479 };
480 
481 struct mpc_disable_dwb_mux_params {
482 	struct mpc *mpc;
483 	unsigned int dwb_id;
484 };
485 
486 struct mcif_wb_config_buf_params {
487 	struct mcif_wb *mcif_wb;
488 	struct mcif_buf_params *mcif_buf_params;
489 	unsigned int dest_height;
490 };
491 
492 struct mcif_wb_config_arb_params {
493 	struct mcif_wb *mcif_wb;
494 	struct mcif_arb_params *mcif_arb_params;
495 };
496 
497 struct mcif_wb_enable_params {
498 	struct mcif_wb *mcif_wb;
499 };
500 
501 struct mcif_wb_disable_params {
502 	struct mcif_wb *mcif_wb;
503 };
504 
505 struct dwbc_enable_params {
506 	struct dwbc *dwb;
507 	struct dc_dwb_params *dwb_params;
508 };
509 
510 struct dwbc_disable_params {
511 	struct dwbc *dwb;
512 };
513 
514 struct dwbc_update_params {
515 	struct dwbc *dwb;
516 	struct dc_dwb_params *dwb_params;
517 };
518 
519 struct hubp_update_mall_sel_params {
520 	struct hubp *hubp;
521 	uint32_t mall_sel;
522 	bool cache_cursor;
523 };
524 
525 struct hubp_prepare_subvp_buffering_params {
526 	struct hubp *hubp;
527 	bool enable;
528 };
529 
530 struct hubp_set_blank_en_params {
531 	struct hubp *hubp;
532 	bool enable;
533 };
534 
535 struct hubp_disable_control_params {
536 	struct hubp *hubp;
537 	bool disable;
538 };
539 
540 struct hubbub_soft_reset_params {
541 	struct hubbub *hubbub;
542 	void (*hubbub_soft_reset)(struct hubbub *hubbub, bool reset);
543 	bool reset;
544 };
545 
546 struct hubp_clk_cntl_params {
547 	struct hubp *hubp;
548 	bool enable;
549 };
550 
551 struct hubp_init_params {
552 	struct hubp *hubp;
553 };
554 
555 struct hubp_set_vm_system_aperture_settings_params {
556 	struct hubp *hubp;
557 	//struct vm_system_aperture_param apt;
558 	PHYSICAL_ADDRESS_LOC sys_default;
559 	PHYSICAL_ADDRESS_LOC sys_low;
560 	PHYSICAL_ADDRESS_LOC sys_high;
561 };
562 
563 struct hubp_set_flip_int_params {
564 	struct hubp *hubp;
565 };
566 
567 struct dpp_dppclk_control_params {
568 	struct dpp *dpp;
569 	bool dppclk_div;
570 	bool enable;
571 };
572 
573 struct disable_phantom_crtc_params {
574 	struct timing_generator *tg;
575 };
576 
577 struct dpp_pg_control_params {
578 	struct dce_hwseq *hws;
579 	unsigned int dpp_inst;
580 	bool power_on;
581 };
582 
583 struct hubp_pg_control_params {
584 	struct dce_hwseq *hws;
585 	unsigned int hubp_inst;
586 	bool power_on;
587 };
588 
589 struct hubp_reset_params {
590 	struct hubp *hubp;
591 };
592 
593 struct dpp_reset_params {
594 	struct dpp *dpp;
595 };
596 
597 struct dpp_root_clock_control_params {
598 	struct dce_hwseq *hws;
599 	unsigned int dpp_inst;
600 	bool clock_on;
601 };
602 
603 struct dc_ip_request_cntl_params {
604 	struct dc *dc;
605 	bool enable;
606 };
607 
608 struct dsc_pg_status_params {
609 	struct dce_hwseq *hws;
610 	int dsc_inst;
611 	bool is_ungated;
612 };
613 
614 struct dsc_wait_disconnect_pending_clear_params {
615 	struct display_stream_compressor *dsc;
616 	bool *is_ungated;
617 };
618 
619 struct dsc_disable_params {
620 	struct display_stream_compressor *dsc;
621 	bool *is_ungated;
622 };
623 
624 struct dccg_set_ref_dscclk_params {
625 	struct dccg *dccg;
626 	int dsc_inst;
627 	bool *is_ungated;
628 };
629 
630 struct dccg_update_dpp_dto_params {
631 	struct dccg *dccg;
632 	int dpp_inst;
633 	int dppclk_khz;
634 };
635 
636 struct hubp_vtg_sel_params {
637 	struct hubp *hubp;
638 	uint32_t otg_inst;
639 };
640 
641 struct hubp_setup2_params {
642 	struct hubp *hubp;
643 	struct dml2_dchub_per_pipe_register_set *hubp_regs;
644 	union dml2_global_sync_programming *global_sync;
645 	struct dc_crtc_timing *timing;
646 };
647 
648 struct hubp_setup_params {
649 	struct hubp *hubp;
650 	struct _vcs_dpi_display_dlg_regs_st *dlg_regs;
651 	struct _vcs_dpi_display_ttu_regs_st *ttu_regs;
652 	struct _vcs_dpi_display_rq_regs_st *rq_regs;
653 	struct _vcs_dpi_display_pipe_dest_params_st *pipe_dest;
654 };
655 
656 struct hubp_set_unbounded_requesting_params {
657 	struct hubp *hubp;
658 	bool unbounded_req;
659 };
660 
661 struct hubp_setup_interdependent2_params {
662 	struct hubp *hubp;
663 	struct dml2_dchub_per_pipe_register_set *hubp_regs;
664 };
665 
666 struct hubp_setup_interdependent_params {
667 	struct hubp *hubp;
668 	struct _vcs_dpi_display_dlg_regs_st *dlg_regs;
669 	struct _vcs_dpi_display_ttu_regs_st *ttu_regs;
670 };
671 
672 struct dpp_set_cursor_matrix_params {
673 	struct dpp *dpp;
674 	enum dc_color_space color_space;
675 	struct dc_csc_transform *cursor_csc_color_matrix;
676 };
677 
678 struct mpc_update_mpcc_params {
679 	struct dc *dc;
680 	struct pipe_ctx *pipe_ctx;
681 };
682 
683 struct dpp_set_scaler_params {
684 	struct dpp *dpp;
685 	const struct scaler_data *scl_data;
686 };
687 
688 struct hubp_mem_program_viewport_params {
689 	struct hubp *hubp;
690 	const struct rect *viewport;
691 	const struct rect *viewport_c;
692 };
693 
694 struct hubp_program_mcache_id_and_split_coordinate_params {
695 	struct hubp *hubp;
696 	struct mcache_regs_struct *mcache_regs;
697 };
698 
699 struct abort_cursor_offload_update_params {
700 	struct dc *dc;
701 	struct pipe_ctx *pipe_ctx;
702 };
703 
704 struct set_cursor_attribute_params {
705 	struct dc *dc;
706 	struct pipe_ctx *pipe_ctx;
707 };
708 
709 struct set_cursor_position_params {
710 	struct dc *dc;
711 	struct pipe_ctx *pipe_ctx;
712 };
713 
714 struct set_cursor_sdr_white_level_params {
715 	struct dc *dc;
716 	struct pipe_ctx *pipe_ctx;
717 };
718 
719 struct program_output_csc_params {
720 	struct dc *dc;
721 	struct pipe_ctx *pipe_ctx;
722 	enum dc_color_space colorspace;
723 	uint16_t *matrix;
724 	int opp_id;
725 };
726 
727 struct hubp_set_blank_params {
728 	struct hubp *hubp;
729 	bool blank;
730 };
731 
732 struct phantom_hubp_post_enable_params {
733 	struct hubp *hubp;
734 };
735 
736 union block_sequence_params {
737 	struct update_plane_addr_params update_plane_addr_params;
738 	struct subvp_pipe_control_lock_fast_params subvp_pipe_control_lock_fast_params;
739 	struct pipe_control_lock_params pipe_control_lock_params;
740 	struct set_flip_control_gsl_params set_flip_control_gsl_params;
741 	struct program_triplebuffer_params program_triplebuffer_params;
742 	struct set_input_transfer_func_params set_input_transfer_func_params;
743 	struct program_gamut_remap_params program_gamut_remap_params;
744 	struct program_manual_trigger_params program_manual_trigger_params;
745 	struct send_dmcub_cmd_params send_dmcub_cmd_params;
746 	struct setup_dpp_params setup_dpp_params;
747 	struct program_bias_and_scale_params program_bias_and_scale_params;
748 	struct set_output_transfer_func_params set_output_transfer_func_params;
749 	struct update_visual_confirm_params update_visual_confirm_params;
750 	struct power_on_mpc_mem_pwr_params power_on_mpc_mem_pwr_params;
751 	struct set_output_csc_params set_output_csc_params;
752 	struct set_ocsc_default_params set_ocsc_default_params;
753 	struct subvp_save_surf_addr subvp_save_surf_addr;
754 	struct wait_for_dcc_meta_propagation_params wait_for_dcc_meta_propagation_params;
755 	struct dmub_hw_control_lock_fast_params dmub_hw_control_lock_fast_params;
756 	struct program_surface_config_params program_surface_config_params;
757 	struct program_mcache_id_and_split_coordinate program_mcache_id_and_split_coordinate;
758 	struct program_cursor_update_now_params program_cursor_update_now_params;
759 	struct hubp_wait_pipe_read_start_params hubp_wait_pipe_read_start_params;
760 	struct apply_update_flags_for_phantom_params apply_update_flags_for_phantom_params;
761 	struct update_phantom_vp_position_params update_phantom_vp_position_params;
762 	struct set_odm_combine_params set_odm_combine_params;
763 	struct set_odm_bypass_params set_odm_bypass_params;
764 	struct opp_pipe_clock_control_params opp_pipe_clock_control_params;
765 	struct opp_program_left_edge_extra_pixel_params opp_program_left_edge_extra_pixel_params;
766 	struct dccg_set_dto_dscclk_params dccg_set_dto_dscclk_params;
767 	struct dsc_set_config_params dsc_set_config_params;
768 	struct dsc_enable_params dsc_enable_params;
769 	struct tg_set_dsc_config_params tg_set_dsc_config_params;
770 	struct dsc_disconnect_params dsc_disconnect_params;
771 	struct dsc_read_state_params dsc_read_state_params;
772 	struct dsc_calculate_and_set_config_params dsc_calculate_and_set_config_params;
773 	struct dsc_enable_with_opp_params dsc_enable_with_opp_params;
774 	struct program_tg_params program_tg_params;
775 	struct tg_program_global_sync_params tg_program_global_sync_params;
776 	struct tg_wait_for_state_params tg_wait_for_state_params;
777 	struct tg_set_vtg_params_params tg_set_vtg_params_params;
778 	struct tg_setup_vertical_interrupt2_params tg_setup_vertical_interrupt2_params;
779 	struct dpp_set_hdr_multiplier_params dpp_set_hdr_multiplier_params;
780 	struct tg_set_gsl_params tg_set_gsl_params;
781 	struct tg_set_gsl_source_select_params tg_set_gsl_source_select_params;
782 	struct setup_vupdate_interrupt_params setup_vupdate_interrupt_params;
783 	struct program_det_size_params program_det_size_params;
784 	struct program_det_segments_params program_det_segments_params;
785 	struct update_dchubp_dpp_params update_dchubp_dpp_params;
786 	struct opp_set_dyn_expansion_params opp_set_dyn_expansion_params;
787 	struct opp_program_fmt_params opp_program_fmt_params;
788 	struct opp_program_bit_depth_reduction_params opp_program_bit_depth_reduction_params;
789 	struct opp_set_disp_pattern_generator_params opp_set_disp_pattern_generator_params;
790 	struct set_abm_pipe_params set_abm_pipe_params;
791 	struct set_abm_level_params set_abm_level_params;
792 	struct set_abm_immediate_disable_params set_abm_immediate_disable_params;
793 	struct set_disp_pattern_generator_params set_disp_pattern_generator_params;
794 	struct mpc_remove_mpcc_params mpc_remove_mpcc_params;
795 	struct opp_set_mpcc_disconnect_pending_params opp_set_mpcc_disconnect_pending_params;
796 	struct dc_set_optimized_required_params dc_set_optimized_required_params;
797 	struct hubp_disconnect_params hubp_disconnect_params;
798 	struct hubbub_force_pstate_change_control_params hubbub_force_pstate_change_control_params;
799 	struct tg_enable_crtc_params tg_enable_crtc_params;
800 	struct hubp_wait_flip_pending_params hubp_wait_flip_pending_params;
801 	struct tg_wait_double_buffer_pending_params tg_wait_double_buffer_pending_params;
802 	struct update_force_pstate_params update_force_pstate_params;
803 	struct hubbub_apply_dedcn21_147_wa_params hubbub_apply_dedcn21_147_wa_params;
804 	struct hubbub_allow_self_refresh_control_params hubbub_allow_self_refresh_control_params;
805 	struct tg_get_frame_count_params tg_get_frame_count_params;
806 	struct mpc_set_dwb_mux_params mpc_set_dwb_mux_params;
807 	struct mpc_disable_dwb_mux_params mpc_disable_dwb_mux_params;
808 	struct mcif_wb_config_buf_params mcif_wb_config_buf_params;
809 	struct mcif_wb_config_arb_params mcif_wb_config_arb_params;
810 	struct mcif_wb_enable_params mcif_wb_enable_params;
811 	struct mcif_wb_disable_params mcif_wb_disable_params;
812 	struct dwbc_enable_params dwbc_enable_params;
813 	struct dwbc_disable_params dwbc_disable_params;
814 	struct dwbc_update_params dwbc_update_params;
815 	struct hubp_update_mall_sel_params hubp_update_mall_sel_params;
816 	struct hubp_prepare_subvp_buffering_params hubp_prepare_subvp_buffering_params;
817 	struct hubp_set_blank_en_params hubp_set_blank_en_params;
818 	struct hubp_disable_control_params hubp_disable_control_params;
819 	struct hubbub_soft_reset_params hubbub_soft_reset_params;
820 	struct hubp_clk_cntl_params hubp_clk_cntl_params;
821 	struct hubp_init_params hubp_init_params;
822 	struct hubp_set_vm_system_aperture_settings_params hubp_set_vm_system_aperture_settings_params;
823 	struct hubp_set_flip_int_params hubp_set_flip_int_params;
824 	struct dpp_dppclk_control_params dpp_dppclk_control_params;
825 	struct disable_phantom_crtc_params disable_phantom_crtc_params;
826 	struct dpp_pg_control_params dpp_pg_control_params;
827 	struct hubp_pg_control_params hubp_pg_control_params;
828 	struct hubp_reset_params hubp_reset_params;
829 	struct dpp_reset_params dpp_reset_params;
830 	struct dpp_root_clock_control_params dpp_root_clock_control_params;
831 	struct dc_ip_request_cntl_params dc_ip_request_cntl_params;
832 	struct dsc_pg_status_params dsc_pg_status_params;
833 	struct dsc_wait_disconnect_pending_clear_params dsc_wait_disconnect_pending_clear_params;
834 	struct dsc_disable_params dsc_disable_params;
835 	struct dccg_set_ref_dscclk_params dccg_set_ref_dscclk_params;
836 	struct dccg_update_dpp_dto_params dccg_update_dpp_dto_params;
837 	struct hubp_vtg_sel_params hubp_vtg_sel_params;
838 	struct hubp_setup2_params hubp_setup2_params;
839 	struct hubp_setup_params hubp_setup_params;
840 	struct hubp_set_unbounded_requesting_params hubp_set_unbounded_requesting_params;
841 	struct hubp_setup_interdependent2_params hubp_setup_interdependent2_params;
842 	struct hubp_setup_interdependent_params hubp_setup_interdependent_params;
843 	struct dpp_set_cursor_matrix_params dpp_set_cursor_matrix_params;
844 	struct mpc_update_mpcc_params mpc_update_mpcc_params;
845 	struct mpc_update_blending_params mpc_update_blending_params;
846 	struct mpc_assert_idle_mpcc_params mpc_assert_idle_mpcc_params;
847 	struct mpc_insert_plane_params mpc_insert_plane_params;
848 	struct dpp_set_scaler_params dpp_set_scaler_params;
849 	struct hubp_mem_program_viewport_params hubp_mem_program_viewport_params;
850 	struct abort_cursor_offload_update_params abort_cursor_offload_update_params;
851 	struct set_cursor_attribute_params set_cursor_attribute_params;
852 	struct set_cursor_position_params set_cursor_position_params;
853 	struct set_cursor_sdr_white_level_params set_cursor_sdr_white_level_params;
854 	struct program_output_csc_params program_output_csc_params;
855 	struct hubp_set_blank_params hubp_set_blank_params;
856 	struct phantom_hubp_post_enable_params phantom_hubp_post_enable_params;
857 };
858 
859 enum block_sequence_func {
860 	DMUB_SUBVP_PIPE_CONTROL_LOCK_FAST = 0,
861 	OPTC_PIPE_CONTROL_LOCK,
862 	HUBP_SET_FLIP_CONTROL_GSL,
863 	HUBP_PROGRAM_TRIPLEBUFFER,
864 	HUBP_UPDATE_PLANE_ADDR,
865 	DPP_SET_INPUT_TRANSFER_FUNC,
866 	DPP_PROGRAM_GAMUT_REMAP,
867 	OPTC_PROGRAM_MANUAL_TRIGGER,
868 	DMUB_SEND_DMCUB_CMD,
869 	DPP_SETUP_DPP,
870 	DPP_PROGRAM_BIAS_AND_SCALE,
871 	DPP_SET_OUTPUT_TRANSFER_FUNC,
872 	DPP_SET_HDR_MULTIPLIER,
873 	MPC_UPDATE_VISUAL_CONFIRM,
874 	MPC_POWER_ON_MPC_MEM_PWR,
875 	MPC_SET_OUTPUT_CSC,
876 	MPC_SET_OCSC_DEFAULT,
877 	DMUB_SUBVP_SAVE_SURF_ADDR,
878 	HUBP_WAIT_FOR_DCC_META_PROP,
879 	DMUB_HW_CONTROL_LOCK_FAST,
880 	HUBP_PROGRAM_SURFACE_CONFIG,
881 	HUBP_PROGRAM_MCACHE_ID,
882 	PROGRAM_CURSOR_UPDATE_NOW,
883 	HUBP_WAIT_PIPE_READ_START,
884 	HWS_APPLY_UPDATE_FLAGS_FOR_PHANTOM,
885 	HWS_UPDATE_PHANTOM_VP_POSITION,
886 	OPTC_SET_ODM_COMBINE,
887 	OPTC_SET_ODM_BYPASS,
888 	OPP_PIPE_CLOCK_CONTROL,
889 	OPP_PROGRAM_LEFT_EDGE_EXTRA_PIXEL,
890 	DCCG_SET_DTO_DSCCLK,
891 	DSC_SET_CONFIG,
892 	DSC_ENABLE,
893 	TG_SET_DSC_CONFIG,
894 	DSC_DISCONNECT,
895 	DSC_READ_STATE,
896 	DSC_CALCULATE_AND_SET_CONFIG,
897 	DSC_ENABLE_WITH_OPP,
898 	TG_PROGRAM_GLOBAL_SYNC,
899 	TG_WAIT_FOR_STATE,
900 	TG_SET_VTG_PARAMS,
901 	TG_SETUP_VERTICAL_INTERRUPT2,
902 	HUBP_PROGRAM_DET_SIZE,
903 	HUBP_PROGRAM_DET_SEGMENTS,
904 	OPP_SET_DYN_EXPANSION,
905 	OPP_PROGRAM_FMT,
906 	OPP_PROGRAM_BIT_DEPTH_REDUCTION,
907 	OPP_SET_DISP_PATTERN_GENERATOR,
908 	ABM_SET_PIPE,
909 	ABM_SET_LEVEL,
910 	ABM_SET_IMMEDIATE_DISABLE,
911 	MPC_REMOVE_MPCC,
912 	OPP_SET_MPCC_DISCONNECT_PENDING,
913 	DC_SET_OPTIMIZED_REQUIRED,
914 	HUBP_DISCONNECT,
915 	HUBBUB_FORCE_PSTATE_CHANGE_CONTROL,
916 	TG_ENABLE_CRTC,
917 	TG_SET_GSL,
918 	TG_SET_GSL_SOURCE_SELECT,
919 	HUBP_WAIT_FLIP_PENDING,
920 	TG_WAIT_DOUBLE_BUFFER_PENDING,
921 	UPDATE_FORCE_PSTATE,
922 	PROGRAM_MALL_PIPE_CONFIG,
923 	HUBBUB_APPLY_DEDCN21_147_WA,
924 	HUBBUB_ALLOW_SELF_REFRESH_CONTROL,
925 	TG_GET_FRAME_COUNT,
926 	MPC_SET_DWB_MUX,
927 	MPC_DISABLE_DWB_MUX,
928 	MCIF_WB_CONFIG_BUF,
929 	MCIF_WB_CONFIG_ARB,
930 	MCIF_WB_ENABLE,
931 	MCIF_WB_DISABLE,
932 	DWBC_ENABLE,
933 	DWBC_DISABLE,
934 	DWBC_UPDATE,
935 	HUBP_UPDATE_MALL_SEL,
936 	HUBP_PREPARE_SUBVP_BUFFERING,
937 	HUBP_SET_BLANK_EN,
938 	HUBP_DISABLE_CONTROL,
939 	HUBBUB_SOFT_RESET,
940 	HUBP_CLK_CNTL,
941 	HUBP_INIT,
942 	HUBP_SET_VM_SYSTEM_APERTURE_SETTINGS,
943 	HUBP_SET_FLIP_INT,
944 	DPP_DPPCLK_CONTROL,
945 	DISABLE_PHANTOM_CRTC,
946 	DSC_PG_STATUS,
947 	DSC_WAIT_DISCONNECT_PENDING_CLEAR,
948 	DSC_DISABLE,
949 	DCCG_SET_REF_DSCCLK,
950 	DPP_PG_CONTROL,
951 	HUBP_PG_CONTROL,
952 	HUBP_RESET,
953 	DPP_RESET,
954 	DPP_ROOT_CLOCK_CONTROL,
955 	DC_IP_REQUEST_CNTL,
956 	DCCG_UPDATE_DPP_DTO,
957 	HUBP_VTG_SEL,
958 	HUBP_SETUP2,
959 	HUBP_SETUP,
960 	HUBP_SET_UNBOUNDED_REQUESTING,
961 	HUBP_SETUP_INTERDEPENDENT2,
962 	HUBP_SETUP_INTERDEPENDENT,
963 	DPP_SET_CURSOR_MATRIX,
964 	MPC_UPDATE_BLENDING,
965 	MPC_ASSERT_IDLE_MPCC,
966 	MPC_INSERT_PLANE,
967 	DPP_SET_SCALER,
968 	HUBP_MEM_PROGRAM_VIEWPORT,
969 	ABORT_CURSOR_OFFLOAD_UPDATE,
970 	SET_CURSOR_ATTRIBUTE,
971 	SET_CURSOR_POSITION,
972 	SET_CURSOR_SDR_WHITE_LEVEL,
973 	PROGRAM_OUTPUT_CSC,
974 	HUBP_SET_LEGACY_TILING_COMPAT_LEVEL,
975 	HUBP_SET_BLANK,
976 	PHANTOM_HUBP_POST_ENABLE,
977 	/* This must be the last value in this enum, add new ones above */
978 	HWSS_BLOCK_SEQUENCE_FUNC_COUNT
979 };
980 
981 struct block_sequence {
982 	union block_sequence_params params;
983 	enum block_sequence_func func;
984 };
985 
986 struct block_sequence_state {
987 	struct block_sequence *steps;
988 	unsigned int *num_steps;
989 };
990 
991 #define MAX_HWSS_BLOCK_SEQUENCE_SIZE (HWSS_BLOCK_SEQUENCE_FUNC_COUNT * MAX_PIPES)
992 
993 struct hw_sequencer_funcs {
994 	void (*hardware_release)(struct dc *dc);
995 	/* Embedded Display Related */
996 	void (*edp_power_control)(struct dc_link *link, bool enable);
997 	void (*edp_wait_for_hpd_ready)(struct dc_link *link, bool power_up);
998 	void (*edp_wait_for_T12)(struct dc_link *link);
999 
1000 	/* Pipe Programming Related */
1001 	void (*init_hw)(struct dc *dc);
1002 	void (*power_down_on_boot)(struct dc *dc);
1003 	void (*enable_accelerated_mode)(struct dc *dc,
1004 			struct dc_state *context);
1005 	enum dc_status (*apply_ctx_to_hw)(struct dc *dc,
1006 			struct dc_state *context);
1007 	void (*disable_plane)(struct dc *dc, struct dc_state *state, struct pipe_ctx *pipe_ctx);
1008 	void (*disable_plane_sequence)(struct dc *dc, struct dc_state *state, struct pipe_ctx *pipe_ctx,
1009 		struct block_sequence_state *seq_state);
1010 	void (*disable_pixel_data)(struct dc *dc, struct pipe_ctx *pipe_ctx, bool blank);
1011 	void (*apply_ctx_for_surface)(struct dc *dc,
1012 			const struct dc_stream_state *stream,
1013 			int num_planes, struct dc_state *context);
1014 	void (*program_front_end_for_ctx)(struct dc *dc,
1015 			struct dc_state *context);
1016 	void (*wait_for_pending_cleared)(struct dc *dc,
1017 			struct dc_state *context);
1018 	void (*post_unlock_program_front_end)(struct dc *dc,
1019 			struct dc_state *context);
1020 	void (*update_plane_addr)(const struct dc *dc,
1021 			struct pipe_ctx *pipe_ctx);
1022 	void (*update_dchub)(struct dce_hwseq *hws,
1023 			struct dchub_init_data *dh_data);
1024 	void (*wait_for_mpcc_disconnect)(struct dc *dc,
1025 			struct resource_pool *res_pool,
1026 			struct pipe_ctx *pipe_ctx);
1027 	void (*wait_for_mpcc_disconnect_sequence)(struct dc *dc,
1028 			struct resource_pool *res_pool,
1029 			struct pipe_ctx *pipe_ctx,
1030 			struct block_sequence_state *seq_state);
1031 	void (*edp_backlight_control)(
1032 			struct dc_link *link,
1033 			bool enable);
1034 	void (*program_triplebuffer)(const struct dc *dc,
1035 		struct pipe_ctx *pipe_ctx, bool enableTripleBuffer);
1036 	void (*update_pending_status)(struct pipe_ctx *pipe_ctx);
1037 	void (*update_dsc_pg)(struct dc *dc, struct dc_state *context, bool safe_to_disable);
1038 	void (*clear_surface_dcc_and_tiling)(struct pipe_ctx *pipe_ctx, struct dc_plane_state *plane_state, bool clear_tiling);
1039 
1040 	/* Pipe Lock Related */
1041 	void (*pipe_control_lock)(struct dc *dc,
1042 			struct pipe_ctx *pipe, bool lock);
1043 	void (*interdependent_update_lock)(struct dc *dc,
1044 			struct dc_state *context, bool lock);
1045 	void (*set_flip_control_gsl)(struct pipe_ctx *pipe_ctx,
1046 			bool flip_immediate);
1047 	void (*cursor_lock)(struct dc *dc, struct pipe_ctx *pipe, bool lock);
1048 
1049 	/* Timing Related */
1050 	void (*get_position)(struct pipe_ctx **pipe_ctx, int num_pipes,
1051 			struct crtc_position *position);
1052 	int (*get_vupdate_offset_from_vsync)(struct pipe_ctx *pipe_ctx);
1053 	void (*calc_vupdate_position)(
1054 			struct dc *dc,
1055 			struct pipe_ctx *pipe_ctx,
1056 			uint32_t *start_line,
1057 			uint32_t *end_line);
1058 	void (*enable_per_frame_crtc_position_reset)(struct dc *dc,
1059 			int group_size, struct pipe_ctx *grouped_pipes[]);
1060 	void (*enable_timing_synchronization)(struct dc *dc,
1061 			struct dc_state *state,
1062 			int group_index, int group_size,
1063 			struct pipe_ctx *grouped_pipes[]);
1064 	void (*enable_vblanks_synchronization)(struct dc *dc,
1065 			int group_index, int group_size,
1066 			struct pipe_ctx *grouped_pipes[]);
1067 	void (*setup_periodic_interrupt)(struct dc *dc,
1068 			struct pipe_ctx *pipe_ctx);
1069 	void (*set_drr)(struct pipe_ctx **pipe_ctx, int num_pipes,
1070 			struct dc_crtc_timing_adjust adjust);
1071 	void (*set_static_screen_control)(struct pipe_ctx **pipe_ctx,
1072 			int num_pipes,
1073 			const struct dc_static_screen_params *events);
1074 
1075 	/* Stream Related */
1076 	void (*enable_stream)(struct pipe_ctx *pipe_ctx);
1077 	void (*disable_stream)(struct pipe_ctx *pipe_ctx);
1078 	void (*blank_stream)(struct pipe_ctx *pipe_ctx);
1079 	void (*unblank_stream)(struct pipe_ctx *pipe_ctx,
1080 			struct dc_link_settings *link_settings);
1081 
1082 	/* Bandwidth Related */
1083 	void (*prepare_bandwidth)(struct dc *dc, struct dc_state *context);
1084 	bool (*update_bandwidth)(struct dc *dc, struct dc_state *context);
1085 	void (*optimize_bandwidth)(struct dc *dc, struct dc_state *context);
1086 
1087 	/* Infopacket Related */
1088 	void (*set_avmute)(struct pipe_ctx *pipe_ctx, bool enable);
1089 	void (*send_immediate_sdp_message)(
1090 			struct pipe_ctx *pipe_ctx,
1091 			const uint8_t *custom_sdp_message,
1092 			unsigned int sdp_message_size);
1093 	void (*update_info_frame)(struct pipe_ctx *pipe_ctx);
1094 	void (*set_dmdata_attributes)(struct pipe_ctx *pipe);
1095 	void (*program_dmdata_engine)(struct pipe_ctx *pipe_ctx);
1096 	bool (*dmdata_status_done)(struct pipe_ctx *pipe_ctx);
1097 
1098 	/* Cursor Related */
1099 	void (*set_cursor_position)(struct pipe_ctx *pipe);
1100 	void (*set_cursor_attribute)(struct pipe_ctx *pipe);
1101 	void (*set_cursor_sdr_white_level)(struct pipe_ctx *pipe);
1102 	void (*abort_cursor_offload_update)(struct dc *dc, const struct pipe_ctx *pipe);
1103 	void (*begin_cursor_offload_update)(struct dc *dc, const struct pipe_ctx *pipe);
1104 	void (*commit_cursor_offload_update)(struct dc *dc, const struct pipe_ctx *pipe);
1105 	void (*update_cursor_offload_pipe)(struct dc *dc, const struct pipe_ctx *pipe);
1106 	void (*notify_cursor_offload_drr_update)(struct dc *dc, struct dc_state *context,
1107 						 const struct dc_stream_state *stream);
1108 	void (*program_cursor_offload_now)(struct dc *dc, const struct pipe_ctx *pipe);
1109 
1110 	/* Colour Related */
1111 	void (*program_gamut_remap)(struct pipe_ctx *pipe_ctx);
1112 	void (*program_output_csc)(struct dc *dc, struct pipe_ctx *pipe_ctx,
1113 			enum dc_color_space colorspace,
1114 			uint16_t *matrix, int opp_id);
1115 	void (*trigger_3dlut_dma_load)(struct dc *dc, struct pipe_ctx *pipe_ctx);
1116 
1117 	/* VM Related */
1118 	int (*init_sys_ctx)(struct dce_hwseq *hws,
1119 			struct dc *dc,
1120 			struct dc_phy_addr_space_config *pa_config);
1121 	void (*init_vm_ctx)(struct dce_hwseq *hws,
1122 			struct dc *dc,
1123 			struct dc_virtual_addr_space_config *va_config,
1124 			int vmid);
1125 
1126 	/* Writeback Related */
1127 	void (*update_writeback)(struct dc *dc,
1128 			struct dc_writeback_info *wb_info,
1129 			struct dc_state *context);
1130 	void (*enable_writeback)(struct dc *dc,
1131 			struct dc_writeback_info *wb_info,
1132 			struct dc_state *context);
1133 	void (*disable_writeback)(struct dc *dc,
1134 			unsigned int dwb_pipe_inst);
1135 
1136 	/* Clock Related */
1137 	enum dc_status (*set_clock)(struct dc *dc,
1138 			enum dc_clock_type clock_type,
1139 			uint32_t clk_khz, uint32_t stepping);
1140 	void (*get_clock)(struct dc *dc, enum dc_clock_type clock_type,
1141 			struct dc_clock_config *clock_cfg);
1142 	void (*optimize_pwr_state)(const struct dc *dc,
1143 			struct dc_state *context);
1144 	void (*exit_optimized_pwr_state)(const struct dc *dc,
1145 			struct dc_state *context);
1146 	void (*calculate_pix_rate_divider)(struct dc *dc,
1147 			struct dc_state *context,
1148 			const struct dc_stream_state *stream);
1149 
1150 	/* Audio Related */
1151 	void (*enable_audio_stream)(struct pipe_ctx *pipe_ctx);
1152 	void (*disable_audio_stream)(struct pipe_ctx *pipe_ctx);
1153 
1154 	/* Stereo 3D Related */
1155 	void (*setup_stereo)(struct pipe_ctx *pipe_ctx, struct dc *dc);
1156 
1157 	/* HW State Logging Related */
1158 	void (*log_hw_state)(struct dc *dc, struct dc_log_buffer_ctx *log_ctx);
1159 	void (*log_color_state)(struct dc *dc,
1160 				struct dc_log_buffer_ctx *log_ctx);
1161 	void (*get_hw_state)(struct dc *dc, char *pBuf,
1162 			unsigned int bufSize, unsigned int mask);
1163 	void (*clear_status_bits)(struct dc *dc, unsigned int mask);
1164 
1165 	bool (*set_backlight_level)(struct pipe_ctx *pipe_ctx,
1166 		struct set_backlight_level_params *params);
1167 
1168 	void (*set_abm_immediate_disable)(struct pipe_ctx *pipe_ctx);
1169 
1170 	void (*set_pipe)(struct pipe_ctx *pipe_ctx);
1171 
1172 	void (*enable_dp_link_output)(struct dc_link *link,
1173 			const struct link_resource *link_res,
1174 			enum signal_type signal,
1175 			enum clock_source_id clock_source,
1176 			const struct dc_link_settings *link_settings);
1177 	void (*enable_tmds_link_output)(struct dc_link *link,
1178 			const struct link_resource *link_res,
1179 			enum signal_type signal,
1180 			enum clock_source_id clock_source,
1181 			enum dc_color_depth color_depth,
1182 			uint32_t pixel_clock);
1183 	void (*enable_lvds_link_output)(struct dc_link *link,
1184 			const struct link_resource *link_res,
1185 			enum clock_source_id clock_source,
1186 			uint32_t pixel_clock);
1187 	void (*disable_link_output)(struct dc_link *link,
1188 			const struct link_resource *link_res,
1189 			enum signal_type signal);
1190 
1191 	void (*get_dcc_en_bits)(struct dc *dc, int *dcc_en_bits);
1192 
1193 	/* Idle Optimization Related */
1194 	bool (*apply_idle_power_optimizations)(struct dc *dc, bool enable);
1195 
1196 	bool (*does_plane_fit_in_mall)(struct dc *dc,
1197 			unsigned int pitch,
1198 			unsigned int height,
1199 			enum surface_pixel_format format,
1200 			struct dc_cursor_attributes *cursor_attr);
1201 	void (*commit_subvp_config)(struct dc *dc, struct dc_state *context);
1202 	void (*enable_phantom_streams)(struct dc *dc, struct dc_state *context);
1203 	void (*disable_phantom_streams)(struct dc *dc, struct dc_state *context);
1204 	void (*subvp_pipe_control_lock)(struct dc *dc,
1205 			struct dc_state *context,
1206 			bool lock,
1207 			bool should_lock_all_pipes,
1208 			struct pipe_ctx *top_pipe_to_program,
1209 			bool subvp_prev_use);
1210 	void (*subvp_pipe_control_lock_fast)(union block_sequence_params *params);
1211 
1212 	void (*z10_restore)(const struct dc *dc);
1213 	void (*z10_save_init)(struct dc *dc);
1214 	bool (*is_abm_supported)(struct dc *dc,
1215 			struct dc_state *context, struct dc_stream_state *stream);
1216 
1217 	void (*set_disp_pattern_generator)(const struct dc *dc,
1218 			struct pipe_ctx *pipe_ctx,
1219 			enum controller_dp_test_pattern test_pattern,
1220 			enum controller_dp_color_space color_space,
1221 			enum dc_color_depth color_depth,
1222 			const struct tg_color *solid_color,
1223 			int width, int height, int offset);
1224 	void (*blank_phantom)(struct dc *dc,
1225 			struct timing_generator *tg,
1226 			int width,
1227 			int height);
1228 	void (*update_visual_confirm_color)(struct dc *dc,
1229 			struct pipe_ctx *pipe_ctx,
1230 			int mpcc_id);
1231 	void (*update_phantom_vp_position)(struct dc *dc,
1232 			struct dc_state *context,
1233 			struct pipe_ctx *phantom_pipe);
1234 	void (*apply_update_flags_for_phantom)(struct pipe_ctx *phantom_pipe);
1235 
1236 	void (*calc_blocks_to_gate)(struct dc *dc, struct dc_state *context,
1237 		struct pg_block_update *update_state);
1238 	void (*calc_blocks_to_ungate)(struct dc *dc, struct dc_state *context,
1239 		struct pg_block_update *update_state);
1240 	void (*hw_block_power_up)(struct dc *dc,
1241 		struct pg_block_update *update_state);
1242 	void (*hw_block_power_down)(struct dc *dc,
1243 		struct pg_block_update *update_state);
1244 	void (*root_clock_control)(struct dc *dc,
1245 		struct pg_block_update *update_state, bool power_on);
1246 	bool (*is_pipe_topology_transition_seamless)(struct dc *dc,
1247 			const struct dc_state *cur_ctx,
1248 			const struct dc_state *new_ctx);
1249 	void (*wait_for_dcc_meta_propagation)(const struct dc *dc,
1250 		const struct pipe_ctx *top_pipe_to_program);
1251 	void (*dmub_hw_control_lock)(struct dc *dc,
1252 			struct dc_state *context,
1253 			bool lock);
1254 	void (*fams2_update_config)(struct dc *dc,
1255 			struct dc_state *context,
1256 			bool enable);
1257 	void (*dmub_hw_control_lock_fast)(union block_sequence_params *params);
1258 	void (*set_long_vtotal)(struct pipe_ctx **pipe_ctx, int num_pipes, uint32_t v_total_min, uint32_t v_total_max);
1259 	void (*program_outstanding_updates)(struct dc *dc,
1260 			struct dc_state *context);
1261 	void (*setup_hpo_hw_control)(const struct dce_hwseq *hws, bool enable);
1262 	void (*wait_for_all_pending_updates)(const struct pipe_ctx *pipe_ctx);
1263 	void (*detect_pipe_changes)(struct dc_state *old_state,
1264 			struct dc_state *new_state,
1265 			struct pipe_ctx *old_pipe,
1266 			struct pipe_ctx *new_pipe);
1267 	void (*enable_plane)(struct dc *dc,
1268 			struct pipe_ctx *pipe_ctx,
1269 			struct dc_state *context);
1270 	void (*enable_plane_sequence)(struct dc *dc,
1271 			struct pipe_ctx *pipe_ctx,
1272 			struct dc_state *context,
1273 			struct block_sequence_state *seq_state);
1274 	void (*update_dchubp_dpp)(struct dc *dc,
1275 			struct pipe_ctx *pipe_ctx,
1276 			struct dc_state *context);
1277 	void (*update_dchubp_dpp_sequence)(struct dc *dc,
1278 			struct pipe_ctx *pipe_ctx,
1279 			struct dc_state *context,
1280 			struct block_sequence_state *seq_state);
1281 	void (*post_unlock_reset_opp)(struct dc *dc,
1282 			struct pipe_ctx *opp_head);
1283 	void (*post_unlock_reset_opp_sequence)(
1284 			struct dc *dc,
1285 			struct pipe_ctx *opp_head,
1286 			struct block_sequence_state *seq_state);
1287 	void (*get_underflow_debug_data)(const struct dc *dc,
1288 			struct timing_generator *tg,
1289 			struct dc_underflow_debug_data *out_data);
1290 };
1291 
1292 void color_space_to_black_color(
1293 	const struct dc *dc,
1294 	enum dc_color_space colorspace,
1295 	struct tg_color *black_color);
1296 
1297 bool hwss_wait_for_blank_complete(
1298 		struct timing_generator *tg);
1299 
1300 const uint16_t *find_color_matrix(
1301 		enum dc_color_space color_space,
1302 		uint32_t *array_size);
1303 
1304 void get_surface_tile_visual_confirm_color(
1305 		struct pipe_ctx *pipe_ctx,
1306 		struct tg_color *color);
1307 void get_surface_visual_confirm_color(
1308 		const struct pipe_ctx *pipe_ctx,
1309 		struct tg_color *color);
1310 
1311 void get_hdr_visual_confirm_color(
1312 		struct pipe_ctx *pipe_ctx,
1313 		struct tg_color *color);
1314 void get_mpctree_visual_confirm_color(
1315 		struct pipe_ctx *pipe_ctx,
1316 		struct tg_color *color);
1317 void get_smartmux_visual_confirm_color(
1318 	struct dc *dc,
1319 	struct tg_color *color);
1320 void get_vabc_visual_confirm_color(
1321 	struct pipe_ctx *pipe_ctx,
1322 	struct tg_color *color);
1323 void get_subvp_visual_confirm_color(
1324 	struct pipe_ctx *pipe_ctx,
1325 	struct tg_color *color);
1326 void get_fams2_visual_confirm_color(
1327 	struct dc *dc,
1328 	struct dc_state *context,
1329 	struct pipe_ctx *pipe_ctx,
1330 	struct tg_color *color);
1331 
1332 void get_mclk_switch_visual_confirm_color(
1333 		struct pipe_ctx *pipe_ctx,
1334 		struct tg_color *color);
1335 
1336 void get_cursor_visual_confirm_color(
1337 		struct pipe_ctx *pipe_ctx,
1338 		struct tg_color *color);
1339 
1340 void get_dcc_visual_confirm_color(
1341 	struct dc *dc,
1342 	struct pipe_ctx *pipe_ctx,
1343 	struct tg_color *color);
1344 
1345 void set_p_state_switch_method(
1346 		struct dc *dc,
1347 		struct dc_state *context,
1348 		struct pipe_ctx *pipe_ctx);
1349 
1350 void set_drr_and_clear_adjust_pending(
1351 		struct pipe_ctx *pipe_ctx,
1352 		struct dc_stream_state *stream,
1353 		struct drr_params *params);
1354 
1355 void hwss_execute_sequence(struct dc *dc,
1356 		struct block_sequence block_sequence[MAX_HWSS_BLOCK_SEQUENCE_SIZE],
1357 		int num_steps);
1358 
1359 void hwss_build_fast_sequence(struct dc *dc,
1360 		struct dc_dmub_cmd *dc_dmub_cmd,
1361 		unsigned int dmub_cmd_count,
1362 		struct block_sequence block_sequence[MAX_HWSS_BLOCK_SEQUENCE_SIZE],
1363 		unsigned int *num_steps,
1364 		struct pipe_ctx *pipe_ctx,
1365 		struct dc_stream_status *stream_status,
1366 		struct dc_state *context);
1367 
1368 void hwss_wait_for_all_blank_complete(struct dc *dc,
1369 		struct dc_state *context);
1370 
1371 void hwss_wait_for_odm_update_pending_complete(struct dc *dc,
1372 		struct dc_state *context);
1373 
1374 void hwss_wait_for_no_pipes_pending(struct dc *dc,
1375 		struct dc_state *context);
1376 
1377 void hwss_wait_for_outstanding_hw_updates(struct dc *dc,
1378 		struct dc_state *dc_context);
1379 
1380 void hwss_process_outstanding_hw_updates(struct dc *dc,
1381 		struct dc_state *dc_context);
1382 
1383 void hwss_send_dmcub_cmd(union block_sequence_params *params);
1384 
1385 void hwss_program_manual_trigger(union block_sequence_params *params);
1386 
1387 void hwss_setup_dpp(union block_sequence_params *params);
1388 
1389 void hwss_program_bias_and_scale(union block_sequence_params *params);
1390 
1391 void hwss_power_on_mpc_mem_pwr(union block_sequence_params *params);
1392 
1393 void hwss_set_output_csc(union block_sequence_params *params);
1394 
1395 void hwss_set_ocsc_default(union block_sequence_params *params);
1396 
1397 void hwss_subvp_save_surf_addr(union block_sequence_params *params);
1398 
1399 void hwss_program_surface_config(union block_sequence_params *params);
1400 
1401 void hwss_program_mcache_id_and_split_coordinate(union block_sequence_params *params);
1402 
1403 void hwss_set_odm_combine(union block_sequence_params *params);
1404 
1405 void hwss_set_odm_bypass(union block_sequence_params *params);
1406 
1407 void hwss_opp_pipe_clock_control(union block_sequence_params *params);
1408 
1409 void hwss_opp_program_left_edge_extra_pixel(union block_sequence_params *params);
1410 
1411 void hwss_blank_pixel_data(union block_sequence_params *params);
1412 
1413 void hwss_dccg_set_dto_dscclk(union block_sequence_params *params);
1414 
1415 void hwss_dsc_set_config(union block_sequence_params *params);
1416 
1417 void hwss_dsc_enable(union block_sequence_params *params);
1418 
1419 void hwss_tg_set_dsc_config(union block_sequence_params *params);
1420 
1421 void hwss_dsc_disconnect(union block_sequence_params *params);
1422 
1423 void hwss_dsc_read_state(union block_sequence_params *params);
1424 
1425 void hwss_dsc_calculate_and_set_config(union block_sequence_params *params);
1426 
1427 void hwss_dsc_enable_with_opp(union block_sequence_params *params);
1428 
1429 void hwss_program_tg(union block_sequence_params *params);
1430 
1431 void hwss_tg_program_global_sync(union block_sequence_params *params);
1432 
1433 void hwss_tg_wait_for_state(union block_sequence_params *params);
1434 
1435 void hwss_tg_set_vtg_params(union block_sequence_params *params);
1436 
1437 void hwss_tg_setup_vertical_interrupt2(union block_sequence_params *params);
1438 
1439 void hwss_dpp_set_hdr_multiplier(union block_sequence_params *params);
1440 
1441 void hwss_program_det_size(union block_sequence_params *params);
1442 
1443 void hwss_program_det_segments(union block_sequence_params *params);
1444 
1445 void hwss_opp_set_dyn_expansion(union block_sequence_params *params);
1446 
1447 void hwss_opp_program_fmt(union block_sequence_params *params);
1448 
1449 void hwss_opp_program_bit_depth_reduction(union block_sequence_params *params);
1450 
1451 void hwss_opp_set_disp_pattern_generator(union block_sequence_params *params);
1452 
1453 void hwss_set_abm_pipe(union block_sequence_params *params);
1454 
1455 void hwss_set_abm_level(union block_sequence_params *params);
1456 
1457 void hwss_set_abm_immediate_disable(union block_sequence_params *params);
1458 
1459 void hwss_mpc_remove_mpcc(union block_sequence_params *params);
1460 
1461 void hwss_opp_set_mpcc_disconnect_pending(union block_sequence_params *params);
1462 
1463 void hwss_dc_set_optimized_required(union block_sequence_params *params);
1464 
1465 void hwss_hubp_disconnect(union block_sequence_params *params);
1466 
1467 void hwss_hubbub_force_pstate_change_control(union block_sequence_params *params);
1468 
1469 void hwss_tg_enable_crtc(union block_sequence_params *params);
1470 
1471 void hwss_tg_set_gsl(union block_sequence_params *params);
1472 
1473 void hwss_tg_set_gsl_source_select(union block_sequence_params *params);
1474 
1475 void hwss_hubp_wait_flip_pending(union block_sequence_params *params);
1476 
1477 void hwss_tg_wait_double_buffer_pending(union block_sequence_params *params);
1478 
1479 void hwss_update_force_pstate(union block_sequence_params *params);
1480 
1481 void hwss_hubbub_apply_dedcn21_147_wa(union block_sequence_params *params);
1482 
1483 void hwss_hubbub_allow_self_refresh_control(union block_sequence_params *params);
1484 
1485 void hwss_tg_get_frame_count(union block_sequence_params *params);
1486 
1487 void hwss_mpc_set_dwb_mux(union block_sequence_params *params);
1488 
1489 void hwss_mpc_disable_dwb_mux(union block_sequence_params *params);
1490 
1491 void hwss_mcif_wb_config_buf(union block_sequence_params *params);
1492 
1493 void hwss_mcif_wb_config_arb(union block_sequence_params *params);
1494 
1495 void hwss_mcif_wb_enable(union block_sequence_params *params);
1496 
1497 void hwss_mcif_wb_disable(union block_sequence_params *params);
1498 
1499 void hwss_dwbc_enable(union block_sequence_params *params);
1500 
1501 void hwss_dwbc_disable(union block_sequence_params *params);
1502 
1503 void hwss_dwbc_update(union block_sequence_params *params);
1504 
1505 void hwss_hubp_update_mall_sel(union block_sequence_params *params);
1506 
1507 void hwss_hubp_prepare_subvp_buffering(union block_sequence_params *params);
1508 
1509 void hwss_hubp_set_blank_en(union block_sequence_params *params);
1510 
1511 void hwss_hubp_disable_control(union block_sequence_params *params);
1512 
1513 void hwss_hubbub_soft_reset(union block_sequence_params *params);
1514 
1515 void hwss_hubp_clk_cntl(union block_sequence_params *params);
1516 
1517 void hwss_hubp_init(union block_sequence_params *params);
1518 
1519 void hwss_hubp_set_vm_system_aperture_settings(union block_sequence_params *params);
1520 
1521 void hwss_hubp_set_flip_int(union block_sequence_params *params);
1522 
1523 void hwss_dpp_dppclk_control(union block_sequence_params *params);
1524 
1525 void hwss_disable_phantom_crtc(union block_sequence_params *params);
1526 
1527 void hwss_dsc_pg_status(union block_sequence_params *params);
1528 
1529 void hwss_dsc_wait_disconnect_pending_clear(union block_sequence_params *params);
1530 
1531 void hwss_dsc_disable(union block_sequence_params *params);
1532 
1533 void hwss_dccg_set_ref_dscclk(union block_sequence_params *params);
1534 
1535 void hwss_dpp_pg_control(union block_sequence_params *params);
1536 
1537 void hwss_hubp_pg_control(union block_sequence_params *params);
1538 
1539 void hwss_hubp_reset(union block_sequence_params *params);
1540 
1541 void hwss_dpp_reset(union block_sequence_params *params);
1542 
1543 void hwss_dpp_root_clock_control(union block_sequence_params *params);
1544 
1545 void hwss_dc_ip_request_cntl(union block_sequence_params *params);
1546 
1547 void hwss_dccg_update_dpp_dto(union block_sequence_params *params);
1548 
1549 void hwss_hubp_vtg_sel(union block_sequence_params *params);
1550 
1551 void hwss_hubp_setup2(union block_sequence_params *params);
1552 
1553 void hwss_hubp_setup(union block_sequence_params *params);
1554 
1555 void hwss_hubp_set_unbounded_requesting(union block_sequence_params *params);
1556 
1557 void hwss_hubp_setup_interdependent2(union block_sequence_params *params);
1558 
1559 void hwss_hubp_setup_interdependent(union block_sequence_params *params);
1560 
1561 void hwss_dpp_set_cursor_matrix(union block_sequence_params *params);
1562 
1563 void hwss_mpc_update_mpcc(union block_sequence_params *params);
1564 
1565 void hwss_mpc_update_blending(union block_sequence_params *params);
1566 
1567 void hwss_mpc_assert_idle_mpcc(union block_sequence_params *params);
1568 
1569 void hwss_mpc_insert_plane(union block_sequence_params *params);
1570 
1571 void hwss_dpp_set_scaler(union block_sequence_params *params);
1572 
1573 void hwss_hubp_mem_program_viewport(union block_sequence_params *params);
1574 
1575 void hwss_abort_cursor_offload_update(union block_sequence_params *params);
1576 
1577 void hwss_set_cursor_attribute(union block_sequence_params *params);
1578 
1579 void hwss_set_cursor_position(union block_sequence_params *params);
1580 
1581 void hwss_set_cursor_sdr_white_level(union block_sequence_params *params);
1582 
1583 void hwss_program_output_csc(union block_sequence_params *params);
1584 
1585 void hwss_hubp_set_legacy_tiling_compat_level(union block_sequence_params *params);
1586 
1587 void hwss_hubp_set_blank(union block_sequence_params *params);
1588 
1589 void hwss_phantom_hubp_post_enable(union block_sequence_params *params);
1590 
1591 void hwss_add_optc_pipe_control_lock(struct block_sequence_state *seq_state,
1592 		struct dc *dc, struct pipe_ctx *pipe_ctx, bool lock);
1593 
1594 void hwss_add_hubp_set_flip_control_gsl(struct block_sequence_state *seq_state,
1595 		struct hubp *hubp, bool flip_immediate);
1596 
1597 void hwss_add_hubp_program_triplebuffer(struct block_sequence_state *seq_state,
1598 		struct dc *dc, struct pipe_ctx *pipe_ctx, bool enableTripleBuffer);
1599 
1600 void hwss_add_hubp_update_plane_addr(struct block_sequence_state *seq_state,
1601 		struct dc *dc, struct pipe_ctx *pipe_ctx);
1602 
1603 void hwss_add_dpp_set_input_transfer_func(struct block_sequence_state *seq_state,
1604 		struct dc *dc, struct pipe_ctx *pipe_ctx, struct dc_plane_state *plane_state);
1605 
1606 void hwss_add_dpp_program_gamut_remap(struct block_sequence_state *seq_state,
1607 		struct pipe_ctx *pipe_ctx);
1608 
1609 void hwss_add_dpp_program_bias_and_scale(struct block_sequence_state *seq_state,
1610 		struct pipe_ctx *pipe_ctx);
1611 
1612 void hwss_add_optc_program_manual_trigger(struct block_sequence_state *seq_state,
1613 		struct pipe_ctx *pipe_ctx);
1614 
1615 void hwss_add_dpp_set_output_transfer_func(struct block_sequence_state *seq_state,
1616 		struct dc *dc, struct pipe_ctx *pipe_ctx, struct dc_stream_state *stream);
1617 
1618 void hwss_add_mpc_update_visual_confirm(struct block_sequence_state *seq_state,
1619 		struct dc *dc, struct pipe_ctx *pipe_ctx, int mpcc_id);
1620 
1621 void hwss_add_mpc_power_on_mpc_mem_pwr(struct block_sequence_state *seq_state,
1622 		struct mpc *mpc, int mpcc_id, bool power_on);
1623 
1624 void hwss_add_mpc_set_output_csc(struct block_sequence_state *seq_state,
1625 		struct mpc *mpc, int opp_id, const uint16_t *regval, enum mpc_output_csc_mode ocsc_mode);
1626 
1627 void hwss_add_mpc_set_ocsc_default(struct block_sequence_state *seq_state,
1628 		struct mpc *mpc, int opp_id, enum dc_color_space colorspace, enum mpc_output_csc_mode ocsc_mode);
1629 
1630 void hwss_add_dmub_send_dmcub_cmd(struct block_sequence_state *seq_state,
1631 		struct dc_context *ctx, union dmub_rb_cmd *cmd, enum dm_dmub_wait_type wait_type);
1632 
1633 void hwss_add_dmub_subvp_save_surf_addr(struct block_sequence_state *seq_state,
1634 		struct dc_dmub_srv *dc_dmub_srv, struct dc_plane_address *addr, uint8_t subvp_index);
1635 
1636 void hwss_add_hubp_wait_for_dcc_meta_prop(struct block_sequence_state *seq_state,
1637 		struct dc *dc, struct pipe_ctx *top_pipe_to_program);
1638 
1639 void hwss_add_hubp_wait_pipe_read_start(struct block_sequence_state *seq_state,
1640 		struct hubp *hubp);
1641 
1642 void hwss_add_hws_apply_update_flags_for_phantom(struct block_sequence_state *seq_state,
1643 		struct pipe_ctx *pipe_ctx);
1644 
1645 void hwss_add_hws_update_phantom_vp_position(struct block_sequence_state *seq_state,
1646 		struct dc *dc, struct dc_state *context, struct pipe_ctx *pipe_ctx);
1647 
1648 void hwss_add_optc_set_odm_combine(struct block_sequence_state *seq_state,
1649 		struct timing_generator *tg, int opp_inst[MAX_PIPES], int opp_head_count,
1650 		int odm_slice_width, int last_odm_slice_width);
1651 
1652 void hwss_add_optc_set_odm_bypass(struct block_sequence_state *seq_state,
1653 		struct timing_generator *optc, struct dc_crtc_timing *timing);
1654 
1655 void hwss_add_tg_program_global_sync(struct block_sequence_state *seq_state,
1656 		struct timing_generator *tg,
1657 		int vready_offset,
1658 		unsigned int vstartup_lines,
1659 		unsigned int vupdate_offset_pixels,
1660 		unsigned int vupdate_vupdate_width_pixels,
1661 		unsigned int pstate_keepout_start_lines);
1662 
1663 void hwss_add_tg_wait_for_state(struct block_sequence_state *seq_state,
1664 		struct timing_generator *tg, enum crtc_state state);
1665 
1666 void hwss_add_tg_set_vtg_params(struct block_sequence_state *seq_state,
1667 		struct timing_generator *tg, struct dc_crtc_timing *dc_crtc_timing, bool program_fp2);
1668 
1669 void hwss_add_tg_setup_vertical_interrupt2(struct block_sequence_state *seq_state,
1670 		struct timing_generator *tg, int start_line);
1671 
1672 void hwss_add_dpp_set_hdr_multiplier(struct block_sequence_state *seq_state,
1673 		struct dpp *dpp, uint32_t hw_mult);
1674 
1675 void hwss_add_hubp_program_det_size(struct block_sequence_state *seq_state,
1676 		struct hubbub *hubbub, unsigned int hubp_inst, unsigned int det_buffer_size_kb);
1677 
1678 void hwss_add_hubp_program_mcache_id(struct block_sequence_state *seq_state,
1679 		struct hubp *hubp, struct dml2_hubp_pipe_mcache_regs *mcache_regs);
1680 
1681 void hwss_add_hubbub_force_pstate_change_control(struct block_sequence_state *seq_state,
1682 		struct hubbub *hubbub, bool enable, bool wait);
1683 
1684 void hwss_add_hubp_program_det_segments(struct block_sequence_state *seq_state,
1685 		struct hubbub *hubbub, unsigned int hubp_inst, unsigned int det_size);
1686 
1687 void hwss_add_opp_set_dyn_expansion(struct block_sequence_state *seq_state,
1688 		struct output_pixel_processor *opp, enum dc_color_space color_sp,
1689 		enum dc_color_depth color_dpth, enum signal_type signal);
1690 
1691 void hwss_add_opp_program_fmt(struct block_sequence_state *seq_state,
1692 		struct output_pixel_processor *opp, struct bit_depth_reduction_params *fmt_bit_depth,
1693 		struct clamping_and_pixel_encoding_params *clamping);
1694 
1695 void hwss_add_abm_set_pipe(struct block_sequence_state *seq_state,
1696 		struct dc *dc, struct pipe_ctx *pipe_ctx);
1697 
1698 void hwss_add_abm_set_level(struct block_sequence_state *seq_state,
1699 		struct abm *abm, uint32_t abm_level);
1700 
1701 void hwss_add_tg_enable_crtc(struct block_sequence_state *seq_state,
1702 		struct timing_generator *tg);
1703 
1704 void hwss_add_hubp_wait_flip_pending(struct block_sequence_state *seq_state,
1705 		struct hubp *hubp, unsigned int timeout_us, unsigned int polling_interval_us);
1706 
1707 void hwss_add_tg_wait_double_buffer_pending(struct block_sequence_state *seq_state,
1708 		struct timing_generator *tg, unsigned int timeout_us, unsigned int polling_interval_us);
1709 
1710 void hwss_add_dccg_set_dto_dscclk(struct block_sequence_state *seq_state,
1711 		struct dccg *dccg, int inst, int num_slices_h);
1712 
1713 void hwss_add_dsc_calculate_and_set_config(struct block_sequence_state *seq_state,
1714 		struct pipe_ctx *pipe_ctx, bool enable, int opp_cnt);
1715 
1716 void hwss_add_mpc_remove_mpcc(struct block_sequence_state *seq_state,
1717 		struct mpc *mpc, struct mpc_tree *mpc_tree_params, struct mpcc *mpcc_to_remove);
1718 
1719 void hwss_add_opp_set_mpcc_disconnect_pending(struct block_sequence_state *seq_state,
1720 		struct output_pixel_processor *opp, int mpcc_inst, bool pending);
1721 
1722 void hwss_add_hubp_disconnect(struct block_sequence_state *seq_state,
1723 		struct hubp *hubp);
1724 
1725 void hwss_add_dsc_enable_with_opp(struct block_sequence_state *seq_state,
1726 		struct pipe_ctx *pipe_ctx);
1727 
1728 void hwss_add_dsc_disconnect(struct block_sequence_state *seq_state,
1729 		struct display_stream_compressor *dsc);
1730 
1731 void hwss_add_dc_set_optimized_required(struct block_sequence_state *seq_state,
1732 		struct dc *dc, bool optimized_required);
1733 
1734 void hwss_add_abm_set_immediate_disable(struct block_sequence_state *seq_state,
1735 		struct dc *dc, struct pipe_ctx *pipe_ctx);
1736 
1737 void hwss_add_opp_set_disp_pattern_generator(struct block_sequence_state *seq_state,
1738 		struct output_pixel_processor *opp,
1739 		enum controller_dp_test_pattern test_pattern,
1740 		enum controller_dp_color_space color_space,
1741 		enum dc_color_depth color_depth,
1742 		struct tg_color solid_color,
1743 		bool use_solid_color,
1744 		int width,
1745 		int height,
1746 		int offset);
1747 
1748 void hwss_add_opp_program_bit_depth_reduction(struct block_sequence_state *seq_state,
1749 		struct output_pixel_processor *opp,
1750 		bool use_default_params,
1751 		struct pipe_ctx *pipe_ctx);
1752 
1753 void hwss_add_dc_ip_request_cntl(struct block_sequence_state *seq_state,
1754 		struct dc *dc,
1755 		bool enable);
1756 
1757 void hwss_add_dwbc_update(struct block_sequence_state *seq_state,
1758 		struct dwbc *dwb,
1759 		struct dc_dwb_params *dwb_params);
1760 
1761 void hwss_add_mcif_wb_config_buf(struct block_sequence_state *seq_state,
1762 		struct mcif_wb *mcif_wb,
1763 		struct mcif_buf_params *mcif_buf_params,
1764 		unsigned int dest_height);
1765 
1766 void hwss_add_mcif_wb_config_arb(struct block_sequence_state *seq_state,
1767 		struct mcif_wb *mcif_wb,
1768 		struct mcif_arb_params *mcif_arb_params);
1769 
1770 void hwss_add_mcif_wb_enable(struct block_sequence_state *seq_state,
1771 		struct mcif_wb *mcif_wb);
1772 
1773 void hwss_add_mcif_wb_disable(struct block_sequence_state *seq_state,
1774 		struct mcif_wb *mcif_wb);
1775 
1776 void hwss_add_mpc_set_dwb_mux(struct block_sequence_state *seq_state,
1777 		struct mpc *mpc,
1778 		int dwb_id,
1779 		int mpcc_id);
1780 
1781 void hwss_add_mpc_disable_dwb_mux(struct block_sequence_state *seq_state,
1782 		struct mpc *mpc,
1783 		unsigned int dwb_id);
1784 
1785 void hwss_add_dwbc_enable(struct block_sequence_state *seq_state,
1786 		struct dwbc *dwb,
1787 		struct dc_dwb_params *dwb_params);
1788 
1789 void hwss_add_dwbc_disable(struct block_sequence_state *seq_state,
1790 		struct dwbc *dwb);
1791 
1792 void hwss_add_tg_set_gsl(struct block_sequence_state *seq_state,
1793 		struct timing_generator *tg,
1794 		struct gsl_params gsl);
1795 
1796 void hwss_add_tg_set_gsl_source_select(struct block_sequence_state *seq_state,
1797 		struct timing_generator *tg,
1798 		int group_idx,
1799 		uint32_t gsl_ready_signal);
1800 
1801 void hwss_add_hubp_update_mall_sel(struct block_sequence_state *seq_state,
1802 		struct hubp *hubp,
1803 		uint32_t mall_sel,
1804 		bool cache_cursor);
1805 
1806 void hwss_add_hubp_prepare_subvp_buffering(struct block_sequence_state *seq_state,
1807 		struct hubp *hubp,
1808 		bool enable);
1809 
1810 void hwss_add_hubp_set_blank_en(struct block_sequence_state *seq_state,
1811 		struct hubp *hubp,
1812 		bool enable);
1813 
1814 void hwss_add_hubp_disable_control(struct block_sequence_state *seq_state,
1815 		struct hubp *hubp,
1816 		bool disable);
1817 
1818 void hwss_add_hubbub_soft_reset(struct block_sequence_state *seq_state,
1819 		struct hubbub *hubbub,
1820 		void (*hubbub_soft_reset)(struct hubbub *hubbub, bool reset),
1821 		bool reset);
1822 
1823 void hwss_add_hubp_clk_cntl(struct block_sequence_state *seq_state,
1824 		struct hubp *hubp,
1825 		bool enable);
1826 
1827 void hwss_add_dpp_dppclk_control(struct block_sequence_state *seq_state,
1828 		struct dpp *dpp,
1829 		bool dppclk_div,
1830 		bool enable);
1831 
1832 void hwss_add_disable_phantom_crtc(struct block_sequence_state *seq_state,
1833 		struct timing_generator *tg);
1834 
1835 void hwss_add_dsc_pg_status(struct block_sequence_state *seq_state,
1836 		struct dce_hwseq *hws,
1837 		int dsc_inst,
1838 		bool is_ungated);
1839 
1840 void hwss_add_dsc_wait_disconnect_pending_clear(struct block_sequence_state *seq_state,
1841 		struct display_stream_compressor *dsc,
1842 		bool *is_ungated);
1843 
1844 void hwss_add_dsc_disable(struct block_sequence_state *seq_state,
1845 		struct display_stream_compressor *dsc,
1846 		bool *is_ungated);
1847 
1848 void hwss_add_dccg_set_ref_dscclk(struct block_sequence_state *seq_state,
1849 		struct dccg *dccg,
1850 		int dsc_inst,
1851 		bool *is_ungated);
1852 
1853 void hwss_add_dpp_root_clock_control(struct block_sequence_state *seq_state,
1854 		struct dce_hwseq *hws,
1855 		unsigned int dpp_inst,
1856 		bool clock_on);
1857 
1858 void hwss_add_dpp_pg_control(struct block_sequence_state *seq_state,
1859 		struct dce_hwseq *hws,
1860 		unsigned int dpp_inst,
1861 		bool power_on);
1862 
1863 void hwss_add_hubp_pg_control(struct block_sequence_state *seq_state,
1864 		struct dce_hwseq *hws,
1865 		unsigned int hubp_inst,
1866 		bool power_on);
1867 
1868 void hwss_add_hubp_set_blank(struct block_sequence_state *seq_state,
1869 		struct hubp *hubp,
1870 		bool blank);
1871 
1872 void hwss_add_hubp_init(struct block_sequence_state *seq_state,
1873 		struct hubp *hubp);
1874 
1875 void hwss_add_hubp_reset(struct block_sequence_state *seq_state,
1876 		struct hubp *hubp);
1877 
1878 void hwss_add_dpp_reset(struct block_sequence_state *seq_state,
1879 		struct dpp *dpp);
1880 
1881 void hwss_add_opp_pipe_clock_control(struct block_sequence_state *seq_state,
1882 		struct output_pixel_processor *opp,
1883 		bool enable);
1884 
1885 void hwss_add_hubp_set_vm_system_aperture_settings(struct block_sequence_state *seq_state,
1886 		struct hubp *hubp,
1887 		uint64_t sys_default,
1888 		uint64_t sys_low,
1889 		uint64_t sys_high);
1890 
1891 void hwss_add_hubp_set_flip_int(struct block_sequence_state *seq_state,
1892 		struct hubp *hubp);
1893 
1894 void hwss_add_dccg_update_dpp_dto(struct block_sequence_state *seq_state,
1895 		struct dccg *dccg,
1896 		int dpp_inst,
1897 		int dppclk_khz);
1898 
1899 void hwss_add_hubp_vtg_sel(struct block_sequence_state *seq_state,
1900 		struct hubp *hubp,
1901 		uint32_t otg_inst);
1902 
1903 void hwss_add_hubp_setup2(struct block_sequence_state *seq_state,
1904 		struct hubp *hubp,
1905 		struct dml2_dchub_per_pipe_register_set *hubp_regs,
1906 		union dml2_global_sync_programming *global_sync,
1907 		struct dc_crtc_timing *timing);
1908 
1909 void hwss_add_hubp_setup(struct block_sequence_state *seq_state,
1910 		struct hubp *hubp,
1911 		struct _vcs_dpi_display_dlg_regs_st *dlg_regs,
1912 		struct _vcs_dpi_display_ttu_regs_st *ttu_regs,
1913 		struct _vcs_dpi_display_rq_regs_st *rq_regs,
1914 		struct _vcs_dpi_display_pipe_dest_params_st *pipe_dest);
1915 
1916 void hwss_add_hubp_set_unbounded_requesting(struct block_sequence_state *seq_state,
1917 		struct hubp *hubp,
1918 		bool unbounded_req);
1919 
1920 void hwss_add_hubp_setup_interdependent2(struct block_sequence_state *seq_state,
1921 		struct hubp *hubp,
1922 		struct dml2_dchub_per_pipe_register_set *hubp_regs);
1923 
1924 void hwss_add_hubp_setup_interdependent(struct block_sequence_state *seq_state,
1925 		struct hubp *hubp,
1926 		struct _vcs_dpi_display_dlg_regs_st *dlg_regs,
1927 		struct _vcs_dpi_display_ttu_regs_st *ttu_regs);
1928 void hwss_add_hubp_program_surface_config(struct block_sequence_state *seq_state,
1929 		struct hubp *hubp,
1930 		enum surface_pixel_format format,
1931 		struct dc_tiling_info *tiling_info,
1932 		struct plane_size plane_size,
1933 		enum dc_rotation_angle rotation,
1934 		struct dc_plane_dcc_param *dcc,
1935 		bool horizontal_mirror,
1936 		int compat_level);
1937 
1938 void hwss_add_dpp_setup_dpp(struct block_sequence_state *seq_state,
1939 		struct pipe_ctx *pipe_ctx);
1940 
1941 void hwss_add_dpp_set_cursor_matrix(struct block_sequence_state *seq_state,
1942 		struct dpp *dpp,
1943 		enum dc_color_space color_space,
1944 		struct dc_csc_transform *cursor_csc_color_matrix);
1945 
1946 void hwss_add_mpc_update_blending(struct block_sequence_state *seq_state,
1947 		struct mpc *mpc,
1948 		struct mpcc_blnd_cfg blnd_cfg,
1949 		int mpcc_id);
1950 
1951 void hwss_add_mpc_assert_idle_mpcc(struct block_sequence_state *seq_state,
1952 		struct mpc *mpc,
1953 		int mpcc_id);
1954 
1955 void hwss_add_mpc_insert_plane(struct block_sequence_state *seq_state,
1956 		struct mpc *mpc,
1957 		struct mpc_tree *mpc_tree_params,
1958 		struct mpcc_blnd_cfg blnd_cfg,
1959 		struct mpcc_sm_cfg *sm_cfg,
1960 		struct mpcc *insert_above_mpcc,
1961 		int dpp_id,
1962 		int mpcc_id);
1963 
1964 void hwss_add_dpp_set_scaler(struct block_sequence_state *seq_state,
1965 		struct dpp *dpp,
1966 		const struct scaler_data *scl_data);
1967 
1968 void hwss_add_hubp_mem_program_viewport(struct block_sequence_state *seq_state,
1969 		struct hubp *hubp,
1970 		const struct rect *viewport,
1971 		const struct rect *viewport_c);
1972 
1973 void hwss_add_abort_cursor_offload_update(struct block_sequence_state *seq_state,
1974 		struct dc *dc,
1975 		struct pipe_ctx *pipe_ctx);
1976 
1977 void hwss_add_set_cursor_attribute(struct block_sequence_state *seq_state,
1978 		struct dc *dc,
1979 		struct pipe_ctx *pipe_ctx);
1980 
1981 void hwss_add_set_cursor_position(struct block_sequence_state *seq_state,
1982 		struct dc *dc,
1983 		struct pipe_ctx *pipe_ctx);
1984 
1985 void hwss_add_set_cursor_sdr_white_level(struct block_sequence_state *seq_state,
1986 		struct dc *dc,
1987 		struct pipe_ctx *pipe_ctx);
1988 
1989 void hwss_add_program_output_csc(struct block_sequence_state *seq_state,
1990 		struct dc *dc,
1991 		struct pipe_ctx *pipe_ctx,
1992 		enum dc_color_space colorspace,
1993 		uint16_t *matrix,
1994 		int opp_id);
1995 
1996 void hwss_add_phantom_hubp_post_enable(struct block_sequence_state *seq_state,
1997 		struct hubp *hubp);
1998 
1999 void hwss_add_update_force_pstate(struct block_sequence_state *seq_state,
2000 		struct dc *dc,
2001 		struct dc_state *context);
2002 
2003 void hwss_add_hubbub_apply_dedcn21_147_wa(struct block_sequence_state *seq_state,
2004 		struct hubbub *hubbub);
2005 
2006 void hwss_add_hubbub_allow_self_refresh_control(struct block_sequence_state *seq_state,
2007 		struct hubbub *hubbub,
2008 		bool allow,
2009 		bool *disallow_self_refresh_applied);
2010 
2011 void hwss_add_tg_get_frame_count(struct block_sequence_state *seq_state,
2012 		struct timing_generator *tg,
2013 		unsigned int *frame_count);
2014 
2015 void hwss_add_tg_set_dsc_config(struct block_sequence_state *seq_state,
2016 		struct timing_generator *tg,
2017 		struct dsc_optc_config *dsc_optc_cfg,
2018 		bool enable);
2019 
2020 void hwss_add_opp_program_left_edge_extra_pixel(struct block_sequence_state *seq_state,
2021 		struct output_pixel_processor *opp,
2022 		enum dc_pixel_encoding pixel_encoding,
2023 		bool is_otg_master);
2024 
2025 #endif /* __DC_HW_SEQUENCER_H__ */
2026