136d26912SBhawanpreet Lakha /* 236d26912SBhawanpreet Lakha * Copyright 2020 Advanced Micro Devices, Inc. 336d26912SBhawanpreet Lakha * 436d26912SBhawanpreet Lakha * Permission is hereby granted, free of charge, to any person obtaining a 536d26912SBhawanpreet Lakha * copy of this software and associated documentation files (the "Software"), 636d26912SBhawanpreet Lakha * to deal in the Software without restriction, including without limitation 736d26912SBhawanpreet Lakha * the rights to use, copy, modify, merge, publish, distribute, sublicense, 836d26912SBhawanpreet Lakha * and/or sell copies of the Software, and to permit persons to whom the 936d26912SBhawanpreet Lakha * Software is furnished to do so, subject to the following conditions: 1036d26912SBhawanpreet Lakha * 1136d26912SBhawanpreet Lakha * The above copyright notice and this permission notice shall be included in 1236d26912SBhawanpreet Lakha * all copies or substantial portions of the Software. 1336d26912SBhawanpreet Lakha * 1436d26912SBhawanpreet Lakha * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 1536d26912SBhawanpreet Lakha * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 1636d26912SBhawanpreet Lakha * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 1736d26912SBhawanpreet Lakha * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR 1836d26912SBhawanpreet Lakha * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 1936d26912SBhawanpreet Lakha * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 2036d26912SBhawanpreet Lakha * OTHER DEALINGS IN THE SOFTWARE. 2136d26912SBhawanpreet Lakha * 2236d26912SBhawanpreet Lakha * Authors: AMD 2336d26912SBhawanpreet Lakha * 2436d26912SBhawanpreet Lakha */ 2536d26912SBhawanpreet Lakha 2636d26912SBhawanpreet Lakha #include "dcn302_init.h" 2736d26912SBhawanpreet Lakha #include "dcn302_resource.h" 2836d26912SBhawanpreet Lakha #include "dcn302_dccg.h" 2936d26912SBhawanpreet Lakha #include "irq/dcn302/irq_service_dcn302.h" 3036d26912SBhawanpreet Lakha 3136d26912SBhawanpreet Lakha #include "dcn30/dcn30_dio_link_encoder.h" 3236d26912SBhawanpreet Lakha #include "dcn30/dcn30_dio_stream_encoder.h" 3336d26912SBhawanpreet Lakha #include "dcn30/dcn30_dwb.h" 3436d26912SBhawanpreet Lakha #include "dcn30/dcn30_dpp.h" 3536d26912SBhawanpreet Lakha #include "dcn30/dcn30_hubbub.h" 3636d26912SBhawanpreet Lakha #include "dcn30/dcn30_hubp.h" 3736d26912SBhawanpreet Lakha #include "dcn30/dcn30_mmhubbub.h" 3836d26912SBhawanpreet Lakha #include "dcn30/dcn30_mpc.h" 3936d26912SBhawanpreet Lakha #include "dcn30/dcn30_opp.h" 4036d26912SBhawanpreet Lakha #include "dcn30/dcn30_optc.h" 4136d26912SBhawanpreet Lakha #include "dcn30/dcn30_resource.h" 4236d26912SBhawanpreet Lakha 4336d26912SBhawanpreet Lakha #include "dcn20/dcn20_dsc.h" 4436d26912SBhawanpreet Lakha #include "dcn20/dcn20_resource.h" 4536d26912SBhawanpreet Lakha 4636d26912SBhawanpreet Lakha #include "dcn10/dcn10_resource.h" 4736d26912SBhawanpreet Lakha 4836d26912SBhawanpreet Lakha #include "dce/dce_abm.h" 4936d26912SBhawanpreet Lakha #include "dce/dce_audio.h" 5036d26912SBhawanpreet Lakha #include "dce/dce_aux.h" 5136d26912SBhawanpreet Lakha #include "dce/dce_clock_source.h" 5236d26912SBhawanpreet Lakha #include "dce/dce_hwseq.h" 5336d26912SBhawanpreet Lakha #include "dce/dce_i2c_hw.h" 5436d26912SBhawanpreet Lakha #include "dce/dce_panel_cntl.h" 5536d26912SBhawanpreet Lakha #include "dce/dmub_abm.h" 5665e05ca7SJoshua Aberback #include "dce/dmub_psr.h" 57163e3bcbSSamson Tam #include "clk_mgr.h" 5836d26912SBhawanpreet Lakha 5936d26912SBhawanpreet Lakha #include "hw_sequencer_private.h" 6036d26912SBhawanpreet Lakha #include "reg_helper.h" 6136d26912SBhawanpreet Lakha #include "resource.h" 6236d26912SBhawanpreet Lakha #include "vm_helper.h" 6336d26912SBhawanpreet Lakha 6436d26912SBhawanpreet Lakha #include "dimgrey_cavefish_ip_offset.h" 659713158cSBhawanpreet Lakha #include "dcn/dcn_3_0_2_offset.h" 669713158cSBhawanpreet Lakha #include "dcn/dcn_3_0_2_sh_mask.h" 6736d26912SBhawanpreet Lakha #include "dcn/dpcs_3_0_0_offset.h" 6836d26912SBhawanpreet Lakha #include "dcn/dpcs_3_0_0_sh_mask.h" 6936d26912SBhawanpreet Lakha #include "nbio/nbio_7_4_offset.h" 7026d94a46SBhawanpreet Lakha #include "amdgpu_socbb.h" 7136d26912SBhawanpreet Lakha 7236d26912SBhawanpreet Lakha #define DC_LOGGER_INIT(logger) 7336d26912SBhawanpreet Lakha 7436d26912SBhawanpreet Lakha struct _vcs_dpi_ip_params_st dcn3_02_ip = { 7536d26912SBhawanpreet Lakha .use_min_dcfclk = 0, 7636d26912SBhawanpreet Lakha .clamp_min_dcfclk = 0, 7736d26912SBhawanpreet Lakha .odm_capable = 1, 7836d26912SBhawanpreet Lakha .gpuvm_enable = 1, 7936d26912SBhawanpreet Lakha .hostvm_enable = 0, 8036d26912SBhawanpreet Lakha .gpuvm_max_page_table_levels = 4, 8136d26912SBhawanpreet Lakha .hostvm_max_page_table_levels = 4, 8236d26912SBhawanpreet Lakha .hostvm_cached_page_table_levels = 0, 8336d26912SBhawanpreet Lakha .pte_group_size_bytes = 2048, 8436d26912SBhawanpreet Lakha .num_dsc = 5, 8536d26912SBhawanpreet Lakha .rob_buffer_size_kbytes = 184, 8636d26912SBhawanpreet Lakha .det_buffer_size_kbytes = 184, 8736d26912SBhawanpreet Lakha .dpte_buffer_size_in_pte_reqs_luma = 64, 8836d26912SBhawanpreet Lakha .dpte_buffer_size_in_pte_reqs_chroma = 34, 8936d26912SBhawanpreet Lakha .pde_proc_buffer_size_64k_reqs = 48, 9036d26912SBhawanpreet Lakha .dpp_output_buffer_pixels = 2560, 9136d26912SBhawanpreet Lakha .opp_output_buffer_lines = 1, 9236d26912SBhawanpreet Lakha .pixel_chunk_size_kbytes = 8, 9336d26912SBhawanpreet Lakha .pte_enable = 1, 9436d26912SBhawanpreet Lakha .max_page_table_levels = 2, 9536d26912SBhawanpreet Lakha .pte_chunk_size_kbytes = 2, // ? 9636d26912SBhawanpreet Lakha .meta_chunk_size_kbytes = 2, 9736d26912SBhawanpreet Lakha .writeback_chunk_size_kbytes = 8, 9836d26912SBhawanpreet Lakha .line_buffer_size_bits = 789504, 9936d26912SBhawanpreet Lakha .is_line_buffer_bpp_fixed = 0, // ? 10036d26912SBhawanpreet Lakha .line_buffer_fixed_bpp = 0, // ? 10136d26912SBhawanpreet Lakha .dcc_supported = true, 10236d26912SBhawanpreet Lakha .writeback_interface_buffer_size_kbytes = 90, 10336d26912SBhawanpreet Lakha .writeback_line_buffer_buffer_size = 0, 104234cc26fSDmytro Laktyushkin .max_line_buffer_lines = 12, 10536d26912SBhawanpreet Lakha .writeback_luma_buffer_size_kbytes = 12, // writeback_line_buffer_buffer_size = 656640 10636d26912SBhawanpreet Lakha .writeback_chroma_buffer_size_kbytes = 8, 10736d26912SBhawanpreet Lakha .writeback_chroma_line_buffer_width_pixels = 4, 10836d26912SBhawanpreet Lakha .writeback_max_hscl_ratio = 1, 10936d26912SBhawanpreet Lakha .writeback_max_vscl_ratio = 1, 11036d26912SBhawanpreet Lakha .writeback_min_hscl_ratio = 1, 11136d26912SBhawanpreet Lakha .writeback_min_vscl_ratio = 1, 11236d26912SBhawanpreet Lakha .writeback_max_hscl_taps = 1, 11336d26912SBhawanpreet Lakha .writeback_max_vscl_taps = 1, 11436d26912SBhawanpreet Lakha .writeback_line_buffer_luma_buffer_size = 0, 11536d26912SBhawanpreet Lakha .writeback_line_buffer_chroma_buffer_size = 14643, 11636d26912SBhawanpreet Lakha .cursor_buffer_size = 8, 11736d26912SBhawanpreet Lakha .cursor_chunk_size = 2, 11836d26912SBhawanpreet Lakha .max_num_otg = 5, 11936d26912SBhawanpreet Lakha .max_num_dpp = 5, 12036d26912SBhawanpreet Lakha .max_num_wb = 1, 12136d26912SBhawanpreet Lakha .max_dchub_pscl_bw_pix_per_clk = 4, 12236d26912SBhawanpreet Lakha .max_pscl_lb_bw_pix_per_clk = 2, 12336d26912SBhawanpreet Lakha .max_lb_vscl_bw_pix_per_clk = 4, 12436d26912SBhawanpreet Lakha .max_vscl_hscl_bw_pix_per_clk = 4, 12536d26912SBhawanpreet Lakha .max_hscl_ratio = 6, 12636d26912SBhawanpreet Lakha .max_vscl_ratio = 6, 12736d26912SBhawanpreet Lakha .hscl_mults = 4, 12836d26912SBhawanpreet Lakha .vscl_mults = 4, 12936d26912SBhawanpreet Lakha .max_hscl_taps = 8, 13036d26912SBhawanpreet Lakha .max_vscl_taps = 8, 13136d26912SBhawanpreet Lakha .dispclk_ramp_margin_percent = 1, 13236d26912SBhawanpreet Lakha .underscan_factor = 1.11, 13336d26912SBhawanpreet Lakha .min_vblank_lines = 32, 13436d26912SBhawanpreet Lakha .dppclk_delay_subtotal = 46, 13536d26912SBhawanpreet Lakha .dynamic_metadata_vm_enabled = true, 13636d26912SBhawanpreet Lakha .dppclk_delay_scl_lb_only = 16, 13736d26912SBhawanpreet Lakha .dppclk_delay_scl = 50, 13836d26912SBhawanpreet Lakha .dppclk_delay_cnvc_formatter = 27, 13936d26912SBhawanpreet Lakha .dppclk_delay_cnvc_cursor = 6, 14036d26912SBhawanpreet Lakha .dispclk_delay_subtotal = 119, 14136d26912SBhawanpreet Lakha .dcfclk_cstate_latency = 5.2, // SRExitTime 14236d26912SBhawanpreet Lakha .max_inter_dcn_tile_repeaters = 8, 14336d26912SBhawanpreet Lakha .max_num_hdmi_frl_outputs = 1, 14436d26912SBhawanpreet Lakha .odm_combine_4to1_supported = true, 14536d26912SBhawanpreet Lakha 14636d26912SBhawanpreet Lakha .xfc_supported = false, 14736d26912SBhawanpreet Lakha .xfc_fill_bw_overhead_percent = 10.0, 14836d26912SBhawanpreet Lakha .xfc_fill_constant_bytes = 0, 14936d26912SBhawanpreet Lakha .gfx7_compat_tiling_supported = 0, 15036d26912SBhawanpreet Lakha .number_of_cursors = 1, 15136d26912SBhawanpreet Lakha }; 15236d26912SBhawanpreet Lakha 15336d26912SBhawanpreet Lakha struct _vcs_dpi_soc_bounding_box_st dcn3_02_soc = { 15436d26912SBhawanpreet Lakha .clock_limits = { 15536d26912SBhawanpreet Lakha { 15636d26912SBhawanpreet Lakha .state = 0, 15736d26912SBhawanpreet Lakha .dispclk_mhz = 562.0, 15836d26912SBhawanpreet Lakha .dppclk_mhz = 300.0, 15936d26912SBhawanpreet Lakha .phyclk_mhz = 300.0, 16036d26912SBhawanpreet Lakha .phyclk_d18_mhz = 667.0, 16136d26912SBhawanpreet Lakha .dscclk_mhz = 405.6, 16236d26912SBhawanpreet Lakha }, 16336d26912SBhawanpreet Lakha }, 16436d26912SBhawanpreet Lakha 16536d26912SBhawanpreet Lakha .min_dcfclk = 500.0, /* TODO: set this to actual min DCFCLK */ 16636d26912SBhawanpreet Lakha .num_states = 1, 167ceaf9f57SAurabindo Pillai .sr_exit_time_us = 26.5, 168ceaf9f57SAurabindo Pillai .sr_enter_plus_exit_time_us = 31, 16936d26912SBhawanpreet Lakha .urgent_latency_us = 4.0, 17036d26912SBhawanpreet Lakha .urgent_latency_pixel_data_only_us = 4.0, 17136d26912SBhawanpreet Lakha .urgent_latency_pixel_mixed_with_vm_data_us = 4.0, 17236d26912SBhawanpreet Lakha .urgent_latency_vm_data_only_us = 4.0, 17336d26912SBhawanpreet Lakha .urgent_out_of_order_return_per_channel_pixel_only_bytes = 4096, 17436d26912SBhawanpreet Lakha .urgent_out_of_order_return_per_channel_pixel_and_vm_bytes = 4096, 17536d26912SBhawanpreet Lakha .urgent_out_of_order_return_per_channel_vm_only_bytes = 4096, 17636d26912SBhawanpreet Lakha .pct_ideal_dram_sdp_bw_after_urgent_pixel_only = 80.0, 17736d26912SBhawanpreet Lakha .pct_ideal_dram_sdp_bw_after_urgent_pixel_and_vm = 60.0, 17836d26912SBhawanpreet Lakha .pct_ideal_dram_sdp_bw_after_urgent_vm_only = 40.0, 17936d26912SBhawanpreet Lakha .max_avg_sdp_bw_use_normal_percent = 60.0, 18036d26912SBhawanpreet Lakha .max_avg_dram_bw_use_normal_percent = 40.0, 18136d26912SBhawanpreet Lakha .writeback_latency_us = 12.0, 18236d26912SBhawanpreet Lakha .max_request_size_bytes = 256, 18336d26912SBhawanpreet Lakha .fabric_datapath_to_dcn_data_return_bytes = 64, 18436d26912SBhawanpreet Lakha .dcn_downspread_percent = 0.5, 18536d26912SBhawanpreet Lakha .downspread_percent = 0.38, 18636d26912SBhawanpreet Lakha .dram_page_open_time_ns = 50.0, 18736d26912SBhawanpreet Lakha .dram_rw_turnaround_time_ns = 17.5, 18836d26912SBhawanpreet Lakha .dram_return_buffer_per_channel_bytes = 8192, 18936d26912SBhawanpreet Lakha .round_trip_ping_latency_dcfclk_cycles = 156, 19036d26912SBhawanpreet Lakha .urgent_out_of_order_return_per_channel_bytes = 4096, 19136d26912SBhawanpreet Lakha .channel_interleave_bytes = 256, 19236d26912SBhawanpreet Lakha .num_banks = 8, 19336d26912SBhawanpreet Lakha .gpuvm_min_page_size_bytes = 4096, 19436d26912SBhawanpreet Lakha .hostvm_min_page_size_bytes = 4096, 195163e3bcbSSamson Tam .dram_clock_change_latency_us = 404, 19636d26912SBhawanpreet Lakha .dummy_pstate_latency_us = 5, 19736d26912SBhawanpreet Lakha .writeback_dram_clock_change_latency_us = 23.0, 19836d26912SBhawanpreet Lakha .return_bus_width_bytes = 64, 19936d26912SBhawanpreet Lakha .dispclk_dppclk_vco_speed_mhz = 3650, 20036d26912SBhawanpreet Lakha .xfc_bus_transport_time_us = 20, // ? 20136d26912SBhawanpreet Lakha .xfc_xbuf_latency_tolerance_us = 4, // ? 20236d26912SBhawanpreet Lakha .use_urgent_burst_bw = 1, // ? 20336d26912SBhawanpreet Lakha .do_urgent_latency_adjustment = true, 20436d26912SBhawanpreet Lakha .urgent_latency_adjustment_fabric_clock_component_us = 1.0, 20536d26912SBhawanpreet Lakha .urgent_latency_adjustment_fabric_clock_reference_mhz = 1000, 20636d26912SBhawanpreet Lakha }; 20736d26912SBhawanpreet Lakha 20836d26912SBhawanpreet Lakha static const struct dc_debug_options debug_defaults_drv = { 20936d26912SBhawanpreet Lakha .disable_dmcu = true, 21036d26912SBhawanpreet Lakha .force_abm_enable = false, 21136d26912SBhawanpreet Lakha .timing_trace = false, 21236d26912SBhawanpreet Lakha .clock_trace = true, 21336d26912SBhawanpreet Lakha .disable_pplib_clock_request = true, 214*458c79a8SAngus Wang .pipe_split_policy = MPC_SPLIT_DYNAMIC, 21536d26912SBhawanpreet Lakha .force_single_disp_pipe_split = false, 21636d26912SBhawanpreet Lakha .disable_dcc = DCC_ENABLE, 21736d26912SBhawanpreet Lakha .vsr_support = true, 21836d26912SBhawanpreet Lakha .performance_trace = false, 21936d26912SBhawanpreet Lakha .max_downscale_src_width = 7680,/*upto 8K*/ 22036d26912SBhawanpreet Lakha .disable_pplib_wm_range = false, 22136d26912SBhawanpreet Lakha .scl_reset_length10 = true, 22236d26912SBhawanpreet Lakha .sanity_checks = false, 22336d26912SBhawanpreet Lakha .underflow_assert_delay_us = 0xFFFFFFFF, 22436d26912SBhawanpreet Lakha .dwb_fi_phase = -1, // -1 = disable, 22536d26912SBhawanpreet Lakha .dmub_command_table = true, 2269d335e17SDmytro Laktyushkin .use_max_lb = true 22736d26912SBhawanpreet Lakha }; 22836d26912SBhawanpreet Lakha 22936d26912SBhawanpreet Lakha static const struct dc_debug_options debug_defaults_diags = { 23036d26912SBhawanpreet Lakha .disable_dmcu = true, 23136d26912SBhawanpreet Lakha .force_abm_enable = false, 23236d26912SBhawanpreet Lakha .timing_trace = true, 23336d26912SBhawanpreet Lakha .clock_trace = true, 23436d26912SBhawanpreet Lakha .disable_dpp_power_gate = true, 23536d26912SBhawanpreet Lakha .disable_hubp_power_gate = true, 23636d26912SBhawanpreet Lakha .disable_clock_gate = true, 23736d26912SBhawanpreet Lakha .disable_pplib_clock_request = true, 23836d26912SBhawanpreet Lakha .disable_pplib_wm_range = true, 23936d26912SBhawanpreet Lakha .disable_stutter = false, 24036d26912SBhawanpreet Lakha .scl_reset_length10 = true, 24136d26912SBhawanpreet Lakha .dwb_fi_phase = -1, // -1 = disable 24236d26912SBhawanpreet Lakha .dmub_command_table = true, 24336d26912SBhawanpreet Lakha .enable_tri_buf = true, 24465e05ca7SJoshua Aberback .disable_psr = true, 2459d335e17SDmytro Laktyushkin .use_max_lb = true 24636d26912SBhawanpreet Lakha }; 24736d26912SBhawanpreet Lakha 24836d26912SBhawanpreet Lakha enum dcn302_clk_src_array_id { 24936d26912SBhawanpreet Lakha DCN302_CLK_SRC_PLL0, 25036d26912SBhawanpreet Lakha DCN302_CLK_SRC_PLL1, 25136d26912SBhawanpreet Lakha DCN302_CLK_SRC_PLL2, 25236d26912SBhawanpreet Lakha DCN302_CLK_SRC_PLL3, 25336d26912SBhawanpreet Lakha DCN302_CLK_SRC_PLL4, 25436d26912SBhawanpreet Lakha DCN302_CLK_SRC_TOTAL 25536d26912SBhawanpreet Lakha }; 25636d26912SBhawanpreet Lakha 25736d26912SBhawanpreet Lakha static const struct resource_caps res_cap_dcn302 = { 25836d26912SBhawanpreet Lakha .num_timing_generator = 5, 25936d26912SBhawanpreet Lakha .num_opp = 5, 26036d26912SBhawanpreet Lakha .num_video_plane = 5, 26136d26912SBhawanpreet Lakha .num_audio = 5, 26236d26912SBhawanpreet Lakha .num_stream_encoder = 5, 26336d26912SBhawanpreet Lakha .num_dwb = 1, 26436d26912SBhawanpreet Lakha .num_ddc = 5, 26536d26912SBhawanpreet Lakha .num_vmid = 16, 26636d26912SBhawanpreet Lakha .num_mpc_3dlut = 2, 26736d26912SBhawanpreet Lakha .num_dsc = 5, 26836d26912SBhawanpreet Lakha }; 26936d26912SBhawanpreet Lakha 27036d26912SBhawanpreet Lakha static const struct dc_plane_cap plane_cap = { 27136d26912SBhawanpreet Lakha .type = DC_PLANE_TYPE_DCN_UNIVERSAL, 27236d26912SBhawanpreet Lakha .blends_with_above = true, 27336d26912SBhawanpreet Lakha .blends_with_below = true, 27436d26912SBhawanpreet Lakha .per_pixel_alpha = true, 27536d26912SBhawanpreet Lakha .pixel_format_support = { 27636d26912SBhawanpreet Lakha .argb8888 = true, 27736d26912SBhawanpreet Lakha .nv12 = true, 27836d26912SBhawanpreet Lakha .fp16 = true, 279ebe5ffd8SStylon Wang .p010 = true, 28036d26912SBhawanpreet Lakha .ayuv = false, 28136d26912SBhawanpreet Lakha }, 28236d26912SBhawanpreet Lakha .max_upscale_factor = { 28336d26912SBhawanpreet Lakha .argb8888 = 16000, 28436d26912SBhawanpreet Lakha .nv12 = 16000, 28536d26912SBhawanpreet Lakha .fp16 = 16000 28636d26912SBhawanpreet Lakha }, 28760d177fdSNikola Cornij /* 6:1 downscaling ratio: 1000/6 = 166.666 */ 28836d26912SBhawanpreet Lakha .max_downscale_factor = { 28960d177fdSNikola Cornij .argb8888 = 167, 29060d177fdSNikola Cornij .nv12 = 167, 29160d177fdSNikola Cornij .fp16 = 167 29236d26912SBhawanpreet Lakha }, 29336d26912SBhawanpreet Lakha 16, 29436d26912SBhawanpreet Lakha 16 29536d26912SBhawanpreet Lakha }; 29636d26912SBhawanpreet Lakha 29736d26912SBhawanpreet Lakha /* NBIO */ 29836d26912SBhawanpreet Lakha #define NBIO_BASE_INNER(seg) \ 29936d26912SBhawanpreet Lakha NBIO_BASE__INST0_SEG ## seg 30036d26912SBhawanpreet Lakha 30136d26912SBhawanpreet Lakha #define NBIO_BASE(seg) \ 30236d26912SBhawanpreet Lakha NBIO_BASE_INNER(seg) 30336d26912SBhawanpreet Lakha 30436d26912SBhawanpreet Lakha #define NBIO_SR(reg_name)\ 30536d26912SBhawanpreet Lakha .reg_name = NBIO_BASE(mm ## reg_name ## _BASE_IDX) + \ 30636d26912SBhawanpreet Lakha mm ## reg_name 30736d26912SBhawanpreet Lakha 30836d26912SBhawanpreet Lakha /* DCN */ 30936d26912SBhawanpreet Lakha #undef BASE_INNER 31036d26912SBhawanpreet Lakha #define BASE_INNER(seg) DCN_BASE__INST0_SEG ## seg 31136d26912SBhawanpreet Lakha 31236d26912SBhawanpreet Lakha #define BASE(seg) BASE_INNER(seg) 31336d26912SBhawanpreet Lakha 31436d26912SBhawanpreet Lakha #define SR(reg_name)\ 31536d26912SBhawanpreet Lakha .reg_name = BASE(mm ## reg_name ## _BASE_IDX) + mm ## reg_name 31636d26912SBhawanpreet Lakha 31736d26912SBhawanpreet Lakha #define SF(reg_name, field_name, post_fix)\ 31836d26912SBhawanpreet Lakha .field_name = reg_name ## __ ## field_name ## post_fix 31936d26912SBhawanpreet Lakha 32036d26912SBhawanpreet Lakha #define SRI(reg_name, block, id)\ 32136d26912SBhawanpreet Lakha .reg_name = BASE(mm ## block ## id ## _ ## reg_name ## _BASE_IDX) + mm ## block ## id ## _ ## reg_name 32236d26912SBhawanpreet Lakha 32336d26912SBhawanpreet Lakha #define SRI2(reg_name, block, id)\ 32436d26912SBhawanpreet Lakha .reg_name = BASE(mm ## reg_name ## _BASE_IDX) + mm ## reg_name 32536d26912SBhawanpreet Lakha 32636d26912SBhawanpreet Lakha #define SRII(reg_name, block, id)\ 32736d26912SBhawanpreet Lakha .reg_name[id] = BASE(mm ## block ## id ## _ ## reg_name ## _BASE_IDX) + \ 32836d26912SBhawanpreet Lakha mm ## block ## id ## _ ## reg_name 32936d26912SBhawanpreet Lakha 33036d26912SBhawanpreet Lakha #define DCCG_SRII(reg_name, block, id)\ 33136d26912SBhawanpreet Lakha .block ## _ ## reg_name[id] = BASE(mm ## block ## id ## _ ## reg_name ## _BASE_IDX) + \ 33236d26912SBhawanpreet Lakha mm ## block ## id ## _ ## reg_name 33336d26912SBhawanpreet Lakha 33436d26912SBhawanpreet Lakha #define VUPDATE_SRII(reg_name, block, id)\ 33536d26912SBhawanpreet Lakha .reg_name[id] = BASE(mm ## reg_name ## _ ## block ## id ## _BASE_IDX) + \ 33636d26912SBhawanpreet Lakha mm ## reg_name ## _ ## block ## id 33736d26912SBhawanpreet Lakha 33836d26912SBhawanpreet Lakha #define SRII_DWB(reg_name, temp_name, block, id)\ 33936d26912SBhawanpreet Lakha .reg_name[id] = BASE(mm ## block ## id ## _ ## temp_name ## _BASE_IDX) + \ 34036d26912SBhawanpreet Lakha mm ## block ## id ## _ ## temp_name 34136d26912SBhawanpreet Lakha 34236d26912SBhawanpreet Lakha #define SRII_MPC_RMU(reg_name, block, id)\ 34336d26912SBhawanpreet Lakha .RMU##_##reg_name[id] = BASE(mm ## block ## id ## _ ## reg_name ## _BASE_IDX) + \ 34436d26912SBhawanpreet Lakha mm ## block ## id ## _ ## reg_name 34536d26912SBhawanpreet Lakha 34636d26912SBhawanpreet Lakha static const struct dcn_hubbub_registers hubbub_reg = { 34736d26912SBhawanpreet Lakha HUBBUB_REG_LIST_DCN30(0) 34836d26912SBhawanpreet Lakha }; 34936d26912SBhawanpreet Lakha 35036d26912SBhawanpreet Lakha static const struct dcn_hubbub_shift hubbub_shift = { 35136d26912SBhawanpreet Lakha HUBBUB_MASK_SH_LIST_DCN30(__SHIFT) 35236d26912SBhawanpreet Lakha }; 35336d26912SBhawanpreet Lakha 35436d26912SBhawanpreet Lakha static const struct dcn_hubbub_mask hubbub_mask = { 35536d26912SBhawanpreet Lakha HUBBUB_MASK_SH_LIST_DCN30(_MASK) 35636d26912SBhawanpreet Lakha }; 35736d26912SBhawanpreet Lakha 35836d26912SBhawanpreet Lakha #define vmid_regs(id)\ 35936d26912SBhawanpreet Lakha [id] = { DCN20_VMID_REG_LIST(id) } 36036d26912SBhawanpreet Lakha 36136d26912SBhawanpreet Lakha static const struct dcn_vmid_registers vmid_regs[] = { 36236d26912SBhawanpreet Lakha vmid_regs(0), 36336d26912SBhawanpreet Lakha vmid_regs(1), 36436d26912SBhawanpreet Lakha vmid_regs(2), 36536d26912SBhawanpreet Lakha vmid_regs(3), 36636d26912SBhawanpreet Lakha vmid_regs(4), 36736d26912SBhawanpreet Lakha vmid_regs(5), 36836d26912SBhawanpreet Lakha vmid_regs(6), 36936d26912SBhawanpreet Lakha vmid_regs(7), 37036d26912SBhawanpreet Lakha vmid_regs(8), 37136d26912SBhawanpreet Lakha vmid_regs(9), 37236d26912SBhawanpreet Lakha vmid_regs(10), 37336d26912SBhawanpreet Lakha vmid_regs(11), 37436d26912SBhawanpreet Lakha vmid_regs(12), 37536d26912SBhawanpreet Lakha vmid_regs(13), 37636d26912SBhawanpreet Lakha vmid_regs(14), 37736d26912SBhawanpreet Lakha vmid_regs(15) 37836d26912SBhawanpreet Lakha }; 37936d26912SBhawanpreet Lakha 38036d26912SBhawanpreet Lakha static const struct dcn20_vmid_shift vmid_shifts = { 38136d26912SBhawanpreet Lakha DCN20_VMID_MASK_SH_LIST(__SHIFT) 38236d26912SBhawanpreet Lakha }; 38336d26912SBhawanpreet Lakha 38436d26912SBhawanpreet Lakha static const struct dcn20_vmid_mask vmid_masks = { 38536d26912SBhawanpreet Lakha DCN20_VMID_MASK_SH_LIST(_MASK) 38636d26912SBhawanpreet Lakha }; 38736d26912SBhawanpreet Lakha 38836d26912SBhawanpreet Lakha static struct hubbub *dcn302_hubbub_create(struct dc_context *ctx) 38936d26912SBhawanpreet Lakha { 39036d26912SBhawanpreet Lakha int i; 39136d26912SBhawanpreet Lakha 39236d26912SBhawanpreet Lakha struct dcn20_hubbub *hubbub3 = kzalloc(sizeof(struct dcn20_hubbub), GFP_KERNEL); 39336d26912SBhawanpreet Lakha 39436d26912SBhawanpreet Lakha if (!hubbub3) 39536d26912SBhawanpreet Lakha return NULL; 39636d26912SBhawanpreet Lakha 39736d26912SBhawanpreet Lakha hubbub3_construct(hubbub3, ctx, &hubbub_reg, &hubbub_shift, &hubbub_mask); 39836d26912SBhawanpreet Lakha 39936d26912SBhawanpreet Lakha for (i = 0; i < res_cap_dcn302.num_vmid; i++) { 40036d26912SBhawanpreet Lakha struct dcn20_vmid *vmid = &hubbub3->vmid[i]; 40136d26912SBhawanpreet Lakha 40236d26912SBhawanpreet Lakha vmid->ctx = ctx; 40336d26912SBhawanpreet Lakha 40436d26912SBhawanpreet Lakha vmid->regs = &vmid_regs[i]; 40536d26912SBhawanpreet Lakha vmid->shifts = &vmid_shifts; 40636d26912SBhawanpreet Lakha vmid->masks = &vmid_masks; 40736d26912SBhawanpreet Lakha } 40836d26912SBhawanpreet Lakha 40936d26912SBhawanpreet Lakha return &hubbub3->base; 41036d26912SBhawanpreet Lakha } 41136d26912SBhawanpreet Lakha 41236d26912SBhawanpreet Lakha #define vpg_regs(id)\ 41336d26912SBhawanpreet Lakha [id] = { VPG_DCN3_REG_LIST(id) } 41436d26912SBhawanpreet Lakha 41536d26912SBhawanpreet Lakha static const struct dcn30_vpg_registers vpg_regs[] = { 41636d26912SBhawanpreet Lakha vpg_regs(0), 41736d26912SBhawanpreet Lakha vpg_regs(1), 41836d26912SBhawanpreet Lakha vpg_regs(2), 41936d26912SBhawanpreet Lakha vpg_regs(3), 42036d26912SBhawanpreet Lakha vpg_regs(4), 42136d26912SBhawanpreet Lakha vpg_regs(5) 42236d26912SBhawanpreet Lakha }; 42336d26912SBhawanpreet Lakha 42436d26912SBhawanpreet Lakha static const struct dcn30_vpg_shift vpg_shift = { 42536d26912SBhawanpreet Lakha DCN3_VPG_MASK_SH_LIST(__SHIFT) 42636d26912SBhawanpreet Lakha }; 42736d26912SBhawanpreet Lakha 42836d26912SBhawanpreet Lakha static const struct dcn30_vpg_mask vpg_mask = { 42936d26912SBhawanpreet Lakha DCN3_VPG_MASK_SH_LIST(_MASK) 43036d26912SBhawanpreet Lakha }; 43136d26912SBhawanpreet Lakha 43236d26912SBhawanpreet Lakha static struct vpg *dcn302_vpg_create(struct dc_context *ctx, uint32_t inst) 43336d26912SBhawanpreet Lakha { 43436d26912SBhawanpreet Lakha struct dcn30_vpg *vpg3 = kzalloc(sizeof(struct dcn30_vpg), GFP_KERNEL); 43536d26912SBhawanpreet Lakha 43636d26912SBhawanpreet Lakha if (!vpg3) 43736d26912SBhawanpreet Lakha return NULL; 43836d26912SBhawanpreet Lakha 43936d26912SBhawanpreet Lakha vpg3_construct(vpg3, ctx, inst, &vpg_regs[inst], &vpg_shift, &vpg_mask); 44036d26912SBhawanpreet Lakha 44136d26912SBhawanpreet Lakha return &vpg3->base; 44236d26912SBhawanpreet Lakha } 44336d26912SBhawanpreet Lakha 44436d26912SBhawanpreet Lakha #define afmt_regs(id)\ 44536d26912SBhawanpreet Lakha [id] = { AFMT_DCN3_REG_LIST(id) } 44636d26912SBhawanpreet Lakha 44736d26912SBhawanpreet Lakha static const struct dcn30_afmt_registers afmt_regs[] = { 44836d26912SBhawanpreet Lakha afmt_regs(0), 44936d26912SBhawanpreet Lakha afmt_regs(1), 45036d26912SBhawanpreet Lakha afmt_regs(2), 45136d26912SBhawanpreet Lakha afmt_regs(3), 45236d26912SBhawanpreet Lakha afmt_regs(4), 45336d26912SBhawanpreet Lakha afmt_regs(5) 45436d26912SBhawanpreet Lakha }; 45536d26912SBhawanpreet Lakha 45636d26912SBhawanpreet Lakha static const struct dcn30_afmt_shift afmt_shift = { 45736d26912SBhawanpreet Lakha DCN3_AFMT_MASK_SH_LIST(__SHIFT) 45836d26912SBhawanpreet Lakha }; 45936d26912SBhawanpreet Lakha 46036d26912SBhawanpreet Lakha static const struct dcn30_afmt_mask afmt_mask = { 46136d26912SBhawanpreet Lakha DCN3_AFMT_MASK_SH_LIST(_MASK) 46236d26912SBhawanpreet Lakha }; 46336d26912SBhawanpreet Lakha 46436d26912SBhawanpreet Lakha static struct afmt *dcn302_afmt_create(struct dc_context *ctx, uint32_t inst) 46536d26912SBhawanpreet Lakha { 46636d26912SBhawanpreet Lakha struct dcn30_afmt *afmt3 = kzalloc(sizeof(struct dcn30_afmt), GFP_KERNEL); 46736d26912SBhawanpreet Lakha 46836d26912SBhawanpreet Lakha if (!afmt3) 46936d26912SBhawanpreet Lakha return NULL; 47036d26912SBhawanpreet Lakha 47136d26912SBhawanpreet Lakha afmt3_construct(afmt3, ctx, inst, &afmt_regs[inst], &afmt_shift, &afmt_mask); 47236d26912SBhawanpreet Lakha 47336d26912SBhawanpreet Lakha return &afmt3->base; 47436d26912SBhawanpreet Lakha } 47536d26912SBhawanpreet Lakha 47636d26912SBhawanpreet Lakha #define audio_regs(id)\ 47736d26912SBhawanpreet Lakha [id] = { AUD_COMMON_REG_LIST(id) } 47836d26912SBhawanpreet Lakha 47936d26912SBhawanpreet Lakha static const struct dce_audio_registers audio_regs[] = { 48036d26912SBhawanpreet Lakha audio_regs(0), 48136d26912SBhawanpreet Lakha audio_regs(1), 48236d26912SBhawanpreet Lakha audio_regs(2), 48336d26912SBhawanpreet Lakha audio_regs(3), 48436d26912SBhawanpreet Lakha audio_regs(4), 48536d26912SBhawanpreet Lakha audio_regs(5), 48636d26912SBhawanpreet Lakha audio_regs(6) 48736d26912SBhawanpreet Lakha }; 48836d26912SBhawanpreet Lakha 48936d26912SBhawanpreet Lakha #define DCE120_AUD_COMMON_MASK_SH_LIST(mask_sh)\ 49036d26912SBhawanpreet Lakha SF(AZF0ENDPOINT0_AZALIA_F0_CODEC_ENDPOINT_INDEX, AZALIA_ENDPOINT_REG_INDEX, mask_sh),\ 49136d26912SBhawanpreet Lakha SF(AZF0ENDPOINT0_AZALIA_F0_CODEC_ENDPOINT_DATA, AZALIA_ENDPOINT_REG_DATA, mask_sh),\ 49236d26912SBhawanpreet Lakha AUD_COMMON_MASK_SH_LIST_BASE(mask_sh) 49336d26912SBhawanpreet Lakha 49436d26912SBhawanpreet Lakha static const struct dce_audio_shift audio_shift = { 49536d26912SBhawanpreet Lakha DCE120_AUD_COMMON_MASK_SH_LIST(__SHIFT) 49636d26912SBhawanpreet Lakha }; 49736d26912SBhawanpreet Lakha 49836d26912SBhawanpreet Lakha static const struct dce_audio_mask audio_mask = { 49936d26912SBhawanpreet Lakha DCE120_AUD_COMMON_MASK_SH_LIST(_MASK) 50036d26912SBhawanpreet Lakha }; 50136d26912SBhawanpreet Lakha 50236d26912SBhawanpreet Lakha static struct audio *dcn302_create_audio(struct dc_context *ctx, unsigned int inst) 50336d26912SBhawanpreet Lakha { 50436d26912SBhawanpreet Lakha return dce_audio_create(ctx, inst, &audio_regs[inst], &audio_shift, &audio_mask); 50536d26912SBhawanpreet Lakha } 50636d26912SBhawanpreet Lakha 50736d26912SBhawanpreet Lakha #define stream_enc_regs(id)\ 50836d26912SBhawanpreet Lakha [id] = { SE_DCN3_REG_LIST(id) } 50936d26912SBhawanpreet Lakha 51036d26912SBhawanpreet Lakha static const struct dcn10_stream_enc_registers stream_enc_regs[] = { 51136d26912SBhawanpreet Lakha stream_enc_regs(0), 51236d26912SBhawanpreet Lakha stream_enc_regs(1), 51336d26912SBhawanpreet Lakha stream_enc_regs(2), 51436d26912SBhawanpreet Lakha stream_enc_regs(3), 51536d26912SBhawanpreet Lakha stream_enc_regs(4) 51636d26912SBhawanpreet Lakha }; 51736d26912SBhawanpreet Lakha 51836d26912SBhawanpreet Lakha static const struct dcn10_stream_encoder_shift se_shift = { 51936d26912SBhawanpreet Lakha SE_COMMON_MASK_SH_LIST_DCN30(__SHIFT) 52036d26912SBhawanpreet Lakha }; 52136d26912SBhawanpreet Lakha 52236d26912SBhawanpreet Lakha static const struct dcn10_stream_encoder_mask se_mask = { 52336d26912SBhawanpreet Lakha SE_COMMON_MASK_SH_LIST_DCN30(_MASK) 52436d26912SBhawanpreet Lakha }; 52536d26912SBhawanpreet Lakha 52636d26912SBhawanpreet Lakha static struct stream_encoder *dcn302_stream_encoder_create(enum engine_id eng_id, struct dc_context *ctx) 52736d26912SBhawanpreet Lakha { 52836d26912SBhawanpreet Lakha struct dcn10_stream_encoder *enc1; 52936d26912SBhawanpreet Lakha struct vpg *vpg; 53036d26912SBhawanpreet Lakha struct afmt *afmt; 53136d26912SBhawanpreet Lakha int vpg_inst; 53236d26912SBhawanpreet Lakha int afmt_inst; 53336d26912SBhawanpreet Lakha 53436d26912SBhawanpreet Lakha /* Mapping of VPG, AFMT, DME register blocks to DIO block instance */ 53536d26912SBhawanpreet Lakha if (eng_id <= ENGINE_ID_DIGE) { 53636d26912SBhawanpreet Lakha vpg_inst = eng_id; 53736d26912SBhawanpreet Lakha afmt_inst = eng_id; 53836d26912SBhawanpreet Lakha } else 53936d26912SBhawanpreet Lakha return NULL; 54036d26912SBhawanpreet Lakha 54136d26912SBhawanpreet Lakha enc1 = kzalloc(sizeof(struct dcn10_stream_encoder), GFP_KERNEL); 54236d26912SBhawanpreet Lakha vpg = dcn302_vpg_create(ctx, vpg_inst); 54336d26912SBhawanpreet Lakha afmt = dcn302_afmt_create(ctx, afmt_inst); 54436d26912SBhawanpreet Lakha 5457b89bf83SAnson Jacob if (!enc1 || !vpg || !afmt) { 5467b89bf83SAnson Jacob kfree(enc1); 5477b89bf83SAnson Jacob kfree(vpg); 5487b89bf83SAnson Jacob kfree(afmt); 54936d26912SBhawanpreet Lakha return NULL; 5507b89bf83SAnson Jacob } 55136d26912SBhawanpreet Lakha 55236d26912SBhawanpreet Lakha dcn30_dio_stream_encoder_construct(enc1, ctx, ctx->dc_bios, eng_id, vpg, afmt, &stream_enc_regs[eng_id], 55336d26912SBhawanpreet Lakha &se_shift, &se_mask); 55436d26912SBhawanpreet Lakha 55536d26912SBhawanpreet Lakha return &enc1->base; 55636d26912SBhawanpreet Lakha } 55736d26912SBhawanpreet Lakha 55836d26912SBhawanpreet Lakha #define clk_src_regs(index, pllid)\ 55936d26912SBhawanpreet Lakha [index] = { CS_COMMON_REG_LIST_DCN3_02(index, pllid) } 56036d26912SBhawanpreet Lakha 56136d26912SBhawanpreet Lakha static const struct dce110_clk_src_regs clk_src_regs[] = { 56236d26912SBhawanpreet Lakha clk_src_regs(0, A), 56336d26912SBhawanpreet Lakha clk_src_regs(1, B), 56436d26912SBhawanpreet Lakha clk_src_regs(2, C), 56536d26912SBhawanpreet Lakha clk_src_regs(3, D), 56636d26912SBhawanpreet Lakha clk_src_regs(4, E) 56736d26912SBhawanpreet Lakha }; 56836d26912SBhawanpreet Lakha 56936d26912SBhawanpreet Lakha static const struct dce110_clk_src_shift cs_shift = { 57036d26912SBhawanpreet Lakha CS_COMMON_MASK_SH_LIST_DCN2_0(__SHIFT) 57136d26912SBhawanpreet Lakha }; 57236d26912SBhawanpreet Lakha 57336d26912SBhawanpreet Lakha static const struct dce110_clk_src_mask cs_mask = { 57436d26912SBhawanpreet Lakha CS_COMMON_MASK_SH_LIST_DCN2_0(_MASK) 57536d26912SBhawanpreet Lakha }; 57636d26912SBhawanpreet Lakha 57736d26912SBhawanpreet Lakha static struct clock_source *dcn302_clock_source_create(struct dc_context *ctx, struct dc_bios *bios, 57836d26912SBhawanpreet Lakha enum clock_source_id id, const struct dce110_clk_src_regs *regs, bool dp_clk_src) 57936d26912SBhawanpreet Lakha { 58036d26912SBhawanpreet Lakha struct dce110_clk_src *clk_src = kzalloc(sizeof(struct dce110_clk_src), GFP_KERNEL); 58136d26912SBhawanpreet Lakha 58236d26912SBhawanpreet Lakha if (!clk_src) 58336d26912SBhawanpreet Lakha return NULL; 58436d26912SBhawanpreet Lakha 58536d26912SBhawanpreet Lakha if (dcn3_clk_src_construct(clk_src, ctx, bios, id, regs, &cs_shift, &cs_mask)) { 58636d26912SBhawanpreet Lakha clk_src->base.dp_clk_src = dp_clk_src; 58736d26912SBhawanpreet Lakha return &clk_src->base; 58836d26912SBhawanpreet Lakha } 58936d26912SBhawanpreet Lakha 59036d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 59136d26912SBhawanpreet Lakha return NULL; 59236d26912SBhawanpreet Lakha } 59336d26912SBhawanpreet Lakha 59436d26912SBhawanpreet Lakha static const struct dce_hwseq_registers hwseq_reg = { 59536d26912SBhawanpreet Lakha HWSEQ_DCN302_REG_LIST() 59636d26912SBhawanpreet Lakha }; 59736d26912SBhawanpreet Lakha 59836d26912SBhawanpreet Lakha static const struct dce_hwseq_shift hwseq_shift = { 59936d26912SBhawanpreet Lakha HWSEQ_DCN302_MASK_SH_LIST(__SHIFT) 60036d26912SBhawanpreet Lakha }; 60136d26912SBhawanpreet Lakha 60236d26912SBhawanpreet Lakha static const struct dce_hwseq_mask hwseq_mask = { 60336d26912SBhawanpreet Lakha HWSEQ_DCN302_MASK_SH_LIST(_MASK) 60436d26912SBhawanpreet Lakha }; 60536d26912SBhawanpreet Lakha 60636d26912SBhawanpreet Lakha static struct dce_hwseq *dcn302_hwseq_create(struct dc_context *ctx) 60736d26912SBhawanpreet Lakha { 60836d26912SBhawanpreet Lakha struct dce_hwseq *hws = kzalloc(sizeof(struct dce_hwseq), GFP_KERNEL); 60936d26912SBhawanpreet Lakha 61036d26912SBhawanpreet Lakha if (hws) { 61136d26912SBhawanpreet Lakha hws->ctx = ctx; 61236d26912SBhawanpreet Lakha hws->regs = &hwseq_reg; 61336d26912SBhawanpreet Lakha hws->shifts = &hwseq_shift; 61436d26912SBhawanpreet Lakha hws->masks = &hwseq_mask; 61536d26912SBhawanpreet Lakha } 61636d26912SBhawanpreet Lakha return hws; 61736d26912SBhawanpreet Lakha } 61836d26912SBhawanpreet Lakha 61936d26912SBhawanpreet Lakha #define hubp_regs(id)\ 62036d26912SBhawanpreet Lakha [id] = { HUBP_REG_LIST_DCN30(id) } 62136d26912SBhawanpreet Lakha 62236d26912SBhawanpreet Lakha static const struct dcn_hubp2_registers hubp_regs[] = { 62336d26912SBhawanpreet Lakha hubp_regs(0), 62436d26912SBhawanpreet Lakha hubp_regs(1), 62536d26912SBhawanpreet Lakha hubp_regs(2), 62636d26912SBhawanpreet Lakha hubp_regs(3), 62736d26912SBhawanpreet Lakha hubp_regs(4) 62836d26912SBhawanpreet Lakha }; 62936d26912SBhawanpreet Lakha 63036d26912SBhawanpreet Lakha static const struct dcn_hubp2_shift hubp_shift = { 63136d26912SBhawanpreet Lakha HUBP_MASK_SH_LIST_DCN30(__SHIFT) 63236d26912SBhawanpreet Lakha }; 63336d26912SBhawanpreet Lakha 63436d26912SBhawanpreet Lakha static const struct dcn_hubp2_mask hubp_mask = { 63536d26912SBhawanpreet Lakha HUBP_MASK_SH_LIST_DCN30(_MASK) 63636d26912SBhawanpreet Lakha }; 63736d26912SBhawanpreet Lakha 63836d26912SBhawanpreet Lakha static struct hubp *dcn302_hubp_create(struct dc_context *ctx, uint32_t inst) 63936d26912SBhawanpreet Lakha { 64036d26912SBhawanpreet Lakha struct dcn20_hubp *hubp2 = kzalloc(sizeof(struct dcn20_hubp), GFP_KERNEL); 64136d26912SBhawanpreet Lakha 64236d26912SBhawanpreet Lakha if (!hubp2) 64336d26912SBhawanpreet Lakha return NULL; 64436d26912SBhawanpreet Lakha 64536d26912SBhawanpreet Lakha if (hubp3_construct(hubp2, ctx, inst, &hubp_regs[inst], &hubp_shift, &hubp_mask)) 64636d26912SBhawanpreet Lakha return &hubp2->base; 64736d26912SBhawanpreet Lakha 64836d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 64936d26912SBhawanpreet Lakha kfree(hubp2); 65036d26912SBhawanpreet Lakha return NULL; 65136d26912SBhawanpreet Lakha } 65236d26912SBhawanpreet Lakha 65336d26912SBhawanpreet Lakha #define dpp_regs(id)\ 65436d26912SBhawanpreet Lakha [id] = { DPP_REG_LIST_DCN30(id) } 65536d26912SBhawanpreet Lakha 65636d26912SBhawanpreet Lakha static const struct dcn3_dpp_registers dpp_regs[] = { 65736d26912SBhawanpreet Lakha dpp_regs(0), 65836d26912SBhawanpreet Lakha dpp_regs(1), 65936d26912SBhawanpreet Lakha dpp_regs(2), 66036d26912SBhawanpreet Lakha dpp_regs(3), 66136d26912SBhawanpreet Lakha dpp_regs(4) 66236d26912SBhawanpreet Lakha }; 66336d26912SBhawanpreet Lakha 66436d26912SBhawanpreet Lakha static const struct dcn3_dpp_shift tf_shift = { 66536d26912SBhawanpreet Lakha DPP_REG_LIST_SH_MASK_DCN30(__SHIFT) 66636d26912SBhawanpreet Lakha }; 66736d26912SBhawanpreet Lakha 66836d26912SBhawanpreet Lakha static const struct dcn3_dpp_mask tf_mask = { 66936d26912SBhawanpreet Lakha DPP_REG_LIST_SH_MASK_DCN30(_MASK) 67036d26912SBhawanpreet Lakha }; 67136d26912SBhawanpreet Lakha 67236d26912SBhawanpreet Lakha static struct dpp *dcn302_dpp_create(struct dc_context *ctx, uint32_t inst) 67336d26912SBhawanpreet Lakha { 67436d26912SBhawanpreet Lakha struct dcn3_dpp *dpp = kzalloc(sizeof(struct dcn3_dpp), GFP_KERNEL); 67536d26912SBhawanpreet Lakha 67636d26912SBhawanpreet Lakha if (!dpp) 67736d26912SBhawanpreet Lakha return NULL; 67836d26912SBhawanpreet Lakha 67936d26912SBhawanpreet Lakha if (dpp3_construct(dpp, ctx, inst, &dpp_regs[inst], &tf_shift, &tf_mask)) 68036d26912SBhawanpreet Lakha return &dpp->base; 68136d26912SBhawanpreet Lakha 68236d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 68336d26912SBhawanpreet Lakha kfree(dpp); 68436d26912SBhawanpreet Lakha return NULL; 68536d26912SBhawanpreet Lakha } 68636d26912SBhawanpreet Lakha 68736d26912SBhawanpreet Lakha #define opp_regs(id)\ 68836d26912SBhawanpreet Lakha [id] = { OPP_REG_LIST_DCN30(id) } 68936d26912SBhawanpreet Lakha 69036d26912SBhawanpreet Lakha static const struct dcn20_opp_registers opp_regs[] = { 69136d26912SBhawanpreet Lakha opp_regs(0), 69236d26912SBhawanpreet Lakha opp_regs(1), 69336d26912SBhawanpreet Lakha opp_regs(2), 69436d26912SBhawanpreet Lakha opp_regs(3), 69536d26912SBhawanpreet Lakha opp_regs(4) 69636d26912SBhawanpreet Lakha }; 69736d26912SBhawanpreet Lakha 69836d26912SBhawanpreet Lakha static const struct dcn20_opp_shift opp_shift = { 69936d26912SBhawanpreet Lakha OPP_MASK_SH_LIST_DCN20(__SHIFT) 70036d26912SBhawanpreet Lakha }; 70136d26912SBhawanpreet Lakha 70236d26912SBhawanpreet Lakha static const struct dcn20_opp_mask opp_mask = { 70336d26912SBhawanpreet Lakha OPP_MASK_SH_LIST_DCN20(_MASK) 70436d26912SBhawanpreet Lakha }; 70536d26912SBhawanpreet Lakha 70636d26912SBhawanpreet Lakha static struct output_pixel_processor *dcn302_opp_create(struct dc_context *ctx, uint32_t inst) 70736d26912SBhawanpreet Lakha { 70836d26912SBhawanpreet Lakha struct dcn20_opp *opp = kzalloc(sizeof(struct dcn20_opp), GFP_KERNEL); 70936d26912SBhawanpreet Lakha 71036d26912SBhawanpreet Lakha if (!opp) { 71136d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 71236d26912SBhawanpreet Lakha return NULL; 71336d26912SBhawanpreet Lakha } 71436d26912SBhawanpreet Lakha 71536d26912SBhawanpreet Lakha dcn20_opp_construct(opp, ctx, inst, &opp_regs[inst], &opp_shift, &opp_mask); 71636d26912SBhawanpreet Lakha return &opp->base; 71736d26912SBhawanpreet Lakha } 71836d26912SBhawanpreet Lakha 71936d26912SBhawanpreet Lakha #define optc_regs(id)\ 72036d26912SBhawanpreet Lakha [id] = { OPTC_COMMON_REG_LIST_DCN3_0(id) } 72136d26912SBhawanpreet Lakha 72236d26912SBhawanpreet Lakha static const struct dcn_optc_registers optc_regs[] = { 72336d26912SBhawanpreet Lakha optc_regs(0), 72436d26912SBhawanpreet Lakha optc_regs(1), 72536d26912SBhawanpreet Lakha optc_regs(2), 72636d26912SBhawanpreet Lakha optc_regs(3), 72736d26912SBhawanpreet Lakha optc_regs(4) 72836d26912SBhawanpreet Lakha }; 72936d26912SBhawanpreet Lakha 73036d26912SBhawanpreet Lakha static const struct dcn_optc_shift optc_shift = { 73136d26912SBhawanpreet Lakha OPTC_COMMON_MASK_SH_LIST_DCN30(__SHIFT) 73236d26912SBhawanpreet Lakha }; 73336d26912SBhawanpreet Lakha 73436d26912SBhawanpreet Lakha static const struct dcn_optc_mask optc_mask = { 73536d26912SBhawanpreet Lakha OPTC_COMMON_MASK_SH_LIST_DCN30(_MASK) 73636d26912SBhawanpreet Lakha }; 73736d26912SBhawanpreet Lakha 73836d26912SBhawanpreet Lakha static struct timing_generator *dcn302_timing_generator_create(struct dc_context *ctx, uint32_t instance) 73936d26912SBhawanpreet Lakha { 74036d26912SBhawanpreet Lakha struct optc *tgn10 = kzalloc(sizeof(struct optc), GFP_KERNEL); 74136d26912SBhawanpreet Lakha 74236d26912SBhawanpreet Lakha if (!tgn10) 74336d26912SBhawanpreet Lakha return NULL; 74436d26912SBhawanpreet Lakha 74536d26912SBhawanpreet Lakha tgn10->base.inst = instance; 74636d26912SBhawanpreet Lakha tgn10->base.ctx = ctx; 74736d26912SBhawanpreet Lakha 74836d26912SBhawanpreet Lakha tgn10->tg_regs = &optc_regs[instance]; 74936d26912SBhawanpreet Lakha tgn10->tg_shift = &optc_shift; 75036d26912SBhawanpreet Lakha tgn10->tg_mask = &optc_mask; 75136d26912SBhawanpreet Lakha 75236d26912SBhawanpreet Lakha dcn30_timing_generator_init(tgn10); 75336d26912SBhawanpreet Lakha 75436d26912SBhawanpreet Lakha return &tgn10->base; 75536d26912SBhawanpreet Lakha } 75636d26912SBhawanpreet Lakha 75736d26912SBhawanpreet Lakha static const struct dcn30_mpc_registers mpc_regs = { 75836d26912SBhawanpreet Lakha MPC_REG_LIST_DCN3_0(0), 75936d26912SBhawanpreet Lakha MPC_REG_LIST_DCN3_0(1), 76036d26912SBhawanpreet Lakha MPC_REG_LIST_DCN3_0(2), 76136d26912SBhawanpreet Lakha MPC_REG_LIST_DCN3_0(3), 76236d26912SBhawanpreet Lakha MPC_REG_LIST_DCN3_0(4), 76336d26912SBhawanpreet Lakha MPC_OUT_MUX_REG_LIST_DCN3_0(0), 76436d26912SBhawanpreet Lakha MPC_OUT_MUX_REG_LIST_DCN3_0(1), 76536d26912SBhawanpreet Lakha MPC_OUT_MUX_REG_LIST_DCN3_0(2), 76636d26912SBhawanpreet Lakha MPC_OUT_MUX_REG_LIST_DCN3_0(3), 76736d26912SBhawanpreet Lakha MPC_OUT_MUX_REG_LIST_DCN3_0(4), 76836d26912SBhawanpreet Lakha MPC_RMU_GLOBAL_REG_LIST_DCN3AG, 76936d26912SBhawanpreet Lakha MPC_RMU_REG_LIST_DCN3AG(0), 77036d26912SBhawanpreet Lakha MPC_RMU_REG_LIST_DCN3AG(1), 77136d26912SBhawanpreet Lakha MPC_RMU_REG_LIST_DCN3AG(2), 77236d26912SBhawanpreet Lakha MPC_DWB_MUX_REG_LIST_DCN3_0(0), 77336d26912SBhawanpreet Lakha }; 77436d26912SBhawanpreet Lakha 77536d26912SBhawanpreet Lakha static const struct dcn30_mpc_shift mpc_shift = { 77636d26912SBhawanpreet Lakha MPC_COMMON_MASK_SH_LIST_DCN30(__SHIFT) 77736d26912SBhawanpreet Lakha }; 77836d26912SBhawanpreet Lakha 77936d26912SBhawanpreet Lakha static const struct dcn30_mpc_mask mpc_mask = { 78036d26912SBhawanpreet Lakha MPC_COMMON_MASK_SH_LIST_DCN30(_MASK) 78136d26912SBhawanpreet Lakha }; 78236d26912SBhawanpreet Lakha 78336d26912SBhawanpreet Lakha static struct mpc *dcn302_mpc_create(struct dc_context *ctx, int num_mpcc, int num_rmu) 78436d26912SBhawanpreet Lakha { 78536d26912SBhawanpreet Lakha struct dcn30_mpc *mpc30 = kzalloc(sizeof(struct dcn30_mpc), GFP_KERNEL); 78636d26912SBhawanpreet Lakha 78736d26912SBhawanpreet Lakha if (!mpc30) 78836d26912SBhawanpreet Lakha return NULL; 78936d26912SBhawanpreet Lakha 79036d26912SBhawanpreet Lakha dcn30_mpc_construct(mpc30, ctx, &mpc_regs, &mpc_shift, &mpc_mask, num_mpcc, num_rmu); 79136d26912SBhawanpreet Lakha 79236d26912SBhawanpreet Lakha return &mpc30->base; 79336d26912SBhawanpreet Lakha } 79436d26912SBhawanpreet Lakha 79536d26912SBhawanpreet Lakha #define dsc_regsDCN20(id)\ 79636d26912SBhawanpreet Lakha [id] = { DSC_REG_LIST_DCN20(id) } 79736d26912SBhawanpreet Lakha 79836d26912SBhawanpreet Lakha static const struct dcn20_dsc_registers dsc_regs[] = { 79936d26912SBhawanpreet Lakha dsc_regsDCN20(0), 80036d26912SBhawanpreet Lakha dsc_regsDCN20(1), 80136d26912SBhawanpreet Lakha dsc_regsDCN20(2), 80236d26912SBhawanpreet Lakha dsc_regsDCN20(3), 80336d26912SBhawanpreet Lakha dsc_regsDCN20(4) 80436d26912SBhawanpreet Lakha }; 80536d26912SBhawanpreet Lakha 80636d26912SBhawanpreet Lakha static const struct dcn20_dsc_shift dsc_shift = { 80736d26912SBhawanpreet Lakha DSC_REG_LIST_SH_MASK_DCN20(__SHIFT) 80836d26912SBhawanpreet Lakha }; 80936d26912SBhawanpreet Lakha 81036d26912SBhawanpreet Lakha static const struct dcn20_dsc_mask dsc_mask = { 81136d26912SBhawanpreet Lakha DSC_REG_LIST_SH_MASK_DCN20(_MASK) 81236d26912SBhawanpreet Lakha }; 81336d26912SBhawanpreet Lakha 81436d26912SBhawanpreet Lakha static struct display_stream_compressor *dcn302_dsc_create(struct dc_context *ctx, uint32_t inst) 81536d26912SBhawanpreet Lakha { 81636d26912SBhawanpreet Lakha struct dcn20_dsc *dsc = kzalloc(sizeof(struct dcn20_dsc), GFP_KERNEL); 81736d26912SBhawanpreet Lakha 81836d26912SBhawanpreet Lakha if (!dsc) { 81936d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 82036d26912SBhawanpreet Lakha return NULL; 82136d26912SBhawanpreet Lakha } 82236d26912SBhawanpreet Lakha 82336d26912SBhawanpreet Lakha dsc2_construct(dsc, ctx, inst, &dsc_regs[inst], &dsc_shift, &dsc_mask); 82436d26912SBhawanpreet Lakha return &dsc->base; 82536d26912SBhawanpreet Lakha } 82636d26912SBhawanpreet Lakha 82736d26912SBhawanpreet Lakha #define dwbc_regs_dcn3(id)\ 82836d26912SBhawanpreet Lakha [id] = { DWBC_COMMON_REG_LIST_DCN30(id) } 82936d26912SBhawanpreet Lakha 83036d26912SBhawanpreet Lakha static const struct dcn30_dwbc_registers dwbc30_regs[] = { 83136d26912SBhawanpreet Lakha dwbc_regs_dcn3(0) 83236d26912SBhawanpreet Lakha }; 83336d26912SBhawanpreet Lakha 83436d26912SBhawanpreet Lakha static const struct dcn30_dwbc_shift dwbc30_shift = { 83536d26912SBhawanpreet Lakha DWBC_COMMON_MASK_SH_LIST_DCN30(__SHIFT) 83636d26912SBhawanpreet Lakha }; 83736d26912SBhawanpreet Lakha 83836d26912SBhawanpreet Lakha static const struct dcn30_dwbc_mask dwbc30_mask = { 83936d26912SBhawanpreet Lakha DWBC_COMMON_MASK_SH_LIST_DCN30(_MASK) 84036d26912SBhawanpreet Lakha }; 84136d26912SBhawanpreet Lakha 84236d26912SBhawanpreet Lakha static bool dcn302_dwbc_create(struct dc_context *ctx, struct resource_pool *pool) 84336d26912SBhawanpreet Lakha { 84436d26912SBhawanpreet Lakha int i; 84536d26912SBhawanpreet Lakha uint32_t pipe_count = pool->res_cap->num_dwb; 84636d26912SBhawanpreet Lakha 84736d26912SBhawanpreet Lakha for (i = 0; i < pipe_count; i++) { 84836d26912SBhawanpreet Lakha struct dcn30_dwbc *dwbc30 = kzalloc(sizeof(struct dcn30_dwbc), GFP_KERNEL); 84936d26912SBhawanpreet Lakha 85036d26912SBhawanpreet Lakha if (!dwbc30) { 85136d26912SBhawanpreet Lakha dm_error("DC: failed to create dwbc30!\n"); 85236d26912SBhawanpreet Lakha return false; 85336d26912SBhawanpreet Lakha } 85436d26912SBhawanpreet Lakha 85536d26912SBhawanpreet Lakha dcn30_dwbc_construct(dwbc30, ctx, &dwbc30_regs[i], &dwbc30_shift, &dwbc30_mask, i); 85636d26912SBhawanpreet Lakha 85736d26912SBhawanpreet Lakha pool->dwbc[i] = &dwbc30->base; 85836d26912SBhawanpreet Lakha } 85936d26912SBhawanpreet Lakha return true; 86036d26912SBhawanpreet Lakha } 86136d26912SBhawanpreet Lakha 86236d26912SBhawanpreet Lakha #define mcif_wb_regs_dcn3(id)\ 86336d26912SBhawanpreet Lakha [id] = { MCIF_WB_COMMON_REG_LIST_DCN30(id) } 86436d26912SBhawanpreet Lakha 86536d26912SBhawanpreet Lakha static const struct dcn30_mmhubbub_registers mcif_wb30_regs[] = { 86636d26912SBhawanpreet Lakha mcif_wb_regs_dcn3(0) 86736d26912SBhawanpreet Lakha }; 86836d26912SBhawanpreet Lakha 86936d26912SBhawanpreet Lakha static const struct dcn30_mmhubbub_shift mcif_wb30_shift = { 87036d26912SBhawanpreet Lakha MCIF_WB_COMMON_MASK_SH_LIST_DCN30(__SHIFT) 87136d26912SBhawanpreet Lakha }; 87236d26912SBhawanpreet Lakha 87336d26912SBhawanpreet Lakha static const struct dcn30_mmhubbub_mask mcif_wb30_mask = { 87436d26912SBhawanpreet Lakha MCIF_WB_COMMON_MASK_SH_LIST_DCN30(_MASK) 87536d26912SBhawanpreet Lakha }; 87636d26912SBhawanpreet Lakha 87736d26912SBhawanpreet Lakha static bool dcn302_mmhubbub_create(struct dc_context *ctx, struct resource_pool *pool) 87836d26912SBhawanpreet Lakha { 87936d26912SBhawanpreet Lakha int i; 88036d26912SBhawanpreet Lakha uint32_t pipe_count = pool->res_cap->num_dwb; 88136d26912SBhawanpreet Lakha 88236d26912SBhawanpreet Lakha for (i = 0; i < pipe_count; i++) { 88336d26912SBhawanpreet Lakha struct dcn30_mmhubbub *mcif_wb30 = kzalloc(sizeof(struct dcn30_mmhubbub), GFP_KERNEL); 88436d26912SBhawanpreet Lakha 88536d26912SBhawanpreet Lakha if (!mcif_wb30) { 88636d26912SBhawanpreet Lakha dm_error("DC: failed to create mcif_wb30!\n"); 88736d26912SBhawanpreet Lakha return false; 88836d26912SBhawanpreet Lakha } 88936d26912SBhawanpreet Lakha 89036d26912SBhawanpreet Lakha dcn30_mmhubbub_construct(mcif_wb30, ctx, &mcif_wb30_regs[i], &mcif_wb30_shift, &mcif_wb30_mask, i); 89136d26912SBhawanpreet Lakha 89236d26912SBhawanpreet Lakha pool->mcif_wb[i] = &mcif_wb30->base; 89336d26912SBhawanpreet Lakha } 89436d26912SBhawanpreet Lakha return true; 89536d26912SBhawanpreet Lakha } 89636d26912SBhawanpreet Lakha 89736d26912SBhawanpreet Lakha #define aux_engine_regs(id)\ 89836d26912SBhawanpreet Lakha [id] = {\ 89936d26912SBhawanpreet Lakha AUX_COMMON_REG_LIST0(id), \ 90036d26912SBhawanpreet Lakha .AUXN_IMPCAL = 0, \ 90136d26912SBhawanpreet Lakha .AUXP_IMPCAL = 0, \ 90236d26912SBhawanpreet Lakha .AUX_RESET_MASK = DP_AUX0_AUX_CONTROL__AUX_RESET_MASK, \ 90336d26912SBhawanpreet Lakha } 90436d26912SBhawanpreet Lakha 90536d26912SBhawanpreet Lakha static const struct dce110_aux_registers aux_engine_regs[] = { 90636d26912SBhawanpreet Lakha aux_engine_regs(0), 90736d26912SBhawanpreet Lakha aux_engine_regs(1), 90836d26912SBhawanpreet Lakha aux_engine_regs(2), 90936d26912SBhawanpreet Lakha aux_engine_regs(3), 91036d26912SBhawanpreet Lakha aux_engine_regs(4) 91136d26912SBhawanpreet Lakha }; 91236d26912SBhawanpreet Lakha 91336d26912SBhawanpreet Lakha static const struct dce110_aux_registers_shift aux_shift = { 91436d26912SBhawanpreet Lakha DCN_AUX_MASK_SH_LIST(__SHIFT) 91536d26912SBhawanpreet Lakha }; 91636d26912SBhawanpreet Lakha 91736d26912SBhawanpreet Lakha static const struct dce110_aux_registers_mask aux_mask = { 91836d26912SBhawanpreet Lakha DCN_AUX_MASK_SH_LIST(_MASK) 91936d26912SBhawanpreet Lakha }; 92036d26912SBhawanpreet Lakha 92136d26912SBhawanpreet Lakha static struct dce_aux *dcn302_aux_engine_create(struct dc_context *ctx, uint32_t inst) 92236d26912SBhawanpreet Lakha { 92336d26912SBhawanpreet Lakha struct aux_engine_dce110 *aux_engine = kzalloc(sizeof(struct aux_engine_dce110), GFP_KERNEL); 92436d26912SBhawanpreet Lakha 92536d26912SBhawanpreet Lakha if (!aux_engine) 92636d26912SBhawanpreet Lakha return NULL; 92736d26912SBhawanpreet Lakha 92836d26912SBhawanpreet Lakha dce110_aux_engine_construct(aux_engine, ctx, inst, SW_AUX_TIMEOUT_PERIOD_MULTIPLIER * AUX_TIMEOUT_PERIOD, 92936d26912SBhawanpreet Lakha &aux_engine_regs[inst], &aux_mask, &aux_shift, ctx->dc->caps.extended_aux_timeout_support); 93036d26912SBhawanpreet Lakha 93136d26912SBhawanpreet Lakha return &aux_engine->base; 93236d26912SBhawanpreet Lakha } 93336d26912SBhawanpreet Lakha 93436d26912SBhawanpreet Lakha #define i2c_inst_regs(id) { I2C_HW_ENGINE_COMMON_REG_LIST(id) } 93536d26912SBhawanpreet Lakha 93636d26912SBhawanpreet Lakha static const struct dce_i2c_registers i2c_hw_regs[] = { 93736d26912SBhawanpreet Lakha i2c_inst_regs(1), 93836d26912SBhawanpreet Lakha i2c_inst_regs(2), 93936d26912SBhawanpreet Lakha i2c_inst_regs(3), 94036d26912SBhawanpreet Lakha i2c_inst_regs(4), 94136d26912SBhawanpreet Lakha i2c_inst_regs(5) 94236d26912SBhawanpreet Lakha }; 94336d26912SBhawanpreet Lakha 94436d26912SBhawanpreet Lakha static const struct dce_i2c_shift i2c_shifts = { 94536d26912SBhawanpreet Lakha I2C_COMMON_MASK_SH_LIST_DCN2(__SHIFT) 94636d26912SBhawanpreet Lakha }; 94736d26912SBhawanpreet Lakha 94836d26912SBhawanpreet Lakha static const struct dce_i2c_mask i2c_masks = { 94936d26912SBhawanpreet Lakha I2C_COMMON_MASK_SH_LIST_DCN2(_MASK) 95036d26912SBhawanpreet Lakha }; 95136d26912SBhawanpreet Lakha 95236d26912SBhawanpreet Lakha static struct dce_i2c_hw *dcn302_i2c_hw_create(struct dc_context *ctx, uint32_t inst) 95336d26912SBhawanpreet Lakha { 95436d26912SBhawanpreet Lakha struct dce_i2c_hw *dce_i2c_hw = kzalloc(sizeof(struct dce_i2c_hw), GFP_KERNEL); 95536d26912SBhawanpreet Lakha 95636d26912SBhawanpreet Lakha if (!dce_i2c_hw) 95736d26912SBhawanpreet Lakha return NULL; 95836d26912SBhawanpreet Lakha 95936d26912SBhawanpreet Lakha dcn2_i2c_hw_construct(dce_i2c_hw, ctx, inst, &i2c_hw_regs[inst], &i2c_shifts, &i2c_masks); 96036d26912SBhawanpreet Lakha 96136d26912SBhawanpreet Lakha return dce_i2c_hw; 96236d26912SBhawanpreet Lakha } 96336d26912SBhawanpreet Lakha 96436d26912SBhawanpreet Lakha static const struct encoder_feature_support link_enc_feature = { 96536d26912SBhawanpreet Lakha .max_hdmi_deep_color = COLOR_DEPTH_121212, 96636d26912SBhawanpreet Lakha .max_hdmi_pixel_clock = 600000, 96736d26912SBhawanpreet Lakha .hdmi_ycbcr420_supported = true, 96836d26912SBhawanpreet Lakha .dp_ycbcr420_supported = true, 96936d26912SBhawanpreet Lakha .fec_supported = true, 97036d26912SBhawanpreet Lakha .flags.bits.IS_HBR2_CAPABLE = true, 97136d26912SBhawanpreet Lakha .flags.bits.IS_HBR3_CAPABLE = true, 97236d26912SBhawanpreet Lakha .flags.bits.IS_TPS3_CAPABLE = true, 97336d26912SBhawanpreet Lakha .flags.bits.IS_TPS4_CAPABLE = true 97436d26912SBhawanpreet Lakha }; 97536d26912SBhawanpreet Lakha 97636d26912SBhawanpreet Lakha #define link_regs(id, phyid)\ 97736d26912SBhawanpreet Lakha [id] = {\ 97836d26912SBhawanpreet Lakha LE_DCN3_REG_LIST(id), \ 97936d26912SBhawanpreet Lakha UNIPHY_DCN2_REG_LIST(phyid), \ 98078deaf5fSBhawanpreet Lakha DPCS_DCN2_REG_LIST(id), \ 98191bda9e9SChris Park SRI(DP_DPHY_INTERNAL_CTRL, DP, id) \ 98236d26912SBhawanpreet Lakha } 98336d26912SBhawanpreet Lakha 98436d26912SBhawanpreet Lakha static const struct dcn10_link_enc_registers link_enc_regs[] = { 98536d26912SBhawanpreet Lakha link_regs(0, A), 98636d26912SBhawanpreet Lakha link_regs(1, B), 98736d26912SBhawanpreet Lakha link_regs(2, C), 98836d26912SBhawanpreet Lakha link_regs(3, D), 98936d26912SBhawanpreet Lakha link_regs(4, E) 99036d26912SBhawanpreet Lakha }; 99136d26912SBhawanpreet Lakha 99236d26912SBhawanpreet Lakha static const struct dcn10_link_enc_shift le_shift = { 99336d26912SBhawanpreet Lakha LINK_ENCODER_MASK_SH_LIST_DCN30(__SHIFT), 99436d26912SBhawanpreet Lakha DPCS_DCN2_MASK_SH_LIST(__SHIFT) 99536d26912SBhawanpreet Lakha }; 99636d26912SBhawanpreet Lakha 99736d26912SBhawanpreet Lakha static const struct dcn10_link_enc_mask le_mask = { 99836d26912SBhawanpreet Lakha LINK_ENCODER_MASK_SH_LIST_DCN30(_MASK), 99936d26912SBhawanpreet Lakha DPCS_DCN2_MASK_SH_LIST(_MASK) 100036d26912SBhawanpreet Lakha }; 100136d26912SBhawanpreet Lakha 100236d26912SBhawanpreet Lakha #define aux_regs(id)\ 100336d26912SBhawanpreet Lakha [id] = { DCN2_AUX_REG_LIST(id) } 100436d26912SBhawanpreet Lakha 100536d26912SBhawanpreet Lakha static const struct dcn10_link_enc_aux_registers link_enc_aux_regs[] = { 100636d26912SBhawanpreet Lakha aux_regs(0), 100736d26912SBhawanpreet Lakha aux_regs(1), 100836d26912SBhawanpreet Lakha aux_regs(2), 100936d26912SBhawanpreet Lakha aux_regs(3), 101036d26912SBhawanpreet Lakha aux_regs(4) 101136d26912SBhawanpreet Lakha }; 101236d26912SBhawanpreet Lakha 101336d26912SBhawanpreet Lakha #define hpd_regs(id)\ 101436d26912SBhawanpreet Lakha [id] = { HPD_REG_LIST(id) } 101536d26912SBhawanpreet Lakha 101636d26912SBhawanpreet Lakha static const struct dcn10_link_enc_hpd_registers link_enc_hpd_regs[] = { 101736d26912SBhawanpreet Lakha hpd_regs(0), 101836d26912SBhawanpreet Lakha hpd_regs(1), 101936d26912SBhawanpreet Lakha hpd_regs(2), 102036d26912SBhawanpreet Lakha hpd_regs(3), 102136d26912SBhawanpreet Lakha hpd_regs(4) 102236d26912SBhawanpreet Lakha }; 102336d26912SBhawanpreet Lakha 102436d26912SBhawanpreet Lakha static struct link_encoder *dcn302_link_encoder_create(const struct encoder_init_data *enc_init_data) 102536d26912SBhawanpreet Lakha { 102636d26912SBhawanpreet Lakha struct dcn20_link_encoder *enc20 = kzalloc(sizeof(struct dcn20_link_encoder), GFP_KERNEL); 102736d26912SBhawanpreet Lakha 102836d26912SBhawanpreet Lakha if (!enc20) 102936d26912SBhawanpreet Lakha return NULL; 103036d26912SBhawanpreet Lakha 103136d26912SBhawanpreet Lakha dcn30_link_encoder_construct(enc20, enc_init_data, &link_enc_feature, 103236d26912SBhawanpreet Lakha &link_enc_regs[enc_init_data->transmitter], &link_enc_aux_regs[enc_init_data->channel - 1], 103336d26912SBhawanpreet Lakha &link_enc_hpd_regs[enc_init_data->hpd_source], &le_shift, &le_mask); 103436d26912SBhawanpreet Lakha 103536d26912SBhawanpreet Lakha return &enc20->enc10.base; 103636d26912SBhawanpreet Lakha } 103736d26912SBhawanpreet Lakha 103836d26912SBhawanpreet Lakha static const struct dce_panel_cntl_registers panel_cntl_regs[] = { 103936d26912SBhawanpreet Lakha { DCN_PANEL_CNTL_REG_LIST() } 104036d26912SBhawanpreet Lakha }; 104136d26912SBhawanpreet Lakha 104236d26912SBhawanpreet Lakha static const struct dce_panel_cntl_shift panel_cntl_shift = { 104336d26912SBhawanpreet Lakha DCE_PANEL_CNTL_MASK_SH_LIST(__SHIFT) 104436d26912SBhawanpreet Lakha }; 104536d26912SBhawanpreet Lakha 104636d26912SBhawanpreet Lakha static const struct dce_panel_cntl_mask panel_cntl_mask = { 104736d26912SBhawanpreet Lakha DCE_PANEL_CNTL_MASK_SH_LIST(_MASK) 104836d26912SBhawanpreet Lakha }; 104936d26912SBhawanpreet Lakha 105036d26912SBhawanpreet Lakha static struct panel_cntl *dcn302_panel_cntl_create(const struct panel_cntl_init_data *init_data) 105136d26912SBhawanpreet Lakha { 105236d26912SBhawanpreet Lakha struct dce_panel_cntl *panel_cntl = kzalloc(sizeof(struct dce_panel_cntl), GFP_KERNEL); 105336d26912SBhawanpreet Lakha 105436d26912SBhawanpreet Lakha if (!panel_cntl) 105536d26912SBhawanpreet Lakha return NULL; 105636d26912SBhawanpreet Lakha 105736d26912SBhawanpreet Lakha dce_panel_cntl_construct(panel_cntl, init_data, &panel_cntl_regs[init_data->inst], 105836d26912SBhawanpreet Lakha &panel_cntl_shift, &panel_cntl_mask); 105936d26912SBhawanpreet Lakha 106036d26912SBhawanpreet Lakha return &panel_cntl->base; 106136d26912SBhawanpreet Lakha } 106236d26912SBhawanpreet Lakha 106336d26912SBhawanpreet Lakha static void read_dce_straps(struct dc_context *ctx, struct resource_straps *straps) 106436d26912SBhawanpreet Lakha { 106536d26912SBhawanpreet Lakha generic_reg_get(ctx, mmDC_PINSTRAPS + BASE(mmDC_PINSTRAPS_BASE_IDX), 106636d26912SBhawanpreet Lakha FN(DC_PINSTRAPS, DC_PINSTRAPS_AUDIO), &straps->dc_pinstraps_audio); 106736d26912SBhawanpreet Lakha } 106836d26912SBhawanpreet Lakha 106936d26912SBhawanpreet Lakha static const struct resource_create_funcs res_create_funcs = { 107036d26912SBhawanpreet Lakha .read_dce_straps = read_dce_straps, 107136d26912SBhawanpreet Lakha .create_audio = dcn302_create_audio, 107236d26912SBhawanpreet Lakha .create_stream_encoder = dcn302_stream_encoder_create, 107336d26912SBhawanpreet Lakha .create_hwseq = dcn302_hwseq_create, 107436d26912SBhawanpreet Lakha }; 107536d26912SBhawanpreet Lakha 107636d26912SBhawanpreet Lakha static const struct resource_create_funcs res_create_maximus_funcs = { 107736d26912SBhawanpreet Lakha .read_dce_straps = NULL, 107836d26912SBhawanpreet Lakha .create_audio = NULL, 107936d26912SBhawanpreet Lakha .create_stream_encoder = NULL, 108036d26912SBhawanpreet Lakha .create_hwseq = dcn302_hwseq_create, 108136d26912SBhawanpreet Lakha }; 108236d26912SBhawanpreet Lakha 108336d26912SBhawanpreet Lakha static bool is_soc_bounding_box_valid(struct dc *dc) 108436d26912SBhawanpreet Lakha { 108536d26912SBhawanpreet Lakha uint32_t hw_internal_rev = dc->ctx->asic_id.hw_internal_rev; 108636d26912SBhawanpreet Lakha 108736d26912SBhawanpreet Lakha if (ASICREV_IS_DIMGREY_CAVEFISH_P(hw_internal_rev)) 108836d26912SBhawanpreet Lakha return true; 108936d26912SBhawanpreet Lakha 109036d26912SBhawanpreet Lakha return false; 109136d26912SBhawanpreet Lakha } 109236d26912SBhawanpreet Lakha 109336d26912SBhawanpreet Lakha static bool init_soc_bounding_box(struct dc *dc, struct resource_pool *pool) 109436d26912SBhawanpreet Lakha { 109536d26912SBhawanpreet Lakha struct _vcs_dpi_soc_bounding_box_st *loaded_bb = &dcn3_02_soc; 109636d26912SBhawanpreet Lakha struct _vcs_dpi_ip_params_st *loaded_ip = &dcn3_02_ip; 109736d26912SBhawanpreet Lakha 109836d26912SBhawanpreet Lakha DC_LOGGER_INIT(dc->ctx->logger); 109936d26912SBhawanpreet Lakha 110036d26912SBhawanpreet Lakha if (!is_soc_bounding_box_valid(dc)) { 110149da4c2bSJoe Perches DC_LOG_ERROR("%s: not valid soc bounding box\n", __func__); 110236d26912SBhawanpreet Lakha return false; 110336d26912SBhawanpreet Lakha } 110436d26912SBhawanpreet Lakha 110536d26912SBhawanpreet Lakha loaded_ip->max_num_otg = pool->pipe_count; 110636d26912SBhawanpreet Lakha loaded_ip->max_num_dpp = pool->pipe_count; 110736d26912SBhawanpreet Lakha loaded_ip->clamp_min_dcfclk = dc->config.clamp_min_dcfclk; 110836d26912SBhawanpreet Lakha dcn20_patch_bounding_box(dc, loaded_bb); 11099253e115SAurabindo Pillai 11109253e115SAurabindo Pillai if (dc->ctx->dc_bios->funcs->get_soc_bb_info) { 11119253e115SAurabindo Pillai struct bp_soc_bb_info bb_info = { 0 }; 11129253e115SAurabindo Pillai 11139253e115SAurabindo Pillai if (dc->ctx->dc_bios->funcs->get_soc_bb_info( 11149253e115SAurabindo Pillai dc->ctx->dc_bios, &bb_info) == BP_RESULT_OK) { 11159253e115SAurabindo Pillai if (bb_info.dram_clock_change_latency_100ns > 0) 11169253e115SAurabindo Pillai dcn3_02_soc.dram_clock_change_latency_us = 11179253e115SAurabindo Pillai bb_info.dram_clock_change_latency_100ns * 10; 11189253e115SAurabindo Pillai 11199253e115SAurabindo Pillai if (bb_info.dram_sr_enter_exit_latency_100ns > 0) 11209253e115SAurabindo Pillai dcn3_02_soc.sr_enter_plus_exit_time_us = 11219253e115SAurabindo Pillai bb_info.dram_sr_enter_exit_latency_100ns * 10; 11229253e115SAurabindo Pillai 11239253e115SAurabindo Pillai if (bb_info.dram_sr_exit_latency_100ns > 0) 11249253e115SAurabindo Pillai dcn3_02_soc.sr_exit_time_us = 11259253e115SAurabindo Pillai bb_info.dram_sr_exit_latency_100ns * 10; 11269253e115SAurabindo Pillai } 11279253e115SAurabindo Pillai } 11289253e115SAurabindo Pillai 112936d26912SBhawanpreet Lakha return true; 113036d26912SBhawanpreet Lakha } 113136d26912SBhawanpreet Lakha 113236d26912SBhawanpreet Lakha static void dcn302_resource_destruct(struct resource_pool *pool) 113336d26912SBhawanpreet Lakha { 113436d26912SBhawanpreet Lakha unsigned int i; 113536d26912SBhawanpreet Lakha 113636d26912SBhawanpreet Lakha for (i = 0; i < pool->stream_enc_count; i++) { 113736d26912SBhawanpreet Lakha if (pool->stream_enc[i] != NULL) { 113836d26912SBhawanpreet Lakha if (pool->stream_enc[i]->vpg != NULL) { 113936d26912SBhawanpreet Lakha kfree(DCN30_VPG_FROM_VPG(pool->stream_enc[i]->vpg)); 114036d26912SBhawanpreet Lakha pool->stream_enc[i]->vpg = NULL; 114136d26912SBhawanpreet Lakha } 114236d26912SBhawanpreet Lakha if (pool->stream_enc[i]->afmt != NULL) { 114336d26912SBhawanpreet Lakha kfree(DCN30_AFMT_FROM_AFMT(pool->stream_enc[i]->afmt)); 114436d26912SBhawanpreet Lakha pool->stream_enc[i]->afmt = NULL; 114536d26912SBhawanpreet Lakha } 114636d26912SBhawanpreet Lakha kfree(DCN10STRENC_FROM_STRENC(pool->stream_enc[i])); 114736d26912SBhawanpreet Lakha pool->stream_enc[i] = NULL; 114836d26912SBhawanpreet Lakha } 114936d26912SBhawanpreet Lakha } 115036d26912SBhawanpreet Lakha 115136d26912SBhawanpreet Lakha for (i = 0; i < pool->res_cap->num_dsc; i++) { 115236d26912SBhawanpreet Lakha if (pool->dscs[i] != NULL) 115336d26912SBhawanpreet Lakha dcn20_dsc_destroy(&pool->dscs[i]); 115436d26912SBhawanpreet Lakha } 115536d26912SBhawanpreet Lakha 115636d26912SBhawanpreet Lakha if (pool->mpc != NULL) { 115736d26912SBhawanpreet Lakha kfree(TO_DCN20_MPC(pool->mpc)); 115836d26912SBhawanpreet Lakha pool->mpc = NULL; 115936d26912SBhawanpreet Lakha } 116036d26912SBhawanpreet Lakha 116136d26912SBhawanpreet Lakha if (pool->hubbub != NULL) { 116236d26912SBhawanpreet Lakha kfree(pool->hubbub); 116336d26912SBhawanpreet Lakha pool->hubbub = NULL; 116436d26912SBhawanpreet Lakha } 116536d26912SBhawanpreet Lakha 116636d26912SBhawanpreet Lakha for (i = 0; i < pool->pipe_count; i++) { 116736d26912SBhawanpreet Lakha if (pool->dpps[i] != NULL) { 116836d26912SBhawanpreet Lakha kfree(TO_DCN20_DPP(pool->dpps[i])); 116936d26912SBhawanpreet Lakha pool->dpps[i] = NULL; 117036d26912SBhawanpreet Lakha } 117136d26912SBhawanpreet Lakha 117236d26912SBhawanpreet Lakha if (pool->hubps[i] != NULL) { 117336d26912SBhawanpreet Lakha kfree(TO_DCN20_HUBP(pool->hubps[i])); 117436d26912SBhawanpreet Lakha pool->hubps[i] = NULL; 117536d26912SBhawanpreet Lakha } 117636d26912SBhawanpreet Lakha 117736d26912SBhawanpreet Lakha if (pool->irqs != NULL) 117836d26912SBhawanpreet Lakha dal_irq_service_destroy(&pool->irqs); 117936d26912SBhawanpreet Lakha } 118036d26912SBhawanpreet Lakha 118136d26912SBhawanpreet Lakha for (i = 0; i < pool->res_cap->num_ddc; i++) { 118236d26912SBhawanpreet Lakha if (pool->engines[i] != NULL) 118336d26912SBhawanpreet Lakha dce110_engine_destroy(&pool->engines[i]); 118436d26912SBhawanpreet Lakha if (pool->hw_i2cs[i] != NULL) { 118536d26912SBhawanpreet Lakha kfree(pool->hw_i2cs[i]); 118636d26912SBhawanpreet Lakha pool->hw_i2cs[i] = NULL; 118736d26912SBhawanpreet Lakha } 118836d26912SBhawanpreet Lakha if (pool->sw_i2cs[i] != NULL) { 118936d26912SBhawanpreet Lakha kfree(pool->sw_i2cs[i]); 119036d26912SBhawanpreet Lakha pool->sw_i2cs[i] = NULL; 119136d26912SBhawanpreet Lakha } 119236d26912SBhawanpreet Lakha } 119336d26912SBhawanpreet Lakha 119436d26912SBhawanpreet Lakha for (i = 0; i < pool->res_cap->num_opp; i++) { 119536d26912SBhawanpreet Lakha if (pool->opps[i] != NULL) 119636d26912SBhawanpreet Lakha pool->opps[i]->funcs->opp_destroy(&pool->opps[i]); 119736d26912SBhawanpreet Lakha } 119836d26912SBhawanpreet Lakha 119936d26912SBhawanpreet Lakha for (i = 0; i < pool->res_cap->num_timing_generator; i++) { 120036d26912SBhawanpreet Lakha if (pool->timing_generators[i] != NULL) { 120136d26912SBhawanpreet Lakha kfree(DCN10TG_FROM_TG(pool->timing_generators[i])); 120236d26912SBhawanpreet Lakha pool->timing_generators[i] = NULL; 120336d26912SBhawanpreet Lakha } 120436d26912SBhawanpreet Lakha } 120536d26912SBhawanpreet Lakha 120636d26912SBhawanpreet Lakha for (i = 0; i < pool->res_cap->num_dwb; i++) { 120736d26912SBhawanpreet Lakha if (pool->dwbc[i] != NULL) { 120836d26912SBhawanpreet Lakha kfree(TO_DCN30_DWBC(pool->dwbc[i])); 120936d26912SBhawanpreet Lakha pool->dwbc[i] = NULL; 121036d26912SBhawanpreet Lakha } 121136d26912SBhawanpreet Lakha if (pool->mcif_wb[i] != NULL) { 121236d26912SBhawanpreet Lakha kfree(TO_DCN30_MMHUBBUB(pool->mcif_wb[i])); 121336d26912SBhawanpreet Lakha pool->mcif_wb[i] = NULL; 121436d26912SBhawanpreet Lakha } 121536d26912SBhawanpreet Lakha } 121636d26912SBhawanpreet Lakha 121736d26912SBhawanpreet Lakha for (i = 0; i < pool->audio_count; i++) { 121836d26912SBhawanpreet Lakha if (pool->audios[i]) 121936d26912SBhawanpreet Lakha dce_aud_destroy(&pool->audios[i]); 122036d26912SBhawanpreet Lakha } 122136d26912SBhawanpreet Lakha 122236d26912SBhawanpreet Lakha for (i = 0; i < pool->clk_src_count; i++) { 122336d26912SBhawanpreet Lakha if (pool->clock_sources[i] != NULL) 122436d26912SBhawanpreet Lakha dcn20_clock_source_destroy(&pool->clock_sources[i]); 122536d26912SBhawanpreet Lakha } 122636d26912SBhawanpreet Lakha 122736d26912SBhawanpreet Lakha if (pool->dp_clock_source != NULL) 122836d26912SBhawanpreet Lakha dcn20_clock_source_destroy(&pool->dp_clock_source); 122936d26912SBhawanpreet Lakha 123036d26912SBhawanpreet Lakha for (i = 0; i < pool->res_cap->num_mpc_3dlut; i++) { 123136d26912SBhawanpreet Lakha if (pool->mpc_lut[i] != NULL) { 123236d26912SBhawanpreet Lakha dc_3dlut_func_release(pool->mpc_lut[i]); 123336d26912SBhawanpreet Lakha pool->mpc_lut[i] = NULL; 123436d26912SBhawanpreet Lakha } 123536d26912SBhawanpreet Lakha if (pool->mpc_shaper[i] != NULL) { 123636d26912SBhawanpreet Lakha dc_transfer_func_release(pool->mpc_shaper[i]); 123736d26912SBhawanpreet Lakha pool->mpc_shaper[i] = NULL; 123836d26912SBhawanpreet Lakha } 123936d26912SBhawanpreet Lakha } 124036d26912SBhawanpreet Lakha 124136d26912SBhawanpreet Lakha for (i = 0; i < pool->pipe_count; i++) { 124236d26912SBhawanpreet Lakha if (pool->multiple_abms[i] != NULL) 124336d26912SBhawanpreet Lakha dce_abm_destroy(&pool->multiple_abms[i]); 124436d26912SBhawanpreet Lakha } 124536d26912SBhawanpreet Lakha 124665e05ca7SJoshua Aberback if (pool->psr != NULL) 124765e05ca7SJoshua Aberback dmub_psr_destroy(&pool->psr); 124865e05ca7SJoshua Aberback 124936d26912SBhawanpreet Lakha if (pool->dccg != NULL) 125036d26912SBhawanpreet Lakha dcn_dccg_destroy(&pool->dccg); 125136d26912SBhawanpreet Lakha } 125236d26912SBhawanpreet Lakha 125336d26912SBhawanpreet Lakha static void dcn302_destroy_resource_pool(struct resource_pool **pool) 125436d26912SBhawanpreet Lakha { 125536d26912SBhawanpreet Lakha dcn302_resource_destruct(*pool); 125636d26912SBhawanpreet Lakha kfree(*pool); 125736d26912SBhawanpreet Lakha *pool = NULL; 125836d26912SBhawanpreet Lakha } 125936d26912SBhawanpreet Lakha 1260163e3bcbSSamson Tam static void dcn302_get_optimal_dcfclk_fclk_for_uclk(unsigned int uclk_mts, 1261163e3bcbSSamson Tam unsigned int *optimal_dcfclk, 1262163e3bcbSSamson Tam unsigned int *optimal_fclk) 1263163e3bcbSSamson Tam { 1264163e3bcbSSamson Tam double bw_from_dram, bw_from_dram1, bw_from_dram2; 1265163e3bcbSSamson Tam 1266163e3bcbSSamson Tam bw_from_dram1 = uclk_mts * dcn3_02_soc.num_chans * 1267163e3bcbSSamson Tam dcn3_02_soc.dram_channel_width_bytes * (dcn3_02_soc.max_avg_dram_bw_use_normal_percent / 100); 1268163e3bcbSSamson Tam bw_from_dram2 = uclk_mts * dcn3_02_soc.num_chans * 1269163e3bcbSSamson Tam dcn3_02_soc.dram_channel_width_bytes * (dcn3_02_soc.max_avg_sdp_bw_use_normal_percent / 100); 1270163e3bcbSSamson Tam 1271163e3bcbSSamson Tam bw_from_dram = (bw_from_dram1 < bw_from_dram2) ? bw_from_dram1 : bw_from_dram2; 1272163e3bcbSSamson Tam 1273163e3bcbSSamson Tam if (optimal_fclk) 1274163e3bcbSSamson Tam *optimal_fclk = bw_from_dram / 1275163e3bcbSSamson Tam (dcn3_02_soc.fabric_datapath_to_dcn_data_return_bytes * (dcn3_02_soc.max_avg_sdp_bw_use_normal_percent / 100)); 1276163e3bcbSSamson Tam 1277163e3bcbSSamson Tam if (optimal_dcfclk) 1278163e3bcbSSamson Tam *optimal_dcfclk = bw_from_dram / 1279163e3bcbSSamson Tam (dcn3_02_soc.return_bus_width_bytes * (dcn3_02_soc.max_avg_sdp_bw_use_normal_percent / 100)); 1280163e3bcbSSamson Tam } 1281163e3bcbSSamson Tam 1282163e3bcbSSamson Tam void dcn302_update_bw_bounding_box(struct dc *dc, struct clk_bw_params *bw_params) 1283163e3bcbSSamson Tam { 1284163e3bcbSSamson Tam unsigned int i, j; 1285163e3bcbSSamson Tam unsigned int num_states = 0; 1286163e3bcbSSamson Tam 1287163e3bcbSSamson Tam unsigned int dcfclk_mhz[DC__VOLTAGE_STATES] = {0}; 1288163e3bcbSSamson Tam unsigned int dram_speed_mts[DC__VOLTAGE_STATES] = {0}; 1289163e3bcbSSamson Tam unsigned int optimal_uclk_for_dcfclk_sta_targets[DC__VOLTAGE_STATES] = {0}; 1290163e3bcbSSamson Tam unsigned int optimal_dcfclk_for_uclk[DC__VOLTAGE_STATES] = {0}; 1291163e3bcbSSamson Tam 1292163e3bcbSSamson Tam unsigned int dcfclk_sta_targets[DC__VOLTAGE_STATES] = {694, 875, 1000, 1200}; 1293163e3bcbSSamson Tam unsigned int num_dcfclk_sta_targets = 4; 1294163e3bcbSSamson Tam unsigned int num_uclk_states; 1295163e3bcbSSamson Tam 1296163e3bcbSSamson Tam 1297163e3bcbSSamson Tam if (dc->ctx->dc_bios->vram_info.num_chans) 1298163e3bcbSSamson Tam dcn3_02_soc.num_chans = dc->ctx->dc_bios->vram_info.num_chans; 1299163e3bcbSSamson Tam 1300163e3bcbSSamson Tam if (dc->ctx->dc_bios->vram_info.dram_channel_width_bytes) 1301163e3bcbSSamson Tam dcn3_02_soc.dram_channel_width_bytes = dc->ctx->dc_bios->vram_info.dram_channel_width_bytes; 1302163e3bcbSSamson Tam 1303163e3bcbSSamson Tam dcn3_02_soc.dispclk_dppclk_vco_speed_mhz = dc->clk_mgr->dentist_vco_freq_khz / 1000.0; 1304163e3bcbSSamson Tam dc->dml.soc.dispclk_dppclk_vco_speed_mhz = dc->clk_mgr->dentist_vco_freq_khz / 1000.0; 1305163e3bcbSSamson Tam 1306163e3bcbSSamson Tam if (bw_params->clk_table.entries[0].memclk_mhz) { 1307163e3bcbSSamson Tam int max_dcfclk_mhz = 0, max_dispclk_mhz = 0, max_dppclk_mhz = 0, max_phyclk_mhz = 0; 1308163e3bcbSSamson Tam 1309163e3bcbSSamson Tam for (i = 0; i < MAX_NUM_DPM_LVL; i++) { 1310163e3bcbSSamson Tam if (bw_params->clk_table.entries[i].dcfclk_mhz > max_dcfclk_mhz) 1311163e3bcbSSamson Tam max_dcfclk_mhz = bw_params->clk_table.entries[i].dcfclk_mhz; 1312163e3bcbSSamson Tam if (bw_params->clk_table.entries[i].dispclk_mhz > max_dispclk_mhz) 1313163e3bcbSSamson Tam max_dispclk_mhz = bw_params->clk_table.entries[i].dispclk_mhz; 1314163e3bcbSSamson Tam if (bw_params->clk_table.entries[i].dppclk_mhz > max_dppclk_mhz) 1315163e3bcbSSamson Tam max_dppclk_mhz = bw_params->clk_table.entries[i].dppclk_mhz; 1316163e3bcbSSamson Tam if (bw_params->clk_table.entries[i].phyclk_mhz > max_phyclk_mhz) 1317163e3bcbSSamson Tam max_phyclk_mhz = bw_params->clk_table.entries[i].phyclk_mhz; 1318163e3bcbSSamson Tam } 1319163e3bcbSSamson Tam if (!max_dcfclk_mhz) 1320163e3bcbSSamson Tam max_dcfclk_mhz = dcn3_02_soc.clock_limits[0].dcfclk_mhz; 1321163e3bcbSSamson Tam if (!max_dispclk_mhz) 1322163e3bcbSSamson Tam max_dispclk_mhz = dcn3_02_soc.clock_limits[0].dispclk_mhz; 1323163e3bcbSSamson Tam if (!max_dppclk_mhz) 1324163e3bcbSSamson Tam max_dppclk_mhz = dcn3_02_soc.clock_limits[0].dppclk_mhz; 1325163e3bcbSSamson Tam if (!max_phyclk_mhz) 1326163e3bcbSSamson Tam max_phyclk_mhz = dcn3_02_soc.clock_limits[0].phyclk_mhz; 1327163e3bcbSSamson Tam 1328163e3bcbSSamson Tam if (max_dcfclk_mhz > dcfclk_sta_targets[num_dcfclk_sta_targets-1]) { 1329163e3bcbSSamson Tam /* If max DCFCLK is greater than the max DCFCLK STA target, insert into the DCFCLK STA target array */ 1330163e3bcbSSamson Tam dcfclk_sta_targets[num_dcfclk_sta_targets] = max_dcfclk_mhz; 1331163e3bcbSSamson Tam num_dcfclk_sta_targets++; 1332163e3bcbSSamson Tam } else if (max_dcfclk_mhz < dcfclk_sta_targets[num_dcfclk_sta_targets-1]) { 1333163e3bcbSSamson Tam /* If max DCFCLK is less than the max DCFCLK STA target, cap values and remove duplicates */ 1334163e3bcbSSamson Tam for (i = 0; i < num_dcfclk_sta_targets; i++) { 1335163e3bcbSSamson Tam if (dcfclk_sta_targets[i] > max_dcfclk_mhz) { 1336163e3bcbSSamson Tam dcfclk_sta_targets[i] = max_dcfclk_mhz; 1337163e3bcbSSamson Tam break; 1338163e3bcbSSamson Tam } 1339163e3bcbSSamson Tam } 1340163e3bcbSSamson Tam /* Update size of array since we "removed" duplicates */ 1341163e3bcbSSamson Tam num_dcfclk_sta_targets = i + 1; 1342163e3bcbSSamson Tam } 1343163e3bcbSSamson Tam 1344163e3bcbSSamson Tam num_uclk_states = bw_params->clk_table.num_entries; 1345163e3bcbSSamson Tam 1346163e3bcbSSamson Tam /* Calculate optimal dcfclk for each uclk */ 1347163e3bcbSSamson Tam for (i = 0; i < num_uclk_states; i++) { 1348163e3bcbSSamson Tam dcn302_get_optimal_dcfclk_fclk_for_uclk(bw_params->clk_table.entries[i].memclk_mhz * 16, 1349163e3bcbSSamson Tam &optimal_dcfclk_for_uclk[i], NULL); 1350163e3bcbSSamson Tam if (optimal_dcfclk_for_uclk[i] < bw_params->clk_table.entries[0].dcfclk_mhz) { 1351163e3bcbSSamson Tam optimal_dcfclk_for_uclk[i] = bw_params->clk_table.entries[0].dcfclk_mhz; 1352163e3bcbSSamson Tam } 1353163e3bcbSSamson Tam } 1354163e3bcbSSamson Tam 1355163e3bcbSSamson Tam /* Calculate optimal uclk for each dcfclk sta target */ 1356163e3bcbSSamson Tam for (i = 0; i < num_dcfclk_sta_targets; i++) { 1357163e3bcbSSamson Tam for (j = 0; j < num_uclk_states; j++) { 1358163e3bcbSSamson Tam if (dcfclk_sta_targets[i] < optimal_dcfclk_for_uclk[j]) { 1359163e3bcbSSamson Tam optimal_uclk_for_dcfclk_sta_targets[i] = 1360163e3bcbSSamson Tam bw_params->clk_table.entries[j].memclk_mhz * 16; 1361163e3bcbSSamson Tam break; 1362163e3bcbSSamson Tam } 1363163e3bcbSSamson Tam } 1364163e3bcbSSamson Tam } 1365163e3bcbSSamson Tam 1366163e3bcbSSamson Tam i = 0; 1367163e3bcbSSamson Tam j = 0; 1368163e3bcbSSamson Tam /* create the final dcfclk and uclk table */ 1369163e3bcbSSamson Tam while (i < num_dcfclk_sta_targets && j < num_uclk_states && num_states < DC__VOLTAGE_STATES) { 1370163e3bcbSSamson Tam if (dcfclk_sta_targets[i] < optimal_dcfclk_for_uclk[j] && i < num_dcfclk_sta_targets) { 1371163e3bcbSSamson Tam dcfclk_mhz[num_states] = dcfclk_sta_targets[i]; 1372163e3bcbSSamson Tam dram_speed_mts[num_states++] = optimal_uclk_for_dcfclk_sta_targets[i++]; 1373163e3bcbSSamson Tam } else { 1374163e3bcbSSamson Tam if (j < num_uclk_states && optimal_dcfclk_for_uclk[j] <= max_dcfclk_mhz) { 1375163e3bcbSSamson Tam dcfclk_mhz[num_states] = optimal_dcfclk_for_uclk[j]; 1376163e3bcbSSamson Tam dram_speed_mts[num_states++] = bw_params->clk_table.entries[j++].memclk_mhz * 16; 1377163e3bcbSSamson Tam } else { 1378163e3bcbSSamson Tam j = num_uclk_states; 1379163e3bcbSSamson Tam } 1380163e3bcbSSamson Tam } 1381163e3bcbSSamson Tam } 1382163e3bcbSSamson Tam 1383163e3bcbSSamson Tam while (i < num_dcfclk_sta_targets && num_states < DC__VOLTAGE_STATES) { 1384163e3bcbSSamson Tam dcfclk_mhz[num_states] = dcfclk_sta_targets[i]; 1385163e3bcbSSamson Tam dram_speed_mts[num_states++] = optimal_uclk_for_dcfclk_sta_targets[i++]; 1386163e3bcbSSamson Tam } 1387163e3bcbSSamson Tam 1388163e3bcbSSamson Tam while (j < num_uclk_states && num_states < DC__VOLTAGE_STATES && 1389163e3bcbSSamson Tam optimal_dcfclk_for_uclk[j] <= max_dcfclk_mhz) { 1390163e3bcbSSamson Tam dcfclk_mhz[num_states] = optimal_dcfclk_for_uclk[j]; 1391163e3bcbSSamson Tam dram_speed_mts[num_states++] = bw_params->clk_table.entries[j++].memclk_mhz * 16; 1392163e3bcbSSamson Tam } 1393163e3bcbSSamson Tam 1394163e3bcbSSamson Tam dcn3_02_soc.num_states = num_states; 1395163e3bcbSSamson Tam for (i = 0; i < dcn3_02_soc.num_states; i++) { 1396163e3bcbSSamson Tam dcn3_02_soc.clock_limits[i].state = i; 1397163e3bcbSSamson Tam dcn3_02_soc.clock_limits[i].dcfclk_mhz = dcfclk_mhz[i]; 1398163e3bcbSSamson Tam dcn3_02_soc.clock_limits[i].fabricclk_mhz = dcfclk_mhz[i]; 1399163e3bcbSSamson Tam dcn3_02_soc.clock_limits[i].dram_speed_mts = dram_speed_mts[i]; 1400163e3bcbSSamson Tam 1401163e3bcbSSamson Tam /* Fill all states with max values of all other clocks */ 1402163e3bcbSSamson Tam dcn3_02_soc.clock_limits[i].dispclk_mhz = max_dispclk_mhz; 1403163e3bcbSSamson Tam dcn3_02_soc.clock_limits[i].dppclk_mhz = max_dppclk_mhz; 1404163e3bcbSSamson Tam dcn3_02_soc.clock_limits[i].phyclk_mhz = max_phyclk_mhz; 1405ce350c6eSBindu Ramamurthy /* Populate from bw_params for DTBCLK, SOCCLK */ 1406ce350c6eSBindu Ramamurthy if (!bw_params->clk_table.entries[i].dtbclk_mhz && i > 0) 1407ce350c6eSBindu Ramamurthy dcn3_02_soc.clock_limits[i].dtbclk_mhz = dcn3_02_soc.clock_limits[i-1].dtbclk_mhz; 1408ce350c6eSBindu Ramamurthy else 1409ce350c6eSBindu Ramamurthy dcn3_02_soc.clock_limits[i].dtbclk_mhz = bw_params->clk_table.entries[i].dtbclk_mhz; 1410f30f5515SBindu Ramamurthy if (!bw_params->clk_table.entries[i].socclk_mhz && i > 0) 1411f30f5515SBindu Ramamurthy dcn3_02_soc.clock_limits[i].socclk_mhz = dcn3_02_soc.clock_limits[i-1].socclk_mhz; 1412f30f5515SBindu Ramamurthy else 1413f30f5515SBindu Ramamurthy dcn3_02_soc.clock_limits[i].socclk_mhz = bw_params->clk_table.entries[i].socclk_mhz; 1414163e3bcbSSamson Tam /* These clocks cannot come from bw_params, always fill from dcn3_02_soc[1] */ 1415f30f5515SBindu Ramamurthy /* FCLK, PHYCLK_D18, DSCCLK */ 1416163e3bcbSSamson Tam dcn3_02_soc.clock_limits[i].phyclk_d18_mhz = dcn3_02_soc.clock_limits[0].phyclk_d18_mhz; 1417163e3bcbSSamson Tam dcn3_02_soc.clock_limits[i].dscclk_mhz = dcn3_02_soc.clock_limits[0].dscclk_mhz; 1418163e3bcbSSamson Tam } 1419163e3bcbSSamson Tam /* re-init DML with updated bb */ 1420163e3bcbSSamson Tam dml_init_instance(&dc->dml, &dcn3_02_soc, &dcn3_02_ip, DML_PROJECT_DCN30); 1421163e3bcbSSamson Tam if (dc->current_state) 1422163e3bcbSSamson Tam dml_init_instance(&dc->current_state->bw_ctx.dml, &dcn3_02_soc, &dcn3_02_ip, DML_PROJECT_DCN30); 1423163e3bcbSSamson Tam } 1424163e3bcbSSamson Tam } 1425163e3bcbSSamson Tam 142636d26912SBhawanpreet Lakha static struct resource_funcs dcn302_res_pool_funcs = { 142736d26912SBhawanpreet Lakha .destroy = dcn302_destroy_resource_pool, 142836d26912SBhawanpreet Lakha .link_enc_create = dcn302_link_encoder_create, 142936d26912SBhawanpreet Lakha .panel_cntl_create = dcn302_panel_cntl_create, 143036d26912SBhawanpreet Lakha .validate_bandwidth = dcn30_validate_bandwidth, 143136d26912SBhawanpreet Lakha .calculate_wm_and_dlg = dcn30_calculate_wm_and_dlg, 1432443dfba0SDmytro Laktyushkin .update_soc_for_wm_a = dcn30_update_soc_for_wm_a, 143336d26912SBhawanpreet Lakha .populate_dml_pipes = dcn30_populate_dml_pipes_from_context, 143436d26912SBhawanpreet Lakha .acquire_idle_pipe_for_layer = dcn20_acquire_idle_pipe_for_layer, 143536d26912SBhawanpreet Lakha .add_stream_to_ctx = dcn30_add_stream_to_ctx, 143636d26912SBhawanpreet Lakha .add_dsc_to_stream_resource = dcn20_add_dsc_to_stream_resource, 143736d26912SBhawanpreet Lakha .remove_stream_from_ctx = dcn20_remove_stream_from_ctx, 143836d26912SBhawanpreet Lakha .populate_dml_writeback_from_context = dcn30_populate_dml_writeback_from_context, 143936d26912SBhawanpreet Lakha .set_mcif_arb_params = dcn30_set_mcif_arb_params, 144036d26912SBhawanpreet Lakha .find_first_free_match_stream_enc_for_link = dcn10_find_first_free_match_stream_enc_for_link, 144136d26912SBhawanpreet Lakha .acquire_post_bldn_3dlut = dcn30_acquire_post_bldn_3dlut, 144236d26912SBhawanpreet Lakha .release_post_bldn_3dlut = dcn30_release_post_bldn_3dlut, 1443163e3bcbSSamson Tam .update_bw_bounding_box = dcn302_update_bw_bounding_box, 144436d26912SBhawanpreet Lakha .patch_unknown_plane_state = dcn20_patch_unknown_plane_state, 144536d26912SBhawanpreet Lakha }; 144636d26912SBhawanpreet Lakha 144736d26912SBhawanpreet Lakha static struct dc_cap_funcs cap_funcs = { 144836d26912SBhawanpreet Lakha .get_dcc_compression_cap = dcn20_get_dcc_compression_cap 144936d26912SBhawanpreet Lakha }; 145036d26912SBhawanpreet Lakha 145136d26912SBhawanpreet Lakha static const struct bios_registers bios_regs = { 145236d26912SBhawanpreet Lakha NBIO_SR(BIOS_SCRATCH_3), 145336d26912SBhawanpreet Lakha NBIO_SR(BIOS_SCRATCH_6) 145436d26912SBhawanpreet Lakha }; 145536d26912SBhawanpreet Lakha 145636d26912SBhawanpreet Lakha static const struct dccg_registers dccg_regs = { 145736d26912SBhawanpreet Lakha DCCG_REG_LIST_DCN3_02() 145836d26912SBhawanpreet Lakha }; 145936d26912SBhawanpreet Lakha 146036d26912SBhawanpreet Lakha static const struct dccg_shift dccg_shift = { 146136d26912SBhawanpreet Lakha DCCG_MASK_SH_LIST_DCN3_02(__SHIFT) 146236d26912SBhawanpreet Lakha }; 146336d26912SBhawanpreet Lakha 146436d26912SBhawanpreet Lakha static const struct dccg_mask dccg_mask = { 146536d26912SBhawanpreet Lakha DCCG_MASK_SH_LIST_DCN3_02(_MASK) 146636d26912SBhawanpreet Lakha }; 146736d26912SBhawanpreet Lakha 146836d26912SBhawanpreet Lakha #define abm_regs(id)\ 1469b5ce6fe8SJosip Pavic [id] = { ABM_DCN302_REG_LIST(id) } 147036d26912SBhawanpreet Lakha 147136d26912SBhawanpreet Lakha static const struct dce_abm_registers abm_regs[] = { 147236d26912SBhawanpreet Lakha abm_regs(0), 147336d26912SBhawanpreet Lakha abm_regs(1), 147436d26912SBhawanpreet Lakha abm_regs(2), 147536d26912SBhawanpreet Lakha abm_regs(3), 147636d26912SBhawanpreet Lakha abm_regs(4) 147736d26912SBhawanpreet Lakha }; 147836d26912SBhawanpreet Lakha 147936d26912SBhawanpreet Lakha static const struct dce_abm_shift abm_shift = { 1480df043738SRoman Li ABM_MASK_SH_LIST_DCN30(__SHIFT) 148136d26912SBhawanpreet Lakha }; 148236d26912SBhawanpreet Lakha 148336d26912SBhawanpreet Lakha static const struct dce_abm_mask abm_mask = { 1484df043738SRoman Li ABM_MASK_SH_LIST_DCN30(_MASK) 148536d26912SBhawanpreet Lakha }; 148636d26912SBhawanpreet Lakha 148736d26912SBhawanpreet Lakha static bool dcn302_resource_construct( 148836d26912SBhawanpreet Lakha uint8_t num_virtual_links, 148936d26912SBhawanpreet Lakha struct dc *dc, 149036d26912SBhawanpreet Lakha struct resource_pool *pool) 149136d26912SBhawanpreet Lakha { 149236d26912SBhawanpreet Lakha int i; 149336d26912SBhawanpreet Lakha struct dc_context *ctx = dc->ctx; 149436d26912SBhawanpreet Lakha struct irq_service_init_data init_data; 149536d26912SBhawanpreet Lakha 149636d26912SBhawanpreet Lakha ctx->dc_bios->regs = &bios_regs; 149736d26912SBhawanpreet Lakha 149836d26912SBhawanpreet Lakha pool->res_cap = &res_cap_dcn302; 149936d26912SBhawanpreet Lakha 150036d26912SBhawanpreet Lakha pool->funcs = &dcn302_res_pool_funcs; 150136d26912SBhawanpreet Lakha 150236d26912SBhawanpreet Lakha /************************************************* 150336d26912SBhawanpreet Lakha * Resource + asic cap harcoding * 150436d26912SBhawanpreet Lakha *************************************************/ 150536d26912SBhawanpreet Lakha pool->underlay_pipe_index = NO_UNDERLAY_PIPE; 150636d26912SBhawanpreet Lakha pool->pipe_count = pool->res_cap->num_timing_generator; 150736d26912SBhawanpreet Lakha pool->mpcc_count = pool->res_cap->num_timing_generator; 150836d26912SBhawanpreet Lakha dc->caps.max_downscale_ratio = 600; 150936d26912SBhawanpreet Lakha dc->caps.i2c_speed_in_khz = 100; 1510e97978e8SCharlene Liu dc->caps.i2c_speed_in_khz_hdcp = 5; /*1.4 w/a applied by derfault*/ 151136d26912SBhawanpreet Lakha dc->caps.max_cursor_size = 256; 151206722b37SAshley Thomas dc->caps.min_horizontal_blanking_period = 80; 151336d26912SBhawanpreet Lakha dc->caps.dmdata_alloc_size = 2048; 1514ea7154d8SBhawanpreet Lakha dc->caps.mall_size_per_mem_channel = 4; 1515ea7154d8SBhawanpreet Lakha /* total size = mall per channel * num channels * 1024 * 1024 */ 1516ea7154d8SBhawanpreet Lakha dc->caps.mall_size_total = dc->caps.mall_size_per_mem_channel * dc->ctx->dc_bios->vram_info.num_chans * 1048576; 15177fc75382SBhawanpreet Lakha dc->caps.cursor_cache_size = dc->caps.max_cursor_size * dc->caps.max_cursor_size * 8; 151836d26912SBhawanpreet Lakha dc->caps.max_slave_planes = 1; 1519ae030570SAtufa Khan dc->caps.max_slave_yuv_planes = 1; 1520ae030570SAtufa Khan dc->caps.max_slave_rgb_planes = 1; 152136d26912SBhawanpreet Lakha dc->caps.post_blend_color_processing = true; 152236d26912SBhawanpreet Lakha dc->caps.force_dp_tps4_for_cp2520 = true; 152336d26912SBhawanpreet Lakha dc->caps.extended_aux_timeout_support = true; 152436d26912SBhawanpreet Lakha dc->caps.dmcub_support = true; 152536d26912SBhawanpreet Lakha 152636d26912SBhawanpreet Lakha /* Color pipeline capabilities */ 152736d26912SBhawanpreet Lakha dc->caps.color.dpp.dcn_arch = 1; 152836d26912SBhawanpreet Lakha dc->caps.color.dpp.input_lut_shared = 0; 152936d26912SBhawanpreet Lakha dc->caps.color.dpp.icsc = 1; 153036d26912SBhawanpreet Lakha dc->caps.color.dpp.dgam_ram = 0; // must use gamma_corr 153136d26912SBhawanpreet Lakha dc->caps.color.dpp.dgam_rom_caps.srgb = 1; 153236d26912SBhawanpreet Lakha dc->caps.color.dpp.dgam_rom_caps.bt2020 = 1; 153336d26912SBhawanpreet Lakha dc->caps.color.dpp.dgam_rom_caps.gamma2_2 = 1; 153436d26912SBhawanpreet Lakha dc->caps.color.dpp.dgam_rom_caps.pq = 1; 153536d26912SBhawanpreet Lakha dc->caps.color.dpp.dgam_rom_caps.hlg = 1; 153636d26912SBhawanpreet Lakha dc->caps.color.dpp.post_csc = 1; 153736d26912SBhawanpreet Lakha dc->caps.color.dpp.gamma_corr = 1; 1538c6160900SJing Zhou dc->caps.color.dpp.dgam_rom_for_yuv = 0; 153936d26912SBhawanpreet Lakha 154036d26912SBhawanpreet Lakha dc->caps.color.dpp.hw_3d_lut = 1; 154136d26912SBhawanpreet Lakha dc->caps.color.dpp.ogam_ram = 1; 154236d26912SBhawanpreet Lakha // no OGAM ROM on DCN3 154336d26912SBhawanpreet Lakha dc->caps.color.dpp.ogam_rom_caps.srgb = 0; 154436d26912SBhawanpreet Lakha dc->caps.color.dpp.ogam_rom_caps.bt2020 = 0; 154536d26912SBhawanpreet Lakha dc->caps.color.dpp.ogam_rom_caps.gamma2_2 = 0; 154636d26912SBhawanpreet Lakha dc->caps.color.dpp.ogam_rom_caps.pq = 0; 154736d26912SBhawanpreet Lakha dc->caps.color.dpp.ogam_rom_caps.hlg = 0; 154836d26912SBhawanpreet Lakha dc->caps.color.dpp.ocsc = 0; 154936d26912SBhawanpreet Lakha 155036d26912SBhawanpreet Lakha dc->caps.color.mpc.gamut_remap = 1; 155136d26912SBhawanpreet Lakha dc->caps.color.mpc.num_3dluts = pool->res_cap->num_mpc_3dlut; //3 155236d26912SBhawanpreet Lakha dc->caps.color.mpc.ogam_ram = 1; 155336d26912SBhawanpreet Lakha dc->caps.color.mpc.ogam_rom_caps.srgb = 0; 155436d26912SBhawanpreet Lakha dc->caps.color.mpc.ogam_rom_caps.bt2020 = 0; 155536d26912SBhawanpreet Lakha dc->caps.color.mpc.ogam_rom_caps.gamma2_2 = 0; 155636d26912SBhawanpreet Lakha dc->caps.color.mpc.ogam_rom_caps.pq = 0; 155736d26912SBhawanpreet Lakha dc->caps.color.mpc.ogam_rom_caps.hlg = 0; 155836d26912SBhawanpreet Lakha dc->caps.color.mpc.ocsc = 1; 155936d26912SBhawanpreet Lakha 15602430be71SAngus Wang /* read VBIOS LTTPR caps */ 15612430be71SAngus Wang if (ctx->dc_bios->funcs->get_lttpr_caps) { 15622430be71SAngus Wang enum bp_result bp_query_result; 15632430be71SAngus Wang uint8_t is_vbios_lttpr_enable = 0; 15642430be71SAngus Wang 15652430be71SAngus Wang bp_query_result = ctx->dc_bios->funcs->get_lttpr_caps(ctx->dc_bios, &is_vbios_lttpr_enable); 15662430be71SAngus Wang dc->caps.vbios_lttpr_enable = (bp_query_result == BP_RESULT_OK) && !!is_vbios_lttpr_enable; 15672430be71SAngus Wang } 15682430be71SAngus Wang 15692430be71SAngus Wang if (ctx->dc_bios->funcs->get_lttpr_interop) { 15702430be71SAngus Wang enum bp_result bp_query_result; 15712430be71SAngus Wang uint8_t is_vbios_interop_enabled = 0; 15722430be71SAngus Wang 15732430be71SAngus Wang bp_query_result = ctx->dc_bios->funcs->get_lttpr_interop(ctx->dc_bios, 15742430be71SAngus Wang &is_vbios_interop_enabled); 15752430be71SAngus Wang dc->caps.vbios_lttpr_aware = (bp_query_result == BP_RESULT_OK) && !!is_vbios_interop_enabled; 15762430be71SAngus Wang } 15772430be71SAngus Wang 157836d26912SBhawanpreet Lakha if (dc->ctx->dce_environment == DCE_ENV_PRODUCTION_DRV) 157936d26912SBhawanpreet Lakha dc->debug = debug_defaults_drv; 158036d26912SBhawanpreet Lakha else 158136d26912SBhawanpreet Lakha dc->debug = debug_defaults_diags; 158236d26912SBhawanpreet Lakha 158336d26912SBhawanpreet Lakha // Init the vm_helper 158436d26912SBhawanpreet Lakha if (dc->vm_helper) 158536d26912SBhawanpreet Lakha vm_helper_init(dc->vm_helper, 16); 158636d26912SBhawanpreet Lakha 158736d26912SBhawanpreet Lakha /************************************************* 158836d26912SBhawanpreet Lakha * Create resources * 158936d26912SBhawanpreet Lakha *************************************************/ 159036d26912SBhawanpreet Lakha 159136d26912SBhawanpreet Lakha /* Clock Sources for Pixel Clock*/ 159236d26912SBhawanpreet Lakha pool->clock_sources[DCN302_CLK_SRC_PLL0] = 159336d26912SBhawanpreet Lakha dcn302_clock_source_create(ctx, ctx->dc_bios, 159436d26912SBhawanpreet Lakha CLOCK_SOURCE_COMBO_PHY_PLL0, 159536d26912SBhawanpreet Lakha &clk_src_regs[0], false); 159636d26912SBhawanpreet Lakha pool->clock_sources[DCN302_CLK_SRC_PLL1] = 159736d26912SBhawanpreet Lakha dcn302_clock_source_create(ctx, ctx->dc_bios, 159836d26912SBhawanpreet Lakha CLOCK_SOURCE_COMBO_PHY_PLL1, 159936d26912SBhawanpreet Lakha &clk_src_regs[1], false); 160036d26912SBhawanpreet Lakha pool->clock_sources[DCN302_CLK_SRC_PLL2] = 160136d26912SBhawanpreet Lakha dcn302_clock_source_create(ctx, ctx->dc_bios, 160236d26912SBhawanpreet Lakha CLOCK_SOURCE_COMBO_PHY_PLL2, 160336d26912SBhawanpreet Lakha &clk_src_regs[2], false); 160436d26912SBhawanpreet Lakha pool->clock_sources[DCN302_CLK_SRC_PLL3] = 160536d26912SBhawanpreet Lakha dcn302_clock_source_create(ctx, ctx->dc_bios, 160636d26912SBhawanpreet Lakha CLOCK_SOURCE_COMBO_PHY_PLL3, 160736d26912SBhawanpreet Lakha &clk_src_regs[3], false); 160836d26912SBhawanpreet Lakha pool->clock_sources[DCN302_CLK_SRC_PLL4] = 160936d26912SBhawanpreet Lakha dcn302_clock_source_create(ctx, ctx->dc_bios, 161036d26912SBhawanpreet Lakha CLOCK_SOURCE_COMBO_PHY_PLL4, 161136d26912SBhawanpreet Lakha &clk_src_regs[4], false); 161236d26912SBhawanpreet Lakha 161336d26912SBhawanpreet Lakha pool->clk_src_count = DCN302_CLK_SRC_TOTAL; 161436d26912SBhawanpreet Lakha 161536d26912SBhawanpreet Lakha /* todo: not reuse phy_pll registers */ 161636d26912SBhawanpreet Lakha pool->dp_clock_source = 161736d26912SBhawanpreet Lakha dcn302_clock_source_create(ctx, ctx->dc_bios, 161836d26912SBhawanpreet Lakha CLOCK_SOURCE_ID_DP_DTO, 161936d26912SBhawanpreet Lakha &clk_src_regs[0], true); 162036d26912SBhawanpreet Lakha 162136d26912SBhawanpreet Lakha for (i = 0; i < pool->clk_src_count; i++) { 162236d26912SBhawanpreet Lakha if (pool->clock_sources[i] == NULL) { 162336d26912SBhawanpreet Lakha dm_error("DC: failed to create clock sources!\n"); 162436d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 162536d26912SBhawanpreet Lakha goto create_fail; 162636d26912SBhawanpreet Lakha } 162736d26912SBhawanpreet Lakha } 162836d26912SBhawanpreet Lakha 162936d26912SBhawanpreet Lakha /* DCCG */ 163036d26912SBhawanpreet Lakha pool->dccg = dccg30_create(ctx, &dccg_regs, &dccg_shift, &dccg_mask); 163136d26912SBhawanpreet Lakha if (pool->dccg == NULL) { 163236d26912SBhawanpreet Lakha dm_error("DC: failed to create dccg!\n"); 163336d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 163436d26912SBhawanpreet Lakha goto create_fail; 163536d26912SBhawanpreet Lakha } 163636d26912SBhawanpreet Lakha 163736d26912SBhawanpreet Lakha /* PP Lib and SMU interfaces */ 163836d26912SBhawanpreet Lakha init_soc_bounding_box(dc, pool); 163936d26912SBhawanpreet Lakha 164036d26912SBhawanpreet Lakha /* DML */ 164136d26912SBhawanpreet Lakha dml_init_instance(&dc->dml, &dcn3_02_soc, &dcn3_02_ip, DML_PROJECT_DCN30); 164236d26912SBhawanpreet Lakha 164336d26912SBhawanpreet Lakha /* IRQ */ 164436d26912SBhawanpreet Lakha init_data.ctx = dc->ctx; 164536d26912SBhawanpreet Lakha pool->irqs = dal_irq_service_dcn302_create(&init_data); 164636d26912SBhawanpreet Lakha if (!pool->irqs) 164736d26912SBhawanpreet Lakha goto create_fail; 164836d26912SBhawanpreet Lakha 164936d26912SBhawanpreet Lakha /* HUBBUB */ 165036d26912SBhawanpreet Lakha pool->hubbub = dcn302_hubbub_create(ctx); 165136d26912SBhawanpreet Lakha if (pool->hubbub == NULL) { 165236d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 165336d26912SBhawanpreet Lakha dm_error("DC: failed to create hubbub!\n"); 165436d26912SBhawanpreet Lakha goto create_fail; 165536d26912SBhawanpreet Lakha } 165636d26912SBhawanpreet Lakha 165736d26912SBhawanpreet Lakha /* HUBPs, DPPs, OPPs and TGs */ 165836d26912SBhawanpreet Lakha for (i = 0; i < pool->pipe_count; i++) { 165936d26912SBhawanpreet Lakha pool->hubps[i] = dcn302_hubp_create(ctx, i); 166036d26912SBhawanpreet Lakha if (pool->hubps[i] == NULL) { 166136d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 166236d26912SBhawanpreet Lakha dm_error("DC: failed to create hubps!\n"); 166336d26912SBhawanpreet Lakha goto create_fail; 166436d26912SBhawanpreet Lakha } 166536d26912SBhawanpreet Lakha 166636d26912SBhawanpreet Lakha pool->dpps[i] = dcn302_dpp_create(ctx, i); 166736d26912SBhawanpreet Lakha if (pool->dpps[i] == NULL) { 166836d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 166936d26912SBhawanpreet Lakha dm_error("DC: failed to create dpps!\n"); 167036d26912SBhawanpreet Lakha goto create_fail; 167136d26912SBhawanpreet Lakha } 167236d26912SBhawanpreet Lakha } 167336d26912SBhawanpreet Lakha 167436d26912SBhawanpreet Lakha for (i = 0; i < pool->res_cap->num_opp; i++) { 167536d26912SBhawanpreet Lakha pool->opps[i] = dcn302_opp_create(ctx, i); 167636d26912SBhawanpreet Lakha if (pool->opps[i] == NULL) { 167736d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 167836d26912SBhawanpreet Lakha dm_error("DC: failed to create output pixel processor!\n"); 167936d26912SBhawanpreet Lakha goto create_fail; 168036d26912SBhawanpreet Lakha } 168136d26912SBhawanpreet Lakha } 168236d26912SBhawanpreet Lakha 168336d26912SBhawanpreet Lakha for (i = 0; i < pool->res_cap->num_timing_generator; i++) { 168436d26912SBhawanpreet Lakha pool->timing_generators[i] = dcn302_timing_generator_create(ctx, i); 168536d26912SBhawanpreet Lakha if (pool->timing_generators[i] == NULL) { 168636d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 168736d26912SBhawanpreet Lakha dm_error("DC: failed to create tg!\n"); 168836d26912SBhawanpreet Lakha goto create_fail; 168936d26912SBhawanpreet Lakha } 169036d26912SBhawanpreet Lakha } 169136d26912SBhawanpreet Lakha pool->timing_generator_count = i; 169236d26912SBhawanpreet Lakha 169365e05ca7SJoshua Aberback /* PSR */ 169465e05ca7SJoshua Aberback pool->psr = dmub_psr_create(ctx); 169565e05ca7SJoshua Aberback if (pool->psr == NULL) { 169665e05ca7SJoshua Aberback dm_error("DC: failed to create psr!\n"); 169765e05ca7SJoshua Aberback BREAK_TO_DEBUGGER(); 169865e05ca7SJoshua Aberback goto create_fail; 169965e05ca7SJoshua Aberback } 170065e05ca7SJoshua Aberback 170136d26912SBhawanpreet Lakha /* ABMs */ 170236d26912SBhawanpreet Lakha for (i = 0; i < pool->res_cap->num_timing_generator; i++) { 170336d26912SBhawanpreet Lakha pool->multiple_abms[i] = dmub_abm_create(ctx, &abm_regs[i], &abm_shift, &abm_mask); 170436d26912SBhawanpreet Lakha if (pool->multiple_abms[i] == NULL) { 170536d26912SBhawanpreet Lakha dm_error("DC: failed to create abm for pipe %d!\n", i); 170636d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 170736d26912SBhawanpreet Lakha goto create_fail; 170836d26912SBhawanpreet Lakha } 170936d26912SBhawanpreet Lakha } 171036d26912SBhawanpreet Lakha 171136d26912SBhawanpreet Lakha /* MPC and DSC */ 171236d26912SBhawanpreet Lakha pool->mpc = dcn302_mpc_create(ctx, pool->mpcc_count, pool->res_cap->num_mpc_3dlut); 171336d26912SBhawanpreet Lakha if (pool->mpc == NULL) { 171436d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 171536d26912SBhawanpreet Lakha dm_error("DC: failed to create mpc!\n"); 171636d26912SBhawanpreet Lakha goto create_fail; 171736d26912SBhawanpreet Lakha } 171836d26912SBhawanpreet Lakha 171936d26912SBhawanpreet Lakha for (i = 0; i < pool->res_cap->num_dsc; i++) { 172036d26912SBhawanpreet Lakha pool->dscs[i] = dcn302_dsc_create(ctx, i); 172136d26912SBhawanpreet Lakha if (pool->dscs[i] == NULL) { 172236d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 172336d26912SBhawanpreet Lakha dm_error("DC: failed to create display stream compressor %d!\n", i); 172436d26912SBhawanpreet Lakha goto create_fail; 172536d26912SBhawanpreet Lakha } 172636d26912SBhawanpreet Lakha } 172736d26912SBhawanpreet Lakha 172836d26912SBhawanpreet Lakha /* DWB and MMHUBBUB */ 172936d26912SBhawanpreet Lakha if (!dcn302_dwbc_create(ctx, pool)) { 173036d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 173136d26912SBhawanpreet Lakha dm_error("DC: failed to create dwbc!\n"); 173236d26912SBhawanpreet Lakha goto create_fail; 173336d26912SBhawanpreet Lakha } 173436d26912SBhawanpreet Lakha 173536d26912SBhawanpreet Lakha if (!dcn302_mmhubbub_create(ctx, pool)) { 173636d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 173736d26912SBhawanpreet Lakha dm_error("DC: failed to create mcif_wb!\n"); 173836d26912SBhawanpreet Lakha goto create_fail; 173936d26912SBhawanpreet Lakha } 174036d26912SBhawanpreet Lakha 174136d26912SBhawanpreet Lakha /* AUX and I2C */ 174236d26912SBhawanpreet Lakha for (i = 0; i < pool->res_cap->num_ddc; i++) { 174336d26912SBhawanpreet Lakha pool->engines[i] = dcn302_aux_engine_create(ctx, i); 174436d26912SBhawanpreet Lakha if (pool->engines[i] == NULL) { 174536d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 174636d26912SBhawanpreet Lakha dm_error("DC:failed to create aux engine!!\n"); 174736d26912SBhawanpreet Lakha goto create_fail; 174836d26912SBhawanpreet Lakha } 174936d26912SBhawanpreet Lakha pool->hw_i2cs[i] = dcn302_i2c_hw_create(ctx, i); 175036d26912SBhawanpreet Lakha if (pool->hw_i2cs[i] == NULL) { 175136d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 175236d26912SBhawanpreet Lakha dm_error("DC:failed to create hw i2c!!\n"); 175336d26912SBhawanpreet Lakha goto create_fail; 175436d26912SBhawanpreet Lakha } 175536d26912SBhawanpreet Lakha pool->sw_i2cs[i] = NULL; 175636d26912SBhawanpreet Lakha } 175736d26912SBhawanpreet Lakha 175836d26912SBhawanpreet Lakha /* Audio, Stream Encoders including HPO and virtual, MPC 3D LUTs */ 175936d26912SBhawanpreet Lakha if (!resource_construct(num_virtual_links, dc, pool, 176036d26912SBhawanpreet Lakha (!IS_FPGA_MAXIMUS_DC(dc->ctx->dce_environment) ? 176136d26912SBhawanpreet Lakha &res_create_funcs : &res_create_maximus_funcs))) 176236d26912SBhawanpreet Lakha goto create_fail; 176336d26912SBhawanpreet Lakha 176436d26912SBhawanpreet Lakha /* HW Sequencer and Plane caps */ 176536d26912SBhawanpreet Lakha dcn302_hw_sequencer_construct(dc); 176636d26912SBhawanpreet Lakha 176736d26912SBhawanpreet Lakha dc->caps.max_planes = pool->pipe_count; 176836d26912SBhawanpreet Lakha 176936d26912SBhawanpreet Lakha for (i = 0; i < dc->caps.max_planes; ++i) 177036d26912SBhawanpreet Lakha dc->caps.planes[i] = plane_cap; 177136d26912SBhawanpreet Lakha 177236d26912SBhawanpreet Lakha dc->cap_funcs = cap_funcs; 177336d26912SBhawanpreet Lakha 177436d26912SBhawanpreet Lakha return true; 177536d26912SBhawanpreet Lakha 177636d26912SBhawanpreet Lakha create_fail: 177736d26912SBhawanpreet Lakha 177836d26912SBhawanpreet Lakha dcn302_resource_destruct(pool); 177936d26912SBhawanpreet Lakha 178036d26912SBhawanpreet Lakha return false; 178136d26912SBhawanpreet Lakha } 178236d26912SBhawanpreet Lakha 178336d26912SBhawanpreet Lakha struct resource_pool *dcn302_create_resource_pool(const struct dc_init_data *init_data, struct dc *dc) 178436d26912SBhawanpreet Lakha { 178536d26912SBhawanpreet Lakha struct resource_pool *pool = kzalloc(sizeof(struct resource_pool), GFP_KERNEL); 178636d26912SBhawanpreet Lakha 178736d26912SBhawanpreet Lakha if (!pool) 178836d26912SBhawanpreet Lakha return NULL; 178936d26912SBhawanpreet Lakha 179036d26912SBhawanpreet Lakha if (dcn302_resource_construct(init_data->num_virtual_links, dc, pool)) 179136d26912SBhawanpreet Lakha return pool; 179236d26912SBhawanpreet Lakha 179336d26912SBhawanpreet Lakha BREAK_TO_DEBUGGER(); 179436d26912SBhawanpreet Lakha kfree(pool); 179536d26912SBhawanpreet Lakha return NULL; 179636d26912SBhawanpreet Lakha } 1797