drm/amd/display: Refactor INIT into component folder
authorRevalla <hrevalla@amd.com>
Wed, 13 Dec 2023 14:26:38 +0000 (19:56 +0530)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 3 Jan 2024 15:47:29 +0000 (10:47 -0500)
[why]
Move all init files to hwss folder.

[how]
moved the dcnxx_init.c and .h files into inside the hwss and cleared the
linkage errors.

Tested-by: Daniel Wheeler <daniel.wheeler@amd.com>
Reviewed-by: Martin Leung <martin.leung@amd.com>
Acked-by: Rodrigo Siqueira <rodrigo.siqueira@amd.com>
Signed-off-by: Revalla <hrevalla@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
65 files changed:
drivers/gpu/drm/amd/display/dc/Makefile
drivers/gpu/drm/amd/display/dc/dcn10/Makefile
drivers/gpu/drm/amd/display/dc/dcn10/dcn10_init.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn10/dcn10_init.h [deleted file]
drivers/gpu/drm/amd/display/dc/dcn20/Makefile
drivers/gpu/drm/amd/display/dc/dcn20/dcn20_init.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn20/dcn20_init.h [deleted file]
drivers/gpu/drm/amd/display/dc/dcn201/Makefile
drivers/gpu/drm/amd/display/dc/dcn201/dcn201_init.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn201/dcn201_init.h [deleted file]
drivers/gpu/drm/amd/display/dc/dcn21/Makefile
drivers/gpu/drm/amd/display/dc/dcn21/dcn21_init.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn21/dcn21_init.h [deleted file]
drivers/gpu/drm/amd/display/dc/dcn30/Makefile
drivers/gpu/drm/amd/display/dc/dcn30/dcn30_init.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn30/dcn30_init.h [deleted file]
drivers/gpu/drm/amd/display/dc/dcn301/Makefile
drivers/gpu/drm/amd/display/dc/dcn301/dcn301_init.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn301/dcn301_init.h [deleted file]
drivers/gpu/drm/amd/display/dc/dcn302/Makefile [deleted file]
drivers/gpu/drm/amd/display/dc/dcn302/dcn302_init.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn302/dcn302_init.h [deleted file]
drivers/gpu/drm/amd/display/dc/dcn303/dcn303_init.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn303/dcn303_init.h [deleted file]
drivers/gpu/drm/amd/display/dc/dcn31/Makefile
drivers/gpu/drm/amd/display/dc/dcn31/dcn31_init.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn31/dcn31_init.h [deleted file]
drivers/gpu/drm/amd/display/dc/dcn314/Makefile
drivers/gpu/drm/amd/display/dc/dcn314/dcn314_init.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn314/dcn314_init.h [deleted file]
drivers/gpu/drm/amd/display/dc/dcn32/Makefile
drivers/gpu/drm/amd/display/dc/dcn32/dcn32_init.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn32/dcn32_init.h [deleted file]
drivers/gpu/drm/amd/display/dc/dcn35/Makefile
drivers/gpu/drm/amd/display/dc/dcn35/dcn35_init.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn35/dcn35_init.h [deleted file]
drivers/gpu/drm/amd/display/dc/hwss/Makefile
drivers/gpu/drm/amd/display/dc/hwss/dcn10/dcn10_init.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn10/dcn10_init.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn20/dcn20_init.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn20/dcn20_init.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn201/dcn201_init.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn201/dcn201_init.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn21/dcn21_init.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn21/dcn21_init.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn30/dcn30_init.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn30/dcn30_init.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn301/dcn301_init.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn301/dcn301_init.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn302/dcn302_init.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn302/dcn302_init.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn303/dcn303_init.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn303/dcn303_init.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn31/dcn31_init.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn31/dcn31_init.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn314/dcn314_init.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn314/dcn314_init.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn32/dcn32_init.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn32/dcn32_init.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn35/dcn35_init.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn35/dcn35_init.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn351/CMakeLists.txt [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn351/Makefile [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn351/dcn351_init.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/hwss/dcn351/dcn351_init.h [new file with mode: 0644]

index bae4fdddbf97c8d0f1dcc52ff4762b2211e21650..7991ae468f752c2e56d35d280795cb0e3758cde6 100644 (file)
@@ -34,8 +34,6 @@ DC_LIBS += dcn21
 DC_LIBS += dcn201
 DC_LIBS += dcn30
 DC_LIBS += dcn301
-DC_LIBS += dcn302
-DC_LIBS += dcn303
 DC_LIBS += dcn31
 DC_LIBS += dcn314
 DC_LIBS += dcn32
index 0dd62934a18ce9497dcaadcfc2a3b3364fd52670..ae6a131be71b6bb2676c7c13556c371af7bb4760 100644 (file)
@@ -22,7 +22,7 @@
 #
 # Makefile for DCN.
 
-DCN10 = dcn10_init.o dcn10_ipp.o \
+DCN10 = dcn10_ipp.o \
                dcn10_hw_sequencer_debug.o \
                dcn10_dpp.o dcn10_opp.o \
                dcn10_hubp.o dcn10_mpc.o \
diff --git a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_init.c b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_init.c
deleted file mode 100644 (file)
index a5bdac7..0000000
+++ /dev/null
@@ -1,128 +0,0 @@
-/*
- * Copyright 2016-2020 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "hw_sequencer_private.h"
-#include "dce110/dce110_hwseq.h"
-#include "dcn10/dcn10_hwseq.h"
-#include "dcn20/dcn20_hwseq.h"
-
-static const struct hw_sequencer_funcs dcn10_funcs = {
-       .program_gamut_remap = dcn10_program_gamut_remap,
-       .init_hw = dcn10_init_hw,
-       .power_down_on_boot = dcn10_power_down_on_boot,
-       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
-       .apply_ctx_for_surface = NULL,
-       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
-       .post_unlock_program_front_end = dcn10_post_unlock_program_front_end,
-       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
-       .update_plane_addr = dcn10_update_plane_addr,
-       .update_dchub = dcn10_update_dchub,
-       .update_pending_status = dcn10_update_pending_status,
-       .program_output_csc = dcn10_program_output_csc,
-       .enable_accelerated_mode = dce110_enable_accelerated_mode,
-       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
-       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
-       .update_info_frame = dce110_update_info_frame,
-       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
-       .enable_stream = dce110_enable_stream,
-       .disable_stream = dce110_disable_stream,
-       .unblank_stream = dcn10_unblank_stream,
-       .blank_stream = dce110_blank_stream,
-       .enable_audio_stream = dce110_enable_audio_stream,
-       .disable_audio_stream = dce110_disable_audio_stream,
-       .disable_plane = dcn10_disable_plane,
-       .pipe_control_lock = dcn10_pipe_control_lock,
-       .cursor_lock = dcn10_cursor_lock,
-       .interdependent_update_lock = dcn10_lock_all_pipes,
-       .prepare_bandwidth = dcn10_prepare_bandwidth,
-       .optimize_bandwidth = dcn10_optimize_bandwidth,
-       .set_drr = dcn10_set_drr,
-       .get_position = dcn10_get_position,
-       .set_static_screen_control = dcn10_set_static_screen_control,
-       .setup_stereo = dcn10_setup_stereo,
-       .set_avmute = dce110_set_avmute,
-       .log_hw_state = dcn10_log_hw_state,
-       .get_hw_state = dcn10_get_hw_state,
-       .clear_status_bits = dcn10_clear_status_bits,
-       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .edp_power_control = dce110_edp_power_control,
-       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
-       .set_cursor_position = dcn10_set_cursor_position,
-       .set_cursor_attribute = dcn10_set_cursor_attribute,
-       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
-       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
-       .set_clock = dcn10_set_clock,
-       .get_clock = dcn10_get_clock,
-       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
-       .calc_vupdate_position = dcn10_calc_vupdate_position,
-       .power_down = dce110_power_down,
-       .set_backlight_level = dce110_set_backlight_level,
-       .set_abm_immediate_disable = dce110_set_abm_immediate_disable,
-       .set_pipe = dce110_set_pipe,
-       .enable_lvds_link_output = dce110_enable_lvds_link_output,
-       .enable_tmds_link_output = dce110_enable_tmds_link_output,
-       .enable_dp_link_output = dce110_enable_dp_link_output,
-       .disable_link_output = dce110_disable_link_output,
-       .get_dcc_en_bits = dcn10_get_dcc_en_bits,
-       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
-};
-
-static const struct hwseq_private_funcs dcn10_private_funcs = {
-       .init_pipes = dcn10_init_pipes,
-       .update_plane_addr = dcn10_update_plane_addr,
-       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
-       .program_pipe = dcn10_program_pipe,
-       .update_mpcc = dcn10_update_mpcc,
-       .set_input_transfer_func = dcn10_set_input_transfer_func,
-       .set_output_transfer_func = dcn10_set_output_transfer_func,
-       .power_down = dce110_power_down,
-       .enable_display_power_gating = dcn10_dummy_display_power_gating,
-       .blank_pixel_data = dcn10_blank_pixel_data,
-       .reset_hw_ctx_wrap = dcn10_reset_hw_ctx_wrap,
-       .enable_stream_timing = dcn10_enable_stream_timing,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .disable_stream_gating = NULL,
-       .enable_stream_gating = NULL,
-       .setup_vupdate_interrupt = dcn10_setup_vupdate_interrupt,
-       .did_underflow_occur = dcn10_did_underflow_occur,
-       .init_blank = NULL,
-       .disable_vga = dcn10_disable_vga,
-       .bios_golden_init = dcn10_bios_golden_init,
-       .plane_atomic_disable = dcn10_plane_atomic_disable,
-       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
-       .enable_power_gating_plane = dcn10_enable_power_gating_plane,
-       .dpp_pg_control = dcn10_dpp_pg_control,
-       .hubp_pg_control = dcn10_hubp_pg_control,
-       .dsc_pg_control = NULL,
-       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
-       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
-};
-
-void dcn10_hw_sequencer_construct(struct dc *dc)
-{
-       dc->hwss = dcn10_funcs;
-       dc->hwseq->funcs = dcn10_private_funcs;
-}
diff --git a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_init.h b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_init.h
deleted file mode 100644 (file)
index 8c6fd7b..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright 2016 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_DCN10_INIT_H__
-#define __DC_DCN10_INIT_H__
-
-struct dc;
-
-void dcn10_hw_sequencer_construct(struct dc *dc);
-
-#endif /* __DC_DCN10_INIT_H__ */
index bd760442ff8935dbb31d8fe69ecf348c34927b42..3dae3943b056c44aaedaa9c90aae42d8f5ac781d 100644 (file)
@@ -2,7 +2,7 @@
 #
 # Makefile for DCN.
 
-DCN20 = dcn20_init.o dcn20_dpp.o dcn20_dpp_cm.o dcn20_hubp.o \
+DCN20 = dcn20_dpp.o dcn20_dpp_cm.o dcn20_hubp.o \
                dcn20_mpc.o dcn20_opp.o dcn20_hubbub.o dcn20_mmhubbub.o \
                dcn20_stream_encoder.o dcn20_link_encoder.o dcn20_dccg.o \
                dcn20_vmid.o dcn20_dwb.o dcn20_dwb_scl.o
diff --git a/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_init.c b/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_init.c
deleted file mode 100644 (file)
index 884e3e3..0000000
+++ /dev/null
@@ -1,145 +0,0 @@
-/*
- * Copyright 2016 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "dce110/dce110_hwseq.h"
-#include "dcn10/dcn10_hwseq.h"
-#include "dcn20/dcn20_hwseq.h"
-
-#include "dcn20_init.h"
-
-static const struct hw_sequencer_funcs dcn20_funcs = {
-       .program_gamut_remap = dcn10_program_gamut_remap,
-       .init_hw = dcn10_init_hw,
-       .power_down_on_boot =  dcn10_power_down_on_boot,
-       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
-       .apply_ctx_for_surface = NULL,
-       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
-       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
-       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .update_dchub = dcn10_update_dchub,
-       .update_pending_status = dcn10_update_pending_status,
-       .program_output_csc = dcn20_program_output_csc,
-       .enable_accelerated_mode = dce110_enable_accelerated_mode,
-       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
-       .enable_vblanks_synchronization = dcn10_enable_vblanks_synchronization,
-       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
-       .update_info_frame = dce110_update_info_frame,
-       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
-       .enable_stream = dcn20_enable_stream,
-       .disable_stream = dce110_disable_stream,
-       .unblank_stream = dcn20_unblank_stream,
-       .blank_stream = dce110_blank_stream,
-       .enable_audio_stream = dce110_enable_audio_stream,
-       .disable_audio_stream = dce110_disable_audio_stream,
-       .disable_plane = dcn20_disable_plane,
-       .pipe_control_lock = dcn20_pipe_control_lock,
-       .interdependent_update_lock = dcn10_lock_all_pipes,
-       .cursor_lock = dcn10_cursor_lock,
-       .prepare_bandwidth = dcn20_prepare_bandwidth,
-       .optimize_bandwidth = dcn20_optimize_bandwidth,
-       .update_bandwidth = dcn20_update_bandwidth,
-       .set_drr = dcn10_set_drr,
-       .get_position = dcn10_get_position,
-       .set_static_screen_control = dcn10_set_static_screen_control,
-       .setup_stereo = dcn10_setup_stereo,
-       .set_avmute = dce110_set_avmute,
-       .log_hw_state = dcn10_log_hw_state,
-       .get_hw_state = dcn10_get_hw_state,
-       .clear_status_bits = dcn10_clear_status_bits,
-       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .edp_power_control = dce110_edp_power_control,
-       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
-       .set_cursor_position = dcn10_set_cursor_position,
-       .set_cursor_attribute = dcn10_set_cursor_attribute,
-       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
-       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
-       .set_clock = dcn10_set_clock,
-       .get_clock = dcn10_get_clock,
-       .program_triplebuffer = dcn20_program_triple_buffer,
-       .enable_writeback = dcn20_enable_writeback,
-       .disable_writeback = dcn20_disable_writeback,
-       .dmdata_status_done = dcn20_dmdata_status_done,
-       .program_dmdata_engine = dcn20_program_dmdata_engine,
-       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
-       .init_sys_ctx = dcn20_init_sys_ctx,
-       .init_vm_ctx = dcn20_init_vm_ctx,
-       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
-       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
-       .calc_vupdate_position = dcn10_calc_vupdate_position,
-       .set_backlight_level = dce110_set_backlight_level,
-       .set_abm_immediate_disable = dce110_set_abm_immediate_disable,
-       .set_pipe = dce110_set_pipe,
-       .enable_lvds_link_output = dce110_enable_lvds_link_output,
-       .enable_tmds_link_output = dce110_enable_tmds_link_output,
-       .enable_dp_link_output = dce110_enable_dp_link_output,
-       .disable_link_output = dce110_disable_link_output,
-       .set_disp_pattern_generator = dcn20_set_disp_pattern_generator,
-       .get_dcc_en_bits = dcn10_get_dcc_en_bits,
-       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
-};
-
-static const struct hwseq_private_funcs dcn20_private_funcs = {
-       .init_pipes = dcn10_init_pipes,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
-       .update_mpcc = dcn20_update_mpcc,
-       .set_input_transfer_func = dcn20_set_input_transfer_func,
-       .set_output_transfer_func = dcn20_set_output_transfer_func,
-       .power_down = dce110_power_down,
-       .enable_display_power_gating = dcn10_dummy_display_power_gating,
-       .blank_pixel_data = dcn20_blank_pixel_data,
-       .reset_hw_ctx_wrap = dcn20_reset_hw_ctx_wrap,
-       .enable_stream_timing = dcn20_enable_stream_timing,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .disable_stream_gating = dcn20_disable_stream_gating,
-       .enable_stream_gating = dcn20_enable_stream_gating,
-       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
-       .did_underflow_occur = dcn10_did_underflow_occur,
-       .init_blank = dcn20_init_blank,
-       .disable_vga = dcn20_disable_vga,
-       .bios_golden_init = dcn10_bios_golden_init,
-       .plane_atomic_disable = dcn20_plane_atomic_disable,
-       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
-       .enable_power_gating_plane = dcn20_enable_power_gating_plane,
-       .dpp_pg_control = dcn20_dpp_pg_control,
-       .hubp_pg_control = dcn20_hubp_pg_control,
-       .update_odm = dcn20_update_odm,
-       .dsc_pg_control = dcn20_dsc_pg_control,
-       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
-       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
-       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
-       .dccg_init = dcn20_dccg_init,
-       .set_blend_lut = dcn20_set_blend_lut,
-       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
-};
-
-void dcn20_hw_sequencer_construct(struct dc *dc)
-{
-       dc->hwss = dcn20_funcs;
-       dc->hwseq->funcs = dcn20_private_funcs;
-
-}
diff --git a/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_init.h b/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_init.h
deleted file mode 100644 (file)
index 1227779..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright 2016 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_DCN20_INIT_H__
-#define __DC_DCN20_INIT_H__
-
-struct dc;
-
-void dcn20_hw_sequencer_construct(struct dc *dc);
-
-#endif /* __DC_DCN20_INIT_H__ */
index a101e651155500a977c4138f7050f6d83f65520b..2b0b4f32e13bf84e74c572778c5dd4fd2564e853 100644 (file)
@@ -1,8 +1,7 @@
 # SPDX-License-Identifier: MIT
 #
 # Makefile for DCN.
-DCN201 = dcn201_init.o \
-       dcn201_hubbub.o\
+DCN201 = dcn201_hubbub.o\
        dcn201_mpc.o dcn201_hubp.o dcn201_opp.o dcn201_dpp.o \
        dcn201_dccg.o dcn201_link_encoder.o
 
diff --git a/drivers/gpu/drm/amd/display/dc/dcn201/dcn201_init.c b/drivers/gpu/drm/amd/display/dc/dcn201/dcn201_init.c
deleted file mode 100644 (file)
index a13bf6c..0000000
+++ /dev/null
@@ -1,136 +0,0 @@
-/*
- * Copyright 2016 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "dce110/dce110_hwseq.h"
-#include "dcn10/dcn10_hwseq.h"
-#include "dcn20/dcn20_hwseq.h"
-#include "dcn201/dcn201_hwseq.h"
-#include "dcn201_init.h"
-
-static const struct hw_sequencer_funcs dcn201_funcs = {
-       .program_gamut_remap = dcn10_program_gamut_remap,
-       .init_hw = dcn201_init_hw,
-       .power_down_on_boot = NULL,
-       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
-       .apply_ctx_for_surface = NULL,
-       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
-       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
-       .post_unlock_program_front_end = dcn10_post_unlock_program_front_end,
-       .update_plane_addr = dcn201_update_plane_addr,
-       .update_dchub = dcn10_update_dchub,
-       .update_pending_status = dcn10_update_pending_status,
-       .program_output_csc = dcn20_program_output_csc,
-       .enable_accelerated_mode = dce110_enable_accelerated_mode,
-       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
-       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
-       .update_info_frame = dce110_update_info_frame,
-       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
-       .enable_stream = dce110_enable_stream,
-       .disable_stream = dce110_disable_stream,
-       .unblank_stream = dcn201_unblank_stream,
-       .blank_stream = dce110_blank_stream,
-       .enable_audio_stream = dce110_enable_audio_stream,
-       .disable_audio_stream = dce110_disable_audio_stream,
-       .disable_plane = dcn10_disable_plane,
-       .pipe_control_lock = dcn201_pipe_control_lock,
-       .interdependent_update_lock = dcn10_lock_all_pipes,
-       .cursor_lock = dcn10_cursor_lock,
-       .prepare_bandwidth = dcn20_prepare_bandwidth,
-       .optimize_bandwidth = dcn20_optimize_bandwidth,
-       .update_bandwidth = dcn20_update_bandwidth,
-       .set_drr = dcn10_set_drr,
-       .get_position = dcn10_get_position,
-       .set_static_screen_control = dcn10_set_static_screen_control,
-       .setup_stereo = dcn10_setup_stereo,
-       .set_avmute = dce110_set_avmute,
-       .log_hw_state = dcn10_log_hw_state,
-       .get_hw_state = dcn10_get_hw_state,
-       .clear_status_bits = dcn10_clear_status_bits,
-       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .edp_power_control = dce110_edp_power_control,
-       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
-       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
-       .set_clock = dcn10_set_clock,
-       .get_clock = dcn10_get_clock,
-       .program_triplebuffer = dcn20_program_triple_buffer,
-       .dmdata_status_done = dcn20_dmdata_status_done,
-       .set_dmdata_attributes = dcn201_set_dmdata_attributes,
-       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
-       .calc_vupdate_position = dcn10_calc_vupdate_position,
-       .set_cursor_position = dcn10_set_cursor_position,
-       .set_cursor_attribute = dcn201_set_cursor_attribute,
-       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
-       .set_backlight_level = dce110_set_backlight_level,
-       .set_abm_immediate_disable = dce110_set_abm_immediate_disable,
-       .set_pipe = dce110_set_pipe,
-       .enable_lvds_link_output = dce110_enable_lvds_link_output,
-       .enable_tmds_link_output = dce110_enable_tmds_link_output,
-       .enable_dp_link_output = dce110_enable_dp_link_output,
-       .disable_link_output = dce110_disable_link_output,
-       .set_disp_pattern_generator = dcn20_set_disp_pattern_generator,
-       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
-};
-
-static const struct hwseq_private_funcs dcn201_private_funcs = {
-       .init_pipes = NULL,
-       .update_plane_addr = dcn201_update_plane_addr,
-       .plane_atomic_disconnect = dcn201_plane_atomic_disconnect,
-       .program_pipe = dcn10_program_pipe,
-       .update_mpcc = dcn201_update_mpcc,
-       .set_input_transfer_func = dcn20_set_input_transfer_func,
-       .set_output_transfer_func = dcn20_set_output_transfer_func,
-       .power_down = dce110_power_down,
-       .enable_display_power_gating = dcn10_dummy_display_power_gating,
-       .blank_pixel_data = dcn20_blank_pixel_data,
-       .reset_hw_ctx_wrap = dcn10_reset_hw_ctx_wrap,
-       .enable_stream_timing = dcn20_enable_stream_timing,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .disable_stream_gating = NULL,
-       .enable_stream_gating = NULL,
-       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
-       .did_underflow_occur = dcn10_did_underflow_occur,
-       .init_blank = dcn201_init_blank,
-       .disable_vga = dcn10_disable_vga,
-       .bios_golden_init = dcn10_bios_golden_init,
-       .plane_atomic_disable = dcn10_plane_atomic_disable,
-       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
-       .enable_power_gating_plane = dcn10_enable_power_gating_plane,
-       .dpp_pg_control = dcn10_dpp_pg_control,
-       .hubp_pg_control = dcn10_hubp_pg_control,
-       .dsc_pg_control = NULL,
-       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
-       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
-       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
-       .dccg_init = dcn20_dccg_init,
-       .set_blend_lut = dcn20_set_blend_lut,
-       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
-};
-
-void dcn201_hw_sequencer_construct(struct dc *dc)
-{
-       dc->hwss = dcn201_funcs;
-       dc->hwseq->funcs = dcn201_private_funcs;
-}
diff --git a/drivers/gpu/drm/amd/display/dc/dcn201/dcn201_init.h b/drivers/gpu/drm/amd/display/dc/dcn201/dcn201_init.h
deleted file mode 100644 (file)
index 1168887..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright 2016 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_DCN201_INIT_H__
-#define __DC_DCN201_INIT_H__
-
-struct dc;
-
-void dcn201_hw_sequencer_construct(struct dc *dc);
-
-#endif /* __DC_DCN201_INIT_H__ */
index dd1eea7212f47058530c2cbbed849c4c85b1884c..ca92f5c8e7fb70e7a37918d43ee552185c796c26 100644 (file)
@@ -2,7 +2,7 @@
 #
 # Makefile for DCN21.
 
-DCN21 = dcn21_init.o dcn21_hubp.o dcn21_hubbub.o \
+DCN21 = dcn21_hubp.o dcn21_hubbub.o \
         dcn21_link_encoder.o dcn21_dccg.o
 
 AMD_DAL_DCN21 = $(addprefix $(AMDDALPATH)/dc/dcn21/,$(DCN21))
diff --git a/drivers/gpu/drm/amd/display/dc/dcn21/dcn21_init.c b/drivers/gpu/drm/amd/display/dc/dcn21/dcn21_init.c
deleted file mode 100644 (file)
index 18249c6..0000000
+++ /dev/null
@@ -1,151 +0,0 @@
-/*
- * Copyright 2016-2020 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "dce110/dce110_hwseq.h"
-#include "dcn10/dcn10_hwseq.h"
-#include "dcn20/dcn20_hwseq.h"
-#include "dcn21/dcn21_hwseq.h"
-
-#include "dcn21_init.h"
-
-static const struct hw_sequencer_funcs dcn21_funcs = {
-       .program_gamut_remap = dcn10_program_gamut_remap,
-       .init_hw = dcn10_init_hw,
-       .power_down_on_boot = dcn10_power_down_on_boot,
-       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
-       .apply_ctx_for_surface = NULL,
-       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
-       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
-       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .update_dchub = dcn10_update_dchub,
-       .update_pending_status = dcn10_update_pending_status,
-       .program_output_csc = dcn20_program_output_csc,
-       .enable_accelerated_mode = dce110_enable_accelerated_mode,
-       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
-       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
-       .update_info_frame = dce110_update_info_frame,
-       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
-       .enable_stream = dcn20_enable_stream,
-       .disable_stream = dce110_disable_stream,
-       .unblank_stream = dcn20_unblank_stream,
-       .blank_stream = dce110_blank_stream,
-       .enable_audio_stream = dce110_enable_audio_stream,
-       .disable_audio_stream = dce110_disable_audio_stream,
-       .disable_plane = dcn20_disable_plane,
-       .pipe_control_lock = dcn20_pipe_control_lock,
-       .interdependent_update_lock = dcn10_lock_all_pipes,
-       .cursor_lock = dcn10_cursor_lock,
-       .prepare_bandwidth = dcn20_prepare_bandwidth,
-       .optimize_bandwidth = dcn20_optimize_bandwidth,
-       .update_bandwidth = dcn20_update_bandwidth,
-       .set_drr = dcn10_set_drr,
-       .get_position = dcn10_get_position,
-       .set_static_screen_control = dcn10_set_static_screen_control,
-       .setup_stereo = dcn10_setup_stereo,
-       .set_avmute = dce110_set_avmute,
-       .log_hw_state = dcn10_log_hw_state,
-       .get_hw_state = dcn10_get_hw_state,
-       .clear_status_bits = dcn10_clear_status_bits,
-       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .edp_power_control = dce110_edp_power_control,
-       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
-       .set_cursor_position = dcn10_set_cursor_position,
-       .set_cursor_attribute = dcn10_set_cursor_attribute,
-       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
-       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
-       .set_clock = dcn10_set_clock,
-       .get_clock = dcn10_get_clock,
-       .program_triplebuffer = dcn20_program_triple_buffer,
-       .enable_writeback = dcn20_enable_writeback,
-       .disable_writeback = dcn20_disable_writeback,
-       .dmdata_status_done = dcn20_dmdata_status_done,
-       .program_dmdata_engine = dcn20_program_dmdata_engine,
-       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
-       .init_sys_ctx = dcn21_init_sys_ctx,
-       .init_vm_ctx = dcn20_init_vm_ctx,
-       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
-       .optimize_pwr_state = dcn21_optimize_pwr_state,
-       .exit_optimized_pwr_state = dcn21_exit_optimized_pwr_state,
-       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
-       .calc_vupdate_position = dcn10_calc_vupdate_position,
-       .power_down = dce110_power_down,
-       .set_backlight_level = dcn21_set_backlight_level,
-       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
-       .set_pipe = dcn21_set_pipe,
-       .enable_lvds_link_output = dce110_enable_lvds_link_output,
-       .enable_tmds_link_output = dce110_enable_tmds_link_output,
-       .enable_dp_link_output = dce110_enable_dp_link_output,
-       .disable_link_output = dce110_disable_link_output,
-       .is_abm_supported = dcn21_is_abm_supported,
-       .set_disp_pattern_generator = dcn20_set_disp_pattern_generator,
-       .get_dcc_en_bits = dcn10_get_dcc_en_bits,
-       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
-};
-
-static const struct hwseq_private_funcs dcn21_private_funcs = {
-       .init_pipes = dcn10_init_pipes,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
-       .update_mpcc = dcn20_update_mpcc,
-       .set_input_transfer_func = dcn20_set_input_transfer_func,
-       .set_output_transfer_func = dcn20_set_output_transfer_func,
-       .power_down = dce110_power_down,
-       .enable_display_power_gating = dcn10_dummy_display_power_gating,
-       .blank_pixel_data = dcn20_blank_pixel_data,
-       .reset_hw_ctx_wrap = dcn20_reset_hw_ctx_wrap,
-       .enable_stream_timing = dcn20_enable_stream_timing,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .disable_stream_gating = dcn20_disable_stream_gating,
-       .enable_stream_gating = dcn20_enable_stream_gating,
-       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
-       .did_underflow_occur = dcn10_did_underflow_occur,
-       .init_blank = dcn20_init_blank,
-       .disable_vga = dcn20_disable_vga,
-       .bios_golden_init = dcn10_bios_golden_init,
-       .plane_atomic_disable = dcn20_plane_atomic_disable,
-       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
-       .enable_power_gating_plane = dcn20_enable_power_gating_plane,
-       .dpp_pg_control = dcn20_dpp_pg_control,
-       .hubp_pg_control = dcn20_hubp_pg_control,
-       .update_odm = dcn20_update_odm,
-       .dsc_pg_control = dcn20_dsc_pg_control,
-       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
-       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
-       .s0i3_golden_init_wa = dcn21_s0i3_golden_init_wa,
-       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
-       .dccg_init = dcn20_dccg_init,
-       .set_blend_lut = dcn20_set_blend_lut,
-       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
-       .PLAT_58856_wa = dcn21_PLAT_58856_wa,
-};
-
-void dcn21_hw_sequencer_construct(struct dc *dc)
-{
-       dc->hwss = dcn21_funcs;
-       dc->hwseq->funcs = dcn21_private_funcs;
-
-}
diff --git a/drivers/gpu/drm/amd/display/dc/dcn21/dcn21_init.h b/drivers/gpu/drm/amd/display/dc/dcn21/dcn21_init.h
deleted file mode 100644 (file)
index 3ed2429..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright 2016 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_DCN21_INIT_H__
-#define __DC_DCN21_INIT_H__
-
-struct dc;
-
-void dcn21_hw_sequencer_construct(struct dc *dc);
-
-#endif /* __DC_DCN20_INIT_H__ */
index cd95f322235e9e47ce2d55dec3fdd6a1d9f52d37..b5b2aa3b3783972a5b81263769f3c6c00e7c1144 100644 (file)
@@ -23,9 +23,7 @@
 #
 #
 
-DCN30 := \
-       dcn30_init.o \
-       dcn30_hubbub.o \
+DCN30 := dcn30_hubbub.o \
        dcn30_hubp.o \
        dcn30_dpp.o \
        dcn30_dccg.o \
diff --git a/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_init.c b/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_init.c
deleted file mode 100644 (file)
index 9894cae..0000000
+++ /dev/null
@@ -1,154 +0,0 @@
-/*
- * Copyright 2016-2020 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "dce110/dce110_hwseq.h"
-#include "dcn10/dcn10_hwseq.h"
-#include "dcn20/dcn20_hwseq.h"
-#include "dcn21/dcn21_hwseq.h"
-#include "dcn30/dcn30_hwseq.h"
-
-#include "dcn30_init.h"
-
-static const struct hw_sequencer_funcs dcn30_funcs = {
-       .program_gamut_remap = dcn30_program_gamut_remap,
-       .init_hw = dcn30_init_hw,
-       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
-       .apply_ctx_for_surface = NULL,
-       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
-       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
-       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .update_dchub = dcn10_update_dchub,
-       .update_pending_status = dcn10_update_pending_status,
-       .program_output_csc = dcn20_program_output_csc,
-       .enable_accelerated_mode = dce110_enable_accelerated_mode,
-       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
-       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
-       .update_info_frame = dcn30_update_info_frame,
-       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
-       .enable_stream = dcn20_enable_stream,
-       .disable_stream = dce110_disable_stream,
-       .unblank_stream = dcn20_unblank_stream,
-       .blank_stream = dce110_blank_stream,
-       .enable_audio_stream = dce110_enable_audio_stream,
-       .disable_audio_stream = dce110_disable_audio_stream,
-       .disable_plane = dcn20_disable_plane,
-       .disable_pixel_data = dcn20_disable_pixel_data,
-       .pipe_control_lock = dcn20_pipe_control_lock,
-       .interdependent_update_lock = dcn10_lock_all_pipes,
-       .cursor_lock = dcn10_cursor_lock,
-       .prepare_bandwidth = dcn30_prepare_bandwidth,
-       .optimize_bandwidth = dcn20_optimize_bandwidth,
-       .update_bandwidth = dcn20_update_bandwidth,
-       .set_drr = dcn10_set_drr,
-       .get_position = dcn10_get_position,
-       .set_static_screen_control = dcn30_set_static_screen_control,
-       .setup_stereo = dcn10_setup_stereo,
-       .set_avmute = dcn30_set_avmute,
-       .log_hw_state = dcn10_log_hw_state,
-       .get_hw_state = dcn10_get_hw_state,
-       .clear_status_bits = dcn10_clear_status_bits,
-       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .edp_power_control = dce110_edp_power_control,
-       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
-       .edp_wait_for_T12 = dce110_edp_wait_for_T12,
-       .set_cursor_position = dcn10_set_cursor_position,
-       .set_cursor_attribute = dcn10_set_cursor_attribute,
-       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
-       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
-       .set_clock = dcn10_set_clock,
-       .get_clock = dcn10_get_clock,
-       .program_triplebuffer = dcn20_program_triple_buffer,
-       .enable_writeback = dcn30_enable_writeback,
-       .disable_writeback = dcn30_disable_writeback,
-       .update_writeback = dcn30_update_writeback,
-       .mmhubbub_warmup = dcn30_mmhubbub_warmup,
-       .dmdata_status_done = dcn20_dmdata_status_done,
-       .program_dmdata_engine = dcn30_program_dmdata_engine,
-       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
-       .init_sys_ctx = dcn20_init_sys_ctx,
-       .init_vm_ctx = dcn20_init_vm_ctx,
-       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
-       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
-       .calc_vupdate_position = dcn10_calc_vupdate_position,
-       .apply_idle_power_optimizations = dcn30_apply_idle_power_optimizations,
-       .does_plane_fit_in_mall = dcn30_does_plane_fit_in_mall,
-       .set_backlight_level = dcn21_set_backlight_level,
-       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
-       .hardware_release = dcn30_hardware_release,
-       .set_pipe = dcn21_set_pipe,
-       .enable_lvds_link_output = dce110_enable_lvds_link_output,
-       .enable_tmds_link_output = dce110_enable_tmds_link_output,
-       .enable_dp_link_output = dce110_enable_dp_link_output,
-       .disable_link_output = dce110_disable_link_output,
-       .set_disp_pattern_generator = dcn30_set_disp_pattern_generator,
-       .get_dcc_en_bits = dcn10_get_dcc_en_bits,
-       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
-       .is_abm_supported = dcn21_is_abm_supported
-};
-
-static const struct hwseq_private_funcs dcn30_private_funcs = {
-       .init_pipes = dcn10_init_pipes,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
-       .update_mpcc = dcn20_update_mpcc,
-       .set_input_transfer_func = dcn30_set_input_transfer_func,
-       .set_output_transfer_func = dcn30_set_output_transfer_func,
-       .power_down = dce110_power_down,
-       .enable_display_power_gating = dcn10_dummy_display_power_gating,
-       .blank_pixel_data = dcn20_blank_pixel_data,
-       .reset_hw_ctx_wrap = dcn20_reset_hw_ctx_wrap,
-       .enable_stream_timing = dcn20_enable_stream_timing,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .disable_stream_gating = dcn20_disable_stream_gating,
-       .enable_stream_gating = dcn20_enable_stream_gating,
-       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
-       .did_underflow_occur = dcn10_did_underflow_occur,
-       .init_blank = dcn20_init_blank,
-       .disable_vga = dcn20_disable_vga,
-       .bios_golden_init = dcn10_bios_golden_init,
-       .plane_atomic_disable = dcn20_plane_atomic_disable,
-       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
-       .enable_power_gating_plane = dcn20_enable_power_gating_plane,
-       .dpp_pg_control = dcn20_dpp_pg_control,
-       .hubp_pg_control = dcn20_hubp_pg_control,
-       .program_all_writeback_pipes_in_tree = dcn30_program_all_writeback_pipes_in_tree,
-       .update_odm = dcn20_update_odm,
-       .dsc_pg_control = dcn20_dsc_pg_control,
-       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
-       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
-       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
-       .dccg_init = dcn20_dccg_init,
-       .set_blend_lut = dcn30_set_blend_lut,
-       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
-};
-
-void dcn30_hw_sequencer_construct(struct dc *dc)
-{
-       dc->hwss = dcn30_funcs;
-       dc->hwseq->funcs = dcn30_private_funcs;
-
-}
diff --git a/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_init.h b/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_init.h
deleted file mode 100644 (file)
index c280ff9..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright 2020 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_DCN30_INIT_H__
-#define __DC_DCN30_INIT_H__
-
-struct dc;
-
-void dcn30_hw_sequencer_construct(struct dc *dc);
-
-#endif /* __DC_DCN30_INIT_H__ */
index 090011300dcdb02a3395baae22b1760021469269..d241f665e40ac4251bbc9bdb97419015ffa6db9a 100644 (file)
@@ -10,7 +10,7 @@
 #
 # Makefile for dcn30.
 
-DCN301 = dcn301_init.o dcn301_dccg.o \
+DCN301 = dcn301_dccg.o \
                dcn301_dio_link_encoder.o dcn301_panel_cntl.o dcn301_hubbub.o
 
 AMD_DAL_DCN301 = $(addprefix $(AMDDALPATH)/dc/dcn301/,$(DCN301))
diff --git a/drivers/gpu/drm/amd/display/dc/dcn301/dcn301_init.c b/drivers/gpu/drm/amd/display/dc/dcn301/dcn301_init.c
deleted file mode 100644 (file)
index 6477009..0000000
+++ /dev/null
@@ -1,154 +0,0 @@
-/*
- * Copyright 2016-2020 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "dce110/dce110_hwseq.h"
-#include "dcn10/dcn10_hwseq.h"
-#include "dcn20/dcn20_hwseq.h"
-#include "dcn21/dcn21_hwseq.h"
-#include "dcn30/dcn30_hwseq.h"
-#include "dcn301/dcn301_hwseq.h"
-
-#include "dcn301_init.h"
-
-static const struct hw_sequencer_funcs dcn301_funcs = {
-       .program_gamut_remap = dcn30_program_gamut_remap,
-       .init_hw = dcn10_init_hw,
-       .power_down_on_boot = dcn10_power_down_on_boot,
-       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
-       .apply_ctx_for_surface = NULL,
-       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
-       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
-       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .update_dchub = dcn10_update_dchub,
-       .update_pending_status = dcn10_update_pending_status,
-       .program_output_csc = dcn20_program_output_csc,
-       .enable_accelerated_mode = dce110_enable_accelerated_mode,
-       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
-       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
-       .update_info_frame = dcn30_update_info_frame,
-       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
-       .enable_stream = dcn20_enable_stream,
-       .disable_stream = dce110_disable_stream,
-       .unblank_stream = dcn20_unblank_stream,
-#ifdef FREESYNC_POWER_OPTIMIZE
-       .are_streams_coarse_grain_aligned = dcn20_are_streams_coarse_grain_aligned,
-#endif
-       .blank_stream = dce110_blank_stream,
-       .enable_audio_stream = dce110_enable_audio_stream,
-       .disable_audio_stream = dce110_disable_audio_stream,
-       .disable_plane = dcn20_disable_plane,
-       .pipe_control_lock = dcn20_pipe_control_lock,
-       .interdependent_update_lock = dcn10_lock_all_pipes,
-       .cursor_lock = dcn10_cursor_lock,
-       .prepare_bandwidth = dcn20_prepare_bandwidth,
-       .optimize_bandwidth = dcn20_optimize_bandwidth,
-       .update_bandwidth = dcn20_update_bandwidth,
-       .set_drr = dcn10_set_drr,
-       .get_position = dcn10_get_position,
-       .set_static_screen_control = dcn10_set_static_screen_control,
-       .setup_stereo = dcn10_setup_stereo,
-       .set_avmute = dcn30_set_avmute,
-       .log_hw_state = dcn10_log_hw_state,
-       .get_hw_state = dcn10_get_hw_state,
-       .clear_status_bits = dcn10_clear_status_bits,
-       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .edp_power_control = dce110_edp_power_control,
-       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
-       .set_cursor_position = dcn10_set_cursor_position,
-       .set_cursor_attribute = dcn10_set_cursor_attribute,
-       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
-       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
-       .set_clock = dcn10_set_clock,
-       .get_clock = dcn10_get_clock,
-       .program_triplebuffer = dcn20_program_triple_buffer,
-       .enable_writeback = dcn30_enable_writeback,
-       .disable_writeback = dcn30_disable_writeback,
-       .update_writeback = dcn30_update_writeback,
-       .mmhubbub_warmup = dcn30_mmhubbub_warmup,
-       .dmdata_status_done = dcn20_dmdata_status_done,
-       .program_dmdata_engine = dcn30_program_dmdata_engine,
-       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
-       .init_sys_ctx = dcn20_init_sys_ctx,
-       .init_vm_ctx = dcn20_init_vm_ctx,
-       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
-       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
-       .calc_vupdate_position = dcn10_calc_vupdate_position,
-       .set_backlight_level = dcn21_set_backlight_level,
-       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
-       .set_pipe = dcn21_set_pipe,
-       .enable_lvds_link_output = dce110_enable_lvds_link_output,
-       .enable_tmds_link_output = dce110_enable_tmds_link_output,
-       .enable_dp_link_output = dce110_enable_dp_link_output,
-       .disable_link_output = dce110_disable_link_output,
-       .set_disp_pattern_generator = dcn30_set_disp_pattern_generator,
-       .get_dcc_en_bits = dcn10_get_dcc_en_bits,
-       .optimize_pwr_state = dcn21_optimize_pwr_state,
-       .exit_optimized_pwr_state = dcn21_exit_optimized_pwr_state,
-       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
-};
-
-static const struct hwseq_private_funcs dcn301_private_funcs = {
-       .init_pipes = dcn10_init_pipes,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
-       .update_mpcc = dcn20_update_mpcc,
-       .set_input_transfer_func = dcn30_set_input_transfer_func,
-       .set_output_transfer_func = dcn30_set_output_transfer_func,
-       .power_down = dce110_power_down,
-       .enable_display_power_gating = dcn10_dummy_display_power_gating,
-       .blank_pixel_data = dcn20_blank_pixel_data,
-       .reset_hw_ctx_wrap = dcn20_reset_hw_ctx_wrap,
-       .enable_stream_timing = dcn20_enable_stream_timing,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .disable_stream_gating = dcn20_disable_stream_gating,
-       .enable_stream_gating = dcn20_enable_stream_gating,
-       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
-       .did_underflow_occur = dcn10_did_underflow_occur,
-       .init_blank = dcn20_init_blank,
-       .disable_vga = dcn20_disable_vga,
-       .bios_golden_init = dcn10_bios_golden_init,
-       .plane_atomic_disable = dcn20_plane_atomic_disable,
-       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
-       .enable_power_gating_plane = dcn20_enable_power_gating_plane,
-       .dpp_pg_control = dcn20_dpp_pg_control,
-       .hubp_pg_control = dcn20_hubp_pg_control,
-       .program_all_writeback_pipes_in_tree = dcn30_program_all_writeback_pipes_in_tree,
-       .update_odm = dcn20_update_odm,
-       .dsc_pg_control = dcn20_dsc_pg_control,
-       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
-       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
-       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
-       .dccg_init = dcn20_dccg_init,
-       .set_blend_lut = dcn30_set_blend_lut,
-       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
-};
-
-void dcn301_hw_sequencer_construct(struct dc *dc)
-{
-       dc->hwss = dcn301_funcs;
-       dc->hwseq->funcs = dcn301_private_funcs;
-}
diff --git a/drivers/gpu/drm/amd/display/dc/dcn301/dcn301_init.h b/drivers/gpu/drm/amd/display/dc/dcn301/dcn301_init.h
deleted file mode 100644 (file)
index 0bca48c..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright 2020 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_DCN30_INIT_H__
-#define __DC_DCN30_INIT_H__
-
-struct dc;
-
-void dcn301_hw_sequencer_construct(struct dc *dc);
-
-#endif /* __DC_DCN30_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/dcn302/Makefile b/drivers/gpu/drm/amd/display/dc/dcn302/Makefile
deleted file mode 100644 (file)
index 0fcd035..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-#
-# (c) Copyright 2020 Advanced Micro Devices, Inc. All the rights reserved
-#
-#  Authors: AMD
-#
-# Makefile for dcn302.
-
-DCN3_02 = dcn302_init.o
-
-AMD_DAL_DCN3_02 = $(addprefix $(AMDDALPATH)/dc/dcn302/,$(DCN3_02))
-
-AMD_DISPLAY_FILES += $(AMD_DAL_DCN3_02)
diff --git a/drivers/gpu/drm/amd/display/dc/dcn302/dcn302_init.c b/drivers/gpu/drm/amd/display/dc/dcn302/dcn302_init.c
deleted file mode 100644 (file)
index 637f951..0000000
+++ /dev/null
@@ -1,41 +0,0 @@
-/*
- * Copyright 2020 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "dcn302/dcn302_hwseq.h"
-
-#include "dcn30/dcn30_init.h"
-
-#include "dc.h"
-
-#include "dcn302_init.h"
-
-void dcn302_hw_sequencer_construct(struct dc *dc)
-{
-       dcn30_hw_sequencer_construct(dc);
-
-       dc->hwseq->funcs.dpp_pg_control = dcn302_dpp_pg_control;
-       dc->hwseq->funcs.hubp_pg_control = dcn302_hubp_pg_control;
-       dc->hwseq->funcs.dsc_pg_control = dcn302_dsc_pg_control;
-}
diff --git a/drivers/gpu/drm/amd/display/dc/dcn302/dcn302_init.h b/drivers/gpu/drm/amd/display/dc/dcn302/dcn302_init.h
deleted file mode 100644 (file)
index 899587b..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright 2020 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_DCN302_INIT_H__
-#define __DC_DCN302_INIT_H__
-
-struct dc;
-
-void dcn302_hw_sequencer_construct(struct dc *dc);
-
-#endif /* __DC_DCN302_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/dcn303/dcn303_init.c b/drivers/gpu/drm/amd/display/dc/dcn303/dcn303_init.c
deleted file mode 100644 (file)
index edb4d68..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-// SPDX-License-Identifier: MIT
-/*
- * Copyright (C) 2021 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- */
-
-#include "dcn303/dcn303_hwseq.h"
-#include "dcn30/dcn30_init.h"
-#include "dc.h"
-
-#include "dcn303_init.h"
-
-void dcn303_hw_sequencer_construct(struct dc *dc)
-{
-       dcn30_hw_sequencer_construct(dc);
-
-       dc->hwseq->funcs.dpp_pg_control = dcn303_dpp_pg_control;
-       dc->hwseq->funcs.hubp_pg_control = dcn303_hubp_pg_control;
-       dc->hwseq->funcs.dsc_pg_control = dcn303_dsc_pg_control;
-       dc->hwseq->funcs.enable_power_gating_plane = dcn303_enable_power_gating_plane;
-}
diff --git a/drivers/gpu/drm/amd/display/dc/dcn303/dcn303_init.h b/drivers/gpu/drm/amd/display/dc/dcn303/dcn303_init.h
deleted file mode 100644 (file)
index 4949981..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-// SPDX-License-Identifier: MIT
-/*
- * Copyright (C) 2021 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_DCN303_INIT_H__
-#define __DC_DCN303_INIT_H__
-
-struct dc;
-
-void dcn303_hw_sequencer_construct(struct dc *dc);
-
-#endif /* __DC_DCN303_INIT_H__ */
index 11a2662e58ef344a1764583ffe32d73dd902444e..5d93ac16c03a9481ac4c25109c9c3b2d6a9b5639 100644 (file)
@@ -10,7 +10,7 @@
 #
 # Makefile for dcn31.
 
-DCN31 = dcn31_hubbub.o dcn31_init.o dcn31_hubp.o \
+DCN31 = dcn31_hubbub.o dcn31_hubp.o \
        dcn31_dccg.o dcn31_dio_link_encoder.o dcn31_panel_cntl.o \
        dcn31_apg.o dcn31_hpo_dp_stream_encoder.o dcn31_hpo_dp_link_encoder.o \
        dcn31_afmt.o dcn31_vpg.o
diff --git a/drivers/gpu/drm/amd/display/dc/dcn31/dcn31_init.c b/drivers/gpu/drm/amd/display/dc/dcn31/dcn31_init.c
deleted file mode 100644 (file)
index 669f524..0000000
+++ /dev/null
@@ -1,157 +0,0 @@
-/*
- * Copyright 2016 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "dce110/dce110_hwseq.h"
-#include "dcn10/dcn10_hwseq.h"
-#include "dcn20/dcn20_hwseq.h"
-#include "dcn21/dcn21_hwseq.h"
-#include "dcn30/dcn30_hwseq.h"
-#include "dcn301/dcn301_hwseq.h"
-#include "dcn31/dcn31_hwseq.h"
-
-#include "dcn31_init.h"
-
-static const struct hw_sequencer_funcs dcn31_funcs = {
-       .program_gamut_remap = dcn30_program_gamut_remap,
-       .init_hw = dcn31_init_hw,
-       .power_down_on_boot = dcn10_power_down_on_boot,
-       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
-       .apply_ctx_for_surface = NULL,
-       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
-       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
-       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .update_dchub = dcn10_update_dchub,
-       .update_pending_status = dcn10_update_pending_status,
-       .program_output_csc = dcn20_program_output_csc,
-       .enable_accelerated_mode = dce110_enable_accelerated_mode,
-       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
-       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
-       .update_info_frame = dcn31_update_info_frame,
-       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
-       .enable_stream = dcn20_enable_stream,
-       .disable_stream = dce110_disable_stream,
-       .unblank_stream = dcn20_unblank_stream,
-       .blank_stream = dce110_blank_stream,
-       .enable_audio_stream = dce110_enable_audio_stream,
-       .disable_audio_stream = dce110_disable_audio_stream,
-       .disable_plane = dcn20_disable_plane,
-       .disable_pixel_data = dcn20_disable_pixel_data,
-       .pipe_control_lock = dcn20_pipe_control_lock,
-       .interdependent_update_lock = dcn10_lock_all_pipes,
-       .cursor_lock = dcn10_cursor_lock,
-       .prepare_bandwidth = dcn20_prepare_bandwidth,
-       .optimize_bandwidth = dcn20_optimize_bandwidth,
-       .update_bandwidth = dcn20_update_bandwidth,
-       .set_drr = dcn10_set_drr,
-       .get_position = dcn10_get_position,
-       .set_static_screen_control = dcn30_set_static_screen_control,
-       .setup_stereo = dcn10_setup_stereo,
-       .set_avmute = dcn30_set_avmute,
-       .log_hw_state = dcn10_log_hw_state,
-       .get_hw_state = dcn10_get_hw_state,
-       .clear_status_bits = dcn10_clear_status_bits,
-       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .edp_power_control = dce110_edp_power_control,
-       .edp_wait_for_T12 = dce110_edp_wait_for_T12,
-       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
-       .set_cursor_position = dcn10_set_cursor_position,
-       .set_cursor_attribute = dcn10_set_cursor_attribute,
-       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
-       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
-       .set_clock = dcn10_set_clock,
-       .get_clock = dcn10_get_clock,
-       .program_triplebuffer = dcn20_program_triple_buffer,
-       .enable_writeback = dcn30_enable_writeback,
-       .disable_writeback = dcn30_disable_writeback,
-       .update_writeback = dcn30_update_writeback,
-       .mmhubbub_warmup = dcn30_mmhubbub_warmup,
-       .dmdata_status_done = dcn20_dmdata_status_done,
-       .program_dmdata_engine = dcn30_program_dmdata_engine,
-       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
-       .init_sys_ctx = dcn31_init_sys_ctx,
-       .init_vm_ctx = dcn20_init_vm_ctx,
-       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
-       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
-       .calc_vupdate_position = dcn10_calc_vupdate_position,
-       .power_down = dce110_power_down,
-       .set_backlight_level = dcn21_set_backlight_level,
-       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
-       .set_pipe = dcn21_set_pipe,
-       .enable_lvds_link_output = dce110_enable_lvds_link_output,
-       .enable_tmds_link_output = dce110_enable_tmds_link_output,
-       .enable_dp_link_output = dce110_enable_dp_link_output,
-       .disable_link_output = dce110_disable_link_output,
-       .z10_restore = dcn31_z10_restore,
-       .z10_save_init = dcn31_z10_save_init,
-       .set_disp_pattern_generator = dcn30_set_disp_pattern_generator,
-       .optimize_pwr_state = dcn21_optimize_pwr_state,
-       .exit_optimized_pwr_state = dcn21_exit_optimized_pwr_state,
-       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
-};
-
-static const struct hwseq_private_funcs dcn31_private_funcs = {
-       .init_pipes = dcn10_init_pipes,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
-       .update_mpcc = dcn20_update_mpcc,
-       .set_input_transfer_func = dcn30_set_input_transfer_func,
-       .set_output_transfer_func = dcn30_set_output_transfer_func,
-       .power_down = dce110_power_down,
-       .enable_display_power_gating = dcn10_dummy_display_power_gating,
-       .blank_pixel_data = dcn20_blank_pixel_data,
-       .reset_hw_ctx_wrap = dcn31_reset_hw_ctx_wrap,
-       .enable_stream_timing = dcn20_enable_stream_timing,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .disable_stream_gating = dcn20_disable_stream_gating,
-       .enable_stream_gating = dcn20_enable_stream_gating,
-       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
-       .did_underflow_occur = dcn10_did_underflow_occur,
-       .init_blank = dcn20_init_blank,
-       .disable_vga = dcn20_disable_vga,
-       .bios_golden_init = dcn10_bios_golden_init,
-       .plane_atomic_disable = dcn20_plane_atomic_disable,
-       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
-       .enable_power_gating_plane = dcn31_enable_power_gating_plane,
-       .hubp_pg_control = dcn31_hubp_pg_control,
-       .program_all_writeback_pipes_in_tree = dcn30_program_all_writeback_pipes_in_tree,
-       .update_odm = dcn20_update_odm,
-       .dsc_pg_control = dcn31_dsc_pg_control,
-       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
-       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
-       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
-       .dccg_init = dcn20_dccg_init,
-       .set_blend_lut = dcn30_set_blend_lut,
-       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
-       .setup_hpo_hw_control = dcn31_setup_hpo_hw_control,
-};
-
-void dcn31_hw_sequencer_construct(struct dc *dc)
-{
-       dc->hwss = dcn31_funcs;
-       dc->hwseq->funcs = dcn31_private_funcs;
-
-}
diff --git a/drivers/gpu/drm/amd/display/dc/dcn31/dcn31_init.h b/drivers/gpu/drm/amd/display/dc/dcn31/dcn31_init.h
deleted file mode 100644 (file)
index a3db08c..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright 2016 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_DCN31_INIT_H__
-#define __DC_DCN31_INIT_H__
-
-struct dc;
-
-void dcn31_hw_sequencer_construct(struct dc *dc);
-
-#endif /* __DC_DCN31_INIT_H__ */
index d5c177346a3bfb1533c7c1d052bebe903da97fe8..b134ab05aa71267d406cc2292ba7bbfd7474b1ea 100644 (file)
@@ -10,8 +10,7 @@
 #
 # Makefile for dcn314.
 
-DCN314 = dcn314_init.o \
-               dcn314_dio_stream_encoder.o dcn314_dccg.o
+DCN314 = dcn314_dio_stream_encoder.o dcn314_dccg.o
 
 AMD_DAL_DCN314 = $(addprefix $(AMDDALPATH)/dc/dcn314/,$(DCN314))
 
diff --git a/drivers/gpu/drm/amd/display/dc/dcn314/dcn314_init.c b/drivers/gpu/drm/amd/display/dc/dcn314/dcn314_init.c
deleted file mode 100644 (file)
index ccb7e31..0000000
+++ /dev/null
@@ -1,163 +0,0 @@
-// SPDX-License-Identifier: MIT
-/*
- * Copyright 2022 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "dce110/dce110_hwseq.h"
-#include "dcn10/dcn10_hwseq.h"
-#include "dcn20/dcn20_hwseq.h"
-#include "dcn21/dcn21_hwseq.h"
-#include "dcn30/dcn30_hwseq.h"
-#include "dcn301/dcn301_hwseq.h"
-#include "dcn31/dcn31_hwseq.h"
-#include "dcn314/dcn314_hwseq.h"
-
-#include "dcn314_init.h"
-
-static const struct hw_sequencer_funcs dcn314_funcs = {
-       .program_gamut_remap = dcn30_program_gamut_remap,
-       .init_hw = dcn31_init_hw,
-       .power_down_on_boot = dcn10_power_down_on_boot,
-       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
-       .apply_ctx_for_surface = NULL,
-       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
-       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
-       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .update_dchub = dcn10_update_dchub,
-       .update_pending_status = dcn10_update_pending_status,
-       .program_output_csc = dcn20_program_output_csc,
-       .enable_accelerated_mode = dce110_enable_accelerated_mode,
-       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
-       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
-       .update_info_frame = dcn31_update_info_frame,
-       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
-       .enable_stream = dcn20_enable_stream,
-       .disable_stream = dce110_disable_stream,
-       .unblank_stream = dcn20_unblank_stream,
-       .blank_stream = dce110_blank_stream,
-       .enable_audio_stream = dce110_enable_audio_stream,
-       .disable_audio_stream = dce110_disable_audio_stream,
-       .disable_plane = dcn20_disable_plane,
-       .disable_pixel_data = dcn20_disable_pixel_data,
-       .pipe_control_lock = dcn20_pipe_control_lock,
-       .interdependent_update_lock = dcn10_lock_all_pipes,
-       .cursor_lock = dcn10_cursor_lock,
-       .prepare_bandwidth = dcn20_prepare_bandwidth,
-       .optimize_bandwidth = dcn20_optimize_bandwidth,
-       .update_bandwidth = dcn20_update_bandwidth,
-       .set_drr = dcn10_set_drr,
-       .get_position = dcn10_get_position,
-       .set_static_screen_control = dcn30_set_static_screen_control,
-       .setup_stereo = dcn10_setup_stereo,
-       .set_avmute = dcn30_set_avmute,
-       .log_hw_state = dcn10_log_hw_state,
-       .get_hw_state = dcn10_get_hw_state,
-       .clear_status_bits = dcn10_clear_status_bits,
-       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .edp_power_control = dce110_edp_power_control,
-       .edp_wait_for_T12 = dce110_edp_wait_for_T12,
-       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
-       .set_cursor_position = dcn10_set_cursor_position,
-       .set_cursor_attribute = dcn10_set_cursor_attribute,
-       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
-       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
-       .set_clock = dcn10_set_clock,
-       .get_clock = dcn10_get_clock,
-       .program_triplebuffer = dcn20_program_triple_buffer,
-       .enable_writeback = dcn30_enable_writeback,
-       .disable_writeback = dcn30_disable_writeback,
-       .update_writeback = dcn30_update_writeback,
-       .mmhubbub_warmup = dcn30_mmhubbub_warmup,
-       .dmdata_status_done = dcn20_dmdata_status_done,
-       .program_dmdata_engine = dcn30_program_dmdata_engine,
-       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
-       .init_sys_ctx = dcn31_init_sys_ctx,
-       .init_vm_ctx = dcn20_init_vm_ctx,
-       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
-       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
-       .calc_vupdate_position = dcn10_calc_vupdate_position,
-       .power_down = dce110_power_down,
-       .set_backlight_level = dcn21_set_backlight_level,
-       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
-       .set_pipe = dcn21_set_pipe,
-       .enable_lvds_link_output = dce110_enable_lvds_link_output,
-       .enable_tmds_link_output = dce110_enable_tmds_link_output,
-       .enable_dp_link_output = dce110_enable_dp_link_output,
-       .disable_link_output = dcn314_disable_link_output,
-       .z10_restore = dcn31_z10_restore,
-       .z10_save_init = dcn31_z10_save_init,
-       .set_disp_pattern_generator = dcn30_set_disp_pattern_generator,
-       .optimize_pwr_state = dcn21_optimize_pwr_state,
-       .exit_optimized_pwr_state = dcn21_exit_optimized_pwr_state,
-       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
-};
-
-static const struct hwseq_private_funcs dcn314_private_funcs = {
-       .init_pipes = dcn10_init_pipes,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
-       .update_mpcc = dcn20_update_mpcc,
-       .set_input_transfer_func = dcn30_set_input_transfer_func,
-       .set_output_transfer_func = dcn30_set_output_transfer_func,
-       .power_down = dce110_power_down,
-       .enable_display_power_gating = dcn10_dummy_display_power_gating,
-       .blank_pixel_data = dcn20_blank_pixel_data,
-       .reset_hw_ctx_wrap = dcn31_reset_hw_ctx_wrap,
-       .enable_stream_timing = dcn20_enable_stream_timing,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .disable_stream_gating = dcn20_disable_stream_gating,
-       .enable_stream_gating = dcn20_enable_stream_gating,
-       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
-       .did_underflow_occur = dcn10_did_underflow_occur,
-       .init_blank = dcn20_init_blank,
-       .disable_vga = dcn20_disable_vga,
-       .bios_golden_init = dcn10_bios_golden_init,
-       .plane_atomic_disable = dcn20_plane_atomic_disable,
-       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
-       .enable_power_gating_plane = dcn314_enable_power_gating_plane,
-       .dpp_root_clock_control = dcn314_dpp_root_clock_control,
-       .hubp_pg_control = dcn31_hubp_pg_control,
-       .program_all_writeback_pipes_in_tree = dcn30_program_all_writeback_pipes_in_tree,
-       .update_odm = dcn314_update_odm,
-       .dsc_pg_control = dcn314_dsc_pg_control,
-       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
-       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
-       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
-       .dccg_init = dcn20_dccg_init,
-       .set_blend_lut = dcn30_set_blend_lut,
-       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
-       .setup_hpo_hw_control = dcn31_setup_hpo_hw_control,
-       .calculate_dccg_k1_k2_values = dcn314_calculate_dccg_k1_k2_values,
-       .set_pixels_per_cycle = dcn314_set_pixels_per_cycle,
-       .resync_fifo_dccg_dio = dcn314_resync_fifo_dccg_dio,
-};
-
-void dcn314_hw_sequencer_construct(struct dc *dc)
-{
-       dc->hwss = dcn314_funcs;
-       dc->hwseq->funcs = dcn314_private_funcs;
-
-}
diff --git a/drivers/gpu/drm/amd/display/dc/dcn314/dcn314_init.h b/drivers/gpu/drm/amd/display/dc/dcn314/dcn314_init.h
deleted file mode 100644 (file)
index 8f92e66..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-/* SPDX-License-Identifier: MIT */
-/*
- * Copyright 2022 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#ifndef __DC_DCN314_INIT_H__
-#define __DC_DCN314_INIT_H__
-
-struct dc;
-
-void dcn314_hw_sequencer_construct(struct dc *dc);
-
-#endif /* __DC_DCN314_INIT_H__ */
index 905b74b5309201e5bf34c7d280e6afc83413167f..5314770fff1c0608bcf75c056738e6b816929509 100644 (file)
@@ -10,7 +10,7 @@
 #
 # Makefile for dcn32.
 
-DCN32 = dcn32_hubbub.o dcn32_init.o dcn32_dccg.o \
+DCN32 = dcn32_hubbub.o dcn32_dccg.o \
                dcn32_mmhubbub.o dcn32_dpp.o dcn32_hubp.o dcn32_mpc.o \
                dcn32_dio_stream_encoder.o dcn32_dio_link_encoder.o dcn32_resource_helpers.o \
                dcn32_hpo_dp_link_encoder.o
diff --git a/drivers/gpu/drm/amd/display/dc/dcn32/dcn32_init.c b/drivers/gpu/drm/amd/display/dc/dcn32/dcn32_init.c
deleted file mode 100644 (file)
index 427cfc8..0000000
+++ /dev/null
@@ -1,169 +0,0 @@
-/*
- * Copyright 2022 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "dce110/dce110_hwseq.h"
-#include "dcn10/dcn10_hwseq.h"
-#include "dcn20/dcn20_hwseq.h"
-#include "dcn21/dcn21_hwseq.h"
-#include "dcn30/dcn30_hwseq.h"
-#include "dcn31/dcn31_hwseq.h"
-#include "dcn32/dcn32_hwseq.h"
-#include "dcn32_init.h"
-
-static const struct hw_sequencer_funcs dcn32_funcs = {
-       .program_gamut_remap = dcn30_program_gamut_remap,
-       .init_hw = dcn32_init_hw,
-       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
-       .apply_ctx_for_surface = NULL,
-       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
-       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
-       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .update_dchub = dcn10_update_dchub,
-       .update_pending_status = dcn10_update_pending_status,
-       .program_output_csc = dcn20_program_output_csc,
-       .enable_accelerated_mode = dce110_enable_accelerated_mode,
-       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
-       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
-       .update_info_frame = dcn31_update_info_frame,
-       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
-       .enable_stream = dcn20_enable_stream,
-       .disable_stream = dce110_disable_stream,
-       .unblank_stream = dcn32_unblank_stream,
-       .blank_stream = dce110_blank_stream,
-       .enable_audio_stream = dce110_enable_audio_stream,
-       .disable_audio_stream = dce110_disable_audio_stream,
-       .disable_plane = dcn20_disable_plane,
-       .disable_pixel_data = dcn20_disable_pixel_data,
-       .pipe_control_lock = dcn20_pipe_control_lock,
-       .interdependent_update_lock = dcn10_lock_all_pipes,
-       .cursor_lock = dcn10_cursor_lock,
-       .prepare_bandwidth = dcn32_prepare_bandwidth,
-       .optimize_bandwidth = dcn20_optimize_bandwidth,
-       .update_bandwidth = dcn20_update_bandwidth,
-       .set_drr = dcn10_set_drr,
-       .get_position = dcn10_get_position,
-       .set_static_screen_control = dcn30_set_static_screen_control,
-       .setup_stereo = dcn10_setup_stereo,
-       .set_avmute = dcn30_set_avmute,
-       .log_hw_state = dcn10_log_hw_state,
-       .get_hw_state = dcn10_get_hw_state,
-       .clear_status_bits = dcn10_clear_status_bits,
-       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .edp_power_control = dce110_edp_power_control,
-       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
-       .edp_wait_for_T12 = dce110_edp_wait_for_T12,
-       .set_cursor_position = dcn10_set_cursor_position,
-       .set_cursor_attribute = dcn10_set_cursor_attribute,
-       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
-       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
-       .set_clock = dcn10_set_clock,
-       .get_clock = dcn10_get_clock,
-       .program_triplebuffer = dcn20_program_triple_buffer,
-       .enable_writeback = dcn30_enable_writeback,
-       .disable_writeback = dcn30_disable_writeback,
-       .update_writeback = dcn30_update_writeback,
-       .mmhubbub_warmup = dcn30_mmhubbub_warmup,
-       .dmdata_status_done = dcn20_dmdata_status_done,
-       .program_dmdata_engine = dcn30_program_dmdata_engine,
-       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
-       .init_sys_ctx = dcn20_init_sys_ctx,
-       .init_vm_ctx = dcn20_init_vm_ctx,
-       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
-       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
-       .calc_vupdate_position = dcn10_calc_vupdate_position,
-       .apply_idle_power_optimizations = dcn32_apply_idle_power_optimizations,
-       .does_plane_fit_in_mall = NULL,
-       .set_backlight_level = dcn21_set_backlight_level,
-       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
-       .hardware_release = dcn30_hardware_release,
-       .set_pipe = dcn21_set_pipe,
-       .enable_lvds_link_output = dce110_enable_lvds_link_output,
-       .enable_tmds_link_output = dce110_enable_tmds_link_output,
-       .enable_dp_link_output = dce110_enable_dp_link_output,
-       .disable_link_output = dcn32_disable_link_output,
-       .set_disp_pattern_generator = dcn30_set_disp_pattern_generator,
-       .get_dcc_en_bits = dcn10_get_dcc_en_bits,
-       .commit_subvp_config = dcn32_commit_subvp_config,
-       .enable_phantom_streams = dcn32_enable_phantom_streams,
-       .subvp_pipe_control_lock = dcn32_subvp_pipe_control_lock,
-       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
-       .subvp_pipe_control_lock_fast = dcn32_subvp_pipe_control_lock_fast,
-       .update_phantom_vp_position = dcn32_update_phantom_vp_position,
-       .update_dsc_pg = dcn32_update_dsc_pg,
-       .apply_update_flags_for_phantom = dcn32_apply_update_flags_for_phantom,
-       .blank_phantom = dcn32_blank_phantom,
-       .is_pipe_topology_transition_seamless = dcn32_is_pipe_topology_transition_seamless,
-};
-
-static const struct hwseq_private_funcs dcn32_private_funcs = {
-       .init_pipes = dcn10_init_pipes,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
-       .update_mpcc = dcn20_update_mpcc,
-       .set_input_transfer_func = dcn32_set_input_transfer_func,
-       .set_output_transfer_func = dcn32_set_output_transfer_func,
-       .power_down = dce110_power_down,
-       .enable_display_power_gating = dcn10_dummy_display_power_gating,
-       .blank_pixel_data = dcn20_blank_pixel_data,
-       .reset_hw_ctx_wrap = dcn20_reset_hw_ctx_wrap,
-       .enable_stream_timing = dcn20_enable_stream_timing,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .disable_stream_gating = dcn20_disable_stream_gating,
-       .enable_stream_gating = dcn20_enable_stream_gating,
-       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
-       .did_underflow_occur = dcn10_did_underflow_occur,
-       .init_blank = dcn32_init_blank,
-       .disable_vga = dcn20_disable_vga,
-       .bios_golden_init = dcn10_bios_golden_init,
-       .plane_atomic_disable = dcn20_plane_atomic_disable,
-       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
-       .enable_power_gating_plane = dcn32_enable_power_gating_plane,
-       .hubp_pg_control = dcn32_hubp_pg_control,
-       .program_all_writeback_pipes_in_tree = dcn30_program_all_writeback_pipes_in_tree,
-       .update_odm = dcn32_update_odm,
-       .dsc_pg_control = dcn32_dsc_pg_control,
-       .dsc_pg_status = dcn32_dsc_pg_status,
-       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
-       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
-       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
-       .dccg_init = dcn20_dccg_init,
-       .set_mcm_luts = dcn32_set_mcm_luts,
-       .program_mall_pipe_config = dcn32_program_mall_pipe_config,
-       .update_force_pstate = dcn32_update_force_pstate,
-       .update_mall_sel = dcn32_update_mall_sel,
-       .calculate_dccg_k1_k2_values = dcn32_calculate_dccg_k1_k2_values,
-       .set_pixels_per_cycle = dcn32_set_pixels_per_cycle,
-       .resync_fifo_dccg_dio = dcn32_resync_fifo_dccg_dio,
-       .is_dp_dig_pixel_rate_div_policy = dcn32_is_dp_dig_pixel_rate_div_policy,
-};
-
-void dcn32_hw_sequencer_init_functions(struct dc *dc)
-{
-       dc->hwss = dcn32_funcs;
-       dc->hwseq->funcs = dcn32_private_funcs;
-
-}
diff --git a/drivers/gpu/drm/amd/display/dc/dcn32/dcn32_init.h b/drivers/gpu/drm/amd/display/dc/dcn32/dcn32_init.h
deleted file mode 100644 (file)
index 89a591e..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright 2022 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#ifndef __DC_DCN32_INIT_H__
-#define __DC_DCN32_INIT_H__
-
-struct dc;
-
-void dcn32_hw_sequencer_init_functions(struct dc *dc);
-
-#endif /* __DC_DCN32_INIT_H__ */
index fa7ec82ae5f58bc2d5ff2476e3c305467073c131..0e317e0c36a083cb492fcbbf803ce2bba45a29bf 100644 (file)
@@ -10,7 +10,7 @@
 #
 # Makefile for DCN35.
 
-DCN35 = dcn35_init.o dcn35_dio_stream_encoder.o \
+DCN35 = dcn35_dio_stream_encoder.o \
        dcn35_dio_link_encoder.o dcn35_dccg.o \
        dcn35_hubp.o dcn35_hubbub.o \
        dcn35_mmhubbub.o dcn35_opp.o dcn35_dpp.o dcn35_pg_cntl.o dcn35_dwb.o
diff --git a/drivers/gpu/drm/amd/display/dc/dcn35/dcn35_init.c b/drivers/gpu/drm/amd/display/dc/dcn35/dcn35_init.c
deleted file mode 100644 (file)
index a630aa7..0000000
+++ /dev/null
@@ -1,172 +0,0 @@
-/* SPDX-License-Identifier: MIT */
-/*
- * Copyright 2023 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "dce110/dce110_hwseq.h"
-#include "dcn10/dcn10_hwseq.h"
-#include "dcn20/dcn20_hwseq.h"
-#include "dcn21/dcn21_hwseq.h"
-#include "dcn30/dcn30_hwseq.h"
-#include "dcn301/dcn301_hwseq.h"
-#include "dcn31/dcn31_hwseq.h"
-#include "dcn32/dcn32_hwseq.h"
-#include "dcn35/dcn35_hwseq.h"
-
-#include "dcn35_init.h"
-
-static const struct hw_sequencer_funcs dcn35_funcs = {
-       .program_gamut_remap = dcn30_program_gamut_remap,
-       .init_hw = dcn35_init_hw,
-       .power_down_on_boot = dcn35_power_down_on_boot,
-       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
-       .apply_ctx_for_surface = NULL,
-       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
-       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
-       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .update_dchub = dcn10_update_dchub,
-       .update_pending_status = dcn10_update_pending_status,
-       .program_output_csc = dcn20_program_output_csc,
-       .enable_accelerated_mode = dce110_enable_accelerated_mode,
-       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
-       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
-       .update_info_frame = dcn31_update_info_frame,
-       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
-       .enable_stream = dcn20_enable_stream,
-       .disable_stream = dce110_disable_stream,
-       .unblank_stream = dcn32_unblank_stream,
-       .blank_stream = dce110_blank_stream,
-       .enable_audio_stream = dce110_enable_audio_stream,
-       .disable_audio_stream = dce110_disable_audio_stream,
-       .disable_plane = dcn35_disable_plane,
-       .disable_pixel_data = dcn20_disable_pixel_data,
-       .pipe_control_lock = dcn20_pipe_control_lock,
-       .interdependent_update_lock = dcn10_lock_all_pipes,
-       .cursor_lock = dcn10_cursor_lock,
-       .prepare_bandwidth = dcn35_prepare_bandwidth,
-       .optimize_bandwidth = dcn35_optimize_bandwidth,
-       .update_bandwidth = dcn20_update_bandwidth,
-       .set_drr = dcn35_set_drr,
-       .get_position = dcn10_get_position,
-       .set_static_screen_control = dcn30_set_static_screen_control,
-       .setup_stereo = dcn10_setup_stereo,
-       .set_avmute = dcn30_set_avmute,
-       .log_hw_state = dcn10_log_hw_state,
-       .get_hw_state = dcn10_get_hw_state,
-       .clear_status_bits = dcn10_clear_status_bits,
-       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .edp_power_control = dce110_edp_power_control,
-       .edp_wait_for_T12 = dce110_edp_wait_for_T12,
-       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
-       .set_cursor_position = dcn10_set_cursor_position,
-       .set_cursor_attribute = dcn10_set_cursor_attribute,
-       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
-       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
-       .set_clock = dcn10_set_clock,
-       .get_clock = dcn10_get_clock,
-       .program_triplebuffer = dcn20_program_triple_buffer,
-       .enable_writeback = dcn30_enable_writeback,
-       .disable_writeback = dcn30_disable_writeback,
-       .update_writeback = dcn30_update_writeback,
-       .mmhubbub_warmup = dcn30_mmhubbub_warmup,
-       .dmdata_status_done = dcn20_dmdata_status_done,
-       .program_dmdata_engine = dcn30_program_dmdata_engine,
-       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
-       .init_sys_ctx = dcn31_init_sys_ctx,
-       .init_vm_ctx = dcn20_init_vm_ctx,
-       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
-       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
-       .calc_vupdate_position = dcn10_calc_vupdate_position,
-       .power_down = dce110_power_down,
-       .set_backlight_level = dcn21_set_backlight_level,
-       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
-       .set_pipe = dcn21_set_pipe,
-       .enable_lvds_link_output = dce110_enable_lvds_link_output,
-       .enable_tmds_link_output = dce110_enable_tmds_link_output,
-       .enable_dp_link_output = dce110_enable_dp_link_output,
-       .disable_link_output = dcn32_disable_link_output,
-       .z10_restore = dcn35_z10_restore,
-       .z10_save_init = dcn31_z10_save_init,
-       .set_disp_pattern_generator = dcn30_set_disp_pattern_generator,
-       .optimize_pwr_state = dcn21_optimize_pwr_state,
-       .exit_optimized_pwr_state = dcn21_exit_optimized_pwr_state,
-       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
-       .apply_idle_power_optimizations = dcn35_apply_idle_power_optimizations,
-       .update_dsc_pg = dcn32_update_dsc_pg,
-       .calc_blocks_to_gate = dcn35_calc_blocks_to_gate,
-       .calc_blocks_to_ungate = dcn35_calc_blocks_to_ungate,
-       .hw_block_power_up = dcn35_hw_block_power_up,
-       .hw_block_power_down = dcn35_hw_block_power_down,
-       .root_clock_control = dcn35_root_clock_control,
-       .set_idle_state = dcn35_set_idle_state,
-       .get_idle_state = dcn35_get_idle_state
-};
-
-static const struct hwseq_private_funcs dcn35_private_funcs = {
-       .init_pipes = dcn35_init_pipes,
-       .update_plane_addr = dcn20_update_plane_addr,
-       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
-       .update_mpcc = dcn20_update_mpcc,
-       .set_input_transfer_func = dcn32_set_input_transfer_func,
-       .set_output_transfer_func = dcn32_set_output_transfer_func,
-       .power_down = dce110_power_down,
-       .enable_display_power_gating = dcn10_dummy_display_power_gating,
-       .blank_pixel_data = dcn20_blank_pixel_data,
-       .reset_hw_ctx_wrap = dcn31_reset_hw_ctx_wrap,
-       .enable_stream_timing = dcn20_enable_stream_timing,
-       .edp_backlight_control = dce110_edp_backlight_control,
-       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
-       .did_underflow_occur = dcn10_did_underflow_occur,
-       .init_blank = dcn20_init_blank,
-       .disable_vga = NULL,
-       .bios_golden_init = dcn10_bios_golden_init,
-       .plane_atomic_disable = dcn35_plane_atomic_disable,
-       //.plane_atomic_disable = dcn20_plane_atomic_disable,/*todo*/
-       //.hubp_pg_control = dcn35_hubp_pg_control,
-       .enable_power_gating_plane = dcn35_enable_power_gating_plane,
-       .dpp_root_clock_control = dcn35_dpp_root_clock_control,
-       .program_all_writeback_pipes_in_tree = dcn30_program_all_writeback_pipes_in_tree,
-       .update_odm = dcn35_update_odm,
-       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
-       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
-       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
-       .dccg_init = dcn20_dccg_init,
-       .set_mcm_luts = dcn32_set_mcm_luts,
-       .setup_hpo_hw_control = dcn35_setup_hpo_hw_control,
-       .calculate_dccg_k1_k2_values = dcn32_calculate_dccg_k1_k2_values,
-       .set_pixels_per_cycle = dcn32_set_pixels_per_cycle,
-       .is_dp_dig_pixel_rate_div_policy = dcn32_is_dp_dig_pixel_rate_div_policy,
-       .dsc_pg_control = dcn35_dsc_pg_control,
-       .dsc_pg_status = dcn32_dsc_pg_status,
-       .enable_plane = dcn35_enable_plane,
-};
-
-void dcn35_hw_sequencer_construct(struct dc *dc)
-{
-       dc->hwss = dcn35_funcs;
-       dc->hwseq->funcs = dcn35_private_funcs;
-
-}
diff --git a/drivers/gpu/drm/amd/display/dc/dcn35/dcn35_init.h b/drivers/gpu/drm/amd/display/dc/dcn35/dcn35_init.h
deleted file mode 100644 (file)
index b670150..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-/* SPDX-License-Identifier: MIT */
-/*
- * Copyright 2023 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_DCN35_INIT_H__
-#define __DC_DCN35_INIT_H__
-
-struct dc;
-
-void dcn35_hw_sequencer_construct(struct dc *dc);
-
-#endif /* __DC_DCN35_INIT_H__ */
index bccd46bd18158cfd1f9750cf02f899dbe4bcae3f..254136f8e3f90784ae33263ff998e70f9fdcfbe8 100644 (file)
@@ -78,7 +78,7 @@ ifdef CONFIG_DRM_AMD_DC_FP
 # DCN
 ###############################################################################
 
-HWSS_DCN10 = dcn10_hwseq.o
+HWSS_DCN10 = dcn10_hwseq.o dcn10_init.o
 
 AMD_DAL_HWSS_DCN10 = $(addprefix $(AMDDALPATH)/dc/hwss/dcn10/,$(HWSS_DCN10))
 
@@ -86,7 +86,7 @@ AMD_DISPLAY_FILES += $(AMD_DAL_HWSS_DCN10)
 
 ###############################################################################
 
-HWSS_DCN20 = dcn20_hwseq.o
+HWSS_DCN20 = dcn20_hwseq.o dcn20_init.o
 
 AMD_DAL_HWSS_DCN20 = $(addprefix $(AMDDALPATH)/dc/hwss/dcn20/,$(HWSS_DCN20))
 
@@ -94,7 +94,7 @@ AMD_DISPLAY_FILES += $(AMD_DAL_HWSS_DCN20)
 
 ###############################################################################
 
-HWSS_DCN201 = dcn201_hwseq.o
+HWSS_DCN201 = dcn201_hwseq.o dcn201_init.o
 
 AMD_DAL_HWSS_DCN201 = $(addprefix $(AMDDALPATH)/dc/hwss/dcn201/,$(HWSS_DCN201))
 
@@ -102,7 +102,7 @@ AMD_DISPLAY_FILES += $(AMD_DAL_HWSS_DCN201)
 
 ###############################################################################
 
-HWSS_DCN21 = dcn21_hwseq.o
+HWSS_DCN21 = dcn21_hwseq.o dcn21_init.o
 
 AMD_DAL_HWSS_DCN21 = $(addprefix $(AMDDALPATH)/dc/hwss/dcn21/,$(HWSS_DCN21))
 
@@ -114,7 +114,7 @@ AMD_DISPLAY_FILES += $(AMD_DAL_HWSS_DCN21)
 
 ###############################################################################
 
-HWSS_DCN30 = dcn30_hwseq.o
+HWSS_DCN30 = dcn30_hwseq.o dcn30_init.o
 
 AMD_DAL_HWSS_DCN30 = $(addprefix $(AMDDALPATH)/dc/hwss/dcn30/,$(HWSS_DCN30))
 
@@ -122,7 +122,7 @@ AMD_DISPLAY_FILES += $(AMD_DAL_HWSS_DCN30)
 
 ###############################################################################
 
-HWSS_DCN301 = dcn301_hwseq.o
+HWSS_DCN301 = dcn301_hwseq.o dcn301_init.o
 
 AMD_DAL_HWSS_DCN301 = $(addprefix $(AMDDALPATH)/dc/hwss/dcn301/,$(HWSS_DCN301))
 
@@ -130,15 +130,17 @@ AMD_DISPLAY_FILES += $(AMD_DAL_HWSS_DCN301)
 
 ###############################################################################
 
-HWSS_DCN302 = dcn302_hwseq.o
+HWSS_DCN302 = dcn302_hwseq.o dcn302_init.o
 
 AMD_DAL_HWSS_DCN302 = $(addprefix $(AMDDALPATH)/dc/hwss/dcn302/,$(HWSS_DCN302))
 
 AMD_DISPLAY_FILES += $(AMD_DAL_HWSS_DCN302)
 
+
+
 ###############################################################################
 
-HWSS_DCN303 = dcn303_hwseq.o
+HWSS_DCN303 = dcn303_hwseq.o dcn303_init.o
 
 AMD_DAL_HWSS_DCN303 = $(addprefix $(AMDDALPATH)/dc/hwss/dcn303/,$(HWSS_DCN303))
 
@@ -146,7 +148,7 @@ AMD_DISPLAY_FILES += $(AMD_DAL_HWSS_DCN303)
 
 ###############################################################################
 
-HWSS_DCN31 = dcn31_hwseq.o
+HWSS_DCN31 = dcn31_hwseq.o dcn31_init.o
 
 AMD_DAL_HWSS_DCN31 = $(addprefix $(AMDDALPATH)/dc/hwss/dcn31/,$(HWSS_DCN31))
 
@@ -154,7 +156,7 @@ AMD_DISPLAY_FILES += $(AMD_DAL_HWSS_DCN31)
 
 ###############################################################################
 
-HWSS_DCN314 = dcn314_hwseq.o
+HWSS_DCN314 = dcn314_hwseq.o dcn314_init.o
 
 AMD_DAL_HWSS_DCN314 = $(addprefix $(AMDDALPATH)/dc/hwss/dcn314/,$(HWSS_DCN314))
 
@@ -162,7 +164,7 @@ AMD_DISPLAY_FILES += $(AMD_DAL_HWSS_DCN314)
 
 ###############################################################################
 
-HWSS_DCN32 = dcn32_hwseq.o
+HWSS_DCN32 = dcn32_hwseq.o dcn32_init.o
 
 AMD_DAL_HWSS_DCN32 = $(addprefix $(AMDDALPATH)/dc/hwss/dcn32/,$(HWSS_DCN32))
 
@@ -170,7 +172,7 @@ AMD_DISPLAY_FILES += $(AMD_DAL_HWSS_DCN32)
 
 ###############################################################################
 
-HWSS_DCN35 = dcn35_hwseq.o
+HWSS_DCN35 = dcn35_hwseq.o dcn35_init.o
 
 AMD_DAL_HWSS_DCN35 = $(addprefix $(AMDDALPATH)/dc/hwss/dcn35/,$(HWSS_DCN35))
 
@@ -180,4 +182,4 @@ AMD_DISPLAY_FILES += $(AMD_DAL_HWSS_DCN35)
 
 ###############################################################################
 
-endif
\ No newline at end of file
+endif
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn10/dcn10_init.c b/drivers/gpu/drm/amd/display/dc/hwss/dcn10/dcn10_init.c
new file mode 100644 (file)
index 0000000..a5bdac7
--- /dev/null
@@ -0,0 +1,128 @@
+/*
+ * Copyright 2016-2020 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "hw_sequencer_private.h"
+#include "dce110/dce110_hwseq.h"
+#include "dcn10/dcn10_hwseq.h"
+#include "dcn20/dcn20_hwseq.h"
+
+static const struct hw_sequencer_funcs dcn10_funcs = {
+       .program_gamut_remap = dcn10_program_gamut_remap,
+       .init_hw = dcn10_init_hw,
+       .power_down_on_boot = dcn10_power_down_on_boot,
+       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
+       .apply_ctx_for_surface = NULL,
+       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
+       .post_unlock_program_front_end = dcn10_post_unlock_program_front_end,
+       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
+       .update_plane_addr = dcn10_update_plane_addr,
+       .update_dchub = dcn10_update_dchub,
+       .update_pending_status = dcn10_update_pending_status,
+       .program_output_csc = dcn10_program_output_csc,
+       .enable_accelerated_mode = dce110_enable_accelerated_mode,
+       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
+       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
+       .update_info_frame = dce110_update_info_frame,
+       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
+       .enable_stream = dce110_enable_stream,
+       .disable_stream = dce110_disable_stream,
+       .unblank_stream = dcn10_unblank_stream,
+       .blank_stream = dce110_blank_stream,
+       .enable_audio_stream = dce110_enable_audio_stream,
+       .disable_audio_stream = dce110_disable_audio_stream,
+       .disable_plane = dcn10_disable_plane,
+       .pipe_control_lock = dcn10_pipe_control_lock,
+       .cursor_lock = dcn10_cursor_lock,
+       .interdependent_update_lock = dcn10_lock_all_pipes,
+       .prepare_bandwidth = dcn10_prepare_bandwidth,
+       .optimize_bandwidth = dcn10_optimize_bandwidth,
+       .set_drr = dcn10_set_drr,
+       .get_position = dcn10_get_position,
+       .set_static_screen_control = dcn10_set_static_screen_control,
+       .setup_stereo = dcn10_setup_stereo,
+       .set_avmute = dce110_set_avmute,
+       .log_hw_state = dcn10_log_hw_state,
+       .get_hw_state = dcn10_get_hw_state,
+       .clear_status_bits = dcn10_clear_status_bits,
+       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .edp_power_control = dce110_edp_power_control,
+       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
+       .set_cursor_position = dcn10_set_cursor_position,
+       .set_cursor_attribute = dcn10_set_cursor_attribute,
+       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
+       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
+       .set_clock = dcn10_set_clock,
+       .get_clock = dcn10_get_clock,
+       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
+       .calc_vupdate_position = dcn10_calc_vupdate_position,
+       .power_down = dce110_power_down,
+       .set_backlight_level = dce110_set_backlight_level,
+       .set_abm_immediate_disable = dce110_set_abm_immediate_disable,
+       .set_pipe = dce110_set_pipe,
+       .enable_lvds_link_output = dce110_enable_lvds_link_output,
+       .enable_tmds_link_output = dce110_enable_tmds_link_output,
+       .enable_dp_link_output = dce110_enable_dp_link_output,
+       .disable_link_output = dce110_disable_link_output,
+       .get_dcc_en_bits = dcn10_get_dcc_en_bits,
+       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
+};
+
+static const struct hwseq_private_funcs dcn10_private_funcs = {
+       .init_pipes = dcn10_init_pipes,
+       .update_plane_addr = dcn10_update_plane_addr,
+       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
+       .program_pipe = dcn10_program_pipe,
+       .update_mpcc = dcn10_update_mpcc,
+       .set_input_transfer_func = dcn10_set_input_transfer_func,
+       .set_output_transfer_func = dcn10_set_output_transfer_func,
+       .power_down = dce110_power_down,
+       .enable_display_power_gating = dcn10_dummy_display_power_gating,
+       .blank_pixel_data = dcn10_blank_pixel_data,
+       .reset_hw_ctx_wrap = dcn10_reset_hw_ctx_wrap,
+       .enable_stream_timing = dcn10_enable_stream_timing,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .disable_stream_gating = NULL,
+       .enable_stream_gating = NULL,
+       .setup_vupdate_interrupt = dcn10_setup_vupdate_interrupt,
+       .did_underflow_occur = dcn10_did_underflow_occur,
+       .init_blank = NULL,
+       .disable_vga = dcn10_disable_vga,
+       .bios_golden_init = dcn10_bios_golden_init,
+       .plane_atomic_disable = dcn10_plane_atomic_disable,
+       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
+       .enable_power_gating_plane = dcn10_enable_power_gating_plane,
+       .dpp_pg_control = dcn10_dpp_pg_control,
+       .hubp_pg_control = dcn10_hubp_pg_control,
+       .dsc_pg_control = NULL,
+       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
+       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
+};
+
+void dcn10_hw_sequencer_construct(struct dc *dc)
+{
+       dc->hwss = dcn10_funcs;
+       dc->hwseq->funcs = dcn10_private_funcs;
+}
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn10/dcn10_init.h b/drivers/gpu/drm/amd/display/dc/hwss/dcn10/dcn10_init.h
new file mode 100644 (file)
index 0000000..8c6fd7b
--- /dev/null
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2016 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_DCN10_INIT_H__
+#define __DC_DCN10_INIT_H__
+
+struct dc;
+
+void dcn10_hw_sequencer_construct(struct dc *dc);
+
+#endif /* __DC_DCN10_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn20/dcn20_init.c b/drivers/gpu/drm/amd/display/dc/hwss/dcn20/dcn20_init.c
new file mode 100644 (file)
index 0000000..884e3e3
--- /dev/null
@@ -0,0 +1,145 @@
+/*
+ * Copyright 2016 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "dce110/dce110_hwseq.h"
+#include "dcn10/dcn10_hwseq.h"
+#include "dcn20/dcn20_hwseq.h"
+
+#include "dcn20_init.h"
+
+static const struct hw_sequencer_funcs dcn20_funcs = {
+       .program_gamut_remap = dcn10_program_gamut_remap,
+       .init_hw = dcn10_init_hw,
+       .power_down_on_boot =  dcn10_power_down_on_boot,
+       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
+       .apply_ctx_for_surface = NULL,
+       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
+       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
+       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .update_dchub = dcn10_update_dchub,
+       .update_pending_status = dcn10_update_pending_status,
+       .program_output_csc = dcn20_program_output_csc,
+       .enable_accelerated_mode = dce110_enable_accelerated_mode,
+       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
+       .enable_vblanks_synchronization = dcn10_enable_vblanks_synchronization,
+       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
+       .update_info_frame = dce110_update_info_frame,
+       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
+       .enable_stream = dcn20_enable_stream,
+       .disable_stream = dce110_disable_stream,
+       .unblank_stream = dcn20_unblank_stream,
+       .blank_stream = dce110_blank_stream,
+       .enable_audio_stream = dce110_enable_audio_stream,
+       .disable_audio_stream = dce110_disable_audio_stream,
+       .disable_plane = dcn20_disable_plane,
+       .pipe_control_lock = dcn20_pipe_control_lock,
+       .interdependent_update_lock = dcn10_lock_all_pipes,
+       .cursor_lock = dcn10_cursor_lock,
+       .prepare_bandwidth = dcn20_prepare_bandwidth,
+       .optimize_bandwidth = dcn20_optimize_bandwidth,
+       .update_bandwidth = dcn20_update_bandwidth,
+       .set_drr = dcn10_set_drr,
+       .get_position = dcn10_get_position,
+       .set_static_screen_control = dcn10_set_static_screen_control,
+       .setup_stereo = dcn10_setup_stereo,
+       .set_avmute = dce110_set_avmute,
+       .log_hw_state = dcn10_log_hw_state,
+       .get_hw_state = dcn10_get_hw_state,
+       .clear_status_bits = dcn10_clear_status_bits,
+       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .edp_power_control = dce110_edp_power_control,
+       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
+       .set_cursor_position = dcn10_set_cursor_position,
+       .set_cursor_attribute = dcn10_set_cursor_attribute,
+       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
+       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
+       .set_clock = dcn10_set_clock,
+       .get_clock = dcn10_get_clock,
+       .program_triplebuffer = dcn20_program_triple_buffer,
+       .enable_writeback = dcn20_enable_writeback,
+       .disable_writeback = dcn20_disable_writeback,
+       .dmdata_status_done = dcn20_dmdata_status_done,
+       .program_dmdata_engine = dcn20_program_dmdata_engine,
+       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
+       .init_sys_ctx = dcn20_init_sys_ctx,
+       .init_vm_ctx = dcn20_init_vm_ctx,
+       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
+       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
+       .calc_vupdate_position = dcn10_calc_vupdate_position,
+       .set_backlight_level = dce110_set_backlight_level,
+       .set_abm_immediate_disable = dce110_set_abm_immediate_disable,
+       .set_pipe = dce110_set_pipe,
+       .enable_lvds_link_output = dce110_enable_lvds_link_output,
+       .enable_tmds_link_output = dce110_enable_tmds_link_output,
+       .enable_dp_link_output = dce110_enable_dp_link_output,
+       .disable_link_output = dce110_disable_link_output,
+       .set_disp_pattern_generator = dcn20_set_disp_pattern_generator,
+       .get_dcc_en_bits = dcn10_get_dcc_en_bits,
+       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
+};
+
+static const struct hwseq_private_funcs dcn20_private_funcs = {
+       .init_pipes = dcn10_init_pipes,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
+       .update_mpcc = dcn20_update_mpcc,
+       .set_input_transfer_func = dcn20_set_input_transfer_func,
+       .set_output_transfer_func = dcn20_set_output_transfer_func,
+       .power_down = dce110_power_down,
+       .enable_display_power_gating = dcn10_dummy_display_power_gating,
+       .blank_pixel_data = dcn20_blank_pixel_data,
+       .reset_hw_ctx_wrap = dcn20_reset_hw_ctx_wrap,
+       .enable_stream_timing = dcn20_enable_stream_timing,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .disable_stream_gating = dcn20_disable_stream_gating,
+       .enable_stream_gating = dcn20_enable_stream_gating,
+       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
+       .did_underflow_occur = dcn10_did_underflow_occur,
+       .init_blank = dcn20_init_blank,
+       .disable_vga = dcn20_disable_vga,
+       .bios_golden_init = dcn10_bios_golden_init,
+       .plane_atomic_disable = dcn20_plane_atomic_disable,
+       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
+       .enable_power_gating_plane = dcn20_enable_power_gating_plane,
+       .dpp_pg_control = dcn20_dpp_pg_control,
+       .hubp_pg_control = dcn20_hubp_pg_control,
+       .update_odm = dcn20_update_odm,
+       .dsc_pg_control = dcn20_dsc_pg_control,
+       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
+       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
+       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
+       .dccg_init = dcn20_dccg_init,
+       .set_blend_lut = dcn20_set_blend_lut,
+       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
+};
+
+void dcn20_hw_sequencer_construct(struct dc *dc)
+{
+       dc->hwss = dcn20_funcs;
+       dc->hwseq->funcs = dcn20_private_funcs;
+
+}
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn20/dcn20_init.h b/drivers/gpu/drm/amd/display/dc/hwss/dcn20/dcn20_init.h
new file mode 100644 (file)
index 0000000..1227779
--- /dev/null
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2016 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_DCN20_INIT_H__
+#define __DC_DCN20_INIT_H__
+
+struct dc;
+
+void dcn20_hw_sequencer_construct(struct dc *dc);
+
+#endif /* __DC_DCN20_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn201/dcn201_init.c b/drivers/gpu/drm/amd/display/dc/hwss/dcn201/dcn201_init.c
new file mode 100644 (file)
index 0000000..a13bf6c
--- /dev/null
@@ -0,0 +1,136 @@
+/*
+ * Copyright 2016 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "dce110/dce110_hwseq.h"
+#include "dcn10/dcn10_hwseq.h"
+#include "dcn20/dcn20_hwseq.h"
+#include "dcn201/dcn201_hwseq.h"
+#include "dcn201_init.h"
+
+static const struct hw_sequencer_funcs dcn201_funcs = {
+       .program_gamut_remap = dcn10_program_gamut_remap,
+       .init_hw = dcn201_init_hw,
+       .power_down_on_boot = NULL,
+       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
+       .apply_ctx_for_surface = NULL,
+       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
+       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
+       .post_unlock_program_front_end = dcn10_post_unlock_program_front_end,
+       .update_plane_addr = dcn201_update_plane_addr,
+       .update_dchub = dcn10_update_dchub,
+       .update_pending_status = dcn10_update_pending_status,
+       .program_output_csc = dcn20_program_output_csc,
+       .enable_accelerated_mode = dce110_enable_accelerated_mode,
+       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
+       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
+       .update_info_frame = dce110_update_info_frame,
+       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
+       .enable_stream = dce110_enable_stream,
+       .disable_stream = dce110_disable_stream,
+       .unblank_stream = dcn201_unblank_stream,
+       .blank_stream = dce110_blank_stream,
+       .enable_audio_stream = dce110_enable_audio_stream,
+       .disable_audio_stream = dce110_disable_audio_stream,
+       .disable_plane = dcn10_disable_plane,
+       .pipe_control_lock = dcn201_pipe_control_lock,
+       .interdependent_update_lock = dcn10_lock_all_pipes,
+       .cursor_lock = dcn10_cursor_lock,
+       .prepare_bandwidth = dcn20_prepare_bandwidth,
+       .optimize_bandwidth = dcn20_optimize_bandwidth,
+       .update_bandwidth = dcn20_update_bandwidth,
+       .set_drr = dcn10_set_drr,
+       .get_position = dcn10_get_position,
+       .set_static_screen_control = dcn10_set_static_screen_control,
+       .setup_stereo = dcn10_setup_stereo,
+       .set_avmute = dce110_set_avmute,
+       .log_hw_state = dcn10_log_hw_state,
+       .get_hw_state = dcn10_get_hw_state,
+       .clear_status_bits = dcn10_clear_status_bits,
+       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .edp_power_control = dce110_edp_power_control,
+       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
+       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
+       .set_clock = dcn10_set_clock,
+       .get_clock = dcn10_get_clock,
+       .program_triplebuffer = dcn20_program_triple_buffer,
+       .dmdata_status_done = dcn20_dmdata_status_done,
+       .set_dmdata_attributes = dcn201_set_dmdata_attributes,
+       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
+       .calc_vupdate_position = dcn10_calc_vupdate_position,
+       .set_cursor_position = dcn10_set_cursor_position,
+       .set_cursor_attribute = dcn201_set_cursor_attribute,
+       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
+       .set_backlight_level = dce110_set_backlight_level,
+       .set_abm_immediate_disable = dce110_set_abm_immediate_disable,
+       .set_pipe = dce110_set_pipe,
+       .enable_lvds_link_output = dce110_enable_lvds_link_output,
+       .enable_tmds_link_output = dce110_enable_tmds_link_output,
+       .enable_dp_link_output = dce110_enable_dp_link_output,
+       .disable_link_output = dce110_disable_link_output,
+       .set_disp_pattern_generator = dcn20_set_disp_pattern_generator,
+       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
+};
+
+static const struct hwseq_private_funcs dcn201_private_funcs = {
+       .init_pipes = NULL,
+       .update_plane_addr = dcn201_update_plane_addr,
+       .plane_atomic_disconnect = dcn201_plane_atomic_disconnect,
+       .program_pipe = dcn10_program_pipe,
+       .update_mpcc = dcn201_update_mpcc,
+       .set_input_transfer_func = dcn20_set_input_transfer_func,
+       .set_output_transfer_func = dcn20_set_output_transfer_func,
+       .power_down = dce110_power_down,
+       .enable_display_power_gating = dcn10_dummy_display_power_gating,
+       .blank_pixel_data = dcn20_blank_pixel_data,
+       .reset_hw_ctx_wrap = dcn10_reset_hw_ctx_wrap,
+       .enable_stream_timing = dcn20_enable_stream_timing,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .disable_stream_gating = NULL,
+       .enable_stream_gating = NULL,
+       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
+       .did_underflow_occur = dcn10_did_underflow_occur,
+       .init_blank = dcn201_init_blank,
+       .disable_vga = dcn10_disable_vga,
+       .bios_golden_init = dcn10_bios_golden_init,
+       .plane_atomic_disable = dcn10_plane_atomic_disable,
+       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
+       .enable_power_gating_plane = dcn10_enable_power_gating_plane,
+       .dpp_pg_control = dcn10_dpp_pg_control,
+       .hubp_pg_control = dcn10_hubp_pg_control,
+       .dsc_pg_control = NULL,
+       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
+       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
+       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
+       .dccg_init = dcn20_dccg_init,
+       .set_blend_lut = dcn20_set_blend_lut,
+       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
+};
+
+void dcn201_hw_sequencer_construct(struct dc *dc)
+{
+       dc->hwss = dcn201_funcs;
+       dc->hwseq->funcs = dcn201_private_funcs;
+}
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn201/dcn201_init.h b/drivers/gpu/drm/amd/display/dc/hwss/dcn201/dcn201_init.h
new file mode 100644 (file)
index 0000000..1168887
--- /dev/null
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2016 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_DCN201_INIT_H__
+#define __DC_DCN201_INIT_H__
+
+struct dc;
+
+void dcn201_hw_sequencer_construct(struct dc *dc);
+
+#endif /* __DC_DCN201_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn21/dcn21_init.c b/drivers/gpu/drm/amd/display/dc/hwss/dcn21/dcn21_init.c
new file mode 100644 (file)
index 0000000..18249c6
--- /dev/null
@@ -0,0 +1,151 @@
+/*
+ * Copyright 2016-2020 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "dce110/dce110_hwseq.h"
+#include "dcn10/dcn10_hwseq.h"
+#include "dcn20/dcn20_hwseq.h"
+#include "dcn21/dcn21_hwseq.h"
+
+#include "dcn21_init.h"
+
+static const struct hw_sequencer_funcs dcn21_funcs = {
+       .program_gamut_remap = dcn10_program_gamut_remap,
+       .init_hw = dcn10_init_hw,
+       .power_down_on_boot = dcn10_power_down_on_boot,
+       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
+       .apply_ctx_for_surface = NULL,
+       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
+       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
+       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .update_dchub = dcn10_update_dchub,
+       .update_pending_status = dcn10_update_pending_status,
+       .program_output_csc = dcn20_program_output_csc,
+       .enable_accelerated_mode = dce110_enable_accelerated_mode,
+       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
+       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
+       .update_info_frame = dce110_update_info_frame,
+       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
+       .enable_stream = dcn20_enable_stream,
+       .disable_stream = dce110_disable_stream,
+       .unblank_stream = dcn20_unblank_stream,
+       .blank_stream = dce110_blank_stream,
+       .enable_audio_stream = dce110_enable_audio_stream,
+       .disable_audio_stream = dce110_disable_audio_stream,
+       .disable_plane = dcn20_disable_plane,
+       .pipe_control_lock = dcn20_pipe_control_lock,
+       .interdependent_update_lock = dcn10_lock_all_pipes,
+       .cursor_lock = dcn10_cursor_lock,
+       .prepare_bandwidth = dcn20_prepare_bandwidth,
+       .optimize_bandwidth = dcn20_optimize_bandwidth,
+       .update_bandwidth = dcn20_update_bandwidth,
+       .set_drr = dcn10_set_drr,
+       .get_position = dcn10_get_position,
+       .set_static_screen_control = dcn10_set_static_screen_control,
+       .setup_stereo = dcn10_setup_stereo,
+       .set_avmute = dce110_set_avmute,
+       .log_hw_state = dcn10_log_hw_state,
+       .get_hw_state = dcn10_get_hw_state,
+       .clear_status_bits = dcn10_clear_status_bits,
+       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .edp_power_control = dce110_edp_power_control,
+       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
+       .set_cursor_position = dcn10_set_cursor_position,
+       .set_cursor_attribute = dcn10_set_cursor_attribute,
+       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
+       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
+       .set_clock = dcn10_set_clock,
+       .get_clock = dcn10_get_clock,
+       .program_triplebuffer = dcn20_program_triple_buffer,
+       .enable_writeback = dcn20_enable_writeback,
+       .disable_writeback = dcn20_disable_writeback,
+       .dmdata_status_done = dcn20_dmdata_status_done,
+       .program_dmdata_engine = dcn20_program_dmdata_engine,
+       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
+       .init_sys_ctx = dcn21_init_sys_ctx,
+       .init_vm_ctx = dcn20_init_vm_ctx,
+       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
+       .optimize_pwr_state = dcn21_optimize_pwr_state,
+       .exit_optimized_pwr_state = dcn21_exit_optimized_pwr_state,
+       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
+       .calc_vupdate_position = dcn10_calc_vupdate_position,
+       .power_down = dce110_power_down,
+       .set_backlight_level = dcn21_set_backlight_level,
+       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
+       .set_pipe = dcn21_set_pipe,
+       .enable_lvds_link_output = dce110_enable_lvds_link_output,
+       .enable_tmds_link_output = dce110_enable_tmds_link_output,
+       .enable_dp_link_output = dce110_enable_dp_link_output,
+       .disable_link_output = dce110_disable_link_output,
+       .is_abm_supported = dcn21_is_abm_supported,
+       .set_disp_pattern_generator = dcn20_set_disp_pattern_generator,
+       .get_dcc_en_bits = dcn10_get_dcc_en_bits,
+       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
+};
+
+static const struct hwseq_private_funcs dcn21_private_funcs = {
+       .init_pipes = dcn10_init_pipes,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
+       .update_mpcc = dcn20_update_mpcc,
+       .set_input_transfer_func = dcn20_set_input_transfer_func,
+       .set_output_transfer_func = dcn20_set_output_transfer_func,
+       .power_down = dce110_power_down,
+       .enable_display_power_gating = dcn10_dummy_display_power_gating,
+       .blank_pixel_data = dcn20_blank_pixel_data,
+       .reset_hw_ctx_wrap = dcn20_reset_hw_ctx_wrap,
+       .enable_stream_timing = dcn20_enable_stream_timing,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .disable_stream_gating = dcn20_disable_stream_gating,
+       .enable_stream_gating = dcn20_enable_stream_gating,
+       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
+       .did_underflow_occur = dcn10_did_underflow_occur,
+       .init_blank = dcn20_init_blank,
+       .disable_vga = dcn20_disable_vga,
+       .bios_golden_init = dcn10_bios_golden_init,
+       .plane_atomic_disable = dcn20_plane_atomic_disable,
+       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
+       .enable_power_gating_plane = dcn20_enable_power_gating_plane,
+       .dpp_pg_control = dcn20_dpp_pg_control,
+       .hubp_pg_control = dcn20_hubp_pg_control,
+       .update_odm = dcn20_update_odm,
+       .dsc_pg_control = dcn20_dsc_pg_control,
+       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
+       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
+       .s0i3_golden_init_wa = dcn21_s0i3_golden_init_wa,
+       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
+       .dccg_init = dcn20_dccg_init,
+       .set_blend_lut = dcn20_set_blend_lut,
+       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
+       .PLAT_58856_wa = dcn21_PLAT_58856_wa,
+};
+
+void dcn21_hw_sequencer_construct(struct dc *dc)
+{
+       dc->hwss = dcn21_funcs;
+       dc->hwseq->funcs = dcn21_private_funcs;
+
+}
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn21/dcn21_init.h b/drivers/gpu/drm/amd/display/dc/hwss/dcn21/dcn21_init.h
new file mode 100644 (file)
index 0000000..3ed2429
--- /dev/null
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2016 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_DCN21_INIT_H__
+#define __DC_DCN21_INIT_H__
+
+struct dc;
+
+void dcn21_hw_sequencer_construct(struct dc *dc);
+
+#endif /* __DC_DCN20_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn30/dcn30_init.c b/drivers/gpu/drm/amd/display/dc/hwss/dcn30/dcn30_init.c
new file mode 100644 (file)
index 0000000..9894cae
--- /dev/null
@@ -0,0 +1,154 @@
+/*
+ * Copyright 2016-2020 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "dce110/dce110_hwseq.h"
+#include "dcn10/dcn10_hwseq.h"
+#include "dcn20/dcn20_hwseq.h"
+#include "dcn21/dcn21_hwseq.h"
+#include "dcn30/dcn30_hwseq.h"
+
+#include "dcn30_init.h"
+
+static const struct hw_sequencer_funcs dcn30_funcs = {
+       .program_gamut_remap = dcn30_program_gamut_remap,
+       .init_hw = dcn30_init_hw,
+       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
+       .apply_ctx_for_surface = NULL,
+       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
+       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
+       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .update_dchub = dcn10_update_dchub,
+       .update_pending_status = dcn10_update_pending_status,
+       .program_output_csc = dcn20_program_output_csc,
+       .enable_accelerated_mode = dce110_enable_accelerated_mode,
+       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
+       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
+       .update_info_frame = dcn30_update_info_frame,
+       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
+       .enable_stream = dcn20_enable_stream,
+       .disable_stream = dce110_disable_stream,
+       .unblank_stream = dcn20_unblank_stream,
+       .blank_stream = dce110_blank_stream,
+       .enable_audio_stream = dce110_enable_audio_stream,
+       .disable_audio_stream = dce110_disable_audio_stream,
+       .disable_plane = dcn20_disable_plane,
+       .disable_pixel_data = dcn20_disable_pixel_data,
+       .pipe_control_lock = dcn20_pipe_control_lock,
+       .interdependent_update_lock = dcn10_lock_all_pipes,
+       .cursor_lock = dcn10_cursor_lock,
+       .prepare_bandwidth = dcn30_prepare_bandwidth,
+       .optimize_bandwidth = dcn20_optimize_bandwidth,
+       .update_bandwidth = dcn20_update_bandwidth,
+       .set_drr = dcn10_set_drr,
+       .get_position = dcn10_get_position,
+       .set_static_screen_control = dcn30_set_static_screen_control,
+       .setup_stereo = dcn10_setup_stereo,
+       .set_avmute = dcn30_set_avmute,
+       .log_hw_state = dcn10_log_hw_state,
+       .get_hw_state = dcn10_get_hw_state,
+       .clear_status_bits = dcn10_clear_status_bits,
+       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .edp_power_control = dce110_edp_power_control,
+       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
+       .edp_wait_for_T12 = dce110_edp_wait_for_T12,
+       .set_cursor_position = dcn10_set_cursor_position,
+       .set_cursor_attribute = dcn10_set_cursor_attribute,
+       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
+       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
+       .set_clock = dcn10_set_clock,
+       .get_clock = dcn10_get_clock,
+       .program_triplebuffer = dcn20_program_triple_buffer,
+       .enable_writeback = dcn30_enable_writeback,
+       .disable_writeback = dcn30_disable_writeback,
+       .update_writeback = dcn30_update_writeback,
+       .mmhubbub_warmup = dcn30_mmhubbub_warmup,
+       .dmdata_status_done = dcn20_dmdata_status_done,
+       .program_dmdata_engine = dcn30_program_dmdata_engine,
+       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
+       .init_sys_ctx = dcn20_init_sys_ctx,
+       .init_vm_ctx = dcn20_init_vm_ctx,
+       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
+       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
+       .calc_vupdate_position = dcn10_calc_vupdate_position,
+       .apply_idle_power_optimizations = dcn30_apply_idle_power_optimizations,
+       .does_plane_fit_in_mall = dcn30_does_plane_fit_in_mall,
+       .set_backlight_level = dcn21_set_backlight_level,
+       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
+       .hardware_release = dcn30_hardware_release,
+       .set_pipe = dcn21_set_pipe,
+       .enable_lvds_link_output = dce110_enable_lvds_link_output,
+       .enable_tmds_link_output = dce110_enable_tmds_link_output,
+       .enable_dp_link_output = dce110_enable_dp_link_output,
+       .disable_link_output = dce110_disable_link_output,
+       .set_disp_pattern_generator = dcn30_set_disp_pattern_generator,
+       .get_dcc_en_bits = dcn10_get_dcc_en_bits,
+       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
+       .is_abm_supported = dcn21_is_abm_supported
+};
+
+static const struct hwseq_private_funcs dcn30_private_funcs = {
+       .init_pipes = dcn10_init_pipes,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
+       .update_mpcc = dcn20_update_mpcc,
+       .set_input_transfer_func = dcn30_set_input_transfer_func,
+       .set_output_transfer_func = dcn30_set_output_transfer_func,
+       .power_down = dce110_power_down,
+       .enable_display_power_gating = dcn10_dummy_display_power_gating,
+       .blank_pixel_data = dcn20_blank_pixel_data,
+       .reset_hw_ctx_wrap = dcn20_reset_hw_ctx_wrap,
+       .enable_stream_timing = dcn20_enable_stream_timing,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .disable_stream_gating = dcn20_disable_stream_gating,
+       .enable_stream_gating = dcn20_enable_stream_gating,
+       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
+       .did_underflow_occur = dcn10_did_underflow_occur,
+       .init_blank = dcn20_init_blank,
+       .disable_vga = dcn20_disable_vga,
+       .bios_golden_init = dcn10_bios_golden_init,
+       .plane_atomic_disable = dcn20_plane_atomic_disable,
+       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
+       .enable_power_gating_plane = dcn20_enable_power_gating_plane,
+       .dpp_pg_control = dcn20_dpp_pg_control,
+       .hubp_pg_control = dcn20_hubp_pg_control,
+       .program_all_writeback_pipes_in_tree = dcn30_program_all_writeback_pipes_in_tree,
+       .update_odm = dcn20_update_odm,
+       .dsc_pg_control = dcn20_dsc_pg_control,
+       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
+       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
+       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
+       .dccg_init = dcn20_dccg_init,
+       .set_blend_lut = dcn30_set_blend_lut,
+       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
+};
+
+void dcn30_hw_sequencer_construct(struct dc *dc)
+{
+       dc->hwss = dcn30_funcs;
+       dc->hwseq->funcs = dcn30_private_funcs;
+
+}
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn30/dcn30_init.h b/drivers/gpu/drm/amd/display/dc/hwss/dcn30/dcn30_init.h
new file mode 100644 (file)
index 0000000..c280ff9
--- /dev/null
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2020 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_DCN30_INIT_H__
+#define __DC_DCN30_INIT_H__
+
+struct dc;
+
+void dcn30_hw_sequencer_construct(struct dc *dc);
+
+#endif /* __DC_DCN30_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn301/dcn301_init.c b/drivers/gpu/drm/amd/display/dc/hwss/dcn301/dcn301_init.c
new file mode 100644 (file)
index 0000000..6477009
--- /dev/null
@@ -0,0 +1,154 @@
+/*
+ * Copyright 2016-2020 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "dce110/dce110_hwseq.h"
+#include "dcn10/dcn10_hwseq.h"
+#include "dcn20/dcn20_hwseq.h"
+#include "dcn21/dcn21_hwseq.h"
+#include "dcn30/dcn30_hwseq.h"
+#include "dcn301/dcn301_hwseq.h"
+
+#include "dcn301_init.h"
+
+static const struct hw_sequencer_funcs dcn301_funcs = {
+       .program_gamut_remap = dcn30_program_gamut_remap,
+       .init_hw = dcn10_init_hw,
+       .power_down_on_boot = dcn10_power_down_on_boot,
+       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
+       .apply_ctx_for_surface = NULL,
+       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
+       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
+       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .update_dchub = dcn10_update_dchub,
+       .update_pending_status = dcn10_update_pending_status,
+       .program_output_csc = dcn20_program_output_csc,
+       .enable_accelerated_mode = dce110_enable_accelerated_mode,
+       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
+       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
+       .update_info_frame = dcn30_update_info_frame,
+       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
+       .enable_stream = dcn20_enable_stream,
+       .disable_stream = dce110_disable_stream,
+       .unblank_stream = dcn20_unblank_stream,
+#ifdef FREESYNC_POWER_OPTIMIZE
+       .are_streams_coarse_grain_aligned = dcn20_are_streams_coarse_grain_aligned,
+#endif
+       .blank_stream = dce110_blank_stream,
+       .enable_audio_stream = dce110_enable_audio_stream,
+       .disable_audio_stream = dce110_disable_audio_stream,
+       .disable_plane = dcn20_disable_plane,
+       .pipe_control_lock = dcn20_pipe_control_lock,
+       .interdependent_update_lock = dcn10_lock_all_pipes,
+       .cursor_lock = dcn10_cursor_lock,
+       .prepare_bandwidth = dcn20_prepare_bandwidth,
+       .optimize_bandwidth = dcn20_optimize_bandwidth,
+       .update_bandwidth = dcn20_update_bandwidth,
+       .set_drr = dcn10_set_drr,
+       .get_position = dcn10_get_position,
+       .set_static_screen_control = dcn10_set_static_screen_control,
+       .setup_stereo = dcn10_setup_stereo,
+       .set_avmute = dcn30_set_avmute,
+       .log_hw_state = dcn10_log_hw_state,
+       .get_hw_state = dcn10_get_hw_state,
+       .clear_status_bits = dcn10_clear_status_bits,
+       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .edp_power_control = dce110_edp_power_control,
+       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
+       .set_cursor_position = dcn10_set_cursor_position,
+       .set_cursor_attribute = dcn10_set_cursor_attribute,
+       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
+       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
+       .set_clock = dcn10_set_clock,
+       .get_clock = dcn10_get_clock,
+       .program_triplebuffer = dcn20_program_triple_buffer,
+       .enable_writeback = dcn30_enable_writeback,
+       .disable_writeback = dcn30_disable_writeback,
+       .update_writeback = dcn30_update_writeback,
+       .mmhubbub_warmup = dcn30_mmhubbub_warmup,
+       .dmdata_status_done = dcn20_dmdata_status_done,
+       .program_dmdata_engine = dcn30_program_dmdata_engine,
+       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
+       .init_sys_ctx = dcn20_init_sys_ctx,
+       .init_vm_ctx = dcn20_init_vm_ctx,
+       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
+       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
+       .calc_vupdate_position = dcn10_calc_vupdate_position,
+       .set_backlight_level = dcn21_set_backlight_level,
+       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
+       .set_pipe = dcn21_set_pipe,
+       .enable_lvds_link_output = dce110_enable_lvds_link_output,
+       .enable_tmds_link_output = dce110_enable_tmds_link_output,
+       .enable_dp_link_output = dce110_enable_dp_link_output,
+       .disable_link_output = dce110_disable_link_output,
+       .set_disp_pattern_generator = dcn30_set_disp_pattern_generator,
+       .get_dcc_en_bits = dcn10_get_dcc_en_bits,
+       .optimize_pwr_state = dcn21_optimize_pwr_state,
+       .exit_optimized_pwr_state = dcn21_exit_optimized_pwr_state,
+       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
+};
+
+static const struct hwseq_private_funcs dcn301_private_funcs = {
+       .init_pipes = dcn10_init_pipes,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
+       .update_mpcc = dcn20_update_mpcc,
+       .set_input_transfer_func = dcn30_set_input_transfer_func,
+       .set_output_transfer_func = dcn30_set_output_transfer_func,
+       .power_down = dce110_power_down,
+       .enable_display_power_gating = dcn10_dummy_display_power_gating,
+       .blank_pixel_data = dcn20_blank_pixel_data,
+       .reset_hw_ctx_wrap = dcn20_reset_hw_ctx_wrap,
+       .enable_stream_timing = dcn20_enable_stream_timing,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .disable_stream_gating = dcn20_disable_stream_gating,
+       .enable_stream_gating = dcn20_enable_stream_gating,
+       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
+       .did_underflow_occur = dcn10_did_underflow_occur,
+       .init_blank = dcn20_init_blank,
+       .disable_vga = dcn20_disable_vga,
+       .bios_golden_init = dcn10_bios_golden_init,
+       .plane_atomic_disable = dcn20_plane_atomic_disable,
+       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
+       .enable_power_gating_plane = dcn20_enable_power_gating_plane,
+       .dpp_pg_control = dcn20_dpp_pg_control,
+       .hubp_pg_control = dcn20_hubp_pg_control,
+       .program_all_writeback_pipes_in_tree = dcn30_program_all_writeback_pipes_in_tree,
+       .update_odm = dcn20_update_odm,
+       .dsc_pg_control = dcn20_dsc_pg_control,
+       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
+       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
+       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
+       .dccg_init = dcn20_dccg_init,
+       .set_blend_lut = dcn30_set_blend_lut,
+       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
+};
+
+void dcn301_hw_sequencer_construct(struct dc *dc)
+{
+       dc->hwss = dcn301_funcs;
+       dc->hwseq->funcs = dcn301_private_funcs;
+}
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn301/dcn301_init.h b/drivers/gpu/drm/amd/display/dc/hwss/dcn301/dcn301_init.h
new file mode 100644 (file)
index 0000000..0bca48c
--- /dev/null
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2020 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_DCN30_INIT_H__
+#define __DC_DCN30_INIT_H__
+
+struct dc;
+
+void dcn301_hw_sequencer_construct(struct dc *dc);
+
+#endif /* __DC_DCN30_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn302/dcn302_init.c b/drivers/gpu/drm/amd/display/dc/hwss/dcn302/dcn302_init.c
new file mode 100644 (file)
index 0000000..637f951
--- /dev/null
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2020 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "dcn302/dcn302_hwseq.h"
+
+#include "dcn30/dcn30_init.h"
+
+#include "dc.h"
+
+#include "dcn302_init.h"
+
+void dcn302_hw_sequencer_construct(struct dc *dc)
+{
+       dcn30_hw_sequencer_construct(dc);
+
+       dc->hwseq->funcs.dpp_pg_control = dcn302_dpp_pg_control;
+       dc->hwseq->funcs.hubp_pg_control = dcn302_hubp_pg_control;
+       dc->hwseq->funcs.dsc_pg_control = dcn302_dsc_pg_control;
+}
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn302/dcn302_init.h b/drivers/gpu/drm/amd/display/dc/hwss/dcn302/dcn302_init.h
new file mode 100644 (file)
index 0000000..899587b
--- /dev/null
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2020 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_DCN302_INIT_H__
+#define __DC_DCN302_INIT_H__
+
+struct dc;
+
+void dcn302_hw_sequencer_construct(struct dc *dc);
+
+#endif /* __DC_DCN302_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn303/dcn303_init.c b/drivers/gpu/drm/amd/display/dc/hwss/dcn303/dcn303_init.c
new file mode 100644 (file)
index 0000000..edb4d68
--- /dev/null
@@ -0,0 +1,40 @@
+// SPDX-License-Identifier: MIT
+/*
+ * Copyright (C) 2021 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ */
+
+#include "dcn303/dcn303_hwseq.h"
+#include "dcn30/dcn30_init.h"
+#include "dc.h"
+
+#include "dcn303_init.h"
+
+void dcn303_hw_sequencer_construct(struct dc *dc)
+{
+       dcn30_hw_sequencer_construct(dc);
+
+       dc->hwseq->funcs.dpp_pg_control = dcn303_dpp_pg_control;
+       dc->hwseq->funcs.hubp_pg_control = dcn303_hubp_pg_control;
+       dc->hwseq->funcs.dsc_pg_control = dcn303_dsc_pg_control;
+       dc->hwseq->funcs.enable_power_gating_plane = dcn303_enable_power_gating_plane;
+}
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn303/dcn303_init.h b/drivers/gpu/drm/amd/display/dc/hwss/dcn303/dcn303_init.h
new file mode 100644 (file)
index 0000000..4949981
--- /dev/null
@@ -0,0 +1,33 @@
+// SPDX-License-Identifier: MIT
+/*
+ * Copyright (C) 2021 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_DCN303_INIT_H__
+#define __DC_DCN303_INIT_H__
+
+struct dc;
+
+void dcn303_hw_sequencer_construct(struct dc *dc);
+
+#endif /* __DC_DCN303_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn31/dcn31_init.c b/drivers/gpu/drm/amd/display/dc/hwss/dcn31/dcn31_init.c
new file mode 100644 (file)
index 0000000..669f524
--- /dev/null
@@ -0,0 +1,157 @@
+/*
+ * Copyright 2016 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "dce110/dce110_hwseq.h"
+#include "dcn10/dcn10_hwseq.h"
+#include "dcn20/dcn20_hwseq.h"
+#include "dcn21/dcn21_hwseq.h"
+#include "dcn30/dcn30_hwseq.h"
+#include "dcn301/dcn301_hwseq.h"
+#include "dcn31/dcn31_hwseq.h"
+
+#include "dcn31_init.h"
+
+static const struct hw_sequencer_funcs dcn31_funcs = {
+       .program_gamut_remap = dcn30_program_gamut_remap,
+       .init_hw = dcn31_init_hw,
+       .power_down_on_boot = dcn10_power_down_on_boot,
+       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
+       .apply_ctx_for_surface = NULL,
+       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
+       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
+       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .update_dchub = dcn10_update_dchub,
+       .update_pending_status = dcn10_update_pending_status,
+       .program_output_csc = dcn20_program_output_csc,
+       .enable_accelerated_mode = dce110_enable_accelerated_mode,
+       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
+       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
+       .update_info_frame = dcn31_update_info_frame,
+       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
+       .enable_stream = dcn20_enable_stream,
+       .disable_stream = dce110_disable_stream,
+       .unblank_stream = dcn20_unblank_stream,
+       .blank_stream = dce110_blank_stream,
+       .enable_audio_stream = dce110_enable_audio_stream,
+       .disable_audio_stream = dce110_disable_audio_stream,
+       .disable_plane = dcn20_disable_plane,
+       .disable_pixel_data = dcn20_disable_pixel_data,
+       .pipe_control_lock = dcn20_pipe_control_lock,
+       .interdependent_update_lock = dcn10_lock_all_pipes,
+       .cursor_lock = dcn10_cursor_lock,
+       .prepare_bandwidth = dcn20_prepare_bandwidth,
+       .optimize_bandwidth = dcn20_optimize_bandwidth,
+       .update_bandwidth = dcn20_update_bandwidth,
+       .set_drr = dcn10_set_drr,
+       .get_position = dcn10_get_position,
+       .set_static_screen_control = dcn30_set_static_screen_control,
+       .setup_stereo = dcn10_setup_stereo,
+       .set_avmute = dcn30_set_avmute,
+       .log_hw_state = dcn10_log_hw_state,
+       .get_hw_state = dcn10_get_hw_state,
+       .clear_status_bits = dcn10_clear_status_bits,
+       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .edp_power_control = dce110_edp_power_control,
+       .edp_wait_for_T12 = dce110_edp_wait_for_T12,
+       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
+       .set_cursor_position = dcn10_set_cursor_position,
+       .set_cursor_attribute = dcn10_set_cursor_attribute,
+       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
+       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
+       .set_clock = dcn10_set_clock,
+       .get_clock = dcn10_get_clock,
+       .program_triplebuffer = dcn20_program_triple_buffer,
+       .enable_writeback = dcn30_enable_writeback,
+       .disable_writeback = dcn30_disable_writeback,
+       .update_writeback = dcn30_update_writeback,
+       .mmhubbub_warmup = dcn30_mmhubbub_warmup,
+       .dmdata_status_done = dcn20_dmdata_status_done,
+       .program_dmdata_engine = dcn30_program_dmdata_engine,
+       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
+       .init_sys_ctx = dcn31_init_sys_ctx,
+       .init_vm_ctx = dcn20_init_vm_ctx,
+       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
+       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
+       .calc_vupdate_position = dcn10_calc_vupdate_position,
+       .power_down = dce110_power_down,
+       .set_backlight_level = dcn21_set_backlight_level,
+       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
+       .set_pipe = dcn21_set_pipe,
+       .enable_lvds_link_output = dce110_enable_lvds_link_output,
+       .enable_tmds_link_output = dce110_enable_tmds_link_output,
+       .enable_dp_link_output = dce110_enable_dp_link_output,
+       .disable_link_output = dce110_disable_link_output,
+       .z10_restore = dcn31_z10_restore,
+       .z10_save_init = dcn31_z10_save_init,
+       .set_disp_pattern_generator = dcn30_set_disp_pattern_generator,
+       .optimize_pwr_state = dcn21_optimize_pwr_state,
+       .exit_optimized_pwr_state = dcn21_exit_optimized_pwr_state,
+       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
+};
+
+static const struct hwseq_private_funcs dcn31_private_funcs = {
+       .init_pipes = dcn10_init_pipes,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
+       .update_mpcc = dcn20_update_mpcc,
+       .set_input_transfer_func = dcn30_set_input_transfer_func,
+       .set_output_transfer_func = dcn30_set_output_transfer_func,
+       .power_down = dce110_power_down,
+       .enable_display_power_gating = dcn10_dummy_display_power_gating,
+       .blank_pixel_data = dcn20_blank_pixel_data,
+       .reset_hw_ctx_wrap = dcn31_reset_hw_ctx_wrap,
+       .enable_stream_timing = dcn20_enable_stream_timing,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .disable_stream_gating = dcn20_disable_stream_gating,
+       .enable_stream_gating = dcn20_enable_stream_gating,
+       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
+       .did_underflow_occur = dcn10_did_underflow_occur,
+       .init_blank = dcn20_init_blank,
+       .disable_vga = dcn20_disable_vga,
+       .bios_golden_init = dcn10_bios_golden_init,
+       .plane_atomic_disable = dcn20_plane_atomic_disable,
+       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
+       .enable_power_gating_plane = dcn31_enable_power_gating_plane,
+       .hubp_pg_control = dcn31_hubp_pg_control,
+       .program_all_writeback_pipes_in_tree = dcn30_program_all_writeback_pipes_in_tree,
+       .update_odm = dcn20_update_odm,
+       .dsc_pg_control = dcn31_dsc_pg_control,
+       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
+       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
+       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
+       .dccg_init = dcn20_dccg_init,
+       .set_blend_lut = dcn30_set_blend_lut,
+       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
+       .setup_hpo_hw_control = dcn31_setup_hpo_hw_control,
+};
+
+void dcn31_hw_sequencer_construct(struct dc *dc)
+{
+       dc->hwss = dcn31_funcs;
+       dc->hwseq->funcs = dcn31_private_funcs;
+
+}
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn31/dcn31_init.h b/drivers/gpu/drm/amd/display/dc/hwss/dcn31/dcn31_init.h
new file mode 100644 (file)
index 0000000..a3db08c
--- /dev/null
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2016 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_DCN31_INIT_H__
+#define __DC_DCN31_INIT_H__
+
+struct dc;
+
+void dcn31_hw_sequencer_construct(struct dc *dc);
+
+#endif /* __DC_DCN31_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn314/dcn314_init.c b/drivers/gpu/drm/amd/display/dc/hwss/dcn314/dcn314_init.c
new file mode 100644 (file)
index 0000000..ccb7e31
--- /dev/null
@@ -0,0 +1,163 @@
+// SPDX-License-Identifier: MIT
+/*
+ * Copyright 2022 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "dce110/dce110_hwseq.h"
+#include "dcn10/dcn10_hwseq.h"
+#include "dcn20/dcn20_hwseq.h"
+#include "dcn21/dcn21_hwseq.h"
+#include "dcn30/dcn30_hwseq.h"
+#include "dcn301/dcn301_hwseq.h"
+#include "dcn31/dcn31_hwseq.h"
+#include "dcn314/dcn314_hwseq.h"
+
+#include "dcn314_init.h"
+
+static const struct hw_sequencer_funcs dcn314_funcs = {
+       .program_gamut_remap = dcn30_program_gamut_remap,
+       .init_hw = dcn31_init_hw,
+       .power_down_on_boot = dcn10_power_down_on_boot,
+       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
+       .apply_ctx_for_surface = NULL,
+       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
+       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
+       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .update_dchub = dcn10_update_dchub,
+       .update_pending_status = dcn10_update_pending_status,
+       .program_output_csc = dcn20_program_output_csc,
+       .enable_accelerated_mode = dce110_enable_accelerated_mode,
+       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
+       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
+       .update_info_frame = dcn31_update_info_frame,
+       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
+       .enable_stream = dcn20_enable_stream,
+       .disable_stream = dce110_disable_stream,
+       .unblank_stream = dcn20_unblank_stream,
+       .blank_stream = dce110_blank_stream,
+       .enable_audio_stream = dce110_enable_audio_stream,
+       .disable_audio_stream = dce110_disable_audio_stream,
+       .disable_plane = dcn20_disable_plane,
+       .disable_pixel_data = dcn20_disable_pixel_data,
+       .pipe_control_lock = dcn20_pipe_control_lock,
+       .interdependent_update_lock = dcn10_lock_all_pipes,
+       .cursor_lock = dcn10_cursor_lock,
+       .prepare_bandwidth = dcn20_prepare_bandwidth,
+       .optimize_bandwidth = dcn20_optimize_bandwidth,
+       .update_bandwidth = dcn20_update_bandwidth,
+       .set_drr = dcn10_set_drr,
+       .get_position = dcn10_get_position,
+       .set_static_screen_control = dcn30_set_static_screen_control,
+       .setup_stereo = dcn10_setup_stereo,
+       .set_avmute = dcn30_set_avmute,
+       .log_hw_state = dcn10_log_hw_state,
+       .get_hw_state = dcn10_get_hw_state,
+       .clear_status_bits = dcn10_clear_status_bits,
+       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .edp_power_control = dce110_edp_power_control,
+       .edp_wait_for_T12 = dce110_edp_wait_for_T12,
+       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
+       .set_cursor_position = dcn10_set_cursor_position,
+       .set_cursor_attribute = dcn10_set_cursor_attribute,
+       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
+       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
+       .set_clock = dcn10_set_clock,
+       .get_clock = dcn10_get_clock,
+       .program_triplebuffer = dcn20_program_triple_buffer,
+       .enable_writeback = dcn30_enable_writeback,
+       .disable_writeback = dcn30_disable_writeback,
+       .update_writeback = dcn30_update_writeback,
+       .mmhubbub_warmup = dcn30_mmhubbub_warmup,
+       .dmdata_status_done = dcn20_dmdata_status_done,
+       .program_dmdata_engine = dcn30_program_dmdata_engine,
+       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
+       .init_sys_ctx = dcn31_init_sys_ctx,
+       .init_vm_ctx = dcn20_init_vm_ctx,
+       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
+       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
+       .calc_vupdate_position = dcn10_calc_vupdate_position,
+       .power_down = dce110_power_down,
+       .set_backlight_level = dcn21_set_backlight_level,
+       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
+       .set_pipe = dcn21_set_pipe,
+       .enable_lvds_link_output = dce110_enable_lvds_link_output,
+       .enable_tmds_link_output = dce110_enable_tmds_link_output,
+       .enable_dp_link_output = dce110_enable_dp_link_output,
+       .disable_link_output = dcn314_disable_link_output,
+       .z10_restore = dcn31_z10_restore,
+       .z10_save_init = dcn31_z10_save_init,
+       .set_disp_pattern_generator = dcn30_set_disp_pattern_generator,
+       .optimize_pwr_state = dcn21_optimize_pwr_state,
+       .exit_optimized_pwr_state = dcn21_exit_optimized_pwr_state,
+       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
+};
+
+static const struct hwseq_private_funcs dcn314_private_funcs = {
+       .init_pipes = dcn10_init_pipes,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
+       .update_mpcc = dcn20_update_mpcc,
+       .set_input_transfer_func = dcn30_set_input_transfer_func,
+       .set_output_transfer_func = dcn30_set_output_transfer_func,
+       .power_down = dce110_power_down,
+       .enable_display_power_gating = dcn10_dummy_display_power_gating,
+       .blank_pixel_data = dcn20_blank_pixel_data,
+       .reset_hw_ctx_wrap = dcn31_reset_hw_ctx_wrap,
+       .enable_stream_timing = dcn20_enable_stream_timing,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .disable_stream_gating = dcn20_disable_stream_gating,
+       .enable_stream_gating = dcn20_enable_stream_gating,
+       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
+       .did_underflow_occur = dcn10_did_underflow_occur,
+       .init_blank = dcn20_init_blank,
+       .disable_vga = dcn20_disable_vga,
+       .bios_golden_init = dcn10_bios_golden_init,
+       .plane_atomic_disable = dcn20_plane_atomic_disable,
+       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
+       .enable_power_gating_plane = dcn314_enable_power_gating_plane,
+       .dpp_root_clock_control = dcn314_dpp_root_clock_control,
+       .hubp_pg_control = dcn31_hubp_pg_control,
+       .program_all_writeback_pipes_in_tree = dcn30_program_all_writeback_pipes_in_tree,
+       .update_odm = dcn314_update_odm,
+       .dsc_pg_control = dcn314_dsc_pg_control,
+       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
+       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
+       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
+       .dccg_init = dcn20_dccg_init,
+       .set_blend_lut = dcn30_set_blend_lut,
+       .set_shaper_3dlut = dcn20_set_shaper_3dlut,
+       .setup_hpo_hw_control = dcn31_setup_hpo_hw_control,
+       .calculate_dccg_k1_k2_values = dcn314_calculate_dccg_k1_k2_values,
+       .set_pixels_per_cycle = dcn314_set_pixels_per_cycle,
+       .resync_fifo_dccg_dio = dcn314_resync_fifo_dccg_dio,
+};
+
+void dcn314_hw_sequencer_construct(struct dc *dc)
+{
+       dc->hwss = dcn314_funcs;
+       dc->hwseq->funcs = dcn314_private_funcs;
+
+}
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn314/dcn314_init.h b/drivers/gpu/drm/amd/display/dc/hwss/dcn314/dcn314_init.h
new file mode 100644 (file)
index 0000000..8f92e66
--- /dev/null
@@ -0,0 +1,34 @@
+/* SPDX-License-Identifier: MIT */
+/*
+ * Copyright 2022 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#ifndef __DC_DCN314_INIT_H__
+#define __DC_DCN314_INIT_H__
+
+struct dc;
+
+void dcn314_hw_sequencer_construct(struct dc *dc);
+
+#endif /* __DC_DCN314_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn32/dcn32_init.c b/drivers/gpu/drm/amd/display/dc/hwss/dcn32/dcn32_init.c
new file mode 100644 (file)
index 0000000..427cfc8
--- /dev/null
@@ -0,0 +1,169 @@
+/*
+ * Copyright 2022 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "dce110/dce110_hwseq.h"
+#include "dcn10/dcn10_hwseq.h"
+#include "dcn20/dcn20_hwseq.h"
+#include "dcn21/dcn21_hwseq.h"
+#include "dcn30/dcn30_hwseq.h"
+#include "dcn31/dcn31_hwseq.h"
+#include "dcn32/dcn32_hwseq.h"
+#include "dcn32_init.h"
+
+static const struct hw_sequencer_funcs dcn32_funcs = {
+       .program_gamut_remap = dcn30_program_gamut_remap,
+       .init_hw = dcn32_init_hw,
+       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
+       .apply_ctx_for_surface = NULL,
+       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
+       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
+       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .update_dchub = dcn10_update_dchub,
+       .update_pending_status = dcn10_update_pending_status,
+       .program_output_csc = dcn20_program_output_csc,
+       .enable_accelerated_mode = dce110_enable_accelerated_mode,
+       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
+       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
+       .update_info_frame = dcn31_update_info_frame,
+       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
+       .enable_stream = dcn20_enable_stream,
+       .disable_stream = dce110_disable_stream,
+       .unblank_stream = dcn32_unblank_stream,
+       .blank_stream = dce110_blank_stream,
+       .enable_audio_stream = dce110_enable_audio_stream,
+       .disable_audio_stream = dce110_disable_audio_stream,
+       .disable_plane = dcn20_disable_plane,
+       .disable_pixel_data = dcn20_disable_pixel_data,
+       .pipe_control_lock = dcn20_pipe_control_lock,
+       .interdependent_update_lock = dcn10_lock_all_pipes,
+       .cursor_lock = dcn10_cursor_lock,
+       .prepare_bandwidth = dcn32_prepare_bandwidth,
+       .optimize_bandwidth = dcn20_optimize_bandwidth,
+       .update_bandwidth = dcn20_update_bandwidth,
+       .set_drr = dcn10_set_drr,
+       .get_position = dcn10_get_position,
+       .set_static_screen_control = dcn30_set_static_screen_control,
+       .setup_stereo = dcn10_setup_stereo,
+       .set_avmute = dcn30_set_avmute,
+       .log_hw_state = dcn10_log_hw_state,
+       .get_hw_state = dcn10_get_hw_state,
+       .clear_status_bits = dcn10_clear_status_bits,
+       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .edp_power_control = dce110_edp_power_control,
+       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
+       .edp_wait_for_T12 = dce110_edp_wait_for_T12,
+       .set_cursor_position = dcn10_set_cursor_position,
+       .set_cursor_attribute = dcn10_set_cursor_attribute,
+       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
+       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
+       .set_clock = dcn10_set_clock,
+       .get_clock = dcn10_get_clock,
+       .program_triplebuffer = dcn20_program_triple_buffer,
+       .enable_writeback = dcn30_enable_writeback,
+       .disable_writeback = dcn30_disable_writeback,
+       .update_writeback = dcn30_update_writeback,
+       .mmhubbub_warmup = dcn30_mmhubbub_warmup,
+       .dmdata_status_done = dcn20_dmdata_status_done,
+       .program_dmdata_engine = dcn30_program_dmdata_engine,
+       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
+       .init_sys_ctx = dcn20_init_sys_ctx,
+       .init_vm_ctx = dcn20_init_vm_ctx,
+       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
+       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
+       .calc_vupdate_position = dcn10_calc_vupdate_position,
+       .apply_idle_power_optimizations = dcn32_apply_idle_power_optimizations,
+       .does_plane_fit_in_mall = NULL,
+       .set_backlight_level = dcn21_set_backlight_level,
+       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
+       .hardware_release = dcn30_hardware_release,
+       .set_pipe = dcn21_set_pipe,
+       .enable_lvds_link_output = dce110_enable_lvds_link_output,
+       .enable_tmds_link_output = dce110_enable_tmds_link_output,
+       .enable_dp_link_output = dce110_enable_dp_link_output,
+       .disable_link_output = dcn32_disable_link_output,
+       .set_disp_pattern_generator = dcn30_set_disp_pattern_generator,
+       .get_dcc_en_bits = dcn10_get_dcc_en_bits,
+       .commit_subvp_config = dcn32_commit_subvp_config,
+       .enable_phantom_streams = dcn32_enable_phantom_streams,
+       .subvp_pipe_control_lock = dcn32_subvp_pipe_control_lock,
+       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
+       .subvp_pipe_control_lock_fast = dcn32_subvp_pipe_control_lock_fast,
+       .update_phantom_vp_position = dcn32_update_phantom_vp_position,
+       .update_dsc_pg = dcn32_update_dsc_pg,
+       .apply_update_flags_for_phantom = dcn32_apply_update_flags_for_phantom,
+       .blank_phantom = dcn32_blank_phantom,
+       .is_pipe_topology_transition_seamless = dcn32_is_pipe_topology_transition_seamless,
+};
+
+static const struct hwseq_private_funcs dcn32_private_funcs = {
+       .init_pipes = dcn10_init_pipes,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
+       .update_mpcc = dcn20_update_mpcc,
+       .set_input_transfer_func = dcn32_set_input_transfer_func,
+       .set_output_transfer_func = dcn32_set_output_transfer_func,
+       .power_down = dce110_power_down,
+       .enable_display_power_gating = dcn10_dummy_display_power_gating,
+       .blank_pixel_data = dcn20_blank_pixel_data,
+       .reset_hw_ctx_wrap = dcn20_reset_hw_ctx_wrap,
+       .enable_stream_timing = dcn20_enable_stream_timing,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .disable_stream_gating = dcn20_disable_stream_gating,
+       .enable_stream_gating = dcn20_enable_stream_gating,
+       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
+       .did_underflow_occur = dcn10_did_underflow_occur,
+       .init_blank = dcn32_init_blank,
+       .disable_vga = dcn20_disable_vga,
+       .bios_golden_init = dcn10_bios_golden_init,
+       .plane_atomic_disable = dcn20_plane_atomic_disable,
+       .plane_atomic_power_down = dcn10_plane_atomic_power_down,
+       .enable_power_gating_plane = dcn32_enable_power_gating_plane,
+       .hubp_pg_control = dcn32_hubp_pg_control,
+       .program_all_writeback_pipes_in_tree = dcn30_program_all_writeback_pipes_in_tree,
+       .update_odm = dcn32_update_odm,
+       .dsc_pg_control = dcn32_dsc_pg_control,
+       .dsc_pg_status = dcn32_dsc_pg_status,
+       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
+       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
+       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
+       .dccg_init = dcn20_dccg_init,
+       .set_mcm_luts = dcn32_set_mcm_luts,
+       .program_mall_pipe_config = dcn32_program_mall_pipe_config,
+       .update_force_pstate = dcn32_update_force_pstate,
+       .update_mall_sel = dcn32_update_mall_sel,
+       .calculate_dccg_k1_k2_values = dcn32_calculate_dccg_k1_k2_values,
+       .set_pixels_per_cycle = dcn32_set_pixels_per_cycle,
+       .resync_fifo_dccg_dio = dcn32_resync_fifo_dccg_dio,
+       .is_dp_dig_pixel_rate_div_policy = dcn32_is_dp_dig_pixel_rate_div_policy,
+};
+
+void dcn32_hw_sequencer_init_functions(struct dc *dc)
+{
+       dc->hwss = dcn32_funcs;
+       dc->hwseq->funcs = dcn32_private_funcs;
+
+}
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn32/dcn32_init.h b/drivers/gpu/drm/amd/display/dc/hwss/dcn32/dcn32_init.h
new file mode 100644 (file)
index 0000000..89a591e
--- /dev/null
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2022 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#ifndef __DC_DCN32_INIT_H__
+#define __DC_DCN32_INIT_H__
+
+struct dc;
+
+void dcn32_hw_sequencer_init_functions(struct dc *dc);
+
+#endif /* __DC_DCN32_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn35/dcn35_init.c b/drivers/gpu/drm/amd/display/dc/hwss/dcn35/dcn35_init.c
new file mode 100644 (file)
index 0000000..a630aa7
--- /dev/null
@@ -0,0 +1,172 @@
+/* SPDX-License-Identifier: MIT */
+/*
+ * Copyright 2023 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "dce110/dce110_hwseq.h"
+#include "dcn10/dcn10_hwseq.h"
+#include "dcn20/dcn20_hwseq.h"
+#include "dcn21/dcn21_hwseq.h"
+#include "dcn30/dcn30_hwseq.h"
+#include "dcn301/dcn301_hwseq.h"
+#include "dcn31/dcn31_hwseq.h"
+#include "dcn32/dcn32_hwseq.h"
+#include "dcn35/dcn35_hwseq.h"
+
+#include "dcn35_init.h"
+
+static const struct hw_sequencer_funcs dcn35_funcs = {
+       .program_gamut_remap = dcn30_program_gamut_remap,
+       .init_hw = dcn35_init_hw,
+       .power_down_on_boot = dcn35_power_down_on_boot,
+       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
+       .apply_ctx_for_surface = NULL,
+       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
+       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
+       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .update_dchub = dcn10_update_dchub,
+       .update_pending_status = dcn10_update_pending_status,
+       .program_output_csc = dcn20_program_output_csc,
+       .enable_accelerated_mode = dce110_enable_accelerated_mode,
+       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
+       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
+       .update_info_frame = dcn31_update_info_frame,
+       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
+       .enable_stream = dcn20_enable_stream,
+       .disable_stream = dce110_disable_stream,
+       .unblank_stream = dcn32_unblank_stream,
+       .blank_stream = dce110_blank_stream,
+       .enable_audio_stream = dce110_enable_audio_stream,
+       .disable_audio_stream = dce110_disable_audio_stream,
+       .disable_plane = dcn35_disable_plane,
+       .disable_pixel_data = dcn20_disable_pixel_data,
+       .pipe_control_lock = dcn20_pipe_control_lock,
+       .interdependent_update_lock = dcn10_lock_all_pipes,
+       .cursor_lock = dcn10_cursor_lock,
+       .prepare_bandwidth = dcn35_prepare_bandwidth,
+       .optimize_bandwidth = dcn35_optimize_bandwidth,
+       .update_bandwidth = dcn20_update_bandwidth,
+       .set_drr = dcn35_set_drr,
+       .get_position = dcn10_get_position,
+       .set_static_screen_control = dcn30_set_static_screen_control,
+       .setup_stereo = dcn10_setup_stereo,
+       .set_avmute = dcn30_set_avmute,
+       .log_hw_state = dcn10_log_hw_state,
+       .get_hw_state = dcn10_get_hw_state,
+       .clear_status_bits = dcn10_clear_status_bits,
+       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .edp_power_control = dce110_edp_power_control,
+       .edp_wait_for_T12 = dce110_edp_wait_for_T12,
+       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
+       .set_cursor_position = dcn10_set_cursor_position,
+       .set_cursor_attribute = dcn10_set_cursor_attribute,
+       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
+       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
+       .set_clock = dcn10_set_clock,
+       .get_clock = dcn10_get_clock,
+       .program_triplebuffer = dcn20_program_triple_buffer,
+       .enable_writeback = dcn30_enable_writeback,
+       .disable_writeback = dcn30_disable_writeback,
+       .update_writeback = dcn30_update_writeback,
+       .mmhubbub_warmup = dcn30_mmhubbub_warmup,
+       .dmdata_status_done = dcn20_dmdata_status_done,
+       .program_dmdata_engine = dcn30_program_dmdata_engine,
+       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
+       .init_sys_ctx = dcn31_init_sys_ctx,
+       .init_vm_ctx = dcn20_init_vm_ctx,
+       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
+       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
+       .calc_vupdate_position = dcn10_calc_vupdate_position,
+       .power_down = dce110_power_down,
+       .set_backlight_level = dcn21_set_backlight_level,
+       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
+       .set_pipe = dcn21_set_pipe,
+       .enable_lvds_link_output = dce110_enable_lvds_link_output,
+       .enable_tmds_link_output = dce110_enable_tmds_link_output,
+       .enable_dp_link_output = dce110_enable_dp_link_output,
+       .disable_link_output = dcn32_disable_link_output,
+       .z10_restore = dcn35_z10_restore,
+       .z10_save_init = dcn31_z10_save_init,
+       .set_disp_pattern_generator = dcn30_set_disp_pattern_generator,
+       .optimize_pwr_state = dcn21_optimize_pwr_state,
+       .exit_optimized_pwr_state = dcn21_exit_optimized_pwr_state,
+       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
+       .apply_idle_power_optimizations = dcn35_apply_idle_power_optimizations,
+       .update_dsc_pg = dcn32_update_dsc_pg,
+       .calc_blocks_to_gate = dcn35_calc_blocks_to_gate,
+       .calc_blocks_to_ungate = dcn35_calc_blocks_to_ungate,
+       .hw_block_power_up = dcn35_hw_block_power_up,
+       .hw_block_power_down = dcn35_hw_block_power_down,
+       .root_clock_control = dcn35_root_clock_control,
+       .set_idle_state = dcn35_set_idle_state,
+       .get_idle_state = dcn35_get_idle_state
+};
+
+static const struct hwseq_private_funcs dcn35_private_funcs = {
+       .init_pipes = dcn35_init_pipes,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
+       .update_mpcc = dcn20_update_mpcc,
+       .set_input_transfer_func = dcn32_set_input_transfer_func,
+       .set_output_transfer_func = dcn32_set_output_transfer_func,
+       .power_down = dce110_power_down,
+       .enable_display_power_gating = dcn10_dummy_display_power_gating,
+       .blank_pixel_data = dcn20_blank_pixel_data,
+       .reset_hw_ctx_wrap = dcn31_reset_hw_ctx_wrap,
+       .enable_stream_timing = dcn20_enable_stream_timing,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
+       .did_underflow_occur = dcn10_did_underflow_occur,
+       .init_blank = dcn20_init_blank,
+       .disable_vga = NULL,
+       .bios_golden_init = dcn10_bios_golden_init,
+       .plane_atomic_disable = dcn35_plane_atomic_disable,
+       //.plane_atomic_disable = dcn20_plane_atomic_disable,/*todo*/
+       //.hubp_pg_control = dcn35_hubp_pg_control,
+       .enable_power_gating_plane = dcn35_enable_power_gating_plane,
+       .dpp_root_clock_control = dcn35_dpp_root_clock_control,
+       .program_all_writeback_pipes_in_tree = dcn30_program_all_writeback_pipes_in_tree,
+       .update_odm = dcn35_update_odm,
+       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
+       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
+       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
+       .dccg_init = dcn20_dccg_init,
+       .set_mcm_luts = dcn32_set_mcm_luts,
+       .setup_hpo_hw_control = dcn35_setup_hpo_hw_control,
+       .calculate_dccg_k1_k2_values = dcn32_calculate_dccg_k1_k2_values,
+       .set_pixels_per_cycle = dcn32_set_pixels_per_cycle,
+       .is_dp_dig_pixel_rate_div_policy = dcn32_is_dp_dig_pixel_rate_div_policy,
+       .dsc_pg_control = dcn35_dsc_pg_control,
+       .dsc_pg_status = dcn32_dsc_pg_status,
+       .enable_plane = dcn35_enable_plane,
+};
+
+void dcn35_hw_sequencer_construct(struct dc *dc)
+{
+       dc->hwss = dcn35_funcs;
+       dc->hwseq->funcs = dcn35_private_funcs;
+
+}
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn35/dcn35_init.h b/drivers/gpu/drm/amd/display/dc/hwss/dcn35/dcn35_init.h
new file mode 100644 (file)
index 0000000..b670150
--- /dev/null
@@ -0,0 +1,34 @@
+/* SPDX-License-Identifier: MIT */
+/*
+ * Copyright 2023 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_DCN35_INIT_H__
+#define __DC_DCN35_INIT_H__
+
+struct dc;
+
+void dcn35_hw_sequencer_construct(struct dc *dc);
+
+#endif /* __DC_DCN35_INIT_H__ */
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn351/CMakeLists.txt b/drivers/gpu/drm/amd/display/dc/hwss/dcn351/CMakeLists.txt
new file mode 100644 (file)
index 0000000..951ca2d
--- /dev/null
@@ -0,0 +1,4 @@
+dal3_subdirectory_sources(
+  dcn351_init.c
+  dcn351_init.h
+)
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn351/Makefile b/drivers/gpu/drm/amd/display/dc/hwss/dcn351/Makefile
new file mode 100644 (file)
index 0000000..b24ad27
--- /dev/null
@@ -0,0 +1,17 @@
+#
+# (c) Copyright 2022 Advanced Micro Devices, Inc. All the rights reserved
+#
+#  All rights reserved.  This notice is intended as a precaution against
+#  inadvertent publication and does not imply publication or any waiver
+#  of confidentiality.  The year included in the foregoing notice is the
+#  year of creation of the work.
+#
+#  Authors: AMD
+#
+# Makefile for DCN351.
+
+DCN351 = dcn351_init.o
+
+AMD_DAL_DCN351 = $(addprefix $(AMDDALPATH)/dc/dcn351/,$(DCN351))
+
+AMD_DISPLAY_FILES += $(AMD_DAL_DCN351)
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn351/dcn351_init.c b/drivers/gpu/drm/amd/display/dc/hwss/dcn351/dcn351_init.c
new file mode 100644 (file)
index 0000000..143d3fc
--- /dev/null
@@ -0,0 +1,171 @@
+/*
+ * Copyright 2023 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "dce110/dce110_hwseq.h"
+#include "dcn10/dcn10_hwseq.h"
+#include "dcn20/dcn20_hwseq.h"
+#include "dcn21/dcn21_hwseq.h"
+#include "dcn30/dcn30_hwseq.h"
+#include "dcn301/dcn301_hwseq.h"
+#include "dcn31/dcn31_hwseq.h"
+#include "dcn32/dcn32_hwseq.h"
+#include "dcn35/dcn35_hwseq.h"
+
+#include "dcn351_init.h"
+
+static const struct hw_sequencer_funcs dcn351_funcs = {
+       .program_gamut_remap = dcn30_program_gamut_remap,
+       .init_hw = dcn35_init_hw,
+       .power_down_on_boot = dcn35_power_down_on_boot,
+       .apply_ctx_to_hw = dce110_apply_ctx_to_hw,
+       .apply_ctx_for_surface = NULL,
+       .program_front_end_for_ctx = dcn20_program_front_end_for_ctx,
+       .wait_for_pending_cleared = dcn10_wait_for_pending_cleared,
+       .post_unlock_program_front_end = dcn20_post_unlock_program_front_end,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .update_dchub = dcn10_update_dchub,
+       .update_pending_status = dcn10_update_pending_status,
+       .program_output_csc = dcn20_program_output_csc,
+       .enable_accelerated_mode = dce110_enable_accelerated_mode,
+       .enable_timing_synchronization = dcn10_enable_timing_synchronization,
+       .enable_per_frame_crtc_position_reset = dcn10_enable_per_frame_crtc_position_reset,
+       .update_info_frame = dcn31_update_info_frame,
+       .send_immediate_sdp_message = dcn10_send_immediate_sdp_message,
+       .enable_stream = dcn20_enable_stream,
+       .disable_stream = dce110_disable_stream,
+       .unblank_stream = dcn32_unblank_stream,
+       .blank_stream = dce110_blank_stream,
+       .enable_audio_stream = dce110_enable_audio_stream,
+       .disable_audio_stream = dce110_disable_audio_stream,
+       .disable_plane = dcn35_disable_plane,
+       .disable_pixel_data = dcn20_disable_pixel_data,
+       .pipe_control_lock = dcn20_pipe_control_lock,
+       .interdependent_update_lock = dcn10_lock_all_pipes,
+       .cursor_lock = dcn10_cursor_lock,
+       .prepare_bandwidth = dcn35_prepare_bandwidth,
+       .optimize_bandwidth = dcn35_optimize_bandwidth,
+       .update_bandwidth = dcn20_update_bandwidth,
+       .set_drr = dcn10_set_drr,
+       .get_position = dcn10_get_position,
+       .set_static_screen_control = dcn30_set_static_screen_control,
+       .setup_stereo = dcn10_setup_stereo,
+       .set_avmute = dcn30_set_avmute,
+       .log_hw_state = dcn10_log_hw_state,
+       .get_hw_state = dcn10_get_hw_state,
+       .clear_status_bits = dcn10_clear_status_bits,
+       .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .edp_power_control = dce110_edp_power_control,
+       .edp_wait_for_T12 = dce110_edp_wait_for_T12,
+       .edp_wait_for_hpd_ready = dce110_edp_wait_for_hpd_ready,
+       .set_cursor_position = dcn10_set_cursor_position,
+       .set_cursor_attribute = dcn10_set_cursor_attribute,
+       .set_cursor_sdr_white_level = dcn10_set_cursor_sdr_white_level,
+       .setup_periodic_interrupt = dcn10_setup_periodic_interrupt,
+       .set_clock = dcn10_set_clock,
+       .get_clock = dcn10_get_clock,
+       .program_triplebuffer = dcn20_program_triple_buffer,
+       .enable_writeback = dcn30_enable_writeback,
+       .disable_writeback = dcn30_disable_writeback,
+       .update_writeback = dcn30_update_writeback,
+       .mmhubbub_warmup = dcn30_mmhubbub_warmup,
+       .dmdata_status_done = dcn20_dmdata_status_done,
+       .program_dmdata_engine = dcn30_program_dmdata_engine,
+       .set_dmdata_attributes = dcn20_set_dmdata_attributes,
+       .init_sys_ctx = dcn31_init_sys_ctx,
+       .init_vm_ctx = dcn20_init_vm_ctx,
+       .set_flip_control_gsl = dcn20_set_flip_control_gsl,
+       .get_vupdate_offset_from_vsync = dcn10_get_vupdate_offset_from_vsync,
+       .calc_vupdate_position = dcn10_calc_vupdate_position,
+       .power_down = dce110_power_down,
+       .set_backlight_level = dcn21_set_backlight_level,
+       .set_abm_immediate_disable = dcn21_set_abm_immediate_disable,
+       .set_pipe = dcn21_set_pipe,
+       .enable_lvds_link_output = dce110_enable_lvds_link_output,
+       .enable_tmds_link_output = dce110_enable_tmds_link_output,
+       .enable_dp_link_output = dce110_enable_dp_link_output,
+       .disable_link_output = dcn32_disable_link_output,
+       .z10_restore = dcn35_z10_restore,
+       .z10_save_init = dcn31_z10_save_init,
+       .set_disp_pattern_generator = dcn30_set_disp_pattern_generator,
+       .optimize_pwr_state = dcn21_optimize_pwr_state,
+       .exit_optimized_pwr_state = dcn21_exit_optimized_pwr_state,
+       .update_visual_confirm_color = dcn10_update_visual_confirm_color,
+       .apply_idle_power_optimizations = dcn35_apply_idle_power_optimizations,
+       .update_dsc_pg = dcn32_update_dsc_pg,
+       .calc_blocks_to_gate = dcn35_calc_blocks_to_gate,
+       .calc_blocks_to_ungate = dcn35_calc_blocks_to_ungate,
+       .hw_block_power_up = dcn35_hw_block_power_up,
+       .hw_block_power_down = dcn35_hw_block_power_down,
+       .root_clock_control = dcn35_root_clock_control,
+       .set_idle_state = dcn35_set_idle_state,
+       .get_idle_state = dcn35_get_idle_state
+};
+
+static const struct hwseq_private_funcs dcn351_private_funcs = {
+       .init_pipes = dcn35_init_pipes,
+       .update_plane_addr = dcn20_update_plane_addr,
+       .plane_atomic_disconnect = dcn10_plane_atomic_disconnect,
+       .update_mpcc = dcn20_update_mpcc,
+       .set_input_transfer_func = dcn32_set_input_transfer_func,
+       .set_output_transfer_func = dcn32_set_output_transfer_func,
+       .power_down = dce110_power_down,
+       .enable_display_power_gating = dcn10_dummy_display_power_gating,
+       .blank_pixel_data = dcn20_blank_pixel_data,
+       .reset_hw_ctx_wrap = dcn31_reset_hw_ctx_wrap,
+       .enable_stream_timing = dcn20_enable_stream_timing,
+       .edp_backlight_control = dce110_edp_backlight_control,
+       .setup_vupdate_interrupt = dcn20_setup_vupdate_interrupt,
+       .did_underflow_occur = dcn10_did_underflow_occur,
+       .init_blank = dcn20_init_blank,
+       .disable_vga = NULL,
+       .bios_golden_init = dcn10_bios_golden_init,
+       .plane_atomic_disable = dcn35_plane_atomic_disable,
+       //.plane_atomic_disable = dcn20_plane_atomic_disable,/*todo*/
+       //.hubp_pg_control = dcn35_hubp_pg_control,
+       .enable_power_gating_plane = dcn35_enable_power_gating_plane,
+       .dpp_root_clock_control = dcn35_dpp_root_clock_control,
+       .program_all_writeback_pipes_in_tree = dcn30_program_all_writeback_pipes_in_tree,
+       .update_odm = dcn35_update_odm,
+       .set_hdr_multiplier = dcn10_set_hdr_multiplier,
+       .verify_allow_pstate_change_high = dcn10_verify_allow_pstate_change_high,
+       .wait_for_blank_complete = dcn20_wait_for_blank_complete,
+       .dccg_init = dcn20_dccg_init,
+       .set_mcm_luts = dcn32_set_mcm_luts,
+       .setup_hpo_hw_control = dcn35_setup_hpo_hw_control,
+       .calculate_dccg_k1_k2_values = dcn32_calculate_dccg_k1_k2_values,
+       .set_pixels_per_cycle = dcn32_set_pixels_per_cycle,
+       .is_dp_dig_pixel_rate_div_policy = dcn32_is_dp_dig_pixel_rate_div_policy,
+       .dsc_pg_control = dcn35_dsc_pg_control,
+       .dsc_pg_status = dcn32_dsc_pg_status,
+       .enable_plane = dcn35_enable_plane,
+};
+
+void dcn351_hw_sequencer_construct(struct dc *dc)
+{
+       dc->hwss = dcn351_funcs;
+       dc->hwseq->funcs = dcn351_private_funcs;
+
+}
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn351/dcn351_init.h b/drivers/gpu/drm/amd/display/dc/hwss/dcn351/dcn351_init.h
new file mode 100644 (file)
index 0000000..970b010
--- /dev/null
@@ -0,0 +1,33 @@
+/*
+ * Copyright 2023 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_DCN351_INIT_H__
+#define __DC_DCN351_INIT_H__
+
+struct dc;
+
+void dcn351_hw_sequencer_construct(struct dc *dc);
+
+#endif /* __DC_DCN351_INIT_H__ */