1 /*
2  * Copyright 2020 Advanced Micro Devices, Inc.
3  *
4  * Permission is hereby granted, free of charge, to any person obtaining a
5  * copy of this software and associated documentation files (the "Software"),
6  * to deal in the Software without restriction, including without limitation
7  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8  * and/or sell copies of the Software, and to permit persons to whom the
9  * Software is furnished to do so, subject to the following conditions:
10  *
11  * The above copyright notice and this permission notice shall be included in
12  * all copies or substantial portions of the Software.
13  *
14  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
17  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20  * OTHER DEALINGS IN THE SOFTWARE.
21  *
22  */
23 
24 #ifndef SMU13_DRIVER_IF_ALDEBARAN_H
25 #define SMU13_DRIVER_IF_ALDEBARAN_H
26 
27 #define NUM_VCLK_DPM_LEVELS   8
28 #define NUM_DCLK_DPM_LEVELS   8
29 #define NUM_SOCCLK_DPM_LEVELS 8
30 #define NUM_LCLK_DPM_LEVELS   8
31 #define NUM_UCLK_DPM_LEVELS   4
32 #define NUM_FCLK_DPM_LEVELS   8
33 #define NUM_XGMI_DPM_LEVELS   4
34 
35 // Feature Control Defines
36 #define FEATURE_DATA_CALCULATIONS       0
37 #define FEATURE_DPM_GFXCLK_BIT          1
38 #define FEATURE_DPM_UCLK_BIT            2
39 #define FEATURE_DPM_SOCCLK_BIT          3
40 #define FEATURE_DPM_FCLK_BIT            4
41 #define FEATURE_DPM_LCLK_BIT            5
42 #define FEATURE_DPM_XGMI_BIT            6
43 #define FEATURE_DS_GFXCLK_BIT           7
44 #define FEATURE_DS_SOCCLK_BIT           8
45 #define FEATURE_DS_LCLK_BIT             9
46 #define FEATURE_DS_FCLK_BIT             10
47 #define FEATURE_DS_UCLK_BIT             11
48 #define FEATURE_GFX_SS_BIT              12
49 #define FEATURE_DPM_VCN_BIT             13
50 #define FEATURE_RSMU_SMN_CG_BIT         14
51 #define FEATURE_WAFL_CG_BIT             15
52 #define FEATURE_PPT_BIT                 16
53 #define FEATURE_TDC_BIT                 17
54 #define FEATURE_APCC_PLUS_BIT           18
55 #define FEATURE_APCC_DFLL_BIT           19
56 #define FEATURE_FW_CTF_BIT              20
57 #define FEATURE_THERMAL_BIT             21
58 #define FEATURE_OUT_OF_BAND_MONITOR_BIT 22
59 #define FEATURE_SPARE_23_BIT            23
60 #define FEATURE_XGMI_PER_LINK_PWR_DWN   24
61 #define FEATURE_DF_CSTATE               25
62 #define FEATURE_FUSE_CG_BIT             26
63 #define FEATURE_MP1_CG_BIT              27
64 #define FEATURE_SMUIO_CG_BIT            28
65 #define FEATURE_THM_CG_BIT              29
66 #define FEATURE_CLK_CG_BIT              30
67 #define FEATURE_EDC_BIT                 31
68 #define FEATURE_SPARE_32_BIT            32
69 #define FEATURE_SPARE_33_BIT            33
70 #define FEATURE_SPARE_34_BIT            34
71 #define FEATURE_SPARE_35_BIT            35
72 #define FEATURE_SPARE_36_BIT            36
73 #define FEATURE_SPARE_37_BIT            37
74 #define FEATURE_SPARE_38_BIT            38
75 #define FEATURE_SPARE_39_BIT            39
76 #define FEATURE_SPARE_40_BIT            40
77 #define FEATURE_SPARE_41_BIT            41
78 #define FEATURE_SPARE_42_BIT            42
79 #define FEATURE_SPARE_43_BIT            43
80 #define FEATURE_SPARE_44_BIT            44
81 #define FEATURE_SPARE_45_BIT            45
82 #define FEATURE_SPARE_46_BIT            46
83 #define FEATURE_SPARE_47_BIT            47
84 #define FEATURE_SPARE_48_BIT            48
85 #define FEATURE_SPARE_49_BIT            49
86 #define FEATURE_SPARE_50_BIT            50
87 #define FEATURE_SPARE_51_BIT            51
88 #define FEATURE_SPARE_52_BIT            52
89 #define FEATURE_SPARE_53_BIT            53
90 #define FEATURE_SPARE_54_BIT            54
91 #define FEATURE_SPARE_55_BIT            55
92 #define FEATURE_SPARE_56_BIT            56
93 #define FEATURE_SPARE_57_BIT            57
94 #define FEATURE_SPARE_58_BIT            58
95 #define FEATURE_SPARE_59_BIT            59
96 #define FEATURE_SPARE_60_BIT            60
97 #define FEATURE_SPARE_61_BIT            61
98 #define FEATURE_SPARE_62_BIT            62
99 #define FEATURE_SPARE_63_BIT            63
100 
101 #define NUM_FEATURES                    64
102 
103 // I2C Config Bit Defines
104 #define I2C_CONTROLLER_ENABLED  1
105 #define I2C_CONTROLLER_DISABLED 0
106 
107 // Throttler Status Bits.
108 // These are aligned with the out of band monitor alarm bits for common throttlers
109 #define THROTTLER_PPT0_BIT         0
110 #define THROTTLER_PPT1_BIT         1
111 #define THROTTLER_TDC_GFX_BIT      2
112 #define THROTTLER_TDC_SOC_BIT      3
113 #define THROTTLER_TDC_HBM_BIT      4
114 #define THROTTLER_SPARE_5          5
115 #define THROTTLER_TEMP_GPU_BIT     6
116 #define THROTTLER_TEMP_MEM_BIT     7
117 #define THORTTLER_SPARE_8          8
118 #define THORTTLER_SPARE_9          9
119 #define THORTTLER_SPARE_10         10
120 #define THROTTLER_TEMP_VR_GFX_BIT  11
121 #define THROTTLER_TEMP_VR_SOC_BIT  12
122 #define THROTTLER_TEMP_VR_MEM_BIT  13
123 #define THORTTLER_SPARE_14         14
124 #define THORTTLER_SPARE_15         15
125 #define THORTTLER_SPARE_16         16
126 #define THORTTLER_SPARE_17         17
127 #define THORTTLER_SPARE_18         18
128 #define THROTTLER_APCC_BIT         19
129 
130 // Table transfer status
131 #define TABLE_TRANSFER_OK         0x0
132 #define TABLE_TRANSFER_FAILED     0xFF
133 #define TABLE_TRANSFER_PENDING    0xAB
134 
135 //I2C Interface
136 #define NUM_I2C_CONTROLLERS                8
137 
138 #define I2C_CONTROLLER_ENABLED             1
139 #define I2C_CONTROLLER_DISABLED            0
140 
141 #define MAX_SW_I2C_COMMANDS                24
142 
143 #define ALDEBARAN_UMC_CHANNEL_NUM    32
144 
145 typedef enum {
146   I2C_CONTROLLER_PORT_0, //CKSVII2C0
147   I2C_CONTROLLER_PORT_1, //CKSVII2C1
148   I2C_CONTROLLER_PORT_COUNT,
149 } I2cControllerPort_e;
150 
151 typedef enum {
152   I2C_CONTROLLER_THROTTLER_TYPE_NONE,
153   I2C_CONTROLLER_THROTTLER_VR_GFX0,
154   I2C_CONTROLLER_THROTTLER_VR_GFX1,
155   I2C_CONTROLLER_THROTTLER_VR_SOC,
156   I2C_CONTROLLER_THROTTLER_VR_MEM,
157   I2C_CONTROLLER_THROTTLER_COUNT,
158 } I2cControllerThrottler_e;
159 
160 typedef enum {
161   I2C_CONTROLLER_PROTOCOL_VR_MP2855,
162   I2C_CONTROLLER_PROTOCOL_COUNT,
163 } I2cControllerProtocol_e;
164 
165 typedef struct {
166   uint8_t   Enabled;
167   uint8_t   Speed;
168   uint8_t   SlaveAddress;
169   uint8_t   ControllerPort;
170   uint8_t   ThermalThrotter;
171   uint8_t   I2cProtocol;
172   uint8_t   PaddingConfig[2];
173 } I2cControllerConfig_t;
174 
175 typedef enum {
176   I2C_PORT_SVD_SCL,
177   I2C_PORT_GPIO,
178 } I2cPort_e;
179 
180 typedef enum {
181   I2C_SPEED_FAST_50K,     //50  Kbits/s
182   I2C_SPEED_FAST_100K,    //100 Kbits/s
183   I2C_SPEED_FAST_400K,    //400 Kbits/s
184   I2C_SPEED_FAST_PLUS_1M, //1   Mbits/s (in fast mode)
185   I2C_SPEED_HIGH_1M,      //1   Mbits/s (in high speed mode)
186   I2C_SPEED_HIGH_2M,      //2.3 Mbits/s
187   I2C_SPEED_COUNT,
188 } I2cSpeed_e;
189 
190 typedef enum {
191   I2C_CMD_READ,
192   I2C_CMD_WRITE,
193   I2C_CMD_COUNT,
194 } I2cCmdType_e;
195 
196 #define CMDCONFIG_STOP_BIT             0
197 #define CMDCONFIG_RESTART_BIT          1
198 #define CMDCONFIG_READWRITE_BIT        2 //bit should be 0 for read, 1 for write
199 
200 #define CMDCONFIG_STOP_MASK           (1 << CMDCONFIG_STOP_BIT)
201 #define CMDCONFIG_RESTART_MASK        (1 << CMDCONFIG_RESTART_BIT)
202 #define CMDCONFIG_READWRITE_MASK      (1 << CMDCONFIG_READWRITE_BIT)
203 
204 typedef struct {
205   uint8_t ReadWriteData;  //Return data for read. Data to send for write
206   uint8_t CmdConfig; //Includes whether associated command should have a stop or restart command, and is a read or write
207 } SwI2cCmd_t; //SW I2C Command Table
208 
209 typedef struct {
210   uint8_t    I2CcontrollerPort; //CKSVII2C0(0) or //CKSVII2C1(1)
211   uint8_t    I2CSpeed;          //Use I2cSpeed_e to indicate speed to select
212   uint8_t    SlaveAddress;      //Slave address of device
213   uint8_t    NumCmds;           //Number of commands
214   SwI2cCmd_t SwI2cCmds[MAX_SW_I2C_COMMANDS];
215 } SwI2cRequest_t; // SW I2C Request Table
216 
217 typedef struct {
218   SwI2cRequest_t SwI2cRequest;
219   uint32_t       Spare[8];
220   uint32_t       MmHubPadding[8]; // SMU internal use
221 } SwI2cRequestExternal_t;
222 
223 typedef struct {
224   uint32_t a;  // store in IEEE float format in this variable
225   uint32_t b;  // store in IEEE float format in this variable
226   uint32_t c;  // store in IEEE float format in this variable
227 } QuadraticInt_t;
228 
229 typedef struct {
230   uint32_t m;  // store in IEEE float format in this variable
231   uint32_t b;  // store in IEEE float format in this variable
232 } LinearInt_t;
233 
234 typedef enum {
235   GFXCLK_SOURCE_PLL,
236   GFXCLK_SOURCE_DFLL,
237   GFXCLK_SOURCE_COUNT,
238 } GfxclkSrc_e;
239 
240 typedef enum {
241   PPCLK_GFXCLK,
242   PPCLK_VCLK,
243   PPCLK_DCLK,
244   PPCLK_SOCCLK,
245   PPCLK_UCLK,
246   PPCLK_FCLK,
247   PPCLK_LCLK,
248   PPCLK_COUNT,
249 } PPCLK_e;
250 
251 typedef enum {
252   GPIO_INT_POLARITY_ACTIVE_LOW,
253   GPIO_INT_POLARITY_ACTIVE_HIGH,
254 } GpioIntPolarity_e;
255 
256 //PPSMC_MSG_SetUclkDpmMode
257 typedef enum {
258   UCLK_DPM_MODE_BANDWIDTH,
259   UCLK_DPM_MODE_LATENCY,
260 } UCLK_DPM_MODE_e;
261 
262 typedef struct {
263   uint8_t        StartupLevel;
264   uint8_t        NumDiscreteLevels;   // Set to 2 (Fmin, Fmax) when using fine grained DPM, otherwise set to # discrete levels used
265   uint16_t       SsFmin;              // Fmin for SS curve. If SS curve is selected, will use V@SSFmin for F <= Fmin
266   LinearInt_t    ConversionToAvfsClk; // Transfer function to AVFS Clock (GHz->GHz)
267   QuadraticInt_t SsCurve;             // Slow-slow curve (GHz->V)
268 } DpmDescriptor_t;
269 
270 #pragma pack(push, 1)
271 typedef struct {
272   uint32_t Version;
273 
274   // SECTION: Feature Enablement
275   uint32_t FeaturesToRun[2];
276 
277   // SECTION: Infrastructure Limits
278   uint16_t PptLimit;      // Watts
279   uint16_t TdcLimitGfx;   // Amps
280   uint16_t TdcLimitSoc;   // Amps
281   uint16_t TdcLimitHbm;   // Amps
282   uint16_t ThotspotLimit; // Celcius
283   uint16_t TmemLimit;     // Celcius
284   uint16_t Tvr_gfxLimit;  // Celcius
285   uint16_t Tvr_memLimit;  // Celcius
286   uint16_t Tvr_socLimit;  // Celcius
287   uint16_t PaddingLimit;
288 
289   // SECTION: Voltage Control Parameters
290   uint16_t MaxVoltageGfx; // In mV(Q2) Maximum Voltage allowable of VDD_GFX
291   uint16_t MaxVoltageSoc; // In mV(Q2) Maximum Voltage allowable of VDD_SOC
292 
293   //SECTION: DPM Config 1
294   DpmDescriptor_t DpmDescriptor[PPCLK_COUNT];
295 
296   uint8_t  DidTableVclk[NUM_VCLK_DPM_LEVELS];     //PPCLK_VCLK
297   uint8_t  DidTableDclk[NUM_DCLK_DPM_LEVELS];     //PPCLK_DCLK
298   uint8_t  DidTableSocclk[NUM_SOCCLK_DPM_LEVELS]; //PPCLK_SOCCLK
299   uint8_t  DidTableLclk[NUM_LCLK_DPM_LEVELS];     //PPCLK_LCLK
300   uint32_t FidTableFclk[NUM_FCLK_DPM_LEVELS];     //PPCLK_FCLK
301   uint8_t  DidTableFclk[NUM_FCLK_DPM_LEVELS];     //PPCLK_FCLK
302   uint32_t FidTableUclk[NUM_UCLK_DPM_LEVELS];     //PPCLK_UCLK
303   uint8_t  DidTableUclk[NUM_UCLK_DPM_LEVELS];     //PPCLK_UCLK
304 
305   uint32_t StartupFidPll0; //GFXAVFSCLK, SOCCLK, MP0CLK, MPIOCLK, DXIOCLK
306   uint32_t StartupFidPll4; //VCLK, DCLK, WAFLCLK
307   uint32_t StartupFidPll5; //SMNCLK, MP1CLK, LCLK
308 
309   uint8_t  StartupSmnclkDid;
310   uint8_t  StartupMp0clkDid;
311   uint8_t  StartupMp1clkDid;
312   uint8_t  StartupWaflclkDid;
313   uint8_t  StartupGfxavfsclkDid;
314   uint8_t  StartupMpioclkDid;
315   uint8_t  StartupDxioclkDid;
316   uint8_t  spare123;
317 
318   uint8_t  StartupVidGpu0Svi0Plane0; //VDDCR_GFX0
319   uint8_t  StartupVidGpu0Svi0Plane1; //VDDCR_SOC
320   uint8_t  StartupVidGpu0Svi1Plane0; //VDDCR_HBM
321   uint8_t  StartupVidGpu0Svi1Plane1; //UNUSED [0 = plane is not used and should not be programmed]
322 
323   uint8_t  StartupVidGpu1Svi0Plane0; //VDDCR_GFX1
324   uint8_t  StartupVidGpu1Svi0Plane1; //UNUSED [0 = plane is not used and should not be programmed]
325   uint8_t  StartupVidGpu1Svi1Plane0; //UNUSED [0 = plane is not used and should not be programmed]
326   uint8_t  StartupVidGpu1Svi1Plane1; //UNUSED [0 = plane is not used and should not be programmed]
327 
328   // GFXCLK DPM
329   uint16_t GfxclkFmax;   // In MHz
330   uint16_t GfxclkFmin;   // In MHz
331   uint16_t GfxclkFidle;  // In MHz
332   uint16_t GfxclkFinit;  // In MHz
333   uint8_t  GfxclkSource; // GfxclkSrc_e [0 = PLL, 1 = DFLL]
334   uint8_t  spare1[2];
335   uint8_t  StartupGfxclkDid;
336   uint32_t StartupGfxclkFid;
337 
338   // SECTION: AVFS
339   uint16_t GFX_Guardband_Freq[8];         // MHz [unsigned]
340   int16_t  GFX_Guardband_Voltage_Cold[8]; // mV [signed]
341   int16_t  GFX_Guardband_Voltage_Mid[8];  // mV [signed]
342   int16_t  GFX_Guardband_Voltage_Hot[8];  // mV [signed]
343 
344   uint16_t SOC_Guardband_Freq[8];         // MHz [unsigned]
345   int16_t  SOC_Guardband_Voltage_Cold[8]; // mV [signed]
346   int16_t  SOC_Guardband_Voltage_Mid[8];  // mV [signed]
347   int16_t  SOC_Guardband_Voltage_Hot[8];  // mV [signed]
348 
349   // VDDCR_GFX BTC
350   uint16_t DcBtcEnabled;
351   int16_t  DcBtcMin;       // mV [signed]
352   int16_t  DcBtcMax;       // mV [signed]
353   int16_t  DcBtcGb;        // mV [signed]
354 
355   // SECTION: XGMI
356   uint8_t  XgmiLinkSpeed[NUM_XGMI_DPM_LEVELS]; //Gbps [EX: 32 = 32Gbps]
357   uint8_t  XgmiLinkWidth[NUM_XGMI_DPM_LEVELS]; //Width [EX: 16 = x16]
358   uint8_t  XgmiStartupLevel;
359   uint8_t  spare12[3];
360 
361   // GFX Vmin
362   uint16_t GFX_PPVmin_Enabled;
363   uint16_t GFX_Vmin_Plat_Offset_Hot;  // mV
364   uint16_t GFX_Vmin_Plat_Offset_Cold; // mV
365   uint16_t GFX_Vmin_Hot_T0;           // mV
366   uint16_t GFX_Vmin_Cold_T0;          // mV
367   uint16_t GFX_Vmin_Hot_Eol;          // mV
368   uint16_t GFX_Vmin_Cold_Eol;         // mV
369   uint16_t GFX_Vmin_Aging_Offset;     // mV
370   uint16_t GFX_Vmin_Temperature_Hot;  // 'C
371   uint16_t GFX_Vmin_Temperature_Cold; // 'C
372 
373   // SOC Vmin
374   uint16_t SOC_PPVmin_Enabled;
375   uint16_t SOC_Vmin_Plat_Offset_Hot;  // mV
376   uint16_t SOC_Vmin_Plat_Offset_Cold; // mV
377   uint16_t SOC_Vmin_Hot_T0;           // mV
378   uint16_t SOC_Vmin_Cold_T0;          // mV
379   uint16_t SOC_Vmin_Hot_Eol;          // mV
380   uint16_t SOC_Vmin_Cold_Eol;         // mV
381   uint16_t SOC_Vmin_Aging_Offset;     // mV
382   uint16_t SOC_Vmin_Temperature_Hot;  // 'C
383   uint16_t SOC_Vmin_Temperature_Cold; // 'C
384 
385   // APCC Settings
386   uint32_t ApccPlusResidencyLimit; //PCC residency % (0-100)
387 
388   // Determinism
389   uint16_t DeterminismVoltageOffset; //mV
390   uint16_t spare22;
391 
392   // reserved
393   uint32_t spare3[14];
394 
395   // SECTION: BOARD PARAMETERS
396   // Telemetry Settings
397   uint16_t GfxMaxCurrent; // in Amps
398   int8_t   GfxOffset;     // in Amps
399   uint8_t  Padding_TelemetryGfx;
400 
401   uint16_t SocMaxCurrent; // in Amps
402   int8_t   SocOffset;     // in Amps
403   uint8_t  Padding_TelemetrySoc;
404 
405   uint16_t MemMaxCurrent; // in Amps
406   int8_t   MemOffset;     // in Amps
407   uint8_t  Padding_TelemetryMem;
408 
409   uint16_t BoardMaxCurrent; // in Amps
410   int8_t   BoardOffset;     // in Amps
411   uint8_t  Padding_TelemetryBoardInput;
412 
413   // Platform input telemetry voltage coefficient
414   uint32_t BoardVoltageCoeffA; // decode by /1000
415   uint32_t BoardVoltageCoeffB; // decode by /1000
416 
417   // GPIO Settings
418   uint8_t  VR0HotGpio;     // GPIO pin configured for VR0 HOT event
419   uint8_t  VR0HotPolarity; // GPIO polarity for VR0 HOT event
420   uint8_t  VR1HotGpio;     // GPIO pin configured for VR1 HOT event
421   uint8_t  VR1HotPolarity; // GPIO polarity for VR1 HOT event
422 
423   // UCLK Spread Spectrum
424   uint8_t  UclkSpreadEnabled; // on or off
425   uint8_t  UclkSpreadPercent; // Q4.4
426   uint16_t UclkSpreadFreq;    // kHz
427 
428   // FCLK Spread Spectrum
429   uint8_t  FclkSpreadEnabled; // on or off
430   uint8_t  FclkSpreadPercent; // Q4.4
431   uint16_t FclkSpreadFreq;    // kHz
432 
433   // I2C Controller Structure
434   I2cControllerConfig_t  I2cControllers[NUM_I2C_CONTROLLERS];
435 
436   // GPIO pins for I2C communications with 2nd controller for Input Telemetry Sequence
437   uint8_t  GpioI2cScl; // Serial Clock
438   uint8_t  GpioI2cSda; // Serial Data
439   uint16_t spare5;
440 
441   uint16_t XgmiMaxCurrent; // in Amps
442   int8_t   XgmiOffset;     // in Amps
443   uint8_t  Padding_TelemetryXgmi;
444 
445   uint16_t  EdcPowerLimit;
446   uint16_t  spare6;
447 
448   //reserved
449   uint32_t reserved[14];
450 
451 } PPTable_t;
452 #pragma pack(pop)
453 
454 typedef struct {
455   // Time constant parameters for clock averages in ms
456   uint16_t     GfxclkAverageLpfTau;
457   uint16_t     SocclkAverageLpfTau;
458   uint16_t     UclkAverageLpfTau;
459   uint16_t     GfxActivityLpfTau;
460   uint16_t     UclkActivityLpfTau;
461 
462   uint16_t     SocketPowerLpfTau;
463 
464   uint32_t     Spare[8];
465   // Padding - ignore
466   uint32_t     MmHubPadding[8]; // SMU internal use
467 } DriverSmuConfig_t;
468 
469 typedef struct {
470   uint16_t CurrClock[PPCLK_COUNT];
471   uint16_t Padding1              ;
472   uint16_t AverageGfxclkFrequency;
473   uint16_t AverageSocclkFrequency;
474   uint16_t AverageUclkFrequency  ;
475   uint16_t AverageGfxActivity    ;
476   uint16_t AverageUclkActivity   ;
477   uint8_t  CurrSocVoltageOffset  ;
478   uint8_t  CurrGfxVoltageOffset  ;
479   uint8_t  CurrMemVidOffset      ;
480   uint8_t  Padding8              ;
481   uint16_t AverageSocketPower    ;
482   uint16_t TemperatureEdge       ;
483   uint16_t TemperatureHotspot    ;
484   uint16_t TemperatureHBM        ;  // Max
485   uint16_t TemperatureVrGfx      ;
486   uint16_t TemperatureVrSoc      ;
487   uint16_t TemperatureVrMem      ;
488   uint32_t ThrottlerStatus       ;
489 
490   uint32_t PublicSerialNumLower32;
491   uint32_t PublicSerialNumUpper32;
492   uint16_t TemperatureAllHBM[4]  ;
493   uint32_t GfxBusyAcc            ;
494   uint32_t DramBusyAcc           ;
495   uint32_t EnergyAcc64bitLow     ; //15.259uJ resolution
496   uint32_t EnergyAcc64bitHigh    ;
497   uint32_t TimeStampLow          ; //10ns resolution
498   uint32_t TimeStampHigh         ;
499 
500   // Padding - ignore
501   uint32_t     MmHubPadding[8]; // SMU internal use
502 } SmuMetrics_t;
503 
504 
505 typedef struct {
506   uint16_t avgPsmCount[76];
507   uint16_t minPsmCount[76];
508   float    avgPsmVoltage[76];
509   float    minPsmVoltage[76];
510 
511   uint32_t MmHubPadding[8]; // SMU internal use
512 } AvfsDebugTable_t;
513 
514 typedef struct {
515 	uint64_t mca_umc_status;
516 	uint64_t mca_umc_addr;
517 	uint16_t ce_count_lo_chip;
518 	uint16_t ce_count_hi_chip;
519 
520 	uint32_t eccPadding;
521 } EccInfo_t;
522 
523 typedef struct {
524 	uint64_t mca_umc_status;
525 	uint64_t mca_umc_addr;
526 
527 	uint16_t ce_count_lo_chip;
528 	uint16_t ce_count_hi_chip;
529 
530 	uint32_t eccPadding;
531 
532 	uint64_t mca_ceumc_addr;
533 } EccInfo_V2_t;
534 
535 typedef struct {
536 	union {
537 		EccInfo_t  EccInfo[ALDEBARAN_UMC_CHANNEL_NUM];
538 		EccInfo_V2_t EccInfo_V2[ALDEBARAN_UMC_CHANNEL_NUM];
539 	};
540 } EccInfoTable_t;
541 
542 // These defines are used with the following messages:
543 // SMC_MSG_TransferTableDram2Smu
544 // SMC_MSG_TransferTableSmu2Dram
545 #define TABLE_PPTABLE                 0
546 #define TABLE_AVFS_PSM_DEBUG          1
547 #define TABLE_AVFS_FUSE_OVERRIDE      2
548 #define TABLE_PMSTATUSLOG             3
549 #define TABLE_SMU_METRICS             4
550 #define TABLE_DRIVER_SMU_CONFIG       5
551 #define TABLE_I2C_COMMANDS            6
552 #define TABLE_ECCINFO                 7
553 #define TABLE_COUNT                   8
554 
555 #endif
556