1*4882a593Smuzhiyun /* 2*4882a593Smuzhiyun * Copyright 2016 Advanced Micro Devices, Inc. 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * Permission is hereby granted, free of charge, to any person obtaining a 5*4882a593Smuzhiyun * copy of this software and associated documentation files (the "Software"), 6*4882a593Smuzhiyun * to deal in the Software without restriction, including without limitation 7*4882a593Smuzhiyun * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8*4882a593Smuzhiyun * and/or sell copies of the Software, and to permit persons to whom the 9*4882a593Smuzhiyun * Software is furnished to do so, subject to the following conditions: 10*4882a593Smuzhiyun * 11*4882a593Smuzhiyun * The above copyright notice and this permission notice shall be included in 12*4882a593Smuzhiyun * all copies or substantial portions of the Software. 13*4882a593Smuzhiyun * 14*4882a593Smuzhiyun * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 15*4882a593Smuzhiyun * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 16*4882a593Smuzhiyun * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 17*4882a593Smuzhiyun * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR 18*4882a593Smuzhiyun * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 19*4882a593Smuzhiyun * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 20*4882a593Smuzhiyun * OTHER DEALINGS IN THE SOFTWARE. 21*4882a593Smuzhiyun * 22*4882a593Smuzhiyun */ 23*4882a593Smuzhiyun #ifndef SMU71_H 24*4882a593Smuzhiyun #define SMU71_H 25*4882a593Smuzhiyun 26*4882a593Smuzhiyun #if !defined(SMC_MICROCODE) 27*4882a593Smuzhiyun #pragma pack(push, 1) 28*4882a593Smuzhiyun #endif 29*4882a593Smuzhiyun 30*4882a593Smuzhiyun #define SMU__NUM_PCIE_DPM_LEVELS 8 31*4882a593Smuzhiyun #define SMU__NUM_SCLK_DPM_STATE 8 32*4882a593Smuzhiyun #define SMU__NUM_MCLK_DPM_LEVELS 4 33*4882a593Smuzhiyun #define SMU__VARIANT__ICELAND 1 34*4882a593Smuzhiyun #define SMU__DGPU_ONLY 1 35*4882a593Smuzhiyun #define SMU__DYNAMIC_MCARB_SETTINGS 1 36*4882a593Smuzhiyun 37*4882a593Smuzhiyun enum SID_OPTION { 38*4882a593Smuzhiyun SID_OPTION_HI, 39*4882a593Smuzhiyun SID_OPTION_LO, 40*4882a593Smuzhiyun SID_OPTION_COUNT 41*4882a593Smuzhiyun }; 42*4882a593Smuzhiyun 43*4882a593Smuzhiyun typedef struct { 44*4882a593Smuzhiyun uint32_t high; 45*4882a593Smuzhiyun uint32_t low; 46*4882a593Smuzhiyun } data_64_t; 47*4882a593Smuzhiyun 48*4882a593Smuzhiyun typedef struct { 49*4882a593Smuzhiyun data_64_t high; 50*4882a593Smuzhiyun data_64_t low; 51*4882a593Smuzhiyun } data_128_t; 52*4882a593Smuzhiyun 53*4882a593Smuzhiyun #define SMU7_CONTEXT_ID_SMC 1 54*4882a593Smuzhiyun #define SMU7_CONTEXT_ID_VBIOS 2 55*4882a593Smuzhiyun 56*4882a593Smuzhiyun #define SMU71_MAX_LEVELS_VDDC 8 57*4882a593Smuzhiyun #define SMU71_MAX_LEVELS_VDDCI 4 58*4882a593Smuzhiyun #define SMU71_MAX_LEVELS_MVDD 4 59*4882a593Smuzhiyun #define SMU71_MAX_LEVELS_VDDNB 8 60*4882a593Smuzhiyun 61*4882a593Smuzhiyun #define SMU71_MAX_LEVELS_GRAPHICS SMU__NUM_SCLK_DPM_STATE 62*4882a593Smuzhiyun #define SMU71_MAX_LEVELS_MEMORY SMU__NUM_MCLK_DPM_LEVELS 63*4882a593Smuzhiyun #define SMU71_MAX_LEVELS_GIO SMU__NUM_LCLK_DPM_LEVELS 64*4882a593Smuzhiyun #define SMU71_MAX_LEVELS_LINK SMU__NUM_PCIE_DPM_LEVELS 65*4882a593Smuzhiyun #define SMU71_MAX_ENTRIES_SMIO 32 66*4882a593Smuzhiyun 67*4882a593Smuzhiyun #define DPM_NO_LIMIT 0 68*4882a593Smuzhiyun #define DPM_NO_UP 1 69*4882a593Smuzhiyun #define DPM_GO_DOWN 2 70*4882a593Smuzhiyun #define DPM_GO_UP 3 71*4882a593Smuzhiyun 72*4882a593Smuzhiyun #define SMU7_FIRST_DPM_GRAPHICS_LEVEL 0 73*4882a593Smuzhiyun #define SMU7_FIRST_DPM_MEMORY_LEVEL 0 74*4882a593Smuzhiyun 75*4882a593Smuzhiyun #define GPIO_CLAMP_MODE_VRHOT 1 76*4882a593Smuzhiyun #define GPIO_CLAMP_MODE_THERM 2 77*4882a593Smuzhiyun #define GPIO_CLAMP_MODE_DC 4 78*4882a593Smuzhiyun 79*4882a593Smuzhiyun #define SCRATCH_B_TARG_PCIE_INDEX_SHIFT 0 80*4882a593Smuzhiyun #define SCRATCH_B_TARG_PCIE_INDEX_MASK (0x7<<SCRATCH_B_TARG_PCIE_INDEX_SHIFT) 81*4882a593Smuzhiyun #define SCRATCH_B_CURR_PCIE_INDEX_SHIFT 3 82*4882a593Smuzhiyun #define SCRATCH_B_CURR_PCIE_INDEX_MASK (0x7<<SCRATCH_B_CURR_PCIE_INDEX_SHIFT) 83*4882a593Smuzhiyun #define SCRATCH_B_TARG_UVD_INDEX_SHIFT 6 84*4882a593Smuzhiyun #define SCRATCH_B_TARG_UVD_INDEX_MASK (0x7<<SCRATCH_B_TARG_UVD_INDEX_SHIFT) 85*4882a593Smuzhiyun #define SCRATCH_B_CURR_UVD_INDEX_SHIFT 9 86*4882a593Smuzhiyun #define SCRATCH_B_CURR_UVD_INDEX_MASK (0x7<<SCRATCH_B_CURR_UVD_INDEX_SHIFT) 87*4882a593Smuzhiyun #define SCRATCH_B_TARG_VCE_INDEX_SHIFT 12 88*4882a593Smuzhiyun #define SCRATCH_B_TARG_VCE_INDEX_MASK (0x7<<SCRATCH_B_TARG_VCE_INDEX_SHIFT) 89*4882a593Smuzhiyun #define SCRATCH_B_CURR_VCE_INDEX_SHIFT 15 90*4882a593Smuzhiyun #define SCRATCH_B_CURR_VCE_INDEX_MASK (0x7<<SCRATCH_B_CURR_VCE_INDEX_SHIFT) 91*4882a593Smuzhiyun #define SCRATCH_B_TARG_ACP_INDEX_SHIFT 18 92*4882a593Smuzhiyun #define SCRATCH_B_TARG_ACP_INDEX_MASK (0x7<<SCRATCH_B_TARG_ACP_INDEX_SHIFT) 93*4882a593Smuzhiyun #define SCRATCH_B_CURR_ACP_INDEX_SHIFT 21 94*4882a593Smuzhiyun #define SCRATCH_B_CURR_ACP_INDEX_MASK (0x7<<SCRATCH_B_CURR_ACP_INDEX_SHIFT) 95*4882a593Smuzhiyun #define SCRATCH_B_TARG_SAMU_INDEX_SHIFT 24 96*4882a593Smuzhiyun #define SCRATCH_B_TARG_SAMU_INDEX_MASK (0x7<<SCRATCH_B_TARG_SAMU_INDEX_SHIFT) 97*4882a593Smuzhiyun #define SCRATCH_B_CURR_SAMU_INDEX_SHIFT 27 98*4882a593Smuzhiyun #define SCRATCH_B_CURR_SAMU_INDEX_MASK (0x7<<SCRATCH_B_CURR_SAMU_INDEX_SHIFT) 99*4882a593Smuzhiyun 100*4882a593Smuzhiyun 101*4882a593Smuzhiyun #if defined SMU__DGPU_ONLY 102*4882a593Smuzhiyun #define SMU71_DTE_ITERATIONS 5 103*4882a593Smuzhiyun #define SMU71_DTE_SOURCES 3 104*4882a593Smuzhiyun #define SMU71_DTE_SINKS 1 105*4882a593Smuzhiyun #define SMU71_NUM_CPU_TES 0 106*4882a593Smuzhiyun #define SMU71_NUM_GPU_TES 1 107*4882a593Smuzhiyun #define SMU71_NUM_NON_TES 2 108*4882a593Smuzhiyun 109*4882a593Smuzhiyun #endif 110*4882a593Smuzhiyun 111*4882a593Smuzhiyun #if defined SMU__FUSION_ONLY 112*4882a593Smuzhiyun #define SMU7_DTE_ITERATIONS 5 113*4882a593Smuzhiyun #define SMU7_DTE_SOURCES 5 114*4882a593Smuzhiyun #define SMU7_DTE_SINKS 3 115*4882a593Smuzhiyun #define SMU7_NUM_CPU_TES 2 116*4882a593Smuzhiyun #define SMU7_NUM_GPU_TES 1 117*4882a593Smuzhiyun #define SMU7_NUM_NON_TES 2 118*4882a593Smuzhiyun 119*4882a593Smuzhiyun #endif 120*4882a593Smuzhiyun 121*4882a593Smuzhiyun struct SMU71_PIDController 122*4882a593Smuzhiyun { 123*4882a593Smuzhiyun uint32_t Ki; 124*4882a593Smuzhiyun int32_t LFWindupUpperLim; 125*4882a593Smuzhiyun int32_t LFWindupLowerLim; 126*4882a593Smuzhiyun uint32_t StatePrecision; 127*4882a593Smuzhiyun uint32_t LfPrecision; 128*4882a593Smuzhiyun uint32_t LfOffset; 129*4882a593Smuzhiyun uint32_t MaxState; 130*4882a593Smuzhiyun uint32_t MaxLfFraction; 131*4882a593Smuzhiyun uint32_t StateShift; 132*4882a593Smuzhiyun }; 133*4882a593Smuzhiyun 134*4882a593Smuzhiyun typedef struct SMU71_PIDController SMU71_PIDController; 135*4882a593Smuzhiyun 136*4882a593Smuzhiyun struct SMU7_LocalDpmScoreboard 137*4882a593Smuzhiyun { 138*4882a593Smuzhiyun uint32_t PercentageBusy; 139*4882a593Smuzhiyun 140*4882a593Smuzhiyun int32_t PIDError; 141*4882a593Smuzhiyun int32_t PIDIntegral; 142*4882a593Smuzhiyun int32_t PIDOutput; 143*4882a593Smuzhiyun 144*4882a593Smuzhiyun uint32_t SigmaDeltaAccum; 145*4882a593Smuzhiyun uint32_t SigmaDeltaOutput; 146*4882a593Smuzhiyun uint32_t SigmaDeltaLevel; 147*4882a593Smuzhiyun 148*4882a593Smuzhiyun uint32_t UtilizationSetpoint; 149*4882a593Smuzhiyun 150*4882a593Smuzhiyun uint8_t TdpClampMode; 151*4882a593Smuzhiyun uint8_t TdcClampMode; 152*4882a593Smuzhiyun uint8_t ThermClampMode; 153*4882a593Smuzhiyun uint8_t VoltageBusy; 154*4882a593Smuzhiyun 155*4882a593Smuzhiyun int8_t CurrLevel; 156*4882a593Smuzhiyun int8_t TargLevel; 157*4882a593Smuzhiyun uint8_t LevelChangeInProgress; 158*4882a593Smuzhiyun uint8_t UpHyst; 159*4882a593Smuzhiyun 160*4882a593Smuzhiyun uint8_t DownHyst; 161*4882a593Smuzhiyun uint8_t VoltageDownHyst; 162*4882a593Smuzhiyun uint8_t DpmEnable; 163*4882a593Smuzhiyun uint8_t DpmRunning; 164*4882a593Smuzhiyun 165*4882a593Smuzhiyun uint8_t DpmForce; 166*4882a593Smuzhiyun uint8_t DpmForceLevel; 167*4882a593Smuzhiyun uint8_t DisplayWatermark; 168*4882a593Smuzhiyun uint8_t McArbIndex; 169*4882a593Smuzhiyun 170*4882a593Smuzhiyun uint32_t MinimumPerfSclk; 171*4882a593Smuzhiyun 172*4882a593Smuzhiyun uint8_t AcpiReq; 173*4882a593Smuzhiyun uint8_t AcpiAck; 174*4882a593Smuzhiyun uint8_t GfxClkSlow; 175*4882a593Smuzhiyun uint8_t GpioClampMode; 176*4882a593Smuzhiyun 177*4882a593Smuzhiyun uint8_t FpsFilterWeight; 178*4882a593Smuzhiyun uint8_t EnabledLevelsChange; 179*4882a593Smuzhiyun uint8_t DteClampMode; 180*4882a593Smuzhiyun uint8_t FpsClampMode; 181*4882a593Smuzhiyun 182*4882a593Smuzhiyun uint16_t LevelResidencyCounters [SMU71_MAX_LEVELS_GRAPHICS]; 183*4882a593Smuzhiyun uint16_t LevelSwitchCounters [SMU71_MAX_LEVELS_GRAPHICS]; 184*4882a593Smuzhiyun 185*4882a593Smuzhiyun void (*TargetStateCalculator)(uint8_t); 186*4882a593Smuzhiyun void (*SavedTargetStateCalculator)(uint8_t); 187*4882a593Smuzhiyun 188*4882a593Smuzhiyun uint16_t AutoDpmInterval; 189*4882a593Smuzhiyun uint16_t AutoDpmRange; 190*4882a593Smuzhiyun 191*4882a593Smuzhiyun uint8_t FpsEnabled; 192*4882a593Smuzhiyun uint8_t MaxPerfLevel; 193*4882a593Smuzhiyun uint8_t AllowLowClkInterruptToHost; 194*4882a593Smuzhiyun uint8_t FpsRunning; 195*4882a593Smuzhiyun 196*4882a593Smuzhiyun uint32_t MaxAllowedFrequency; 197*4882a593Smuzhiyun }; 198*4882a593Smuzhiyun 199*4882a593Smuzhiyun typedef struct SMU7_LocalDpmScoreboard SMU7_LocalDpmScoreboard; 200*4882a593Smuzhiyun 201*4882a593Smuzhiyun #define SMU7_MAX_VOLTAGE_CLIENTS 12 202*4882a593Smuzhiyun 203*4882a593Smuzhiyun struct SMU7_VoltageScoreboard 204*4882a593Smuzhiyun { 205*4882a593Smuzhiyun uint16_t CurrentVoltage; 206*4882a593Smuzhiyun uint16_t HighestVoltage; 207*4882a593Smuzhiyun uint16_t MaxVid; 208*4882a593Smuzhiyun uint8_t HighestVidOffset; 209*4882a593Smuzhiyun uint8_t CurrentVidOffset; 210*4882a593Smuzhiyun #if defined (SMU__DGPU_ONLY) 211*4882a593Smuzhiyun uint8_t CurrentPhases; 212*4882a593Smuzhiyun uint8_t HighestPhases; 213*4882a593Smuzhiyun #else 214*4882a593Smuzhiyun uint8_t AvsOffset; 215*4882a593Smuzhiyun uint8_t AvsOffsetApplied; 216*4882a593Smuzhiyun #endif 217*4882a593Smuzhiyun uint8_t ControllerBusy; 218*4882a593Smuzhiyun uint8_t CurrentVid; 219*4882a593Smuzhiyun uint16_t RequestedVoltage[SMU7_MAX_VOLTAGE_CLIENTS]; 220*4882a593Smuzhiyun #if defined (SMU__DGPU_ONLY) 221*4882a593Smuzhiyun uint8_t RequestedPhases[SMU7_MAX_VOLTAGE_CLIENTS]; 222*4882a593Smuzhiyun #endif 223*4882a593Smuzhiyun uint8_t EnabledRequest[SMU7_MAX_VOLTAGE_CLIENTS]; 224*4882a593Smuzhiyun uint8_t TargetIndex; 225*4882a593Smuzhiyun uint8_t Delay; 226*4882a593Smuzhiyun uint8_t ControllerEnable; 227*4882a593Smuzhiyun uint8_t ControllerRunning; 228*4882a593Smuzhiyun uint16_t CurrentStdVoltageHiSidd; 229*4882a593Smuzhiyun uint16_t CurrentStdVoltageLoSidd; 230*4882a593Smuzhiyun #if defined (SMU__DGPU_ONLY) 231*4882a593Smuzhiyun uint16_t RequestedVddci; 232*4882a593Smuzhiyun uint16_t CurrentVddci; 233*4882a593Smuzhiyun uint16_t HighestVddci; 234*4882a593Smuzhiyun uint8_t CurrentVddciVid; 235*4882a593Smuzhiyun uint8_t TargetVddciIndex; 236*4882a593Smuzhiyun #endif 237*4882a593Smuzhiyun }; 238*4882a593Smuzhiyun 239*4882a593Smuzhiyun typedef struct SMU7_VoltageScoreboard SMU7_VoltageScoreboard; 240*4882a593Smuzhiyun 241*4882a593Smuzhiyun // ------------------------------------------------------------------------------------------------------------------------- 242*4882a593Smuzhiyun #define SMU7_MAX_PCIE_LINK_SPEEDS 3 /* 0:Gen1 1:Gen2 2:Gen3 */ 243*4882a593Smuzhiyun 244*4882a593Smuzhiyun struct SMU7_PCIeLinkSpeedScoreboard 245*4882a593Smuzhiyun { 246*4882a593Smuzhiyun uint8_t DpmEnable; 247*4882a593Smuzhiyun uint8_t DpmRunning; 248*4882a593Smuzhiyun uint8_t DpmForce; 249*4882a593Smuzhiyun uint8_t DpmForceLevel; 250*4882a593Smuzhiyun 251*4882a593Smuzhiyun uint8_t CurrentLinkSpeed; 252*4882a593Smuzhiyun uint8_t EnabledLevelsChange; 253*4882a593Smuzhiyun uint16_t AutoDpmInterval; 254*4882a593Smuzhiyun 255*4882a593Smuzhiyun uint16_t AutoDpmRange; 256*4882a593Smuzhiyun uint16_t AutoDpmCount; 257*4882a593Smuzhiyun 258*4882a593Smuzhiyun uint8_t DpmMode; 259*4882a593Smuzhiyun uint8_t AcpiReq; 260*4882a593Smuzhiyun uint8_t AcpiAck; 261*4882a593Smuzhiyun uint8_t CurrentLinkLevel; 262*4882a593Smuzhiyun 263*4882a593Smuzhiyun }; 264*4882a593Smuzhiyun 265*4882a593Smuzhiyun typedef struct SMU7_PCIeLinkSpeedScoreboard SMU7_PCIeLinkSpeedScoreboard; 266*4882a593Smuzhiyun 267*4882a593Smuzhiyun // -------------------------------------------------------- CAC table ------------------------------------------------------ 268*4882a593Smuzhiyun #define SMU7_LKGE_LUT_NUM_OF_TEMP_ENTRIES 16 269*4882a593Smuzhiyun #define SMU7_LKGE_LUT_NUM_OF_VOLT_ENTRIES 16 270*4882a593Smuzhiyun 271*4882a593Smuzhiyun #define SMU7_SCALE_I 7 272*4882a593Smuzhiyun #define SMU7_SCALE_R 12 273*4882a593Smuzhiyun 274*4882a593Smuzhiyun struct SMU7_PowerScoreboard 275*4882a593Smuzhiyun { 276*4882a593Smuzhiyun uint16_t MinVoltage; 277*4882a593Smuzhiyun uint16_t MaxVoltage; 278*4882a593Smuzhiyun 279*4882a593Smuzhiyun uint32_t AvgGpuPower; 280*4882a593Smuzhiyun 281*4882a593Smuzhiyun uint16_t VddcLeakagePower[SID_OPTION_COUNT]; 282*4882a593Smuzhiyun uint16_t VddcSclkConstantPower[SID_OPTION_COUNT]; 283*4882a593Smuzhiyun uint16_t VddcSclkDynamicPower[SID_OPTION_COUNT]; 284*4882a593Smuzhiyun uint16_t VddcNonSclkDynamicPower[SID_OPTION_COUNT]; 285*4882a593Smuzhiyun uint16_t VddcTotalPower[SID_OPTION_COUNT]; 286*4882a593Smuzhiyun uint16_t VddcTotalCurrent[SID_OPTION_COUNT]; 287*4882a593Smuzhiyun uint16_t VddcLoadVoltage[SID_OPTION_COUNT]; 288*4882a593Smuzhiyun uint16_t VddcNoLoadVoltage[SID_OPTION_COUNT]; 289*4882a593Smuzhiyun 290*4882a593Smuzhiyun uint16_t DisplayPhyPower; 291*4882a593Smuzhiyun uint16_t PciePhyPower; 292*4882a593Smuzhiyun 293*4882a593Smuzhiyun uint16_t VddciTotalPower; 294*4882a593Smuzhiyun uint16_t Vddr1TotalPower; 295*4882a593Smuzhiyun 296*4882a593Smuzhiyun uint32_t RocPower; 297*4882a593Smuzhiyun 298*4882a593Smuzhiyun uint32_t last_power; 299*4882a593Smuzhiyun uint32_t enableWinAvg; 300*4882a593Smuzhiyun 301*4882a593Smuzhiyun uint32_t lkg_acc; 302*4882a593Smuzhiyun uint16_t VoltLkgeScaler; 303*4882a593Smuzhiyun uint16_t TempLkgeScaler; 304*4882a593Smuzhiyun 305*4882a593Smuzhiyun uint32_t uvd_cac_dclk; 306*4882a593Smuzhiyun uint32_t uvd_cac_vclk; 307*4882a593Smuzhiyun uint32_t vce_cac_eclk; 308*4882a593Smuzhiyun uint32_t samu_cac_samclk; 309*4882a593Smuzhiyun uint32_t display_cac_dispclk; 310*4882a593Smuzhiyun uint32_t acp_cac_aclk; 311*4882a593Smuzhiyun uint32_t unb_cac; 312*4882a593Smuzhiyun 313*4882a593Smuzhiyun uint32_t WinTime; 314*4882a593Smuzhiyun 315*4882a593Smuzhiyun uint16_t GpuPwr_MAWt; 316*4882a593Smuzhiyun uint16_t FilteredVddcTotalPower; 317*4882a593Smuzhiyun 318*4882a593Smuzhiyun uint8_t CalculationRepeats; 319*4882a593Smuzhiyun uint8_t WaterfallUp; 320*4882a593Smuzhiyun uint8_t WaterfallDown; 321*4882a593Smuzhiyun uint8_t WaterfallLimit; 322*4882a593Smuzhiyun }; 323*4882a593Smuzhiyun 324*4882a593Smuzhiyun typedef struct SMU7_PowerScoreboard SMU7_PowerScoreboard; 325*4882a593Smuzhiyun 326*4882a593Smuzhiyun // -------------------------------------------------------------------------------------------------- 327*4882a593Smuzhiyun 328*4882a593Smuzhiyun struct SMU7_ThermalScoreboard 329*4882a593Smuzhiyun { 330*4882a593Smuzhiyun int16_t GpuLimit; 331*4882a593Smuzhiyun int16_t GpuHyst; 332*4882a593Smuzhiyun uint16_t CurrGnbTemp; 333*4882a593Smuzhiyun uint16_t FilteredGnbTemp; 334*4882a593Smuzhiyun uint8_t ControllerEnable; 335*4882a593Smuzhiyun uint8_t ControllerRunning; 336*4882a593Smuzhiyun uint8_t WaterfallUp; 337*4882a593Smuzhiyun uint8_t WaterfallDown; 338*4882a593Smuzhiyun uint8_t WaterfallLimit; 339*4882a593Smuzhiyun uint8_t padding[3]; 340*4882a593Smuzhiyun }; 341*4882a593Smuzhiyun 342*4882a593Smuzhiyun typedef struct SMU7_ThermalScoreboard SMU7_ThermalScoreboard; 343*4882a593Smuzhiyun 344*4882a593Smuzhiyun // For FeatureEnables: 345*4882a593Smuzhiyun #define SMU7_SCLK_DPM_CONFIG_MASK 0x01 346*4882a593Smuzhiyun #define SMU7_VOLTAGE_CONTROLLER_CONFIG_MASK 0x02 347*4882a593Smuzhiyun #define SMU7_THERMAL_CONTROLLER_CONFIG_MASK 0x04 348*4882a593Smuzhiyun #define SMU7_MCLK_DPM_CONFIG_MASK 0x08 349*4882a593Smuzhiyun #define SMU7_UVD_DPM_CONFIG_MASK 0x10 350*4882a593Smuzhiyun #define SMU7_VCE_DPM_CONFIG_MASK 0x20 351*4882a593Smuzhiyun #define SMU7_ACP_DPM_CONFIG_MASK 0x40 352*4882a593Smuzhiyun #define SMU7_SAMU_DPM_CONFIG_MASK 0x80 353*4882a593Smuzhiyun #define SMU7_PCIEGEN_DPM_CONFIG_MASK 0x100 354*4882a593Smuzhiyun 355*4882a593Smuzhiyun #define SMU7_ACP_MCLK_HANDSHAKE_DISABLE 0x00000001 356*4882a593Smuzhiyun #define SMU7_ACP_SCLK_HANDSHAKE_DISABLE 0x00000002 357*4882a593Smuzhiyun #define SMU7_UVD_MCLK_HANDSHAKE_DISABLE 0x00000100 358*4882a593Smuzhiyun #define SMU7_UVD_SCLK_HANDSHAKE_DISABLE 0x00000200 359*4882a593Smuzhiyun #define SMU7_VCE_MCLK_HANDSHAKE_DISABLE 0x00010000 360*4882a593Smuzhiyun #define SMU7_VCE_SCLK_HANDSHAKE_DISABLE 0x00020000 361*4882a593Smuzhiyun 362*4882a593Smuzhiyun // All 'soft registers' should be uint32_t. 363*4882a593Smuzhiyun struct SMU71_SoftRegisters 364*4882a593Smuzhiyun { 365*4882a593Smuzhiyun uint32_t RefClockFrequency; 366*4882a593Smuzhiyun uint32_t PmTimerPeriod; 367*4882a593Smuzhiyun uint32_t FeatureEnables; 368*4882a593Smuzhiyun #if defined (SMU__DGPU_ONLY) 369*4882a593Smuzhiyun uint32_t PreVBlankGap; 370*4882a593Smuzhiyun uint32_t VBlankTimeout; 371*4882a593Smuzhiyun uint32_t TrainTimeGap; 372*4882a593Smuzhiyun uint32_t MvddSwitchTime; 373*4882a593Smuzhiyun uint32_t LongestAcpiTrainTime; 374*4882a593Smuzhiyun uint32_t AcpiDelay; 375*4882a593Smuzhiyun uint32_t G5TrainTime; 376*4882a593Smuzhiyun uint32_t DelayMpllPwron; 377*4882a593Smuzhiyun uint32_t VoltageChangeTimeout; 378*4882a593Smuzhiyun #endif 379*4882a593Smuzhiyun uint32_t HandshakeDisables; 380*4882a593Smuzhiyun 381*4882a593Smuzhiyun uint8_t DisplayPhy1Config; 382*4882a593Smuzhiyun uint8_t DisplayPhy2Config; 383*4882a593Smuzhiyun uint8_t DisplayPhy3Config; 384*4882a593Smuzhiyun uint8_t DisplayPhy4Config; 385*4882a593Smuzhiyun 386*4882a593Smuzhiyun uint8_t DisplayPhy5Config; 387*4882a593Smuzhiyun uint8_t DisplayPhy6Config; 388*4882a593Smuzhiyun uint8_t DisplayPhy7Config; 389*4882a593Smuzhiyun uint8_t DisplayPhy8Config; 390*4882a593Smuzhiyun 391*4882a593Smuzhiyun uint32_t AverageGraphicsActivity; 392*4882a593Smuzhiyun uint32_t AverageMemoryActivity; 393*4882a593Smuzhiyun uint32_t AverageGioActivity; 394*4882a593Smuzhiyun 395*4882a593Smuzhiyun uint8_t SClkDpmEnabledLevels; 396*4882a593Smuzhiyun uint8_t MClkDpmEnabledLevels; 397*4882a593Smuzhiyun uint8_t LClkDpmEnabledLevels; 398*4882a593Smuzhiyun uint8_t PCIeDpmEnabledLevels; 399*4882a593Smuzhiyun 400*4882a593Smuzhiyun uint32_t DRAM_LOG_ADDR_H; 401*4882a593Smuzhiyun uint32_t DRAM_LOG_ADDR_L; 402*4882a593Smuzhiyun uint32_t DRAM_LOG_PHY_ADDR_H; 403*4882a593Smuzhiyun uint32_t DRAM_LOG_PHY_ADDR_L; 404*4882a593Smuzhiyun uint32_t DRAM_LOG_BUFF_SIZE; 405*4882a593Smuzhiyun uint32_t UlvEnterCount; 406*4882a593Smuzhiyun uint32_t UlvTime; 407*4882a593Smuzhiyun uint32_t UcodeLoadStatus; 408*4882a593Smuzhiyun uint8_t DPMFreezeAndForced; 409*4882a593Smuzhiyun uint8_t Activity_Weight; 410*4882a593Smuzhiyun uint8_t Reserved8[2]; 411*4882a593Smuzhiyun uint32_t Reserved; 412*4882a593Smuzhiyun }; 413*4882a593Smuzhiyun 414*4882a593Smuzhiyun typedef struct SMU71_SoftRegisters SMU71_SoftRegisters; 415*4882a593Smuzhiyun 416*4882a593Smuzhiyun struct SMU71_Firmware_Header 417*4882a593Smuzhiyun { 418*4882a593Smuzhiyun uint32_t Digest[5]; 419*4882a593Smuzhiyun uint32_t Version; 420*4882a593Smuzhiyun uint32_t HeaderSize; 421*4882a593Smuzhiyun uint32_t Flags; 422*4882a593Smuzhiyun uint32_t EntryPoint; 423*4882a593Smuzhiyun uint32_t CodeSize; 424*4882a593Smuzhiyun uint32_t ImageSize; 425*4882a593Smuzhiyun 426*4882a593Smuzhiyun uint32_t Rtos; 427*4882a593Smuzhiyun uint32_t SoftRegisters; 428*4882a593Smuzhiyun uint32_t DpmTable; 429*4882a593Smuzhiyun uint32_t FanTable; 430*4882a593Smuzhiyun uint32_t CacConfigTable; 431*4882a593Smuzhiyun uint32_t CacStatusTable; 432*4882a593Smuzhiyun 433*4882a593Smuzhiyun uint32_t mcRegisterTable; 434*4882a593Smuzhiyun 435*4882a593Smuzhiyun uint32_t mcArbDramTimingTable; 436*4882a593Smuzhiyun 437*4882a593Smuzhiyun uint32_t PmFuseTable; 438*4882a593Smuzhiyun uint32_t Globals; 439*4882a593Smuzhiyun uint32_t UvdDpmTable; 440*4882a593Smuzhiyun uint32_t AcpDpmTable; 441*4882a593Smuzhiyun uint32_t VceDpmTable; 442*4882a593Smuzhiyun uint32_t SamuDpmTable; 443*4882a593Smuzhiyun uint32_t UlvSettings; 444*4882a593Smuzhiyun uint32_t Reserved[37]; 445*4882a593Smuzhiyun uint32_t Signature; 446*4882a593Smuzhiyun }; 447*4882a593Smuzhiyun 448*4882a593Smuzhiyun typedef struct SMU71_Firmware_Header SMU71_Firmware_Header; 449*4882a593Smuzhiyun 450*4882a593Smuzhiyun struct SMU7_HystController_Data 451*4882a593Smuzhiyun { 452*4882a593Smuzhiyun uint8_t waterfall_up; 453*4882a593Smuzhiyun uint8_t waterfall_down; 454*4882a593Smuzhiyun uint8_t pstate; 455*4882a593Smuzhiyun uint8_t clamp_mode; 456*4882a593Smuzhiyun }; 457*4882a593Smuzhiyun 458*4882a593Smuzhiyun typedef struct SMU7_HystController_Data SMU7_HystController_Data; 459*4882a593Smuzhiyun 460*4882a593Smuzhiyun #define SMU71_FIRMWARE_HEADER_LOCATION 0x20000 461*4882a593Smuzhiyun 462*4882a593Smuzhiyun enum DisplayConfig { 463*4882a593Smuzhiyun PowerDown = 1, 464*4882a593Smuzhiyun DP54x4, 465*4882a593Smuzhiyun DP54x2, 466*4882a593Smuzhiyun DP54x1, 467*4882a593Smuzhiyun DP27x4, 468*4882a593Smuzhiyun DP27x2, 469*4882a593Smuzhiyun DP27x1, 470*4882a593Smuzhiyun HDMI297, 471*4882a593Smuzhiyun HDMI162, 472*4882a593Smuzhiyun LVDS, 473*4882a593Smuzhiyun DP324x4, 474*4882a593Smuzhiyun DP324x2, 475*4882a593Smuzhiyun DP324x1 476*4882a593Smuzhiyun }; 477*4882a593Smuzhiyun 478*4882a593Smuzhiyun //#define SX_BLOCK_COUNT 8 479*4882a593Smuzhiyun //#define MC_BLOCK_COUNT 1 480*4882a593Smuzhiyun //#define CPL_BLOCK_COUNT 27 481*4882a593Smuzhiyun 482*4882a593Smuzhiyun #if defined SMU__VARIANT__ICELAND 483*4882a593Smuzhiyun #define SX_BLOCK_COUNT 8 484*4882a593Smuzhiyun #define MC_BLOCK_COUNT 1 485*4882a593Smuzhiyun #define CPL_BLOCK_COUNT 29 486*4882a593Smuzhiyun #endif 487*4882a593Smuzhiyun 488*4882a593Smuzhiyun struct SMU7_Local_Cac { 489*4882a593Smuzhiyun uint8_t BlockId; 490*4882a593Smuzhiyun uint8_t SignalId; 491*4882a593Smuzhiyun uint8_t Threshold; 492*4882a593Smuzhiyun uint8_t Padding; 493*4882a593Smuzhiyun }; 494*4882a593Smuzhiyun 495*4882a593Smuzhiyun typedef struct SMU7_Local_Cac SMU7_Local_Cac; 496*4882a593Smuzhiyun 497*4882a593Smuzhiyun struct SMU7_Local_Cac_Table { 498*4882a593Smuzhiyun SMU7_Local_Cac SxLocalCac[SX_BLOCK_COUNT]; 499*4882a593Smuzhiyun SMU7_Local_Cac CplLocalCac[CPL_BLOCK_COUNT]; 500*4882a593Smuzhiyun SMU7_Local_Cac McLocalCac[MC_BLOCK_COUNT]; 501*4882a593Smuzhiyun }; 502*4882a593Smuzhiyun 503*4882a593Smuzhiyun typedef struct SMU7_Local_Cac_Table SMU7_Local_Cac_Table; 504*4882a593Smuzhiyun 505*4882a593Smuzhiyun #if !defined(SMC_MICROCODE) 506*4882a593Smuzhiyun #pragma pack(pop) 507*4882a593Smuzhiyun #endif 508*4882a593Smuzhiyun 509*4882a593Smuzhiyun #endif 510*4882a593Smuzhiyun 511