drm/amd: Add atomfirmware.h definitions needed for DCN32/321
Add new structures for DCN 3.2.x. Signed-off-by: Aurabindo Pillai <aurabindo.pillai@amd.com> Acked-by: Alex Deucher <alexander.deucher@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
2f6247dad2
commit
b801d8ad1b
|
@ -726,18 +726,20 @@ struct vram_usagebyfirmware_v2_1
|
|||
***************************************************************************
|
||||
*/
|
||||
|
||||
enum atom_object_record_type_id
|
||||
{
|
||||
ATOM_I2C_RECORD_TYPE =1,
|
||||
ATOM_HPD_INT_RECORD_TYPE =2,
|
||||
ATOM_OBJECT_GPIO_CNTL_RECORD_TYPE =9,
|
||||
ATOM_CONNECTOR_HPDPIN_LUT_RECORD_TYPE =16,
|
||||
ATOM_CONNECTOR_AUXDDC_LUT_RECORD_TYPE =17,
|
||||
ATOM_ENCODER_CAP_RECORD_TYPE=20,
|
||||
ATOM_BRACKET_LAYOUT_RECORD_TYPE=21,
|
||||
ATOM_CONNECTOR_FORCED_TMDS_CAP_RECORD_TYPE=22,
|
||||
ATOM_DISP_CONNECTOR_CAPS_RECORD_TYPE=23,
|
||||
ATOM_RECORD_END_TYPE =0xFF,
|
||||
enum atom_object_record_type_id {
|
||||
ATOM_I2C_RECORD_TYPE = 1,
|
||||
ATOM_HPD_INT_RECORD_TYPE = 2,
|
||||
ATOM_CONNECTOR_CAP_RECORD_TYPE = 3,
|
||||
ATOM_CONNECTOR_SPEED_UPTO = 4,
|
||||
ATOM_OBJECT_GPIO_CNTL_RECORD_TYPE = 9,
|
||||
ATOM_CONNECTOR_HPDPIN_LUT_RECORD_TYPE = 16,
|
||||
ATOM_CONNECTOR_AUXDDC_LUT_RECORD_TYPE = 17,
|
||||
ATOM_ENCODER_CAP_RECORD_TYPE = 20,
|
||||
ATOM_BRACKET_LAYOUT_RECORD_TYPE = 21,
|
||||
ATOM_CONNECTOR_FORCED_TMDS_CAP_RECORD_TYPE = 22,
|
||||
ATOM_DISP_CONNECTOR_CAPS_RECORD_TYPE = 23,
|
||||
ATOM_BRACKET_LAYOUT_V2_RECORD_TYPE = 25,
|
||||
ATOM_RECORD_END_TYPE = 0xFF,
|
||||
};
|
||||
|
||||
struct atom_common_record_header
|
||||
|
@ -760,6 +762,19 @@ struct atom_hpd_int_record
|
|||
uint8_t plugin_pin_state;
|
||||
};
|
||||
|
||||
struct atom_connector_caps_record {
|
||||
struct atom_common_record_header
|
||||
record_header; //record_type = ATOM_CONN_CAP_RECORD_TYPE
|
||||
uint16_t connector_caps; //01b if internal display is checked; 10b if internal BL is checked; 0 of Not
|
||||
};
|
||||
|
||||
struct atom_connector_speed_record {
|
||||
struct atom_common_record_header
|
||||
record_header; //record_type = ATOM_CONN_SPEED_UPTO
|
||||
uint32_t connector_max_speed; // connector Max speed attribute, it sets 8100 in Mhz when DP connector @8.1Ghz.
|
||||
uint16_t reserved;
|
||||
};
|
||||
|
||||
// Bit maps for ATOM_ENCODER_CAP_RECORD.usEncoderCap
|
||||
enum atom_encoder_caps_def
|
||||
{
|
||||
|
@ -885,6 +900,21 @@ struct atom_bracket_layout_record
|
|||
uint8_t reserved;
|
||||
struct atom_connector_layout_info conn_info[1];
|
||||
};
|
||||
struct atom_bracket_layout_record_v2 {
|
||||
struct atom_common_record_header
|
||||
record_header; //record_type = ATOM_BRACKET_LAYOUT_RECORD_TYPE
|
||||
uint8_t bracketlen; //Bracket Length in mm
|
||||
uint8_t bracketwidth; //Bracket Width in mm
|
||||
uint8_t conn_num; //Connector numbering
|
||||
uint8_t mini_type; //Mini Type (0 = Normal; 1 = Mini)
|
||||
uint8_t reserved1;
|
||||
uint8_t reserved2;
|
||||
};
|
||||
|
||||
enum atom_connector_layout_info_mini_type_def {
|
||||
MINI_TYPE_NORMAL = 0,
|
||||
MINI_TYPE_MINI = 1,
|
||||
};
|
||||
|
||||
enum atom_display_device_tag_def{
|
||||
ATOM_DISPLAY_LCD1_SUPPORT = 0x0002, //an embedded display is either an LVDS or eDP signal type of display
|
||||
|
@ -911,6 +941,19 @@ struct atom_display_object_path_v2
|
|||
uint8_t reserved;
|
||||
};
|
||||
|
||||
struct atom_display_object_path_v3 {
|
||||
uint16_t display_objid; //Connector Object ID or Misc Object ID
|
||||
uint16_t disp_recordoffset;
|
||||
uint16_t encoderobjid; //first encoder closer to the connector, could be either an external or intenal encoder
|
||||
uint16_t reserved1; //only on USBC case, otherwise always = 0
|
||||
uint16_t reserved2; //reserved and always = 0
|
||||
uint16_t reserved3; //reserved and always = 0
|
||||
//a supported device vector, each display path starts with this.the paths are enumerated in the way of priority,
|
||||
//a path appears first
|
||||
uint16_t device_tag;
|
||||
uint16_t reserved4; //reserved and always = 0
|
||||
};
|
||||
|
||||
struct display_object_info_table_v1_4
|
||||
{
|
||||
struct atom_common_table_header table_header;
|
||||
|
@ -920,6 +963,15 @@ struct display_object_info_table_v1_4
|
|||
struct atom_display_object_path_v2 display_path[8]; //the real number of this included in the structure is calculated by using the (whole structure size - the header size- number_of_path)/size of atom_display_object_path
|
||||
};
|
||||
|
||||
struct display_object_info_table_v1_5 {
|
||||
struct atom_common_table_header table_header;
|
||||
uint16_t supporteddevices;
|
||||
uint8_t number_of_path;
|
||||
uint8_t reserved;
|
||||
// the real number of this included in the structure is calculated by using the
|
||||
// (whole structure size - the header size- number_of_path)/size of atom_display_object_path
|
||||
struct atom_display_object_path_v3 display_path[8];
|
||||
};
|
||||
|
||||
/*
|
||||
***************************************************************************
|
||||
|
@ -1080,17 +1132,73 @@ struct atom_dc_golden_table_v1
|
|||
uint32_t reserved[23];
|
||||
};
|
||||
|
||||
enum dce_info_caps_def
|
||||
enum dce_info_caps_def {
|
||||
// only for VBIOS
|
||||
DCE_INFO_CAPS_FORCE_DISPDEV_CONNECTED = 0x02,
|
||||
// only for VBIOS
|
||||
DCE_INFO_CAPS_DISABLE_DFP_DP_HBR2 = 0x04,
|
||||
// only for VBIOS
|
||||
DCE_INFO_CAPS_ENABLE_INTERLAC_TIMING = 0x08,
|
||||
// only for VBIOS
|
||||
DCE_INFO_CAPS_LTTPR_SUPPORT_ENABLE = 0x20,
|
||||
DCE_INFO_CAPS_VBIOS_LTTPR_TRANSPARENT_ENABLE = 0x40,
|
||||
};
|
||||
|
||||
struct atom_display_controller_info_v4_5
|
||||
{
|
||||
// only for VBIOS
|
||||
DCE_INFO_CAPS_FORCE_DISPDEV_CONNECTED =0x02,
|
||||
// only for VBIOS
|
||||
DCE_INFO_CAPS_DISABLE_DFP_DP_HBR2 =0x04,
|
||||
// only for VBIOS
|
||||
DCE_INFO_CAPS_ENABLE_INTERLAC_TIMING =0x08,
|
||||
// only for VBIOS
|
||||
DCE_INFO_CAPS_LTTPR_SUPPORT_ENABLE =0x20,
|
||||
DCE_INFO_CAPS_VBIOS_LTTPR_TRANSPARENT_ENABLE = 0x40,
|
||||
struct atom_common_table_header table_header;
|
||||
uint32_t display_caps;
|
||||
uint32_t bootup_dispclk_10khz;
|
||||
uint16_t dce_refclk_10khz;
|
||||
uint16_t i2c_engine_refclk_10khz;
|
||||
uint16_t dvi_ss_percentage; // in unit of 0.001%
|
||||
uint16_t dvi_ss_rate_10hz;
|
||||
uint16_t hdmi_ss_percentage; // in unit of 0.001%
|
||||
uint16_t hdmi_ss_rate_10hz;
|
||||
uint16_t dp_ss_percentage; // in unit of 0.001%
|
||||
uint16_t dp_ss_rate_10hz;
|
||||
uint8_t dvi_ss_mode; // enum of atom_spread_spectrum_mode
|
||||
uint8_t hdmi_ss_mode; // enum of atom_spread_spectrum_mode
|
||||
uint8_t dp_ss_mode; // enum of atom_spread_spectrum_mode
|
||||
uint8_t ss_reserved;
|
||||
// DFP hardcode mode number defined in StandardVESA_TimingTable when EDID is not available
|
||||
uint8_t dfp_hardcode_mode_num;
|
||||
// DFP hardcode mode refreshrate defined in StandardVESA_TimingTable when EDID is not available
|
||||
uint8_t dfp_hardcode_refreshrate;
|
||||
// VGA hardcode mode number defined in StandardVESA_TimingTable when EDID is not avablable
|
||||
uint8_t vga_hardcode_mode_num;
|
||||
// VGA hardcode mode number defined in StandardVESA_TimingTable when EDID is not avablable
|
||||
uint8_t vga_hardcode_refreshrate;
|
||||
uint16_t dpphy_refclk_10khz;
|
||||
uint16_t hw_chip_id;
|
||||
uint8_t dcnip_min_ver;
|
||||
uint8_t dcnip_max_ver;
|
||||
uint8_t max_disp_pipe_num;
|
||||
uint8_t max_vbios_active_disp_pipe_num;
|
||||
uint8_t max_ppll_num;
|
||||
uint8_t max_disp_phy_num;
|
||||
uint8_t max_aux_pairs;
|
||||
uint8_t remotedisplayconfig;
|
||||
uint32_t dispclk_pll_vco_freq;
|
||||
uint32_t dp_ref_clk_freq;
|
||||
// Worst case blackout duration for a memory clock frequency (p-state) change, units of 100s of ns (0.1 us)
|
||||
uint32_t max_mclk_chg_lat;
|
||||
// Worst case memory self refresh exit time, units of 100ns of ns (0.1us)
|
||||
uint32_t max_sr_exit_lat;
|
||||
// Worst case memory self refresh entry followed by immediate exit time, units of 100ns of ns (0.1us)
|
||||
uint32_t max_sr_enter_exit_lat;
|
||||
uint16_t dc_golden_table_offset; // point of struct of atom_dc_golden_table_vxx
|
||||
uint16_t dc_golden_table_ver;
|
||||
uint32_t aux_dphy_rx_control0_val;
|
||||
uint32_t aux_dphy_tx_control_val;
|
||||
uint32_t aux_dphy_rx_control1_val;
|
||||
uint32_t dc_gpio_aux_ctrl_0_val;
|
||||
uint32_t dc_gpio_aux_ctrl_1_val;
|
||||
uint32_t dc_gpio_aux_ctrl_2_val;
|
||||
uint32_t dc_gpio_aux_ctrl_3_val;
|
||||
uint32_t dc_gpio_aux_ctrl_4_val;
|
||||
uint32_t dc_gpio_aux_ctrl_5_val;
|
||||
uint32_t reserved[26];
|
||||
};
|
||||
|
||||
/*
|
||||
|
@ -1806,6 +1914,63 @@ struct atom_smu_info_v3_3 {
|
|||
uint32_t reserved;
|
||||
};
|
||||
|
||||
struct atom_smu_info_v3_5
|
||||
{
|
||||
struct atom_common_table_header table_header;
|
||||
uint8_t smuip_min_ver;
|
||||
uint8_t smuip_max_ver;
|
||||
uint8_t waflclk_ss_mode;
|
||||
uint8_t gpuclk_ss_mode;
|
||||
uint16_t sclk_ss_percentage;
|
||||
uint16_t sclk_ss_rate_10hz;
|
||||
uint16_t gpuclk_ss_percentage; // in unit of 0.001%
|
||||
uint16_t gpuclk_ss_rate_10hz;
|
||||
uint32_t core_refclk_10khz;
|
||||
uint32_t syspll0_1_vco_freq_10khz;
|
||||
uint32_t syspll0_2_vco_freq_10khz;
|
||||
uint8_t pcc_gpio_bit; // GPIO bit shift in SMU_GPIOPAD_A configured for PCC, =0xff means invalid
|
||||
uint8_t pcc_gpio_polarity; // GPIO polarity for CTF
|
||||
uint16_t smugoldenoffset;
|
||||
uint32_t syspll0_0_vco_freq_10khz;
|
||||
uint32_t bootup_smnclk_10khz;
|
||||
uint32_t bootup_socclk_10khz;
|
||||
uint32_t bootup_mp0clk_10khz;
|
||||
uint32_t bootup_mp1clk_10khz;
|
||||
uint32_t bootup_lclk_10khz;
|
||||
uint32_t bootup_dcefclk_10khz;
|
||||
uint32_t ctf_threshold_override_value;
|
||||
uint32_t syspll3_0_vco_freq_10khz;
|
||||
uint32_t syspll3_1_vco_freq_10khz;
|
||||
uint32_t bootup_fclk_10khz;
|
||||
uint32_t bootup_waflclk_10khz;
|
||||
uint32_t smu_info_caps;
|
||||
uint16_t waflclk_ss_percentage; // in unit of 0.001%
|
||||
uint16_t smuinitoffset;
|
||||
uint32_t bootup_dprefclk_10khz;
|
||||
uint32_t bootup_usbclk_10khz;
|
||||
uint32_t smb_slave_address;
|
||||
uint32_t cg_fdo_ctrl0_val;
|
||||
uint32_t cg_fdo_ctrl1_val;
|
||||
uint32_t cg_fdo_ctrl2_val;
|
||||
uint32_t gdfll_as_wait_ctrl_val;
|
||||
uint32_t gdfll_as_step_ctrl_val;
|
||||
uint32_t bootup_dtbclk_10khz;
|
||||
uint32_t fclk_syspll_refclk_10khz;
|
||||
uint32_t smusvi_svc0_val;
|
||||
uint32_t smusvi_svc1_val;
|
||||
uint32_t smusvi_svd0_val;
|
||||
uint32_t smusvi_svd1_val;
|
||||
uint32_t smusvi_svt0_val;
|
||||
uint32_t smusvi_svt1_val;
|
||||
uint32_t cg_tach_ctrl_val;
|
||||
uint32_t cg_pump_ctrl1_val;
|
||||
uint32_t cg_pump_tach_ctrl_val;
|
||||
uint32_t thm_ctf_delay_val;
|
||||
uint32_t thm_thermal_int_ctrl_val;
|
||||
uint32_t thm_tmon_config_val;
|
||||
uint32_t reserved[16];
|
||||
};
|
||||
|
||||
struct atom_smu_info_v3_6
|
||||
{
|
||||
struct atom_common_table_header table_header;
|
||||
|
|
Loading…
Reference in New Issue