Home | History | Annotate | Line # | Download | only in radeon
      1  1.2  riastrad /*	$NetBSD: sislands_smc.h,v 1.3 2021/12/18 23:45:43 riastradh Exp $	*/
      2  1.2  riastrad 
      3  1.1  riastrad /*
      4  1.1  riastrad  * Copyright 2013 Advanced Micro Devices, Inc.
      5  1.1  riastrad  *
      6  1.1  riastrad  * Permission is hereby granted, free of charge, to any person obtaining a
      7  1.1  riastrad  * copy of this software and associated documentation files (the "Software"),
      8  1.1  riastrad  * to deal in the Software without restriction, including without limitation
      9  1.1  riastrad  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
     10  1.1  riastrad  * and/or sell copies of the Software, and to permit persons to whom the
     11  1.1  riastrad  * Software is furnished to do so, subject to the following conditions:
     12  1.1  riastrad  *
     13  1.1  riastrad  * The above copyright notice and this permission notice shall be included in
     14  1.1  riastrad  * all copies or substantial portions of the Software.
     15  1.1  riastrad  *
     16  1.1  riastrad  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
     17  1.1  riastrad  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
     18  1.1  riastrad  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
     19  1.1  riastrad  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
     20  1.1  riastrad  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
     21  1.1  riastrad  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
     22  1.1  riastrad  * OTHER DEALINGS IN THE SOFTWARE.
     23  1.1  riastrad  *
     24  1.1  riastrad  */
     25  1.1  riastrad #ifndef PP_SISLANDS_SMC_H
     26  1.1  riastrad #define PP_SISLANDS_SMC_H
     27  1.1  riastrad 
     28  1.1  riastrad #include "ppsmc.h"
     29  1.1  riastrad 
     30  1.1  riastrad #pragma pack(push, 1)
     31  1.1  riastrad 
     32  1.1  riastrad #define SISLANDS_MAX_SMC_PERFORMANCE_LEVELS_PER_SWSTATE 16
     33  1.1  riastrad 
     34  1.1  riastrad struct PP_SIslands_Dpm2PerfLevel
     35  1.1  riastrad {
     36  1.1  riastrad     uint8_t MaxPS;
     37  1.1  riastrad     uint8_t TgtAct;
     38  1.1  riastrad     uint8_t MaxPS_StepInc;
     39  1.1  riastrad     uint8_t MaxPS_StepDec;
     40  1.1  riastrad     uint8_t PSSamplingTime;
     41  1.1  riastrad     uint8_t NearTDPDec;
     42  1.1  riastrad     uint8_t AboveSafeInc;
     43  1.1  riastrad     uint8_t BelowSafeInc;
     44  1.1  riastrad     uint8_t PSDeltaLimit;
     45  1.1  riastrad     uint8_t PSDeltaWin;
     46  1.1  riastrad     uint16_t PwrEfficiencyRatio;
     47  1.1  riastrad     uint8_t Reserved[4];
     48  1.1  riastrad };
     49  1.1  riastrad 
     50  1.1  riastrad typedef struct PP_SIslands_Dpm2PerfLevel PP_SIslands_Dpm2PerfLevel;
     51  1.1  riastrad 
     52  1.1  riastrad struct PP_SIslands_DPM2Status
     53  1.1  riastrad {
     54  1.1  riastrad     uint32_t    dpm2Flags;
     55  1.1  riastrad     uint8_t     CurrPSkip;
     56  1.1  riastrad     uint8_t     CurrPSkipPowerShift;
     57  1.1  riastrad     uint8_t     CurrPSkipTDP;
     58  1.1  riastrad     uint8_t     CurrPSkipOCP;
     59  1.1  riastrad     uint8_t     MaxSPLLIndex;
     60  1.1  riastrad     uint8_t     MinSPLLIndex;
     61  1.1  riastrad     uint8_t     CurrSPLLIndex;
     62  1.1  riastrad     uint8_t     InfSweepMode;
     63  1.1  riastrad     uint8_t     InfSweepDir;
     64  1.1  riastrad     uint8_t     TDPexceeded;
     65  1.1  riastrad     uint8_t     reserved;
     66  1.1  riastrad     uint8_t     SwitchDownThreshold;
     67  1.1  riastrad     uint32_t    SwitchDownCounter;
     68  1.1  riastrad     uint32_t    SysScalingFactor;
     69  1.1  riastrad };
     70  1.1  riastrad 
     71  1.1  riastrad typedef struct PP_SIslands_DPM2Status PP_SIslands_DPM2Status;
     72  1.1  riastrad 
     73  1.1  riastrad struct PP_SIslands_DPM2Parameters
     74  1.1  riastrad {
     75  1.1  riastrad     uint32_t    TDPLimit;
     76  1.1  riastrad     uint32_t    NearTDPLimit;
     77  1.1  riastrad     uint32_t    SafePowerLimit;
     78  1.1  riastrad     uint32_t    PowerBoostLimit;
     79  1.1  riastrad     uint32_t    MinLimitDelta;
     80  1.1  riastrad };
     81  1.1  riastrad typedef struct PP_SIslands_DPM2Parameters PP_SIslands_DPM2Parameters;
     82  1.1  riastrad 
     83  1.1  riastrad struct PP_SIslands_PAPMStatus
     84  1.1  riastrad {
     85  1.1  riastrad     uint32_t    EstimatedDGPU_T;
     86  1.1  riastrad     uint32_t    EstimatedDGPU_P;
     87  1.1  riastrad     uint32_t    EstimatedAPU_T;
     88  1.1  riastrad     uint32_t    EstimatedAPU_P;
     89  1.1  riastrad     uint8_t     dGPU_T_Limit_Exceeded;
     90  1.1  riastrad     uint8_t     reserved[3];
     91  1.1  riastrad };
     92  1.1  riastrad typedef struct PP_SIslands_PAPMStatus PP_SIslands_PAPMStatus;
     93  1.1  riastrad 
     94  1.1  riastrad struct PP_SIslands_PAPMParameters
     95  1.1  riastrad {
     96  1.1  riastrad     uint32_t    NearTDPLimitTherm;
     97  1.1  riastrad     uint32_t    NearTDPLimitPAPM;
     98  1.1  riastrad     uint32_t    PlatformPowerLimit;
     99  1.1  riastrad     uint32_t    dGPU_T_Limit;
    100  1.1  riastrad     uint32_t    dGPU_T_Warning;
    101  1.1  riastrad     uint32_t    dGPU_T_Hysteresis;
    102  1.1  riastrad };
    103  1.1  riastrad typedef struct PP_SIslands_PAPMParameters PP_SIslands_PAPMParameters;
    104  1.1  riastrad 
    105  1.1  riastrad struct SISLANDS_SMC_SCLK_VALUE
    106  1.1  riastrad {
    107  1.1  riastrad     uint32_t    vCG_SPLL_FUNC_CNTL;
    108  1.1  riastrad     uint32_t    vCG_SPLL_FUNC_CNTL_2;
    109  1.1  riastrad     uint32_t    vCG_SPLL_FUNC_CNTL_3;
    110  1.1  riastrad     uint32_t    vCG_SPLL_FUNC_CNTL_4;
    111  1.1  riastrad     uint32_t    vCG_SPLL_SPREAD_SPECTRUM;
    112  1.1  riastrad     uint32_t    vCG_SPLL_SPREAD_SPECTRUM_2;
    113  1.1  riastrad     uint32_t    sclk_value;
    114  1.1  riastrad };
    115  1.1  riastrad 
    116  1.1  riastrad typedef struct SISLANDS_SMC_SCLK_VALUE SISLANDS_SMC_SCLK_VALUE;
    117  1.1  riastrad 
    118  1.1  riastrad struct SISLANDS_SMC_MCLK_VALUE
    119  1.1  riastrad {
    120  1.1  riastrad     uint32_t    vMPLL_FUNC_CNTL;
    121  1.1  riastrad     uint32_t    vMPLL_FUNC_CNTL_1;
    122  1.1  riastrad     uint32_t    vMPLL_FUNC_CNTL_2;
    123  1.1  riastrad     uint32_t    vMPLL_AD_FUNC_CNTL;
    124  1.1  riastrad     uint32_t    vMPLL_DQ_FUNC_CNTL;
    125  1.1  riastrad     uint32_t    vMCLK_PWRMGT_CNTL;
    126  1.1  riastrad     uint32_t    vDLL_CNTL;
    127  1.1  riastrad     uint32_t    vMPLL_SS;
    128  1.1  riastrad     uint32_t    vMPLL_SS2;
    129  1.1  riastrad     uint32_t    mclk_value;
    130  1.1  riastrad };
    131  1.1  riastrad 
    132  1.1  riastrad typedef struct SISLANDS_SMC_MCLK_VALUE SISLANDS_SMC_MCLK_VALUE;
    133  1.1  riastrad 
    134  1.1  riastrad struct SISLANDS_SMC_VOLTAGE_VALUE
    135  1.1  riastrad {
    136  1.1  riastrad     uint16_t    value;
    137  1.1  riastrad     uint8_t     index;
    138  1.1  riastrad     uint8_t     phase_settings;
    139  1.1  riastrad };
    140  1.1  riastrad 
    141  1.1  riastrad typedef struct SISLANDS_SMC_VOLTAGE_VALUE SISLANDS_SMC_VOLTAGE_VALUE;
    142  1.1  riastrad 
    143  1.1  riastrad struct SISLANDS_SMC_HW_PERFORMANCE_LEVEL
    144  1.1  riastrad {
    145  1.1  riastrad     uint8_t                     ACIndex;
    146  1.1  riastrad     uint8_t                     displayWatermark;
    147  1.1  riastrad     uint8_t                     gen2PCIE;
    148  1.1  riastrad     uint8_t                     UVDWatermark;
    149  1.1  riastrad     uint8_t                     VCEWatermark;
    150  1.1  riastrad     uint8_t                     strobeMode;
    151  1.1  riastrad     uint8_t                     mcFlags;
    152  1.1  riastrad     uint8_t                     padding;
    153  1.1  riastrad     uint32_t                    aT;
    154  1.1  riastrad     uint32_t                    bSP;
    155  1.1  riastrad     SISLANDS_SMC_SCLK_VALUE     sclk;
    156  1.1  riastrad     SISLANDS_SMC_MCLK_VALUE     mclk;
    157  1.1  riastrad     SISLANDS_SMC_VOLTAGE_VALUE  vddc;
    158  1.1  riastrad     SISLANDS_SMC_VOLTAGE_VALUE  mvdd;
    159  1.1  riastrad     SISLANDS_SMC_VOLTAGE_VALUE  vddci;
    160  1.1  riastrad     SISLANDS_SMC_VOLTAGE_VALUE  std_vddc;
    161  1.1  riastrad     uint8_t                     hysteresisUp;
    162  1.1  riastrad     uint8_t                     hysteresisDown;
    163  1.1  riastrad     uint8_t                     stateFlags;
    164  1.1  riastrad     uint8_t                     arbRefreshState;
    165  1.1  riastrad     uint32_t                    SQPowerThrottle;
    166  1.1  riastrad     uint32_t                    SQPowerThrottle_2;
    167  1.1  riastrad     uint32_t                    MaxPoweredUpCU;
    168  1.1  riastrad     SISLANDS_SMC_VOLTAGE_VALUE  high_temp_vddc;
    169  1.1  riastrad     SISLANDS_SMC_VOLTAGE_VALUE  low_temp_vddc;
    170  1.1  riastrad     uint32_t                    reserved[2];
    171  1.1  riastrad     PP_SIslands_Dpm2PerfLevel   dpm2;
    172  1.1  riastrad };
    173  1.1  riastrad 
    174  1.1  riastrad #define SISLANDS_SMC_STROBE_RATIO    0x0F
    175  1.1  riastrad #define SISLANDS_SMC_STROBE_ENABLE   0x10
    176  1.1  riastrad 
    177  1.1  riastrad #define SISLANDS_SMC_MC_EDC_RD_FLAG  0x01
    178  1.1  riastrad #define SISLANDS_SMC_MC_EDC_WR_FLAG  0x02
    179  1.1  riastrad #define SISLANDS_SMC_MC_RTT_ENABLE   0x04
    180  1.1  riastrad #define SISLANDS_SMC_MC_STUTTER_EN   0x08
    181  1.1  riastrad #define SISLANDS_SMC_MC_PG_EN        0x10
    182  1.1  riastrad 
    183  1.1  riastrad typedef struct SISLANDS_SMC_HW_PERFORMANCE_LEVEL SISLANDS_SMC_HW_PERFORMANCE_LEVEL;
    184  1.1  riastrad 
    185  1.1  riastrad struct SISLANDS_SMC_SWSTATE
    186  1.1  riastrad {
    187  1.1  riastrad     uint8_t                             flags;
    188  1.1  riastrad     uint8_t                             levelCount;
    189  1.1  riastrad     uint8_t                             padding2;
    190  1.1  riastrad     uint8_t                             padding3;
    191  1.1  riastrad     SISLANDS_SMC_HW_PERFORMANCE_LEVEL   levels[1];
    192  1.1  riastrad };
    193  1.1  riastrad 
    194  1.1  riastrad typedef struct SISLANDS_SMC_SWSTATE SISLANDS_SMC_SWSTATE;
    195  1.1  riastrad 
    196  1.1  riastrad #define SISLANDS_SMC_VOLTAGEMASK_VDDC  0
    197  1.1  riastrad #define SISLANDS_SMC_VOLTAGEMASK_MVDD  1
    198  1.1  riastrad #define SISLANDS_SMC_VOLTAGEMASK_VDDCI 2
    199  1.2  riastrad #define SISLANDS_SMC_VOLTAGEMASK_VDDC_PHASE_SHEDDING 3
    200  1.1  riastrad #define SISLANDS_SMC_VOLTAGEMASK_MAX   4
    201  1.1  riastrad 
    202  1.1  riastrad struct SISLANDS_SMC_VOLTAGEMASKTABLE
    203  1.1  riastrad {
    204  1.1  riastrad     uint32_t lowMask[SISLANDS_SMC_VOLTAGEMASK_MAX];
    205  1.1  riastrad };
    206  1.1  riastrad 
    207  1.1  riastrad typedef struct SISLANDS_SMC_VOLTAGEMASKTABLE SISLANDS_SMC_VOLTAGEMASKTABLE;
    208  1.1  riastrad 
    209  1.1  riastrad #define SISLANDS_MAX_NO_VREG_STEPS 32
    210  1.1  riastrad 
    211  1.1  riastrad struct SISLANDS_SMC_STATETABLE
    212  1.1  riastrad {
    213  1.1  riastrad     uint8_t                             thermalProtectType;
    214  1.1  riastrad     uint8_t                             systemFlags;
    215  1.1  riastrad     uint8_t                             maxVDDCIndexInPPTable;
    216  1.1  riastrad     uint8_t                             extraFlags;
    217  1.1  riastrad     uint32_t                            lowSMIO[SISLANDS_MAX_NO_VREG_STEPS];
    218  1.1  riastrad     SISLANDS_SMC_VOLTAGEMASKTABLE       voltageMaskTable;
    219  1.1  riastrad     SISLANDS_SMC_VOLTAGEMASKTABLE       phaseMaskTable;
    220  1.1  riastrad     PP_SIslands_DPM2Parameters          dpm2Params;
    221  1.1  riastrad     SISLANDS_SMC_SWSTATE                initialState;
    222  1.1  riastrad     SISLANDS_SMC_SWSTATE                ACPIState;
    223  1.1  riastrad     SISLANDS_SMC_SWSTATE                ULVState;
    224  1.1  riastrad     SISLANDS_SMC_SWSTATE                driverState;
    225  1.1  riastrad     SISLANDS_SMC_HW_PERFORMANCE_LEVEL   dpmLevels[SISLANDS_MAX_SMC_PERFORMANCE_LEVELS_PER_SWSTATE - 1];
    226  1.1  riastrad };
    227  1.1  riastrad 
    228  1.1  riastrad typedef struct SISLANDS_SMC_STATETABLE SISLANDS_SMC_STATETABLE;
    229  1.1  riastrad 
    230  1.1  riastrad #define SI_SMC_SOFT_REGISTER_mclk_chg_timeout         0x0
    231  1.1  riastrad #define SI_SMC_SOFT_REGISTER_delay_vreg               0xC
    232  1.1  riastrad #define SI_SMC_SOFT_REGISTER_delay_acpi               0x28
    233  1.1  riastrad #define SI_SMC_SOFT_REGISTER_seq_index                0x5C
    234  1.1  riastrad #define SI_SMC_SOFT_REGISTER_mvdd_chg_time            0x60
    235  1.1  riastrad #define SI_SMC_SOFT_REGISTER_mclk_switch_lim          0x70
    236  1.1  riastrad #define SI_SMC_SOFT_REGISTER_watermark_threshold      0x78
    237  1.1  riastrad #define SI_SMC_SOFT_REGISTER_phase_shedding_delay     0x88
    238  1.1  riastrad #define SI_SMC_SOFT_REGISTER_ulv_volt_change_delay    0x8C
    239  1.1  riastrad #define SI_SMC_SOFT_REGISTER_mc_block_delay           0x98
    240  1.1  riastrad #define SI_SMC_SOFT_REGISTER_ticks_per_us             0xA8
    241  1.1  riastrad #define SI_SMC_SOFT_REGISTER_crtc_index               0xC4
    242  1.1  riastrad #define SI_SMC_SOFT_REGISTER_mclk_change_block_cp_min 0xC8
    243  1.1  riastrad #define SI_SMC_SOFT_REGISTER_mclk_change_block_cp_max 0xCC
    244  1.1  riastrad #define SI_SMC_SOFT_REGISTER_non_ulv_pcie_link_width  0xF4
    245  1.1  riastrad #define SI_SMC_SOFT_REGISTER_tdr_is_about_to_happen   0xFC
    246  1.1  riastrad #define SI_SMC_SOFT_REGISTER_vr_hot_gpio              0x100
    247  1.2  riastrad #define SI_SMC_SOFT_REGISTER_svi_rework_plat_type     0x118
    248  1.2  riastrad #define SI_SMC_SOFT_REGISTER_svi_rework_gpio_id_svd   0x11c
    249  1.2  riastrad #define SI_SMC_SOFT_REGISTER_svi_rework_gpio_id_svc   0x120
    250  1.2  riastrad 
    251  1.2  riastrad struct PP_SIslands_FanTable
    252  1.2  riastrad {
    253  1.2  riastrad 	uint8_t  fdo_mode;
    254  1.2  riastrad 	uint8_t  padding;
    255  1.2  riastrad 	int16_t  temp_min;
    256  1.2  riastrad 	int16_t  temp_med;
    257  1.2  riastrad 	int16_t  temp_max;
    258  1.2  riastrad 	int16_t  slope1;
    259  1.2  riastrad 	int16_t  slope2;
    260  1.2  riastrad 	int16_t  fdo_min;
    261  1.2  riastrad 	int16_t  hys_up;
    262  1.2  riastrad 	int16_t  hys_down;
    263  1.2  riastrad 	int16_t  hys_slope;
    264  1.2  riastrad 	int16_t  temp_resp_lim;
    265  1.2  riastrad 	int16_t  temp_curr;
    266  1.2  riastrad 	int16_t  slope_curr;
    267  1.2  riastrad 	int16_t  pwm_curr;
    268  1.2  riastrad 	uint32_t refresh_period;
    269  1.2  riastrad 	int16_t  fdo_max;
    270  1.2  riastrad 	uint8_t  temp_src;
    271  1.2  riastrad 	int8_t  padding2;
    272  1.2  riastrad };
    273  1.2  riastrad 
    274  1.2  riastrad typedef struct PP_SIslands_FanTable PP_SIslands_FanTable;
    275  1.1  riastrad 
    276  1.1  riastrad #define SMC_SISLANDS_LKGE_LUT_NUM_OF_TEMP_ENTRIES 16
    277  1.1  riastrad #define SMC_SISLANDS_LKGE_LUT_NUM_OF_VOLT_ENTRIES 32
    278  1.1  riastrad 
    279  1.1  riastrad #define SMC_SISLANDS_SCALE_I  7
    280  1.1  riastrad #define SMC_SISLANDS_SCALE_R 12
    281  1.1  riastrad 
    282  1.1  riastrad struct PP_SIslands_CacConfig
    283  1.1  riastrad {
    284  1.1  riastrad     uint16_t   cac_lkge_lut[SMC_SISLANDS_LKGE_LUT_NUM_OF_TEMP_ENTRIES][SMC_SISLANDS_LKGE_LUT_NUM_OF_VOLT_ENTRIES];
    285  1.1  riastrad     uint32_t   lkge_lut_V0;
    286  1.1  riastrad     uint32_t   lkge_lut_Vstep;
    287  1.1  riastrad     uint32_t   WinTime;
    288  1.1  riastrad     uint32_t   R_LL;
    289  1.1  riastrad     uint32_t   calculation_repeats;
    290  1.1  riastrad     uint32_t   l2numWin_TDP;
    291  1.1  riastrad     uint32_t   dc_cac;
    292  1.1  riastrad     uint8_t    lts_truncate_n;
    293  1.1  riastrad     uint8_t    SHIFT_N;
    294  1.1  riastrad     uint8_t    log2_PG_LKG_SCALE;
    295  1.1  riastrad     uint8_t    cac_temp;
    296  1.1  riastrad     uint32_t   lkge_lut_T0;
    297  1.1  riastrad     uint32_t   lkge_lut_Tstep;
    298  1.1  riastrad };
    299  1.1  riastrad 
    300  1.1  riastrad typedef struct PP_SIslands_CacConfig PP_SIslands_CacConfig;
    301  1.1  riastrad 
    302  1.1  riastrad #define SMC_SISLANDS_MC_REGISTER_ARRAY_SIZE 16
    303  1.1  riastrad #define SMC_SISLANDS_MC_REGISTER_ARRAY_SET_COUNT 20
    304  1.1  riastrad 
    305  1.1  riastrad struct SMC_SIslands_MCRegisterAddress
    306  1.1  riastrad {
    307  1.1  riastrad     uint16_t s0;
    308  1.1  riastrad     uint16_t s1;
    309  1.1  riastrad };
    310  1.1  riastrad 
    311  1.1  riastrad typedef struct SMC_SIslands_MCRegisterAddress SMC_SIslands_MCRegisterAddress;
    312  1.1  riastrad 
    313  1.1  riastrad struct SMC_SIslands_MCRegisterSet
    314  1.1  riastrad {
    315  1.1  riastrad     uint32_t value[SMC_SISLANDS_MC_REGISTER_ARRAY_SIZE];
    316  1.1  riastrad };
    317  1.1  riastrad 
    318  1.1  riastrad typedef struct SMC_SIslands_MCRegisterSet SMC_SIslands_MCRegisterSet;
    319  1.1  riastrad 
    320  1.1  riastrad struct SMC_SIslands_MCRegisters
    321  1.1  riastrad {
    322  1.1  riastrad     uint8_t                             last;
    323  1.1  riastrad     uint8_t                             reserved[3];
    324  1.1  riastrad     SMC_SIslands_MCRegisterAddress      address[SMC_SISLANDS_MC_REGISTER_ARRAY_SIZE];
    325  1.1  riastrad     SMC_SIslands_MCRegisterSet          data[SMC_SISLANDS_MC_REGISTER_ARRAY_SET_COUNT];
    326  1.1  riastrad };
    327  1.1  riastrad 
    328  1.1  riastrad typedef struct SMC_SIslands_MCRegisters SMC_SIslands_MCRegisters;
    329  1.1  riastrad 
    330  1.1  riastrad struct SMC_SIslands_MCArbDramTimingRegisterSet
    331  1.1  riastrad {
    332  1.1  riastrad     uint32_t mc_arb_dram_timing;
    333  1.1  riastrad     uint32_t mc_arb_dram_timing2;
    334  1.1  riastrad     uint8_t  mc_arb_rfsh_rate;
    335  1.1  riastrad     uint8_t  mc_arb_burst_time;
    336  1.1  riastrad     uint8_t  padding[2];
    337  1.1  riastrad };
    338  1.1  riastrad 
    339  1.1  riastrad typedef struct SMC_SIslands_MCArbDramTimingRegisterSet SMC_SIslands_MCArbDramTimingRegisterSet;
    340  1.1  riastrad 
    341  1.1  riastrad struct SMC_SIslands_MCArbDramTimingRegisters
    342  1.1  riastrad {
    343  1.1  riastrad     uint8_t                                     arb_current;
    344  1.1  riastrad     uint8_t                                     reserved[3];
    345  1.1  riastrad     SMC_SIslands_MCArbDramTimingRegisterSet     data[16];
    346  1.1  riastrad };
    347  1.1  riastrad 
    348  1.1  riastrad typedef struct SMC_SIslands_MCArbDramTimingRegisters SMC_SIslands_MCArbDramTimingRegisters;
    349  1.1  riastrad 
    350  1.1  riastrad struct SMC_SISLANDS_SPLL_DIV_TABLE
    351  1.1  riastrad {
    352  1.1  riastrad     uint32_t    freq[256];
    353  1.1  riastrad     uint32_t    ss[256];
    354  1.1  riastrad };
    355  1.1  riastrad 
    356  1.1  riastrad #define SMC_SISLANDS_SPLL_DIV_TABLE_FBDIV_MASK  0x01ffffff
    357  1.1  riastrad #define SMC_SISLANDS_SPLL_DIV_TABLE_FBDIV_SHIFT 0
    358  1.1  riastrad #define SMC_SISLANDS_SPLL_DIV_TABLE_PDIV_MASK   0xfe000000
    359  1.1  riastrad #define SMC_SISLANDS_SPLL_DIV_TABLE_PDIV_SHIFT  25
    360  1.1  riastrad #define SMC_SISLANDS_SPLL_DIV_TABLE_CLKV_MASK   0x000fffff
    361  1.1  riastrad #define SMC_SISLANDS_SPLL_DIV_TABLE_CLKV_SHIFT  0
    362  1.1  riastrad #define SMC_SISLANDS_SPLL_DIV_TABLE_CLKS_MASK   0xfff00000
    363  1.1  riastrad #define SMC_SISLANDS_SPLL_DIV_TABLE_CLKS_SHIFT  20
    364  1.1  riastrad 
    365  1.1  riastrad typedef struct SMC_SISLANDS_SPLL_DIV_TABLE SMC_SISLANDS_SPLL_DIV_TABLE;
    366  1.1  riastrad 
    367  1.1  riastrad #define SMC_SISLANDS_DTE_MAX_FILTER_STAGES 5
    368  1.1  riastrad 
    369  1.1  riastrad #define SMC_SISLANDS_DTE_MAX_TEMPERATURE_DEPENDENT_ARRAY_SIZE 16
    370  1.1  riastrad 
    371  1.1  riastrad struct Smc_SIslands_DTE_Configuration
    372  1.1  riastrad {
    373  1.1  riastrad     uint32_t tau[SMC_SISLANDS_DTE_MAX_FILTER_STAGES];
    374  1.1  riastrad     uint32_t R[SMC_SISLANDS_DTE_MAX_FILTER_STAGES];
    375  1.1  riastrad     uint32_t K;
    376  1.1  riastrad     uint32_t T0;
    377  1.1  riastrad     uint32_t MaxT;
    378  1.1  riastrad     uint8_t  WindowSize;
    379  1.1  riastrad     uint8_t  Tdep_count;
    380  1.1  riastrad     uint8_t  temp_select;
    381  1.1  riastrad     uint8_t  DTE_mode;
    382  1.1  riastrad     uint8_t  T_limits[SMC_SISLANDS_DTE_MAX_TEMPERATURE_DEPENDENT_ARRAY_SIZE];
    383  1.1  riastrad     uint32_t Tdep_tau[SMC_SISLANDS_DTE_MAX_TEMPERATURE_DEPENDENT_ARRAY_SIZE];
    384  1.1  riastrad     uint32_t Tdep_R[SMC_SISLANDS_DTE_MAX_TEMPERATURE_DEPENDENT_ARRAY_SIZE];
    385  1.1  riastrad     uint32_t Tthreshold;
    386  1.1  riastrad };
    387  1.1  riastrad 
    388  1.1  riastrad typedef struct Smc_SIslands_DTE_Configuration Smc_SIslands_DTE_Configuration;
    389  1.1  riastrad 
    390  1.1  riastrad #define SMC_SISLANDS_DTE_STATUS_FLAG_DTE_ON 1
    391  1.1  riastrad 
    392  1.1  riastrad #define SISLANDS_SMC_FIRMWARE_HEADER_LOCATION 0x10000
    393  1.1  riastrad 
    394  1.1  riastrad #define SISLANDS_SMC_FIRMWARE_HEADER_version                   0x0
    395  1.1  riastrad #define SISLANDS_SMC_FIRMWARE_HEADER_flags                     0x4
    396  1.1  riastrad #define SISLANDS_SMC_FIRMWARE_HEADER_softRegisters             0xC
    397  1.1  riastrad #define SISLANDS_SMC_FIRMWARE_HEADER_stateTable                0x10
    398  1.1  riastrad #define SISLANDS_SMC_FIRMWARE_HEADER_fanTable                  0x14
    399  1.1  riastrad #define SISLANDS_SMC_FIRMWARE_HEADER_CacConfigTable            0x18
    400  1.1  riastrad #define SISLANDS_SMC_FIRMWARE_HEADER_mcRegisterTable           0x24
    401  1.1  riastrad #define SISLANDS_SMC_FIRMWARE_HEADER_mcArbDramAutoRefreshTable 0x30
    402  1.1  riastrad #define SISLANDS_SMC_FIRMWARE_HEADER_spllTable                 0x38
    403  1.1  riastrad #define SISLANDS_SMC_FIRMWARE_HEADER_DteConfiguration          0x40
    404  1.1  riastrad #define SISLANDS_SMC_FIRMWARE_HEADER_PAPMParameters            0x48
    405  1.1  riastrad 
    406  1.1  riastrad #pragma pack(pop)
    407  1.1  riastrad 
    408  1.1  riastrad int si_copy_bytes_to_smc(struct radeon_device *rdev,
    409  1.1  riastrad 			 u32 smc_start_address,
    410  1.1  riastrad 			 const u8 *src, u32 byte_count, u32 limit);
    411  1.1  riastrad void si_start_smc(struct radeon_device *rdev);
    412  1.1  riastrad void si_reset_smc(struct radeon_device *rdev);
    413  1.1  riastrad int si_program_jump_on_start(struct radeon_device *rdev);
    414  1.1  riastrad void si_stop_smc_clock(struct radeon_device *rdev);
    415  1.1  riastrad void si_start_smc_clock(struct radeon_device *rdev);
    416  1.1  riastrad bool si_is_smc_running(struct radeon_device *rdev);
    417  1.1  riastrad PPSMC_Result si_send_msg_to_smc(struct radeon_device *rdev, PPSMC_Msg msg);
    418  1.1  riastrad PPSMC_Result si_wait_for_smc_inactive(struct radeon_device *rdev);
    419  1.1  riastrad int si_load_smc_ucode(struct radeon_device *rdev, u32 limit);
    420  1.1  riastrad int si_read_smc_sram_dword(struct radeon_device *rdev, u32 smc_address,
    421  1.1  riastrad 			   u32 *value, u32 limit);
    422  1.1  riastrad int si_write_smc_sram_dword(struct radeon_device *rdev, u32 smc_address,
    423  1.1  riastrad 			    u32 value, u32 limit);
    424  1.1  riastrad 
    425  1.1  riastrad #endif
    426  1.1  riastrad 
    427