# Intel® Speed Select Technology TPMI Interface

### Introduction

TPMI (Topology Aware Register and PM Capsule Interface), planned for future Intel® Xeon® processor generations, is an architectural, PCIe-standards based model, where feature support is provided cleanly as a driver and not as part of the base OS.

TPMI provides an enumerable and unified SW interface to support die disaggregation, hierarchical PM and improves product quality via an abstraction that minimizes software-hardware inter-dependences.

Software interfaces with TPMI could discover and control all aspects of Intel® Speed Select Technology (SST) including discovery and enumeration, select SST-PP level, enable/disable individual SST feature, setup CLOS priority and frequency limit, and assign core-CLOS mapping.

The legacy SST OS mailbox and PCU BAR based CLOS MMIO interfaces are being replaced with TPMI implementation in future Intel® Xeon® processors.

SST prioritization schemes (CP, TF, BF) are supported via CLOS interface. The legacy HWP interface will not be used for SST prioritization post-TPMI implementation.

Note: The term "Software (SW)" throughout this document includes BIOS as one of the software entities.

# **Register Structure**

SST registers are presented to SW in multi-layer structures as shown in the diagram below. This structure is extendable as need arises in the future. When this happens, a new value should be assigned to SST\_HEADER.INTERFACE\_VERSION and software is expected to interpret the structure accordingly to maintain backward compatibility.

The extendability includes things like changes in number of PP levels or AVX levels, PP/BF/TF/CP registers, adding or removing SST features, etc..

Note that the diagram below is for illustrative purpose only. It doesn't represent the actual register name/definition. This is provided in the "Register Spec" section of this document.



#### **SST Register Hierarchy**

SST registers consist of a set of common registers and some per SST-PP level registers. Common registers are shared among all SST-PP config levels. Per SST-PP level registers are grouped together as "strides" and repeated for each config level.

The first SST register is SST\_HEADER. The first register of each stride is SST\_PP\_INF\_0. One SST-PP config level has one stride of registers.

The TPMI\_Offset of SST\_HEADER is 0x0. Other SST registers are SW enumerable based on SOC's feature capability. See the <u>section below</u> for SW enumeration mechanism.

## **Register Spec**

#### SST\_HEADER

This register allows SW to discover SST capability and the offsets to CP and PP register banks.

SST feature set can be expanded over time, the INTERFACE\_VERSION field is used as an indication for feature evolution.

#### SST Header (source)

| SST_HEADER        |      |       |                |                                                                                                                |         |
|-------------------|------|-------|----------------|----------------------------------------------------------------------------------------------------------------|---------|
| Field Name        | Bits | Width | Access<br>Type | Description                                                                                                    | Default |
| INTERFACE_VERSION | 7:0  | 8     | RO             | Version number for this interface                                                                              | 0x1     |
|                   |      |       |                | bitmask of the supported sub<br>features. 1=the sub feature is<br>enabled. 0=disabled.                         |         |
| CAPABILITY_MASK   | 15:8 | 8     | RO             | Pcode populates the HW capability setting during early reset. SW uses this field to discover SST sub features. | 0x2     |
|                   |      |       |                | Bit[8]= SST_CP enable (1), disable (0)                                                                         |         |
|                   |      |       |                | bit[9]= SST_PP enable (1),<br>disable (0)                                                                      |         |

| SST_CP_OFFSET | 23:16 | 8  | RO | Qword (8 bytes) offset to the SST_CP register bank | 0x1 |
|---------------|-------|----|----|----------------------------------------------------|-----|
| SST_PP_OFFSET | 31:24 | 8  | RO | Qword (8 bytes) offset to the SST_PP register bank | 0xC |
| RSVD          | 63:32 | 32 | RO | reserved offset for new features                   | 0x0 |

# **SST-CP Registers**

### **SST-CP Registers** (<u>source</u>)

| SST_CP_HEADER    |           |           |                    |                                                                        |             |
|------------------|-----------|-----------|--------------------|------------------------------------------------------------------------|-------------|
| Field Name       | Bits      | Widt<br>h | Acces<br>s<br>Type | Description                                                            | Defau<br>It |
| SST_FEATURE_ID   | 3:0       | 4         | RO                 | Set to 0. (0=SST-CP, 1=SST-PP, 2=SST-BF, 3=SST-TF, 4-15 = reserved)    | 0           |
| FEATURE_REVISION | 11:4      | 8         | RO                 | Interface Version number for this SST feature                          | 1           |
| RATIO_UNIT       | 13:1<br>2 | 2         | RO                 | Frequency ratio unit. 00: 100MHz.<br>All others : Reserved. Default=0. | 0           |
| RSVD             | 63:1<br>4 | 50        | RO                 | Reserved                                                               | 0           |
| SST_CP_CONTROL   |           |           |                    |                                                                        |             |
| Field Name       | Bits      | Widt<br>h | Acces<br>s<br>Type | Description                                                            | Defau<br>It |
| SST_CP_ENABLE    | 0:0       | 1         | RW                 | 1: Enable SST-CP. 0: Disable SST-CP                                    | 0           |

| SST_CP_PRIORITY_TYPE       | 1:1       | 1         | RW                 | 0x0 (Default) =Proportional.<br>0x1=Ordered Throttling.                                                                                                                                                              | 0           |
|----------------------------|-----------|-----------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| RSVD1                      | 7:2       | 6         | RW                 | Reserved                                                                                                                                                                                                             | 0           |
| RESET_EXCURSION_TO_<br>MIN | 11:8      | 4         | RW                 | Bitmask for the CLOS groups. SW clears SST_CP_STATUS.EXCURSION_TO _MIN bits by writing zero (0) to the respective RESET_EXCURSIONS bit here. Pcode ignores the bit that SW writes 1 to. Bit8=CLOSO, bit9=CLOS1, etc. | 0           |
| RSVD2                      | 63:1<br>2 | 52        | RW                 | Reserved                                                                                                                                                                                                             | 0           |
| SST_CP_STATUS              |           |           |                    |                                                                                                                                                                                                                      |             |
| Field Name                 | Bits      | Widt<br>h | Acces<br>s<br>Type | Description                                                                                                                                                                                                          | Defau<br>It |
| SST_CP_ENABLE              | 0:0       | 1         | RO                 | Returns 1 if SST-CP is enabled.                                                                                                                                                                                      | 0           |
| SST_CP_PRIORITY_TYPE       | 1:1       | 1         | RO                 | Returns current prioritization type. 0x0 (Default) =Proportional. 0x1=Ordered Throttling.                                                                                                                            | 0           |
| ERROR_TYPE                 | 5:2       | 4         | RO                 | Returns the type of last error in this feature.  0x0: no error  0x1: SST-CP is not supported by the hardware.  all others: reserved.                                                                                 | 0           |
| RSVD1                      | 7:6       | 2         | RO                 | Reserved                                                                                                                                                                                                             | 0           |
| EXCURSION_TO_MIN           | 11:8      | 4         | RO                 | Bitmask for the CLOS groups. If set (1), an excursion to Minimum Performance has occurred for the CLOS. Bit8=CLOS0, bit9=CLOS1, etc.                                                                                 | 0           |
| RSVD2                      | 63:1<br>2 | 52        | RO                 | Reserved                                                                                                                                                                                                             | 0           |
| SST_CLOS_CONFIG_0          |           |           |                    |                                                                                                                                                                                                                      |             |

| Field Name                         | Bits                       | Widt<br>h   | Acces<br>s<br>Type | Description                                                                                                                                                                                                                                                                                                                                             | Defau<br>It |
|------------------------------------|----------------------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| RSVD1                              | 3:0                        | 4           | RW                 | Reserved                                                                                                                                                                                                                                                                                                                                                | 0           |
| PROPORTIONAL_PRIORI                | 7:4                        | 4           | RW                 | Used to set frequency weight when CLOS_PRIORITY_TYPE is set to Proportional.  (freq_weight = 0xf - CLOS_PROPORTIONAL_PRIORITY                                                                                                                                                                                                                           | 0           |
|                                    |                            |             |                    | 0x0 = Max Perf (highest priority)<br>0xF = Min Perf (lowest priority)                                                                                                                                                                                                                                                                                   |             |
| MIN                                | 15:8                       | 8           | RW                 | Hold the minimum PM CLOS frequency ratio (100MHz bins) for this CLOS group.                                                                                                                                                                                                                                                                             | 0           |
| MAX                                | 23:1<br>6                  | 8           | RW                 | Hold the maximum PM CLOS frequency ratio (100MHz bins) for this CLOS group.                                                                                                                                                                                                                                                                             | 0xFF        |
| RSVD2                              | 63:2<br>4                  | 40          | RW                 | Reserved                                                                                                                                                                                                                                                                                                                                                | 0           |
| SST_CLOS_CONFIG_1                  |                            |             |                    |                                                                                                                                                                                                                                                                                                                                                         |             |
|                                    |                            |             |                    |                                                                                                                                                                                                                                                                                                                                                         |             |
| Field Name                         | Bits                       | Widt<br>h   | Acces<br>s<br>Type | Description                                                                                                                                                                                                                                                                                                                                             | Defau<br>It |
| Field Name RSVD1                   | Bits<br>3:0                |             | s                  | <b>Description</b> Reserved                                                                                                                                                                                                                                                                                                                             |             |
|                                    |                            | h           | s<br>Type          | -                                                                                                                                                                                                                                                                                                                                                       | lt          |
| RSVD1 PROPORTIONAL_PRIORI          | 3:0                        | h 4         | s<br>Type<br>RW    | Reserved  Used to set frequency weight when CLOS_PRIORITY_TYPE is set to Proportional.  (freq_weight = 0xf - CLOS_PROPORTIONAL_PRIORITY )  0x0 = Max Perf (highest priority)                                                                                                                                                                            | 0           |
| RSVD1  PROPORTIONAL_PRIORI TY      | 3:0<br>7:4                 | 4<br>4      | s<br>Type<br>RW    | Reserved  Used to set frequency weight when CLOS_PRIORITY_TYPE is set to Proportional.  (freq_weight = 0xf - CLOS_PROPORTIONAL_PRIORITY)  0x0 = Max Perf (highest priority)  0xF = Min Perf (lowest priority)  Hold the minimum PM CLOS frequency ratio (100MHz bins) for                                                                               | 0           |
| RSVD1  PROPORTIONAL_PRIORI TY  MIN | 3:0<br>7:4<br>15:8<br>23:1 | 4<br>4<br>8 | RW RW              | Reserved  Used to set frequency weight when CLOS_PRIORITY_TYPE is set to Proportional.  (freq_weight = 0xf - CLOS_PROPORTIONAL_PRIORITY )  0x0 = Max Perf (highest priority)  0xF = Min Perf (lowest priority)  Hold the minimum PM CLOS frequency ratio (100MHz bins) for this CLOS group.  Hold the maximum PM CLOS frequency ratio (100MHz bins) for | 0 0         |

| Field Name                         | Bits                       | Widt<br>h   | Acces<br>s<br>Type | Description                                                                                                                                                                                                                                                                                                                                             | Defau<br>It |
|------------------------------------|----------------------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| RSVD1                              | 3:0                        | 4           | RW                 | Reserved                                                                                                                                                                                                                                                                                                                                                | 0           |
| PROPORTIONAL_PRIORI                |                            |             |                    | Used to set frequency weight when CLOS_PRIORITY_TYPE is set to Proportional.  (freq_weight = 0xf -                                                                                                                                                                                                                                                      |             |
| TY                                 | 7:4                        | 4           | RW                 | CLOS_PROPORTIONAL_PRIORITY )  0x0 = Max Perf (highest priority)  0xF = Min Perf (lowest priority)                                                                                                                                                                                                                                                       | 0           |
| MIN                                | 15:8                       | 8           | RW                 | Hold the minimum PM CLOS frequency ratio (100MHz bins) for this CLOS group.                                                                                                                                                                                                                                                                             | 0           |
| MAX                                | 23:1<br>6                  | 8           | RW                 | Hold the maximum PM CLOS frequency ratio (100MHz bins) for this CLOS group.                                                                                                                                                                                                                                                                             | 0xFF        |
| RSVD2                              | 63:2<br>4                  | 40          | RW                 | Reserved                                                                                                                                                                                                                                                                                                                                                | 0           |
| SST_CLOS_CONFIG_3                  |                            |             |                    |                                                                                                                                                                                                                                                                                                                                                         |             |
|                                    |                            |             |                    |                                                                                                                                                                                                                                                                                                                                                         |             |
| Field Name                         | Bits                       | Widt<br>h   | Acces<br>s<br>Type | Description                                                                                                                                                                                                                                                                                                                                             | Defau<br>It |
| Field Name RSVD1                   | Bits                       | _           | s                  | <b>Description</b> Reserved                                                                                                                                                                                                                                                                                                                             |             |
|                                    |                            | h           | s<br>Type          | -                                                                                                                                                                                                                                                                                                                                                       | lt          |
| RSVD1 PROPORTIONAL_PRIORI          | 3:0                        | h<br>4      | s<br>Type<br>RW    | Reserved  Used to set frequency weight when CLOS_PRIORITY_TYPE is set to Proportional.  (freq_weight = 0xf - CLOS_PROPORTIONAL_PRIORITY )  0x0 = Max Perf (highest priority)                                                                                                                                                                            | <b>It</b> 0 |
| RSVD1  PROPORTIONAL_PRIORI TY      | 3:0<br>7:4                 | 4<br>4      | s<br>Type<br>RW    | Reserved  Used to set frequency weight when CLOS_PRIORITY_TYPE is set to Proportional.  (freq_weight = 0xf - CLOS_PROPORTIONAL_PRIORITY)  0x0 = Max Perf (highest priority)  0xF = Min Perf (lowest priority)  Hold the minimum PM CLOS frequency ratio (100MHz bins) for                                                                               | 0<br>0      |
| RSVD1  PROPORTIONAL_PRIORI TY  MIN | 3:0<br>7:4<br>15:8<br>23:1 | 4<br>4<br>8 | RW RW              | Reserved  Used to set frequency weight when CLOS_PRIORITY_TYPE is set to Proportional.  (freq_weight = 0xf - CLOS_PROPORTIONAL_PRIORITY )  0x0 = Max Perf (highest priority)  0xF = Min Perf (lowest priority)  Hold the minimum PM CLOS frequency ratio (100MHz bins) for this CLOS group.  Hold the maximum PM CLOS frequency ratio (100MHz bins) for | 0 0 0       |

| Field Name       | Bits      | Widt<br>h | Acces<br>s<br>Type | Description         | Defau<br>It |
|------------------|-----------|-----------|--------------------|---------------------|-------------|
| CLOS_ID_core0    | 3:0       | 4         | RW                 | CLOS_ID for Core 0  | 0           |
| CLOS_ID_core1    | 7:4       | 4         | RW                 | CLOS_ID for Core 1  | 0           |
| CLOS_ID_core2    | 11:8      | 4         | RW                 | CLOS_ID for Core 2  | 0           |
| CLOS_ID_core3    | 15:1<br>2 | 4         | RW                 | CLOS_ID for Core 3  | 0           |
| CLOS_ID_core4    | 19:1<br>6 | 4         | RW                 | CLOS_ID for Core 4  | 0           |
| CLOS_ID_core5    | 23:2<br>0 | 4         | RW                 | CLOS_ID for Core 5  | 0           |
| CLOS_ID_core6    | 27:2<br>4 | 4         | RW                 | CLOS_ID for Core 6  | 0           |
| CLOS_ID_core7    | 31:2<br>8 | 4         | RW                 | CLOS_ID for Core 7  | 0           |
| CLOS_ID_core8    | 35:3<br>2 | 4         | RW                 | CLOS_ID for Core 8  | 0           |
| CLOS_ID_core9    | 39:3<br>6 | 4         | RW                 | CLOS_ID for Core 9  | 0           |
| CLOS_ID_core10   | 43:4<br>0 | 4         | RW                 | CLOS_ID for Core 10 | 0           |
| CLOS_ID_core11   | 47:4<br>4 | 4         | RW                 | CLOS_ID for Core 11 | 0           |
| CLOS_ID_core12   | 51:4<br>8 | 4         | RW                 | CLOS_ID for Core 12 | 0           |
| CLOS_ID_core13   | 55:5<br>2 | 4         | RW                 | CLOS_ID for Core 13 | 0           |
| CLOS_ID_core14   | 59:5<br>6 | 4         | RW                 | CLOS_ID for Core 14 | 0           |
| CLOS_ID_core15   | 63:6<br>0 | 4         | RW                 | CLOS_ID for Core 15 | 0           |
| SST_CLOS_ASSOC_1 |           |           |                    |                     |             |
| Field Name       | Bits      | Widt<br>h | Acces<br>s<br>Type | Description         | Defau<br>It |
| CLOS_ID_core16   | 3:0       | 4         | RW                 | CLOS_ID for Core 16 | 0           |
| CLOS_ID_core17   | 7:4       | 4         | RW                 | CLOS_ID for Core 17 | 0           |
| CLOS_ID_core18   | 11:8      | 4         | RW                 | CLOS_ID for Core 18 | 0           |
| CLOS_ID_core19   | 15:1<br>2 | 4         | RW                 | CLOS_ID for Core 19 | 0           |

| CLOS_ID_core20   | 19:1<br>6 | 4         | RW                 | CLOS_ID for Core 20 | 0           |
|------------------|-----------|-----------|--------------------|---------------------|-------------|
| CLOS_ID_core21   | 23:2      | 4         | RW                 | CLOS_ID for Core 21 | 0           |
| CLOS_ID_core22   | 27:2<br>4 | 4         | RW                 | CLOS_ID for Core 22 | 0           |
| CLOS_ID_core23   | 31:2<br>8 | 4         | RW                 | CLOS_ID for Core 23 | 0           |
| CLOS_ID_core24   | 35:3<br>2 | 4         | RW                 | CLOS_ID for Core 24 | 0           |
| CLOS_ID_core25   | 39:3<br>6 | 4         | RW                 | CLOS_ID for Core 25 | 0           |
| CLOS_ID_core26   | 43:4<br>0 | 4         | RW                 | CLOS_ID for Core 26 | 0           |
| CLOS_ID_core27   | 47:4<br>4 | 4         | RW                 | CLOS_ID for Core 27 | 0           |
| CLOS_ID_core28   | 51:4<br>8 | 4         | RW                 | CLOS_ID for Core 28 | 0           |
| CLOS_ID_core29   | 55:5<br>2 | 4         | RW                 | CLOS_ID for Core 29 | 0           |
| CLOS_ID_core30   | 59:5<br>6 | 4         | RW                 | CLOS_ID for Core 30 | 0           |
| CLOS_ID_core31   | 63:6<br>0 | 4         | RW                 | CLOS_ID for Core 31 | 0           |
| SST_CLOS_ASSOC_2 |           |           |                    |                     |             |
| Field Name       | Bits      | Widt<br>h | Acces<br>s<br>Type | Description         | Defau<br>It |
| CLOS_ID_core32   | 3:0       | 4         | RW                 | CLOS_ID for Core 32 | 0           |
| CLOS_ID_core33   | 7:4       | 4         | RW                 | CLOS_ID for Core 33 | 0           |
| CLOS_ID_core34   | 11:8      | 4         | RW                 | CLOS_ID for Core 34 | 0           |
| CLOS_ID_core35   | 15:1<br>2 | 4         | RW                 | CLOS_ID for Core 35 | 0           |
| CLOS_ID_core36   | 19:1<br>6 | 4         | RW                 | CLOS_ID for Core 36 | 0           |
| CLOS_ID_core37   | 23:2      | 4         | RW                 | CLOS_ID for Core 37 | 0           |
| CLOS_ID_core38   | 27:2<br>4 | 4         | RW                 | CLOS_ID for Core 38 | 0           |
| CLOS_ID_core39   | 31:2<br>8 | 4         | RW                 | CLOS_ID for Core 39 | 0           |

| CLOS_ID_core40   | 35:3<br>2 | 4         | RW                 | CLOS_ID for Core 40 | 0           |
|------------------|-----------|-----------|--------------------|---------------------|-------------|
| CLOS_ID_core41   | 39:3<br>6 | 4         | RW                 | CLOS_ID for Core 41 | 0           |
| CLOS_ID_core42   | 43:4<br>0 | 4         | RW                 | CLOS_ID for Core 42 | 0           |
| CLOS_ID_core43   | 47:4<br>4 | 4         | RW                 | CLOS_ID for Core 43 | 0           |
| CLOS_ID_core44   | 51:4<br>8 | 4         | RW                 | CLOS_ID for Core 44 | 0           |
| CLOS_ID_core45   | 55:5<br>2 | 4         | RW                 | CLOS_ID for Core 45 | 0           |
| CLOS_ID_core46   | 59:5<br>6 | 4         | RW                 | CLOS_ID for Core 46 | 0           |
| CLOS_ID_core47   | 63:6<br>0 | 4         | RW                 | CLOS_ID for Core 47 | 0           |
| SST_CLOS_ASSOC_3 |           |           |                    |                     |             |
| Field Name       | Bits      | Widt<br>h | Acces<br>s<br>Type | Description         | Defau<br>It |
| CLOS_ID_core48   | 3:0       | 4         | RW                 | CLOS_ID for Core 48 | 0           |
| CLOS_ID_core49   | 7:4       | 4         | RW                 | CLOS_ID for Core 49 | 0           |
| CLOS_ID_core50   | 11:8      | 4         | RW                 | CLOS_ID for Core 50 | 0           |
| CLOS_ID_core51   | 15:1<br>2 | 4         | RW                 | CLOS_ID for Core 51 | 0           |
| CLOS_ID_core52   | 19:1<br>6 | 4         | RW                 | CLOS_ID for Core 52 | 0           |
| CLOS_ID_core53   | 23:2      | 4         | RW                 | CLOS_ID for Core 53 | 0           |
| CLOS_ID_core54   | 27:2<br>4 | 4         | RW                 | CLOS_ID for Core 54 | 0           |
| CLOS_ID_core55   | 31:2<br>8 | 4         | RW                 | CLOS_ID for Core 55 | 0           |
| CLOS_ID_core56   | 35:3<br>2 | 4         | RW                 | CLOS_ID for Core 56 | 0           |
| CLOS_ID_core57   | 39:3<br>6 | 4         | RW                 | CLOS_ID for Core 57 | 0           |
| CLOS_ID_core58   | 43:4<br>0 | 4         | RW                 | CLOS_ID for Core 58 | 0           |
| CLOS_ID_core59   | 47:4<br>4 | 4         | RW                 | CLOS_ID for Core 59 | 0           |

| CLOS_ID_core60 | 51:4<br>8 | 4 | RW | CLOS_ID for Core 60 | 0 |
|----------------|-----------|---|----|---------------------|---|
| CLOS_ID_core61 | 55:5<br>2 | 4 | RW | CLOS_ID for Core 61 | 0 |
| CLOS_ID_core62 | 59:5<br>6 | 4 | RW | CLOS_ID for Core 62 | 0 |
| CLOS_ID_core63 | 63:6<br>0 | 4 | RW | CLOS_ID for Core 63 | 0 |

## **SST-PP Registers**

This register bank provides SW the interface to PP, BF and TF features.

#### **SST-PP Registers** (<u>source</u>)

| SST_PP_HEADER            |           |           |                 |                                                                                                                           |             |
|--------------------------|-----------|-----------|-----------------|---------------------------------------------------------------------------------------------------------------------------|-------------|
| Field Name               | Bits      | Widt<br>h | Acces<br>s Type | Description                                                                                                               | Defaul<br>t |
| SST_FEATURE_ID           | 3:0       | 4         | RO              | Set to 1. (0=SST-CP, 1=SST-PP, 2=SST-BF, 3=SST-TF, 4-15 = reserved)                                                       | 1           |
| FEATURE_REVISION         | 11:4      | 8         | RO              | Interface Version number for this SST feature                                                                             | 1           |
| SST_PP_LEVEL_EN_MA<br>SK | 19:1<br>2 | 8         | RO              | SST-PP level enable/disable fuse mask. SoftSKU can toggle fuse bit to enable/disable a specific level.                    | 0           |
| ALLOWED_LEVEL_MAS        | 27:2<br>0 | 8         | RO              | Allowed level mask used for dynamic config level switching. Pcode programs the mask based on fuse and the current config. | 0           |
| RSVD1                    | 31:2<br>8 | 4         | RO              | Reserved                                                                                                                  | 0           |
| RATIO_UNIT               | 33:3<br>2 | 2         | RO              | Core frequency ratio unit. 00:<br>100MHz. All others : Reserved.<br>Default=0.                                            | 0           |

| PP_OFFSET_1  PP_OFFSET_2  PP_OFFSET_3  PP_OFFSET_4  RSVD  SST_PP_CONTROL  Field Name | 23:1<br>6<br>31:2<br>4<br>39:3<br>2<br>63:4<br>0 | 8<br>8<br>8<br>24<br>Widt | RO RO RO Acces s Type | Qword offset to the register block (stride) of PP level 2  Qword offset to the register block (stride) of PP level 3  Qword offset to the register block (stride) of PP level 4  Reserved  Description | 0x31<br>0x47<br>0x5D<br>0<br><b>Defaul</b> |
|--------------------------------------------------------------------------------------|--------------------------------------------------|---------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|
| PP_OFFSET_2 PP_OFFSET_3 PP_OFFSET_4 RSVD                                             | 6<br>31:2<br>4<br>39:3<br>2<br>63:4              | 8                         | RO<br>RO              | Qword offset to the register block<br>(stride) of PP level 2<br>Qword offset to the register block<br>(stride) of PP level 3<br>Qword offset to the register block<br>(stride) of PP level 4           | 0x47<br>0x5D                               |
| PP_OFFSET_2 PP_OFFSET_3 PP_OFFSET_4                                                  | 6<br>31:2<br>4<br>39:3<br>2<br>63:4              | 8                         | RO<br>RO              | Qword offset to the register block<br>(stride) of PP level 2<br>Qword offset to the register block<br>(stride) of PP level 3<br>Qword offset to the register block<br>(stride) of PP level 4           | 0x47<br>0x5D                               |
| PP_OFFSET_2 PP_OFFSET_3                                                              | 6<br>31:2<br>4<br>39:3                           | 8                         | RO                    | Qword offset to the register block (stride) of PP level 2  Qword offset to the register block (stride) of PP level 3  Qword offset to the register block                                               | 0x47                                       |
| PP_OFFSET_2                                                                          | 6<br>31:2                                        |                           |                       | Qword offset to the register block (stride) of PP level 2  Qword offset to the register block                                                                                                          |                                            |
|                                                                                      |                                                  | 8                         | RO                    | Qword offset to the register block                                                                                                                                                                     | 0x31                                       |
| PP_OFFSET_1                                                                          |                                                  |                           |                       | (Stride) of FF level 1                                                                                                                                                                                 |                                            |
| DD 055555 1                                                                          | 15:8                                             | 8                         | RO                    | Qword offset to the register block (stride) of PP level 1                                                                                                                                              | 0x1B                                       |
| PP_OFFSET_0                                                                          | 7:0                                              | 8                         | RO                    | Qword offset to the register block (stride) of PP level 0                                                                                                                                              | 0x5                                        |
| Field Name                                                                           | Bits                                             | Widt<br>h                 | Acces<br>s Type       | Description                                                                                                                                                                                            | Defaul<br>t                                |
| SST_PP_OFFSET_1                                                                      |                                                  |                           |                       |                                                                                                                                                                                                        |                                            |
| RSVD                                                                                 | 63:2<br>4                                        | 40                        | RO                    | Reserved                                                                                                                                                                                               | 0                                          |
| SST_TF_OFFSET                                                                        | 23:1<br>6                                        | 8                         | RO                    | Qword offset within PP level for the SST_TF register bank                                                                                                                                              | 0xE                                        |
| SST_BF_OFFSET                                                                        | 15:8                                             | 8                         | RO                    | Qword offset within PP level for the SST_BF register bank                                                                                                                                              | 0xC                                        |
| SST_PP_OFFSET                                                                        | 7:0                                              | 8                         | RO                    | Qword offset within PP level for the SST_PP register bank                                                                                                                                              | 0x0                                        |
| Field Name                                                                           | Bits                                             | Widt<br>h                 | Acces<br>s Type       | Description                                                                                                                                                                                            | Defaul<br>t                                |
| SST_PP_OFFSET_0                                                                      |                                                  |                           |                       |                                                                                                                                                                                                        |                                            |
| RSVD2                                                                                | 63:4<br>5                                        | 19                        | RO                    | Reserved                                                                                                                                                                                               | 0                                          |
| MEMORY_RATIO_UNIT                                                                    | 44:4<br>3                                        | 2                         | RO                    | Memory Controller frequency<br>ratio unit. 00: 100MHz. All others :<br>Reserved. Default=0.                                                                                                            | 0                                          |
| DYNAMIC_SWITCHING                                                                    | 42:4<br>2                                        | 1                         | RO                    | If set (1), dynamic switching of<br>SST performance profiles is<br>supported, else, not.                                                                                                               | 0                                          |
|                                                                                      | 41:3<br>4                                        | 8                         | RO                    | Size of PP block (stride) in Qword unit (8 bytes)                                                                                                                                                      | 0x16                                       |

|                    |           |           |                 | SW must program PP level setting to each SST instance per their instance-ID order. I.e. program instance 0 first, and follow by 1, 2, 3, etc.           |             |
|--------------------|-----------|-----------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| SST_PP_LOCK        | 3:3       | 1         | RW              | SST-PP level select lock. 0 - unlocked. 1 - locked till next reset.                                                                                     | 0           |
| RSVD0              | 7:4       | 4         | RW              | Reserved                                                                                                                                                | 0           |
| FEATURE_STATE      | 15:8      | 8         | RW              | Bit mask to control the enable(1)/disable(0) state of each feature of the current PP level bit 0 = BF, bit 1 = TF, bit 2-7 = reserved.                  | 0           |
| RSVD1              | 63:1<br>6 | 48        | RW              | Reserved                                                                                                                                                | 0           |
| SST_PP_STATUS      |           |           |                 |                                                                                                                                                         |             |
| Field Name         | Bits      | Widt<br>h | Acces<br>s Type | Description                                                                                                                                             | Defaul<br>t |
| SST_PP_LEVEL       | 2:0       | 3         | RO              | Returns the current SST-PP level.                                                                                                                       | 0           |
| SST_PP_LOCK        | 3:3       | 1         | RO              | Returns the lock bit setting in SST_PP_CONTROL.SST_PP_LOC K                                                                                             | 0           |
| SST_PP_ERROR_TYPE  | 7:4       | 4         | RO              | Returns last error of SST-PP control.  0x0: no error  0x1: dynamic PP switch is not allowed.  0x20xF: reserved.                                         | 0           |
| FEATURE_STATE      | 15:8      | 8         | RO              | Bit mask to indicate the enable(1)/disable(0) state of each feature of the current PP level bit 0 = BF, bit 1 = TF, bit 2-7 = reserved.                 | 0           |
| RSVD0              | 31:1<br>6 | 16        | RO              | Reserved                                                                                                                                                | 0           |
| FEATURE_ERROR_TYPE | 55:3<br>2 | 24        | RO              | Returns last error of the specific feature.  Three error_type bits per feature. i.e. ERROR_TYPE[2:0] for BF, ERROR_TYPE[5:3] for TF, etc. 0x0: no error | 0           |

|                                                                             |                                               |               |                 | 0x1: The specific feature is not supported by the hardware. 0x2-0x6: Reserved 0x7: feature state change is not allowed.                                               |                  |
|-----------------------------------------------------------------------------|-----------------------------------------------|---------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| RSVD1                                                                       | 63:5<br>6                                     | 8             | RO              | Reserved                                                                                                                                                              | 0                |
| SST_PP_INFO-01                                                              |                                               |               |                 |                                                                                                                                                                       |                  |
| Field Name                                                                  | Bits                                          | Widt<br>h     | Acces<br>s Type | Description                                                                                                                                                           | Defaul<br>t      |
| P1_SSE                                                                      | 7:0                                           | 8             | RO              | Base frequency ratio of the TDP workload, a.k.a. SSE P1                                                                                                               | 0                |
| P1_AVX2                                                                     | 15:8                                          | 8             | RO              | P1 frequency ratio of the AVX2 representative workload                                                                                                                | 0                |
| P1_AVX512                                                                   | 23:1<br>6                                     | 8             | RO              | P1 frequency ratio of the AVX512 representative workload                                                                                                              | 0                |
| P1_AMX                                                                      | 31:2<br>4                                     | 8             | RO              | P1 frequency ratio of the AMX representative workload                                                                                                                 | 0                |
| RSVD                                                                        | 63:3<br>2                                     | 32            | RO              | Reserved                                                                                                                                                              | 0                |
| SST_PP_INFO-1                                                               |                                               |               |                 |                                                                                                                                                                       |                  |
|                                                                             |                                               |               |                 |                                                                                                                                                                       |                  |
| Field Name                                                                  | Bits                                          | Widt<br>h     | Acces<br>s Type | Description                                                                                                                                                           | Defaul<br>t      |
|                                                                             | <b>Bits</b> 7:0                               |               |                 | Description  Core Count of the fuse enabled cores.                                                                                                                    |                  |
| Field Name                                                                  |                                               | h             | ѕ Туре          | Core Count of the fuse enabled                                                                                                                                        | t                |
| Field Name  FUSED_CORE_COUNT  RESOLVED_CORE_COU                             | 7:0                                           | <b>h</b><br>8 | s Type<br>RO    | Core Count of the fuse enabled cores.  Core count of Pcode's resolved                                                                                                 | <b>t</b>         |
| Field Name  FUSED_CORE_COUNT  RESOLVED_CORE_COU  NT <sup>2</sup>            | 7:0<br>15:8<br>23:1                           | 8<br>8        | RO RO           | Core Count of the fuse enabled cores.  Core count of Pcode's resolved cores.  LLC count of the fuse enabled                                                           | 0<br>0           |
| Field Name  FUSED_CORE_COUNT  RESOLVED_CORE_COU  NT2  FUSED_LLC_COUNT       | 7:0<br>15:8<br>23:1<br>6<br>31:2              | 8<br>8<br>8   | RO RO           | Core Count of the fuse enabled cores.  Core count of Pcode's resolved cores.  LLC count of the fuse enabled LLC slices.                                               | 0<br>0<br>0      |
| Field Name  FUSED_CORE_COUNT  RESOLVED_CORE_COU  NT2  FUSED_LLC_COUNT  RSVD | 7:0<br>15:8<br>23:1<br>6<br>31:2<br>4<br>46:3 | 8<br>8<br>8   | RO RO RO        | Core Count of the fuse enabled cores.  Core count of Pcode's resolved cores.  LLC count of the fuse enabled LLC slices.  Reserved  Power for this TDP level. In 1/8 W | 0<br>0<br>0<br>0 |

| COOLING_TYPE           | 63:6<br>2 | 2         | RO              | Cooling Type                                                                                                                                                                  | 0           |
|------------------------|-----------|-----------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| SST_PP_INFO-2          |           |           |                 |                                                                                                                                                                               |             |
| Field Name             | Bits      | Widt<br>h | Acces<br>s Type | Description                                                                                                                                                                   | Defaul<br>t |
| RESOLVED_CORE_MAS<br>K | 63:0      | 64        | RO              | This is the logical core ID mask containing the functional (enabled in SKU) and non-defeatured (not in BIST failure or BIOS disables) cores. 1=enabled core, 0=disabled core. | 0           |
| SST_PP_INFO-3          |           |           |                 |                                                                                                                                                                               |             |
| Field Name             | Bits      | Widt<br>h | Acces<br>s Type | Description                                                                                                                                                                   | Defaul<br>t |
| RSVD                   | 63:0      | 64        | RO              | Reserved                                                                                                                                                                      | 0           |
| SST_PP_INFO-4          |           |           |                 |                                                                                                                                                                               |             |
| Field Name             | Bits      | Widt<br>h | Acces<br>s Type | Description                                                                                                                                                                   | Defaul<br>t |
| RATIO_0                | 7:0       | 8         | RO              | Turbo ratio limit level 0, bucket 0. (Note: Ratio of 0x0 in the TRL registers implies that particular turbo limit level is not supported.)                                    | 0           |
| RATIO_1                | 15:8      | 8         | RO              | Turbo ratio limit level 0, bucket 1                                                                                                                                           | 0           |
| RATIO_2                | 23:1<br>6 | 8         | RO              | Turbo ratio limit level 0, bucket 2                                                                                                                                           | 0           |
| RATIO_3                | 31:2<br>4 | 8         | RO              | Turbo ratio limit level 0, bucket 3                                                                                                                                           | 0           |
| RATIO_4                | 39:3<br>2 | 8         | RO              | Turbo ratio limit level 0, bucket 4                                                                                                                                           | 0           |
| RATIO_5                | 47:4<br>0 | 8         | RO              | Turbo ratio limit level 0, bucket 5                                                                                                                                           | 0           |
| RATIO_6                | 55:4<br>8 | 8         | RO              | Turbo ratio limit level 0, bucket 6                                                                                                                                           | 0           |
| RATIO_7                | 63:5<br>6 | 8         | RO              | Turbo ratio limit level 0, bucket 7                                                                                                                                           | 0           |
| SST_PP_INFO-5          |           |           |                 |                                                                                                                                                                               |             |
| Field Name             | Bits      | Widt<br>h | Acces<br>s Type | Description                                                                                                                                                                   | Defaul<br>t |
| RATIO_0                | 7:0       | 8         | RO              | Turbo ratio limit level 1, bucket 0                                                                                                                                           | 0           |
| RATIO_1                | 15:8      | 8         | RO              | Turbo ratio limit level 1, bucket 1                                                                                                                                           | 0           |

| RATIO_2       | 23:1<br>6 | 8         | RO              | Turbo ratio limit level 1, bucket 2 | 0           |
|---------------|-----------|-----------|-----------------|-------------------------------------|-------------|
| RATIO_3       | 31:2<br>4 | 8         | RO              | Turbo ratio limit level 1, bucket 3 | 0           |
| RATIO_4       | 39:3<br>2 | 8         | RO              | Turbo ratio limit level 1, bucket 4 | 0           |
| RATIO_5       | 47:4<br>0 | 8         | RO              | Turbo ratio limit level 1, bucket 5 | 0           |
| RATIO_6       | 55:4<br>8 | 8         | RO              | Turbo ratio limit level 1, bucket 6 | 0           |
| RATIO_7       | 63:5<br>6 | 8         | RO              | Turbo ratio limit level 1, bucket 7 | 0           |
| SST_PP_INFO-6 |           |           |                 |                                     |             |
| Field Name    | Bits      | Widt<br>h | Acces<br>s Type | Description                         | Defaul<br>t |
| RATIO_0       | 7:0       | 8         | RO              | Turbo ratio limit level 2, bucket 0 | 0           |
| RATIO_1       | 15:8      | 8         | RO              | Turbo ratio limit level 2, bucket 1 | 0           |
| RATIO_2       | 23:1<br>6 | 8         | RO              | Turbo ratio limit level 2, bucket 2 | 0           |
| RATIO_3       | 31:2<br>4 | 8         | RO              | Turbo ratio limit level 2, bucket 3 | 0           |
| RATIO_4       | 39:3<br>2 | 8         | RO              | Turbo ratio limit level 2, bucket 4 | 0           |
| RATIO_5       | 47:4<br>0 | 8         | RO              | Turbo ratio limit level 2, bucket 5 | 0           |
| RATIO_6       | 55:4<br>8 | 8         | RO              | Turbo ratio limit level 2, bucket 6 | 0           |
| RATIO_7       | 63:5<br>6 | 8         | RO              | Turbo ratio limit level 2, bucket 7 | 0           |
| SST_PP_INFO-7 |           |           |                 |                                     |             |
| Field Name    | Bits      | Widt<br>h | Acces<br>s Type | Description                         | Defaul<br>t |
| RATIO_0       | 7:0       | 8         | RO              | Turbo ratio limit level 3, bucket 0 | 0           |
| RATIO_1       | 15:8      | 8         | RO              | Turbo ratio limit level 3, bucket 1 | 0           |
| RATIO_2       | 23:1<br>6 | 8         | RO              | Turbo ratio limit level 3, bucket 2 | 0           |
| RATIO_3       | 31:2<br>4 | 8         | RO              | Turbo ratio limit level 3, bucket 3 | 0           |
| RATIO_4       | 39:3<br>2 | 8         | RO              | Turbo ratio limit level 3, bucket 4 | 0           |

| RATIO_5        | 47:4<br>0 | 8         | RO              | Turbo ratio limit level 3, bucket 5 | 0           |
|----------------|-----------|-----------|-----------------|-------------------------------------|-------------|
| RATIO_6        | 55:4<br>8 | 8         | RO              | Turbo ratio limit level 3, bucket 6 | 0           |
| RATIO_7        | 63:5<br>6 | 8         | RO              | Turbo ratio limit level 3, bucket 7 | 0           |
| SST_PP_INFO-8  |           |           |                 |                                     |             |
| Field Name     | Bits      | Widt<br>h | Acces<br>s Type | Description                         | Defaul<br>t |
| RATIO_0        | 7:0       | 8         | RO              | Turbo ratio limit level 4, bucket 0 | 0           |
| RATIO_1        | 15:8      | 8         | RO              | Turbo ratio limit level 4, bucket 1 | 0           |
| RATIO_2        | 23:1<br>6 | 8         | RO              | Turbo ratio limit level 4, bucket 2 | 0           |
| RATIO_3        | 31:2<br>4 | 8         | RO              | Turbo ratio limit level 4, bucket 3 | 0           |
| RATIO_4        | 39:3<br>2 | 8         | RO              | Turbo ratio limit level 4, bucket 4 | 0           |
| RATIO_5        | 47:4<br>0 | 8         | RO              | Turbo ratio limit level 4, bucket 5 | 0           |
| RATIO_6        | 55:4<br>8 | 8         | RO              | Turbo ratio limit level 4, bucket 6 | 0           |
| RATIO_7        | 63:5<br>6 | 8         | RO              | Turbo ratio limit level 4, bucket 7 | 0           |
| SST_PP_INFO-9  |           |           |                 |                                     |             |
| Field Name     | Bits      | Widt<br>h | Acces<br>s Type | Description                         | Defaul<br>t |
| RATIO_0        | 7:0       | 8         | RO              | Turbo ratio limit level 5, bucket 0 | 0           |
| RATIO_1        | 15:8      | 8         | RO              | Turbo ratio limit level 5, bucket 1 | 0           |
| RATIO_2        | 23:1<br>6 | 8         | RO              | Turbo ratio limit level 5, bucket 2 | 0           |
| RATIO_3        | 31:2<br>4 | 8         | RO              | Turbo ratio limit level 5, bucket 3 | 0           |
| RATIO_4        | 39:3<br>2 | 8         | RO              | Turbo ratio limit level 5, bucket 4 | 0           |
| RATIO_5        | 47:4<br>0 | 8         | RO              | Turbo ratio limit level 5, bucket 5 | 0           |
| RATIO_6        | 55:4<br>8 | 8         | RO              | Turbo ratio limit level 5, bucket 6 | 0           |
| RATIO_7        | 63:5<br>6 | 8         | RO              | Turbo ratio limit level 5, bucket 7 | 0           |
| SST_PP_INFO-10 |           |           |                 |                                     |             |

| Field Name                                                                           | Bits                                                       | Widt<br>h        | Acces<br>s Type | Description                                                                                                                                                                                                            | Defaul<br>t      |
|--------------------------------------------------------------------------------------|------------------------------------------------------------|------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| NUM_CORE_0                                                                           | 7:0                                                        | 8                | RO              | TRL num_core defines the active core ranges for TRL bucket 0                                                                                                                                                           | 0                |
| NUM_CORE_1                                                                           | 15:8                                                       | 8                | RO              | TRL num_core defines the active core ranges for TRL bucket 1                                                                                                                                                           | 0                |
| NUM_CORE_2                                                                           | 23:1<br>6                                                  | 8                | RO              | TRL num_core defines the active core ranges for TRL bucket 2                                                                                                                                                           | 0                |
| NUM_CORE_3                                                                           | 31:2<br>4                                                  | 8                | RO              | TRL num_core defines the active core ranges for TRL bucket 3                                                                                                                                                           | 0                |
| NUM_CORE_4                                                                           | 39:3<br>2                                                  | 8                | RO              | TRL num_core defines the active core ranges for TRL bucket 4                                                                                                                                                           | 0                |
| NUM_CORE_5                                                                           | 47:4<br>0                                                  | 8                | RO              | TRL num_core defines the active core ranges for TRL bucket 5                                                                                                                                                           | 0                |
| NUM_CORE_6                                                                           | 55:4<br>8                                                  | 8                | RO              | TRL num_core defines the active core ranges for TRL bucket 6                                                                                                                                                           | 0                |
| NUM_CORE_7                                                                           | 63:5<br>6                                                  | 8                | RO              | TRL num_core defines the active core ranges for TRL bucket 7                                                                                                                                                           | 0                |
| SST_PP_INFO-11                                                                       |                                                            |                  |                 |                                                                                                                                                                                                                        |                  |
|                                                                                      |                                                            |                  |                 |                                                                                                                                                                                                                        |                  |
| Field Name                                                                           | Bits                                                       | Widt<br>h        | Acces<br>s Type | Description                                                                                                                                                                                                            | Defaul<br>t      |
| Field Name P0_CORE_RATIO <sup>3</sup>                                                | <b>Bits</b> 7:0                                            |                  |                 | Description  Core maximum frequency ratio limit.                                                                                                                                                                       |                  |
|                                                                                      |                                                            | h                | ѕ Туре          | Core maximum frequency ratio                                                                                                                                                                                           | t                |
| P0_CORE_RATIO <sup>3</sup>                                                           | 7:0                                                        | <b>h</b><br>8    | s Type<br>RO    | Core maximum frequency ratio limit.                                                                                                                                                                                    | <b>t</b>         |
| P0_CORE_RATIO <sup>3</sup> P1_CORE_RATIO                                             | 7:0<br>15:8<br>23:1                                        | <b>h</b><br>8    | RO RO           | Core maximum frequency ratio limit.  Core TDP frequency ratio.  Core maximum efficiency                                                                                                                                | 0<br>0           |
| P0_CORE_RATIO <sup>3</sup> P1_CORE_RATIO PN_CORE_RATIO                               | 7:0<br>15:8<br>23:1<br>6<br>31:2                           | 8<br>8<br>8      | RO<br>RO<br>RO  | Core maximum frequency ratio limit.  Core TDP frequency ratio.  Core maximum efficiency frequency ratio.                                                                                                               | 0<br>0<br>0      |
| P0_CORE_RATIO <sup>3</sup> P1_CORE_RATIO PN_CORE_RATIO PM_CORE_RATIO                 | 7:0<br>15:8<br>23:1<br>6<br>31:2<br>4<br>39:3              | 8<br>8<br>8<br>8 | RO RO RO        | Core maximum frequency ratio limit.  Core TDP frequency ratio.  Core maximum efficiency frequency ratio.  Core minimum frequency ratio.  Fabric (Uncore) maximum                                                       | 0<br>0<br>0<br>0 |
| P0_CORE_RATIO <sup>3</sup> P1_CORE_RATIO PN_CORE_RATIO PM_CORE_RATIO P0_FABRIC_RATIO | 7:0<br>15:8<br>23:1<br>6<br>31:2<br>4<br>39:3<br>2<br>47:4 | 8<br>8<br>8<br>8 | RO RO RO RO     | Core maximum frequency ratio limit.  Core TDP frequency ratio.  Core maximum efficiency frequency ratio.  Core minimum frequency ratio.  Fabric (Uncore) maximum frequency ratio limit.  Fabric (Uncore) TDP frequency | t 0 0 0 0 0 0 0  |

## SST-BF Registers

SST-BF Registers (<u>source</u>)

| SST_BF_INFO-0      |           |           |                 |                                                                                                                    |             |
|--------------------|-----------|-----------|-----------------|--------------------------------------------------------------------------------------------------------------------|-------------|
| Field Name         | Bits      | Widt<br>h | Acces<br>s Type | Description                                                                                                        | Defaul<br>t |
| SST_FEATURE_ID     | 3:0       | 4         | RO              | Set to 2. (0=SST-CP, 1=SST-PP, 2=SST-BF, 3=SST-TF, 4-15 = reserved)                                                | 2           |
| FEATURE_REVISION   | 11:4      | 8         | RO              | Interface Version number for this SST feature                                                                      | 1           |
| FEATURE_SUPPORTE D | 12:1<br>2 | 1         | RO              | 1: This SST feature is supported in this PP level. 0: This SST feature is not supported                            | 0           |
| P1_HI              | 20:1      | 8         | RO              | base frequency for high priority cores                                                                             | 0           |
| P1_LO              | 28:2<br>1 | 8         | RO              | base frequency for low priority cores                                                                              | 0           |
| RSVD0              | 31:2<br>9 | 3         | RO              | Reserved                                                                                                           | 0           |
| T_CONTROL          | 37:3<br>2 | 6         | RO              | Fan Temperature Target Offset                                                                                      | 0           |
| T_PROHOT           | 45:3<br>8 | 8         | RO              | Provides the DTS max or external Prochot for the specific configuration.                                           | 0           |
| TDP                | 60:4      | 15        | RO              | TDP = SKU TDP - SST_BF_CONFIG_n_TDP_OFFSET . Pcode returns the resolved TDP in this configuration. In 1/8 W units. | 0           |

| RSVD1           | 63:6<br>1 | 3         | RO              | Reserved                                                                                  | 0           |
|-----------------|-----------|-----------|-----------------|-------------------------------------------------------------------------------------------|-------------|
| SST_BF_INFO-1   |           |           |                 |                                                                                           |             |
| Field Name      | Bits      | Widt<br>h | Acces<br>s Type | Description                                                                               | Defaul<br>t |
| P1_HI_CORE_MASK | 63:0      | 64        | RO              | Value of PBF_P1_HI_CORE_MASK for index provided as input. This is a logical core ID mask. | 0           |
|                 |           |           |                 | Bitmask polarity: 1=high priority core, 0=low priority core                               |             |

## SST-TF Registers

### **SST-TF Registers** (<u>source</u>)

| SST_TF_INFO-0     |       |       |                |                                                                                                  |         |
|-------------------|-------|-------|----------------|--------------------------------------------------------------------------------------------------|---------|
| Field Name        | Bits  | Width | Access<br>Type | Description                                                                                      | Default |
| SST_FEATURE_ID    | 3:0   | 4     | RO             | Set to 3. (0=SST-CP, 1=SST-PP, 2=SST-BF, 3=SST-TF, 4-15 = reserved)                              | 3       |
| FEATURE_REVISION  | 11:4  | 8     | RO             | Interface Version number for this SST feature                                                    | 1       |
| FEATURE_SUPPORTED | 12:12 | 1     | RO             | 1: This SST feature is<br>supported in this PP level. 0:<br>This SST feature is not<br>supported | 0       |
| RSVD1             | 15:13 | 3     | RO             | Reserved                                                                                         | 0       |
| LP_CLIP_RATIO_0   | 23:16 | 8     | RO             | Low priority cores frequency clipping ratio level 0                                              | 0       |

| LP_CLIP_RATIO_1        | 31:24       | 8          | RO                | Low priority cores frequency clipping ratio level 1                                                        | 0                   |
|------------------------|-------------|------------|-------------------|------------------------------------------------------------------------------------------------------------|---------------------|
| LP_CLIP_RATIO_2        | 39:32       | 8          | RO                | Low priority cores frequency clipping ratio level 2                                                        | 0                   |
| LP_CLIP_RATIO_3        | 47:40       | 8          | RO                | Low priority cores frequency clipping ratio level 3                                                        | 0                   |
| LP_CLIP_RATIO_4        | 55:48       | 8          | RO                | Low priority cores frequency clipping ratio level 4                                                        | 0                   |
| LP_CLIP_RATIO_5        | 63:56       | 8          | RO                | Low priority cores frequency clipping ratio level 5                                                        | 0                   |
| SST_TF_INFO-1          |             |            |                   |                                                                                                            |                     |
|                        |             |            |                   |                                                                                                            |                     |
| Field Name             | Bits        | Width      | Access<br>Type    | Description                                                                                                | Default             |
| Field Name  NUM_CORE_0 | Bits        | Width<br>8 | 1                 | Description  High Priority core count for bucket 0                                                         | <b>Default</b><br>0 |
|                        |             |            | Туре              | High Priority core count for                                                                               |                     |
| NUM_CORE_0             | 7:0         | 8          | <b>Type</b><br>RO | High Priority core count for bucket 0  High Priority core count for                                        | 0                   |
| NUM_CORE_0  NUM_CORE_1 | 7:0<br>15:8 | 8          | RO RO             | High Priority core count for bucket 0  High Priority core count for bucket 1  High Priority core count for | 0                   |

| NUM_CORE_5    | 47:40 | 8     | RO             | High Priority core count for bucket 5         | 0       |
|---------------|-------|-------|----------------|-----------------------------------------------|---------|
| NUM_CORE_6    | 55:48 | 8     | RO             | High Priority core count for bucket 6         | 0       |
| NUM_CORE_7    | 63:56 | 8     | RO             | High Priority core count for bucket 7         | 0       |
| SST_TF_INFO-2 |       |       |                |                                               |         |
| Field Name    | Bits  | Width | Access<br>Type | Description                                   | Default |
| RATIO_0       | 7:0   | 8     | RO             | SST-TF turbo ratio limit level 0,<br>bucket 0 | 0       |
| RATIO_1       | 15:8  | 8     | RO             | SST-TF turbo ratio limit level 0,<br>bucket 1 | 0       |
| RATIO_2       | 23:16 | 8     | RO             | SST-TF turbo ratio limit level 0,<br>bucket 2 | 0       |
| RATIO_3       | 31:24 | 8     | RO             | SST-TF turbo ratio limit level 0,<br>bucket 3 | 0       |
| RATIO_4       | 39:32 | 8     | RO             | SST-TF turbo ratio limit level 0,<br>bucket 4 | 0       |
| RATIO_5       | 47:40 | 8     | RO             | SST-TF turbo ratio limit level 0,<br>bucket 5 | 0       |
| RATIO_6       | 55:48 | 8     | RO             | SST-TF turbo ratio limit level 0,<br>bucket 6 | 0       |

| RATIO_7       | 63:56 | 8     | RO             | SST-TF turbo ratio limit level 0,<br>bucket 7 | 0       |
|---------------|-------|-------|----------------|-----------------------------------------------|---------|
| SST_TF_INFO-3 |       |       |                |                                               |         |
| Field Name    | Bits  | Width | Access<br>Type | Description                                   | Default |
| RATIO_0       | 7:0   | 8     | RO             | SST-TF turbo ratio limit level 1,<br>bucket 0 | 0       |
| RATIO_1       | 15:8  | 8     | RO             | SST-TF turbo ratio limit level 1,<br>bucket 1 | 0       |
| RATIO_2       | 23:16 | 8     | RO             | SST-TF turbo ratio limit level 1,<br>bucket 2 | 0       |
| RATIO_3       | 31:24 | 8     | RO             | SST-TF turbo ratio limit level 1,<br>bucket 3 | 0       |
| RATIO_4       | 39:32 | 8     | RO             | SST-TF turbo ratio limit level 1,<br>bucket 4 | 0       |
| RATIO_5       | 47:40 | 8     | RO             | SST-TF turbo ratio limit level 1,<br>bucket 5 | 0       |
| RATIO_6       | 55:48 | 8     | RO             | SST-TF turbo ratio limit level 1,<br>bucket 6 | 0       |
| RATIO_7       | 63:56 | 8     | RO             | SST-TF turbo ratio limit level 1,<br>bucket 7 | 0       |
| SST_TF_INFO-4 |       |       |                |                                               |         |

| Field Name    | Bits  | Width | Access<br>Type | Description                                   | Default |
|---------------|-------|-------|----------------|-----------------------------------------------|---------|
| RATIO_0       | 7:0   | 8     | RO             | SST-TF turbo ratio limit level 2,<br>bucket 0 | 0       |
| RATIO_1       | 15:8  | 8     | RO             | SST-TF turbo ratio limit level 2,<br>bucket 1 | 0       |
| RATIO_2       | 23:16 | 8     | RO             | SST-TF turbo ratio limit level 2, bucket 2    | 0       |
| RATIO_3       | 31:24 | 8     | RO             | SST-TF turbo ratio limit level 2, bucket 3    | 0       |
| RATIO_4       | 39:32 | 8     | RO             | SST-TF turbo ratio limit level 2, bucket 4    | 0       |
| RATIO_5       | 47:40 | 8     | RO             | SST-TF turbo ratio limit level 2, bucket 5    | 0       |
| RATIO_6       | 55:48 | 8     | RO             | SST-TF turbo ratio limit level 2,<br>bucket 6 | 0       |
| RATIO_7       | 63:56 | 8     | RO             | SST-TF turbo ratio limit level 2, bucket 7    | 0       |
| SST_TF_INFO-5 |       |       |                |                                               |         |
| Field Name    | Bits  | Width | Access<br>Type | Description                                   | Default |
| RATIO_0       | 7:0   | 8     | RO             | SST-TF turbo ratio limit level 3,<br>bucket 0 | 0       |

| RATIO_2       | 23:16 | 8     | RO             | SST-TF turbo ratio limit level 4,<br>bucket 2 | 0       |
|---------------|-------|-------|----------------|-----------------------------------------------|---------|
| RATIO_1       | 15:8  | 8     | RO             | SST-TF turbo ratio limit level 4,<br>bucket 1 | 0       |
| RATIO_0       | 7:0   | 8     | RO             | SST-TF turbo ratio limit level 4,<br>bucket 0 | 0       |
| Field Name    | Bits  | Width | Access<br>Type | Description                                   | Default |
| SST_TF_INFO-6 |       |       |                |                                               |         |
| RATIO_7       | 63:56 | 8     | RO             | SST-TF turbo ratio limit level 3, bucket 7    | 0       |
| RATIO_6       | 55:48 | 8     | RO             | SST-TF turbo ratio limit level 3,<br>bucket 6 | 0       |
| RATIO_5       | 47:40 | 8     | RO             | SST-TF turbo ratio limit level 3,<br>bucket 5 | 0       |
| RATIO_4       | 39:32 | 8     | RO             | SST-TF turbo ratio limit level 3,<br>bucket 4 | 0       |
| RATIO_3       | 31:24 | 8     | RO             | SST-TF turbo ratio limit level 3, bucket 3    | 0       |
| RATIO_2       | 23:16 | 8     | RO             | SST-TF turbo ratio limit level 3,<br>bucket 2 | 0       |
| RATIO_1       | 15:8  | 8     | RO             | SST-TF turbo ratio limit level 3,<br>bucket 1 | 0       |

| RATIO_3             | 31:24       | 8          | RO                | SST-TF turbo ratio limit level 4, bucket 3                                                                                | 0                |
|---------------------|-------------|------------|-------------------|---------------------------------------------------------------------------------------------------------------------------|------------------|
| RATIO_4             | 39:32       | 8          | RO                | SST-TF turbo ratio limit level 4,<br>bucket 4                                                                             | 0                |
| RATIO_5             | 47:40       | 8          | RO                | SST-TF turbo ratio limit level 4,<br>bucket 5                                                                             | 0                |
| RATIO_6             | 55:48       | 8          | RO                | SST-TF turbo ratio limit level 4,<br>bucket 6                                                                             | 0                |
| RATIO_7             | 63:56       | 8          | RO                | SST-TF turbo ratio limit level 4,<br>bucket 7                                                                             | 0                |
| SST_TF_INFO-7       |             |            |                   |                                                                                                                           |                  |
|                     |             |            |                   |                                                                                                                           |                  |
| Field Name          | Bits        | Width      | Access<br>Type    | Description                                                                                                               | Default          |
| Field Name  RATIO_0 | Bits        | Width<br>8 |                   | Description  SST-TF turbo ratio limit level 5, bucket 0                                                                   | <b>Default</b> 0 |
|                     |             |            | Туре              | SST-TF turbo ratio limit level 5,                                                                                         |                  |
| RATIO_0             | 7:0         | 8          | <b>Type</b><br>RO | SST-TF turbo ratio limit level 5, bucket 0  SST-TF turbo ratio limit level 5,                                             | 0                |
| RATIO_0  RATIO_1    | 7:0<br>15:8 | 8          | RO RO             | SST-TF turbo ratio limit level 5, bucket 0  SST-TF turbo ratio limit level 5, bucket 1  SST-TF turbo ratio limit level 5, | 0                |

| RATIO_5 | 47:40 | 8 | RO | SST-TF turbo ratio limit level 5,<br>bucket 5 | 0 |
|---------|-------|---|----|-----------------------------------------------|---|
| RATIO_6 | 55:48 | 8 | RO | SST-TF turbo ratio limit level 5,<br>bucket 6 | 0 |
| RATIO_7 | 63:56 | 8 | RO | SST-TF turbo ratio limit level 5, bucket 7    | 0 |

# **Register Discovery and Access**

SW responsibility includes (but not limited to) the following:

- Discover SST TPMI\_ID encoding (0x5) from the TPMI PFS structure and calculate SST's base MMIO address.
- Read SST\_HEADER and enumerate capability supported
- Calculate the offset to CP register banks. Enumerate CP header, control, and configuration registers
- Calculate the offset to PP register banks. Enumerate PP header, control, offsets, and register strides.
- Enumerate BF and TF registers within PP register bank.
- Handle SST as per-die scope feature.
- Enumerate the number of valid SST instances.
- Use {TPMI Register Name, TPMI ID, TPMI Offset} as documented in EDS/datasheet to construct MMIO address for register access.
- Write to all valid SST instances (lower numbered instance first, highest numbered instance last) and when performing SST\_PP config level switch and SST\_BF/SST\_TF state change.

#### **MMIO Address Calculation Details**

- Search for VSEC\_ID in extended PCIe config space
- Find VSEC\_ID=0x42 (TPMI Feature). Get the BARs of this BDF
- Calculate the MMIO Base Address for TPMI PM Features
  - o BasePtr = BAR[tBIR] + Table\_Offset
- Search for SST TPMI\_ID in the PFS
- Calculate the MMIO Base Address of SST registers
  - BasePtr[SST] = BasePtr + Cap\_Offset[SST]
- Discover X, the number of SST instances

```
• valid = 1; p = 0;
```

while (valid) {

```
data= [BasePtr[SST] + p * PFS.EntrySize*4 + 0]; // read
the first register of each instance
```

• valid = (data != -1); // All Fs indicates invalid data.

```
• p ++;
```

• }

$$X = p;$$

- Calc mmio\_addr of SST\_HEADER of instance k, where k = 0 .. X-1
  - mmio\_addr[k, SST\_HEADER] = BasePtr[SST] + k \* PFS.EntrySize \* 4 + SST\_HEADER.TPMI\_Offset
- Calc mmio\_addr of register in the CP register bank
  - BasePtr[SST] + k \* PFS.EntrySize \* 4 + SST\_HEADER.SST\_CP\_OFFSET \* 8 + (register).TPMI\_Offset
- Calc mmio\_addr of common register (non PP level specific) in the PP register bank
  - BasePtr[SST] + k \* PFS.EntrySize \* 4 + SST\_HEADER.SST\_PP\_OFFSET \* 8 + (register).TPMI\_Offset
- Calc mmio\_addr of PP[BF|TF] register in register stride S
  - BasePtr[SST] + k \* PFS.EntrySize \* 4 + SST\_HEADER.SST\_PP\_OFFSET \* 8 + SST\_PP\_OFFSET\_1.PP\_OFFSET\_[S] \* 8 + SST\_PP\_OFFSET\_0.SST\_PP[BF|TF]\_OFFSET \* 8 + (register).TPMI\_Offset

SW should look up register definition document (e.g. EDS, CPU datasheet, etc.) to determine the TPMI\_Offset of each register. An example is shown below.

#### **TPMI Offset (source)**

|  | Name | TPMI ID | TPMI Offset |
|--|------|---------|-------------|
|--|------|---------|-------------|

|               | SST_HEADER        | 5 | 0  |
|---------------|-------------------|---|----|
|               | SST_CP_HEADER     | 5 | 0  |
|               | SST_CP_CONTROL    | 5 | 8  |
|               | SST_CP_STATUS     | 5 | 16 |
|               | SST_CLOS_CONFIG_0 | 5 | 24 |
|               | SST_CLOS_CONFIG_1 | 5 | 32 |
|               | SST_CLOS_CONFIG_2 | 5 | 40 |
| All DD L avel | SST_CLOS_CONFIG_3 | 5 | 48 |
| All PP Level  | SST_CLOS_ASSOC_0  | 5 | 56 |
|               | SST_CLOS_ASSOC_1  | 5 | 64 |
|               | SST_CLOS_ASSOC_2  | 5 | 72 |
|               | SST_CLOS_ASSOC_3  | 5 | 80 |
|               | SST_PP_HEADER     | 5 | 0  |
|               | SST_PP_OFFSET_0   | 5 | 8  |
|               | SST_PP_OFFSET_1   | 5 | 16 |
|               | SST_PP_CONTROL    | 5 | 24 |

|              | SST_PP_STATUS  | 5 | 32 |
|--------------|----------------|---|----|
|              |                | _ |    |
|              | SST_PP_INFO_0  | 5 | 0  |
|              | SST_PP_INFO_1  | 5 | 8  |
|              | SST_PP_INFO_2  | 5 | 16 |
|              | SST_PP_INFO_3  | 5 | 24 |
|              | SST_PP_INFO_4  | 5 | 32 |
|              | SST_PP_INFO_5  | 5 | 40 |
|              | SST_PP_INFO_6  | 5 | 48 |
| Per PP Level | SST_PP_INFO_7  | 5 | 56 |
|              | SST_PP_INFO_8  | 5 | 64 |
|              | SST_PP_INFO_9  | 5 | 72 |
|              | SST_PP_INFO_10 | 5 | 80 |
|              | SST_PP_INFO_11 | 5 | 88 |
|              | SST_BF_INFO_0  | 5 | 0  |
|              | SST_BF_INFO_1  | 5 | 8  |
|              | SST_TF_INFO_0  | 5 | 0  |

|               | SST_TF_INFO_1 | 5   | 8  |
|---------------|---------------|-----|----|
|               | SST_TF_INFO_2 | 5   | 16 |
|               | SST_TF_INFO_3 | 5   | 24 |
|               | SST_TF_INFO_4 | 5   | 32 |
|               | SST_TF_INFO_5 | 5   | 40 |
|               | SST_TF_INFO_6 | 5   | 48 |
|               | SST_TF_INFO_7 | 5   | 56 |
| Total Number  | of Registers  | 127 |    |
| PFS.EntrySize |               | 254 |    |