

| Document Identifier: DSP0237 | 2 |
|------------------------------|---|
| Date: 2020-04-06             | 3 |
| Version: 1.2.0               | 4 |
|                              |   |

- **5 Management Component Transport Protocol**
- 6 (MCTP) SMBus/I2C Transport Binding
- 7 Specification

- 8 Supersedes: 1.1.0
- 9 Document Class: Normative
- 10 Document Status: Published
- 11 Document Language: en-US

13 Copyright Notice

14 Copyright © 2009, 2017, 2020 DMTF. All rights reserved.

DMTF is a not-for-profit association of industry members dedicated to promoting enterprise and systems management and interoperability. Members and non-members may reproduce DMTF specifications and documents, provided that correct attribution is given. As DMTF specifications may be revised from time to time, the particular version and release date should always be noted.

19 Implementation of certain elements of this standard or proposed standard may be subject to third party patent rights, including provisional patent rights (herein "patent rights"). DMTF makes no representations 20 21 to users of the standard as to the existence of such rights, and is not responsible to recognize, disclose, 22 or identify any or all such third party patent right, owners or claimants, nor for any incomplete or 23 inaccurate identification or disclosure of such rights, owners or claimants. DMTF shall have no liability to 24 any party, in any manner or circumstance, under any legal theory whatsoever, for failure to recognize, 25 disclose, or identify any such third party patent rights, or for such party's reliance on the standard or 26 incorporation thereof in its product, protocols or testing procedures. DMTF shall have no liability to any 27 party implementing such standard, whether such implementation is foreseeable or not, nor to any patent 28 owner or claimant, and shall have no liability or responsibility for costs or losses incurred if a standard is 29 withdrawn or modified after publication, and shall be indemnified and held harmless by any party implementing the standard from any and all claims of infringement by a patent owner for such 30 31 implementations. 32 For information about patents held by third-parties which have notified the DMTF that, in their opinion. 33 such patent may relate to or impact implementations of DMTF standards, visit http://www.dmtf.org/about/policies/disclosures.php. 34

PCI-SIG, PCIe, and the PCI HOT PLUG design mark are registered trademarks or service marks of PCI-SIG.

- 37 All other marks and brands are the property of their respective owners.
- 38 This document's normative language is English. Translation into other languages is permitted.
- 39

# CONTENTS

| 41 | Fore  | word.  |                                                            | 5   |
|----|-------|--------|------------------------------------------------------------|-----|
| 42 | Intro | ductio | ٦                                                          | 6   |
| 43 | 1     | Scope  | )                                                          | 7   |
| 44 | 2     | Norma  | ative references                                           | 7   |
| 45 | 3     | Terms  | and definitions                                            | 7   |
| 46 | 4     | Svmb   | ols and abbreviated terms                                  | 8   |
| 47 | 5     | •      | entions                                                    |     |
| 48 | -     | 5.1    | Reserved and unassigned values                             |     |
| 49 |       | 5.2    | Byte ordering                                              |     |
| 50 | 6     | MCTF   | over SMBus/I <sup>2</sup> C transport                      | .11 |
| 51 |       | 6.1    | Terminology                                                |     |
| 52 |       | 6.2    | Transport binding use with I <sup>2</sup> C                | .11 |
| 53 |       | 6.3    | MCTP packet encapsulation                                  |     |
| 54 |       | 6.4    | Bridges and packet formatting                              | .13 |
| 55 |       | 6.5    | MCTP support discovery                                     |     |
| 56 |       | 6.6    | Support for fixed-address devices                          |     |
| 57 |       | 6.7    | Supported media                                            |     |
| 58 |       | 6.8    | Physical address format for MCTP control messages          | 15  |
| 59 |       | 6.9    | Get endpoint ID medium-specific information                | .15 |
| 60 |       | 6.10   | Bus owner address                                          |     |
| 61 |       | 6.11   | Bus address assignment                                     |     |
| 62 |       | 6.12   | SMBus/I <sup>2</sup> C considerations for MCTP messages    |     |
| 63 |       | 6.13   | Fairness arbitration                                       |     |
| 64 |       | 6.14   | NACK window                                                |     |
| 65 |       | 6.15   | Fairness arbitration requirements for MCTP bridges         |     |
| 66 |       | 6.16   | Fairness arbitration requirements for non-bridge endpoints |     |
| 67 |       | 6.17   | Fairness arbitration timing                                |     |
| 68 |       | 6.18   | MCTP packet timing requirements                            |     |
| 69 |       | 6.19   | MCTP control message timing requirements                   |     |
| 70 |       | 6.20   | "Stuck 0" condition handling                               |     |
| 71 |       | 6.21   | MCTP over SMBus/I <sup>2</sup> C protocol anti-aliasing    |     |
| 72 |       | 6.22   | Well-known and reserved slave addresses                    |     |
| 73 |       | 6.23   | Fixed address allocation                                   |     |
| 74 |       | 6.24   | Recommended address range allocation for computer systems  |     |
| 75 |       |        | (informative) Notation                                     |     |
| 76 | ANN   | IEX B  | (informative) Change log                                   | 37  |
| 77 |       |        |                                                            |     |

# 78 Figures

| 79 | Figure 1 – MCTP over SMBus/I <sup>2</sup> C packet format                         |    |
|----|-----------------------------------------------------------------------------------|----|
|    | Figure 2 – Address assignment flow                                                |    |
|    | Figure 3 – Allowed byte range for first NACK'd byte                               |    |
| 82 | Figure 4 – Fairness arbitration timing measurement for SMBus and I <sup>2</sup> C | 24 |
| 83 | Figure 5 – Example system configuration                                           |    |
| 84 |                                                                                   |    |

## 85 **Tables**

| 86 | Table 1 – Packet header field descriptions                                      | . 12 |
|----|---------------------------------------------------------------------------------|------|
| 87 | Table 2 – Supported media                                                       | . 15 |
| 88 | Table 3 – Physical address format                                               | . 15 |
| 89 | Table 4 – Medium-specific information                                           | . 15 |
| 90 | Table 5 – Fairness arbitration timing values for 100 kHz SMBus/I <sup>2</sup> C | . 24 |
| 91 | Table 6 – Fairness arbitration timing values for 400 kHz I <sup>2</sup> C       | . 25 |
| 92 | Table 7 – Fairness arbitration timing values for 1MHz I <sup>2</sup> C          | . 25 |
| 93 | Table 8 – Timing specifications for MCTP packets on SMBus/I <sup>2</sup> C      | . 26 |
| 94 | Table 9 – Timing specifications for MCTP control messages on SMBus              | . 27 |
| 95 | Table 10 – Well-known and reserved slave addresses                              | . 30 |
| 96 | Table 11 – Slave address allocation for computer systems                        | . 34 |
| 97 |                                                                                 |      |

### Foreword

- 99 The Management Component Transport Protocol (MCTP) SMBus/I2C Transport Binding Specification
- 100 (DSP0237) was prepared by the PMCI Working Group.
- 101 DMTF is a not-for-profit association of industry members dedicated to promoting enterprise and systems 102 management and interoperability.

### 103 Acknowledgments

- 104 The DMTF acknowledges the following individuals for their contributions to this document:
- 105 Editor:
- Yuval Itkin Mellanox Technologies

### 107 Contributors:

- 108 Alan Berenbaum SMSC
- 109 Patrick Caporale Lenovo
- Phil Chidester Dell Inc
- 111 Edward Klodnicki IBM
- 112 Joe Kozlowski Dell Inc
- 113 John Leung Intel Corporation
- Eliel Louzoun Intel Corporation
- 115 Patrick Schoeller Hewlett Packard Enterprise
- Hemal Shah Broadcom Limited
- Tom Slaight Intel Corporation
- Yi Zeng Intel Corporation

### Introduction

121 The Management Component Transport Protocol (MCTP) over SMBus/I2C transport binding defines a 122 transport binding for facilitating communication between platform management subsystem components 123 (e.g., management controllers, managed devices) over SMBus/I2C.

124 The MCTP Base Specification (MCTP) describes the protocol and commands used for communication

within, and the initialization of, an MCTP network. The MCTP over SMBus/I2C transport binding definition
 in this specification includes a packet format, physical address format, message routing, and discovery

- 127 mechanisms for MCTP over SMBus/I2C communications.
- 128

# Management Component Transport Protocol (MCTP) SMBus/I2C Transport Binding Specification

### 131 **1 Scope**

This document provides the specifications for the Management Component Transport Protocol (MCTP)
 transport binding for SMBus/l<sup>2</sup>C.

### **134 2 Normative references**

- 135 The following referenced documents are indispensable for the application of this document. For dated or
- 136 versioned references, only the edition cited applies (including any corrigenda or DMTF update versions)
- applies. For references without a date or version, the latest published edition of the referenced document(including any corrigenda or DMTF update versions) applies.
- 139 DMTF DSP0136, Alert Standard Format Specification 2.0,
- 140 https://www.dmtf.org/sites/default/files/standards/documents/DSP0136.pdf
- DMTF, DSP0236, Management Component Transport Protocol (MCTP) Base Specification 1.3, MCTP,
   <u>http://www.dmtf.org/sites/default/files/standards/documents/DSP0236\_1.3.pdf</u>
- 143 DMTF, DSP0239, *Management Component Transport Protocol (MCTP) IDs and Codes 1.4*, MCTP\_ID, 144 <u>http://www.dmtf.org/sites/default/files/standards/documents/DSP0239\_1.4.pdf</u>
- 145 IPMI Consortium, Intelligent Platform Management Interface Specification, Second Generation 2.0, 2006,
   <u>ftp://download.intel.com/design/servers/ipmi/IPMIv2\_0rev1\_0.pdf</u>
- 147 ISO/IEC Directives, Part 2, *Rules for the structure and drafting of International Standards,* 148 http://isotc.iso.org/livelink/livelink?func=Il&obild=4230456&obiAction=browse&sort=subtype
- 149 NXP Semiconductors, *PC-bus specification and user manual*, 4 April 2014
- 150 http://www.nxp.com/documents/user\_manual/UM10204.pdf
- 151 System Management Bus (SMBus) Specification, version 3.1 19-Mar-2018
- 152 http://smbus.org/specs/SMBus\_3\_1\_20180319.pdf

### **153 3 Terms and definitions**

- 154 In this document, some terms have a specific meaning beyond the normal English meaning. Those terms155 are defined in this clause.
- The terms "shall" ("required"), "shall not," "should" ("recommended"), "should not" ("not recommended"),
  "may," "need not" ("not required"), "can" and "cannot" in this document are to be interpreted as described
  in <u>ISO/IEC Directives, Part 2</u>, Clause 7. The terms in parenthesis are alternatives for the preceding term,
  for use in exceptional cases when the preceding term cannot be used for linguistic reasons. Note that
  <u>ISO/IEC Directives, Part 2</u>, Clause 7 specifies additional alternatives. Occurrences of such additional
  alternatives shall be interpreted in their normal English meaning.
- 162 The terms "clause," "subclause," "paragraph," and "annex" in this document are to be interpreted as 163 described in ISO/IEC Directives, Part 2, Clause 6.

- 164 The terms "normative" and "informative" in this document are to be interpreted as described in <u>ISO/IEC</u>
- 165 <u>Directives, Part 2</u>, Clause 3. In this document, clauses, subclauses, or annexes labeled "(informative)" do 166 not contain normative content. Notes and examples are always informative elements.

### 167 **4** Symbols and abbreviated terms

- 168 The following symbols and abbreviations are used in this document.
- 169 **4.1** 170 **ACK**
- 171 acknowledge
- 172 **4.2**
- 173 **ARP**
- 174 Address Resolution Protocol
- 175 **4.3**
- 176 **ASF**
- 177 Alert Standard Format
- 178 **4.4**
- 179 **BMC**
- 180 baseboard management controller
- 181 **4.5**
- 182 **EEPROM**
- 183 Electrically Erasable Programmable Read-Only Memory
- 184 **4.6**
- 185 **EID**
- 186 endpoint identifier
- 187 **4.7**
- 188 **I**<sup>2</sup>**C**
- 189 Inter-Integrated Circuit
- 190 **4.8**
- 191 **I/O**
- 192 input/output
- 193 **4.9**
- 194 **IPMB**
- 195 Intelligent Platform Management Bus
- 196 **4.10**
- 197 **IPMI**
- 198 Intelligent Platform Management Interface
- 199 **4.11**
- 200 **kHz**
- 201 kilohertz

| 202 | 4.12                                              |
|-----|---------------------------------------------------|
| 203 | LSb                                               |
| 204 | least significant bit                             |
| 205 | 4.13                                              |
| 206 | LSB                                               |
| 207 | least significant byte                            |
| 208 | 4.14                                              |
| 209 | max                                               |
| 210 | maximum                                           |
| 211 | 4.15                                              |
| 212 | МСТР                                              |
| 213 | Management Component Transport Protocol           |
| 214 | 4.16                                              |
| 215 | min                                               |
| 216 | minimum                                           |
| 217 | 4.17                                              |
| 218 | ms                                                |
| 219 | millisecond                                       |
| 220 | 4.18                                              |
| 221 | MSB                                               |
| 222 | most significant byte                             |
| 223 | 4.19                                              |
| 224 | MTU                                               |
| 225 | Maximum Transmission Unit                         |
| 226 | 4.20                                              |
| 227 | NACK                                              |
| 228 | not acknowledge                                   |
| 229 | 4.21                                              |
| 230 | PCI                                               |
| 231 | peripheral component interconnect                 |
| 232 | 4.22                                              |
| 233 | PCIe®                                             |
| 234 | PCI Express™                                      |
| 235 | 4.23                                              |
| 236 | PEC                                               |
| 237 | packet error code                                 |
| 238 | 4.24                                              |
| 239 | PMCI                                              |
| 240 | Platform Management Component Intercommunications |

| 241                                                         | 4.25                                                                                                |
|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| 242                                                         |                                                                                                     |
| 243                                                         |                                                                                                     |
| 240                                                         |                                                                                                     |
| 244                                                         | -                                                                                                   |
| 245                                                         | rsvd                                                                                                |
| 246                                                         | reserved (not case sensitive)                                                                       |
| 247                                                         | 4.27                                                                                                |
| 248                                                         | SCL                                                                                                 |
| 249                                                         | serial clock                                                                                        |
| 250                                                         | 4.28                                                                                                |
| 251                                                         | SDA                                                                                                 |
| 252                                                         | serial data                                                                                         |
|                                                             | 4.00                                                                                                |
| 253                                                         | 4.29                                                                                                |
| 253<br>254                                                  |                                                                                                     |
| 254                                                         |                                                                                                     |
| 254                                                         | sec<br>second                                                                                       |
| 254<br>255<br>256                                           | sec<br>second                                                                                       |
| 254<br>255<br>256<br>257                                    | sec<br>second<br>4.30                                                                               |
| 254<br>255<br>256<br>257                                    | sec<br>second<br>4.30<br>SEEPROM<br>serial EEPROM                                                   |
| 254<br>255<br>256<br>257<br>258                             | sec<br>second<br>4.30<br>SEEPROM<br>serial EEPROM<br>4.31                                           |
| 254<br>255<br>256<br>257<br>258<br>259                      | sec<br>second<br>4.30<br>SEEPROM<br>serial EEPROM<br>4.31                                           |
| 254<br>255<br>256<br>257<br>258<br>259<br>260               | sec<br>second<br>4.30<br>SEEPROM<br>serial EEPROM<br>4.31<br>SMBus                                  |
| 254<br>255<br>256<br>257<br>258<br>259<br>260<br>261        | sec<br>second<br>4.30<br>SEEPROM<br>serial EEPROM<br>4.31<br>SMBus<br>System Management Bus<br>4.32 |
| 254<br>255<br>256<br>257<br>258<br>259<br>260<br>261<br>262 | sec<br>second<br>4.30<br>SEEPROM<br>serial EEPROM<br>4.31<br>SMBus<br>System Management Bus<br>4.32 |

## 265 **5 Conventions**

266 The conventions described in the following clauses apply to this specification.

### 267 5.1 Reserved and unassigned values

- 268 Unless otherwise specified, any reserved, unspecified, or unassigned values in enumerations or other 269 numeric ranges are reserved for future definition by the DMTF.
- Unless otherwise specified, numeric or bit fields that are designated as reserved shall be written as 0
   (zero) and ignored when read.

### 272 5.2 Byte ordering

Unless otherwise specified, byte ordering of multibyte numeric fields or bit fields is "Big Endian" (that is,
 the lower byte offset holds the most significant byte, and higher offsets hold lesser significant bytes).

### **6 MCTP over SMBus/I<sup>2</sup>C transport**

The MCTP over SMBus/I<sup>2</sup>C transport binding defines how MCTP packets are delivered over a physical SMBus or I<sup>2</sup>C medium using SMBus transactions. This includes how physical addresses are used, how

fixed addresses are accommodated, how physical address assignment is accomplished for hot-plug or other devices that require dynamic physical address assignment, and how MCTP support is discovered.

280 Timing specifications for bus and MCTP control operations are also given, and a "fairness" protocol is

defined for the purpose of avoiding deadlock and starvation/lockout situations among MCTP endpoints.

282 The binding has been designed to be able to share the same bus as devices communicating using earlier

- 283 SMBus/I<sup>2</sup>C management protocols such as Alert Standard Format (ASF) and IPMI, and with vendor-
- specific devices using SMBus/I<sup>2</sup>C protocols. The specifications can also allow a given device to
   incorporate non-MCTP SMBus functions alongside MCTP. This is described in more detail in 6.21.

### 286 6.1 Terminology

According to <u>SMBus</u>, SMBus devices are categorized as follows, where Address Resolution Protocol (ARP) refers to the SMBus Address Resolution Protocol (a dynamic slave address assignment protocol) and UDID refers to a "unique device identifier", a 128-bit value that a device uses during the ARP process to uniquely identify itself. Because these protocols are implemented with command transactions that are run on top of the SMBus physical specification, it is possible to use these protocols on devices that support an I<sup>2</sup>C physical interface.

### **ARP-capable**

294SMBus term indicating a device that supports all SMBus ARP commands with the exception of295the optional Host Notify command. The slave address is assignable. The device supports both296Reset commands.

### • Fixed and Discoverable

298SMBus term indicating a device supports the Prepare to ARP, directed Get UDID, general Get299UDID, and Assign Address commands. The slave address is fixed; the device will accept the300Assign Address command but will not allow address reassignment. The device supports both301Reset commands.

### 302 • Fixed - Not Discoverable

303SMBus term indicating a device supports the directed Get UDID command. The slave address304is fixed.

### 305 • Non-ARP-capable

306SMBusterm indicating a device does not support any ARP commands. The slave address is307fixed.

### 308 • Fixed Address

For this specification, this term is be used to refer to any device that uses a fixed slave address,
without distinguishing whether it is "Fixed and Discoverable", "Fixed, not Discoverable", or
"Non-ARP-capable".

### 312 6.2 Transport binding use with I<sup>2</sup>C

- 313 The transport binding defined in this specification has also been designed to be able to work with
- 314 standard-mode fast-mode (400 kHz) and Fast-mode Plus (1MHz) I<sup>2</sup>C buses that use 7-bit addressing; 10-
- 315 bit addressing is not supported. This binding has not been specified for use with high-speed I<sup>2</sup>C
- 316 specifications.

### 317 6.3 MCTP packet encapsulation

All MCTP transactions are based on the SMBus Block Write bus protocol. The first 8 bytes make up the

319 packet header. The first three fields—Destination Slave Address, Command Code, and Length—map 320 directly to SMBus functional fields. The remaining header and payload fields map to SMBus Block Write

321 "Data Byte" fields, as indicated in Figure 1. Hence, the inclusion of the Source Slave Address in the

header is specified by <u>MCTP</u> rather than <u>SMBus</u>. This is done to facilitate addressing required for

323 establishing communications back to the message originator.



324

325

### Figure 1 – MCTP over SMBus/I<sup>2</sup>C packet format

326

### Table 1 – Packet header field descriptions

| Byte | Block Write<br>Field(s) | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1    | Slave Address<br>Wr     | [7:1] SMBus Destination Slave Address: The slave address of the target device for the local SMBus link                                                                                                                                                                                                                                                                                                                                                                                 |  |
|      |                         | [0]: SMBus R/W# bit: Shall be set to 0b as all MCTP messages use SMBus write transactions.                                                                                                                                                                                                                                                                                                                                                                                             |  |
| 2    | Command Code            | Command Code: SMBus Command Code                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|      |                         | All MCTP over SMBus messages use a command code of $0 \times 0F$ .                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| 3    | Byte Count              | Byte Count: Byte count for the SMBus Block Write protocol transaction that is carrying the MCTP packet content.                                                                                                                                                                                                                                                                                                                                                                        |  |
|      |                         | This value is the count of bytes that follow the Byte Count field up to,<br>but not including, the PEC byte. For example, if the MCTP packet<br>payload length (starting with byte 9) is 64 bytes, the value in the Byte<br>Count field would be 69. (The count of 69 accounts for 64 bytes of<br>MCTP packet payload plus the five bytes [bytes 4 through 8,<br>inclusive] that comprise the bytes of the SMBus-specific header and<br>MCTP header that follow the Byte Count field.) |  |

| Byte          | Block Write<br>Field(s)   | Description                                                                                                                                                                                                                   |  |
|---------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 4             | Data Byte 1               | SMBus Source Slave address                                                                                                                                                                                                    |  |
|               |                           | [7:1] : For the local SMBus link, the slave address of the source device.                                                                                                                                                     |  |
|               |                           | [0]: This bit shall be set to 1b. The value enables MCTP to be differentiated from IPMI over SMBus and IPMB (IPMI over I <sup>2</sup> C) protocols.                                                                           |  |
| 5             | Data Byte 2               | [7:4] MCTP reserved: This nibble is reserved for definition by the <u>MCTP</u><br><u>Base Specification</u> .                                                                                                                 |  |
|               |                           | [3:0] MCTP header version:                                                                                                                                                                                                    |  |
|               |                           | Set to 0001b for MCTP devices that are conformant to the <u>MCTP</u><br><u>Base Specification</u> 1.0 and this version of the SMBus transport<br>binding.                                                                     |  |
|               |                           | All other values = Reserved.                                                                                                                                                                                                  |  |
| 6             | Data Byte 3               | Destination endpoint ID (*)                                                                                                                                                                                                   |  |
| 7             | Data Byte 4               | Source endpoint ID (*)                                                                                                                                                                                                        |  |
| 8             | Data Byte 5               | [7] SOM: Start Of Message flag (*)                                                                                                                                                                                            |  |
|               |                           | [6] EOM: End Of Message flag (*)                                                                                                                                                                                              |  |
|               |                           | [5:4] Packet sequence number (*)                                                                                                                                                                                              |  |
|               |                           | [3] Tag Owner (TO) bit (*)                                                                                                                                                                                                    |  |
|               |                           | [2:0] Message tag (*)                                                                                                                                                                                                         |  |
| 9             | Data Byte 6               | [7] IC: Integrity Check bit (*)                                                                                                                                                                                               |  |
|               |                           | [6:0] Message type (*)                                                                                                                                                                                                        |  |
| 10:N-1        | Data Bytes 7:M            | Message header and data (*)                                                                                                                                                                                                   |  |
| Ν             | PEC                       | Packet error code (PEC): The PEC as defined in the <u>SMBus 2.0</u><br><u>Specification</u> . All MCTP transactions shall include a PEC byte. The PEC byte shall be transmitted by the source and checked by the destination. |  |
| (*) Indicates | a field that is defined b | y the <u>MCTP Base Specification</u> .                                                                                                                                                                                        |  |

### 327 6.4 Bridges and packet formatting

As an MCTP packet travels through a bridge from one SMBus/I<sup>2</sup>C port to another, the bridge leaves all packet header and message header and data fields alone with the exception of the source and destination slave address, which shall be modified to route across the intended bus/link. When an MCTP bridge forwards a message from an input port to an output port, it replaces the destination slave address with the targeted slave on the destination bus, and replaces the source slave address with the bridge's slave address.

The MCTP SMBus/I<sup>2</sup>C bridge shall re-calculate the PEC byte to account for changes in the source and destination slave address fields.

A similar process is used when bridging between different media. The physical addressing and header
 information gets changed by the bridge to match the requirements of the target bus, and any packet-level
 integrity check information is also updated.

### 339 **6.5 MCTP support discovery**

All SMBus devices that support an MCTP endpoint and the SMBus Get UDID command for a particular SMBus/l<sup>2</sup>C interface (that is, devices with ARP-capable, fixed and discoverable, or fixed-not discoverable interfaces) are required to have their MCTP support discoverable through the Get UDID command. To do this, endpoints shall return a value of 1b in bit 5 (the ASF bit) in the Interface field in the Get UDID

344 command.

Once support for ASF has been indicated, an MCTP control message (for example, Get MCTP Version Support) can be issued to the device to determine whether it supports MCTP. The SMBus command byte for MCTP packets uses a value that has been allocated by the DMTF for MCTP use and does not overlap values used for ASF. This enables older devices that indicate ASF support to be queried for MCTP support without conflict. This is described in more detail in 6.6. Devices that do not support the Get UDID command will need to have their support for MCTP configured into the bus owner as described in 6.6.

I<sup>2</sup>C devices can also support the SMBus protocols and commands for being an ARP-able device that is
 also discoverable as an MCTP device. This is required for hot-plug I<sup>2</sup>C devices using MCTP.

### 353 6.6 Support for fixed-address devices

- MCTP bus owners shall include nonvolatile options to record the addresses used by fixed-address devices on SMBus/I<sup>2</sup>C buses that they own, and which of those devices support MCTP.
- For non-MCTP devices, the MCTP bus owner needs this information to know which fixed addresses to avoid when performing SMBus ARP for the bus. (Alternatively, the bus owner could be configured with a range of SMBus slave addresses that the bus owner is allowed to allocate from.)
- For MCTP devices, the bus owner needs this information to perform EID assignment and, if the bus owner is also an MCTP bridge, routing table initialization and operation.
- 361 For fixed-address MCTP devices that do not support the Get UDID command (that is, non-ARP-capable
- 362 devices), the bus owner needs to also be configured with information that identifies the device as 363 supporting MCTP.
- 364 For fixed-address devices that support the <u>SMBus</u> Get UDID command (that is, devices with ARP-
- 365 capable, Fixed and Discoverable, or Fixed-Not Discoverable SMBus interfaces) the bus owner can either
- discover whether the device supports MCTP by using the discovery approach described in 6.5, or could
- have this information configured at the same time that the slave address information for the fixed-addressdevice is provided.
- 369 It is recommended that general-purpose devices that act as MCTP bus owners allow being configured to
   370 support at least 16 different fixed-address devices for each SMBus/I<sup>2</sup>C bus they own. This number would
   371 include both MCTP and non-MCTP devices.

### 372 6.7 Supported media

This physical transport binding has been designed to work with the media specified in <u>DSP0239</u>. Table 2

- 374 quotes relevant physical media identifiers from <u>DSP0239</u>. In case of any contradiction <u>DSP0239</u> shall be 375 used as the normative definition. Use of this binding with other types of physical media is not covered by
- 376 this specification. At least one of the physical media identifiers listed in Table 2 shall be supported to 377 comply with this specification.

### Table 2 – Supported media

| Physical Media Identifier | Description                                 |
|---------------------------|---------------------------------------------|
| 0x01                      | SMBus 100 kHz compatible                    |
| 0x02                      | SMBus + I <sup>2</sup> C 100 kHz compatible |
| 0x03                      | I <sup>2</sup> C 100 kHz compatible         |
| 0x04                      | I <sup>2</sup> C 400 kHz compatible         |
| 0x05                      | SMBus + I <sup>2</sup> C 1 MHz compatible   |

### **6.8** Physical address format for MCTP control messages

380 The address format shown in Table 3 shall be used for MCTP control commands that require a physical

- 381 address parameter to be returned for a bus that uses this transport binding with one of the supported
- 382 media types listed in 6.7. This includes commands such as the Resolve Endpoint ID, Routing Information
- 383 Update, and Get Routing Table Entries commands.

384

| Table 3 – | Physical | address | format |
|-----------|----------|---------|--------|
|           |          |         |        |

| Format Size | Layout and Description |                    |
|-------------|------------------------|--------------------|
| 1 hute      | [7:1]                  | slave address bits |
| 1 byte      | [0]                    | 0b                 |

### 385 6.9 Get endpoint ID medium-specific information

The medium-specific information as shown in Table 4 shall be used for the medium-specific Information field returned in the response to the Get Endpoint ID MCTP control message.

388

### Table 4 – Medium-specific information

| Description        |                                            |  |
|--------------------|--------------------------------------------|--|
| [7:1]              | [7:1] reserved                             |  |
| [0]                | 0] fairness arbitration support (see 6.13) |  |
| 0b = not supported |                                            |  |
|                    | 1b = supported                             |  |

### 389 6.10 Bus owner address

390 In order to be the target of the SMBus Notify ARP Master protocol transaction the MCTP bus owner shall

391 be configurable to be accessed at the SMBus host slave address. This configuration does not need to be

- used if the bus implementation does not include any MCTP devices that require dynamic address
   assignment of their slave address. For more information, see 6.11.4.
- 394 The bus owner may use a different, second slave address for all other MCTP communication functions.

### 395 **6.11 Bus address assignment**

- 396 This clause describes the configuration, setup, and operation of communication between MCTP
- 397 endpoints using SMBus/I<sup>2</sup>C as the communication medium.

#### 398 6.11.1 Slave addresses

399 Each device on SMBus/I<sup>2</sup>C shall have a slave address to be the target of transactions by bus masters.

400 The MCTP transport protocol solely utilizes Master Write transactions to transfer MCTP packets between 401

MCTP endpoints. For endpoint "A" to send an MCTP packet to endpoint "B", endpoint A shall master the bus and issue a Block-Write transaction to the slave address of endpoint B. Similarly, for endpoint B to 402

403 send an MCTP packet to endpoint A, it shall master the bus and issue a Block-Write transaction to the

404 slave address of endpoint A. Thus, bi-directional transfer of MCTP packets requires that both sides of the

405 communication have slave addresses.

406 Device support for slave addresses can be of two general types: fixed or assignable. Devices with assignable addresses (also referred to as "ARP-capable" or "ARP-able") can use the SMBus ARP. The 407 entity that assigns slave addresses to ARP-able devices is referred to as the "ARP master". 408

409 A bus can include a mix of fixed-address and ARP-able devices. Most fixed-address devices do not

410 include a discovery mechanism, and neither SMBus nor I<sup>2</sup>C require one. Therefore, for a generic bus

implementation that support ARP-able devices (such as SMBus to PCI/PCIe connectors) the ARP master 411

412 needs to know what ranges of addresses are being used for fixed-address devices so that it doesn't give

413 an ARP-able device an address that conflicts with a fixed-address device.

This transport binding allows for non-MCTP devices (both fixed address and ARP-able) to reside on the 414 same bus segment used for MCTP devices. The use and assignment of slave addresses shall therefore 415 416 be compatible with pre-existing devices. To accomplish this, the following approach is used for managing

417 devices on a bus that supports MCTP.

#### 6.11.2 Well-known and reserved slave addresses 418

419 The SMBus and I<sup>2</sup>C specifications define certain slave addresses that should either be avoided by

420 devices or are reserved (not to be used as a general device slave address) because those addresses are related to functions that are used by MCTP. These addresses are listed in Table 10. 421

#### 6.11.3 Fixed address recommendations for device manufacturers 422

423 MCTP may be used within a typical computer system application where the motherboard/baseboard may 424 come from one supplier, the chassis from another supplier, and possibly add-in modules from yet another. 425

426 Referring to Table 11, it is thus recommended that devices that use fixed addresses and are targeted for

427 uses that can include baseboard (B), chassis/system (C), and add-in (A) applications are configurable to

428 cover for at least three different "B" addresses, at least three different "C" addresses, and at least two

different "A" addresses to help avoid address conflicts in those applications. 429

#### 430 6.11.4 Dynamic address assignment (SMBus ARP) support

431 MCTP buses that support connections to standard PCI/PCIe add-in cards are required by the PCI

specifications to support SMBus ARP (be ARP-capable) to allow the devices to be dynamically assigned 432

addresses to avoid address conflicts and eliminate the need for manual configuration of addresses. 433

434 Figure 2 presents an overview of the address assignment process.

#### 6.11.5 Devices supporting multiple interfaces 435

436 Devices that support multiple, separate SMBus or I<sup>2</sup>C interfaces where the interfaces are intended to be 437 connected to the same bus shall meet the following requirements:

438 The interfaces shall be either be ARP-capable or be fixed-address interfaces that are configured • to use a different slave address for each interface. 439

- If the interfaces support SMBus ARP, (as either ARP-able or ARP-enumerable devices) a
   different SMBus UDID shall be used for each SMBus ARP-able interface.
- 442 NOTE Devices that have internal hardware interfaces that may be implemented as separate blocks but are designed to share a slave address are not considered to have separate interfaces in this context.

### DSP0237



\* It is possible that hot-plug devices may have been inserted after the Prepare to ARP command was initially sent out.

### Figure 2 – Address assignment flow

#### 446 6.11.6 MCTP requirements on SMBus ARP master support

447 If the bus supports ARP-able devices, MCTP requires that each bus shall have a controller that operates as the ARP master and assigns slave addresses to all ARP-able devices on the segment. Because the 448 449 MCTP bus owner shall know the physical addresses of ARP-able devices that support MCTP, the ARP 450 master role will typically be handled by the same device that serves as the MCTP bus owner.

451 If a different physical device than the device holding the bus owner functions as the ARP master, there 452 shall be a mechanism to communicate the address assignment information to the bus owner function. 453 The mechanism for this is not specified by MCTP.

454 Only one controller is allowed to function as the ARP master for the segment at a given time. The ARP master function is allowed to fail-over or be transferred to another controller. The mechanism for this 455 capability, if provided, is not specified by MCTP. 456

#### 6.11.7 Recommendations on ARP master allocation of slave addresses 457

458 For PCI and PCI Express™ (PCIe) bus implementations, it is recommended that, by default, the ARP master only assigns addresses to ARP-able devices from the "B" range. This is because the PCI 459 460 slots/connectors themselves are most commonly implemented as part of the board set.

461 Device manufacturers of controllers that function as ARP masters should provide a mechanism to enable system integrators to either configure which fixed addresses that ARP should avoid, or a pool of non-462

- 463 conflicting addresses from which ARP can draw.
- 464 For PCI and PCIe SMBus implementations, the ARP master should be able to assign at least two addresses for each PCI connector on the segment. 465

#### 6.11.8 MCTP requirements on hot-pluggable bridges using SMBus 466

467 Hot-pluggable MCTP devices that include bridging functionality are required to have static, pre-assigned, 468 SMBus UDIDs. This is because it is considered a more robust and reliable mechanism than randomly 469 generated UDIDs, and because it simplifies tracking and managing MCTP device hot-add and hot-470 removal.

471 If devices regenerate their UDIDs on hot-plug, the MCTP bus owner/ARP master cannot rely on the UDID 472 to determine whether a device was newly added to the system. When a hot-plug device includes MCTP 473 bridging functionality, the bus owner shall be able to allocate the device a range of EIDs from a fixed pool 474 of IDs. Thus, it is important for the bus owner to be able to determine which devices have been removed

475 so that any EIDs it had given out can be returned to the pool.

476 It is straightforward for the ARP master to re-enumerate the UDIDs on the bus and determine which

477 UDIDs (if any) are no longer present (re-enumeration is a natural fallout of the ARP process). If there are

478 MCTP devices without fixed UDIDs in the mix, however, the bus owner would need to take additional steps to check to see which devices had already been allocated EIDs to determine by elimination which 479

480 ranges, if any, had become freed. With fixed UDID, the bus owner can track which EIDs have been

481 allocated to which UDIDs and thereby determine which have been freed by a hot swap by just re-

enumerating the UDIDs. 482

#### 6.12 SMBus/I<sup>2</sup>C considerations for MCTP messages 483

484 The following applies to MCTP messages on SMBus regardless of their message type. Note that MCTP 485 messages require Block Write byte count sizes that exceed limits specified by SMBus. Additional 486 restrictions on MCTP packets over what the SMBus and I<sup>2</sup>C allow are given in 6.3 and 6.18.

### 487 6.12.1 Slave address ACKs/NACKs

- 488 Per <u>SMBus</u> and <u>I<sup>2</sup>C</u>, the NACK of a slave address indicates the physical absence of the device interface.
- 489
   Devices are therefore required to always ACK their slave addresses. This includes ACK'ing slave addresses used for ARP if the device is ARP-able or ARP-enumerable.
- An MCTP device *shall* ACK its slave address(es) when the R/W bit on the slave address is 0.

### 492 6.12.2 Clock stretching for non-addressed devices

MCTP devices that are monitoring the bus as slaves and do not have a slave address that matches the
 transaction shall not clock stretch past the ACK bit for the slave address byte. This requirement only
 applies to MCTP packet transactions. It does not apply to non-MCTP-defined messages or transactions,
 such as those used for SMBus ARP.

### 497 6.13 Fairness arbitration

### 498 **6.13.1 General**

The following clauses describe an extension to the SMBus/I<sup>2</sup>C arbitration mechanism for device ports that are used with MCTP. The extensions define a 'fairness' mechanism that helps ensure that ports that are arbitrating for access to the bus will eventually get access and will not be locked out of access by other MCTP ports that are using the bus.

- 503NOTEFairness arbitration only applies for messages using the MCTP base protocol. SMBus messages such as504Host Notify are not required to use fairness arbitration.
- 505 This mechanism works as follows:
- An MCTP port that wins bus arbitration (per <u>SMBus</u> or <u>I<sup>2</sup>C</u>) for a given transaction shall wait
   until it detects a particular bus idle interval before the device can again attempt to arbitrate for
   the bus. This is referred to as the device waiting to detect the "FAIR\_IDLE" condition.
- Once the port has succeeded in detecting the FAIR\_IDLE condition, it can attempt to get on the bus and no longer needs to wait to detect the FAIR\_IDLE condition. The port can continue to attempt to access the bus without waiting for FAIR\_IDLE until the next time the port wins arbitration. After winning arbitration, the port shall again wait to detect the FAIR\_IDLE condition before it can attempt to get on the bus.
- 514 With this approach, all ports that lose arbitration will eventually get a turn at accessing the bus, because 515 any ports that win arbitration will need to wait until a bus idle interval is detected, while those that have 516 lost arbitration will not need to wait.
- 517 For this to work, endpoints shall be able to do two things:
- Be able to recognize the FAIR\_IDLE condition. Ports that are waiting to detect a FAIR\_IDLE
   condition shall recognize that no other port has made the bus become busy within a particular
   window of time (T<sub>IDLE\_WINDOW</sub>) after the bus becomes free.

5212)Ports that have not won arbitration shall be able to issue a START condition soon enough after522the bus becomes free so that a bus busy condition is seen by ports that are waiting to detect a523FAIR\_IDLE condition. To ensure this condition is met, START shall be issued by the port within524a particular window of time (T<sub>START\_WINDOW</sub>) after the bus becomes free.

525NOTEThere is actually no explicit indication in SMBus or I<sup>2</sup>C that arbitration has been won. Instead, what the<br/>master detects is that it was able to access the bus and did not have a collision (lose arbitration) with<br/>another master. For this specification, this is referred to as *winning arbitration*. Because of the way<br/>arbitration works, an MCTP endpoint that is transmitting as a master onto the bus will know that it has won<br/>arbitration if it is able to transmit from the destination slave address byte through the end of the source slave<br/>address byte (byte 4) without receiving a collision or NACK.

### 531 6.13.2 Deadlock avoidance with fairness arbitration

532 A device that wins arbitration but is subsequently NACK'd for its write transaction shall return to waiting 533 for the FAIR\_IDLE period before it can attempt the transaction again.

### 534 6.13.3 Fairness arbitration support

535 Bridges and endpoints should support fairness arbitration. An endpoint's support for fairness arbitration 536 shall be reported through the medium-specific Information field in the response to the Get Endpoint ID

537 MCTP control message.

### 538 6.13.4 Bus busy sampling requirements for fairness arbitration

It is atypical and unlikely that the bus will go busy and then free again within T<sub>IDLE\_WINDOW</sub>. This is because T<sub>IDLE\_WINDOW</sub> is shorter than the time required to send one byte on the bus. Thus, this condition would only occur on an error or under a usage of the bus that is not legal within the specifications. Therefore, an implementation is not required to continuously check the bus busy status during the entire duration of T<sub>IDLE\_WINDOW</sub> (though this is recommended). An implementation is allowed to check the bus busy status

only at the conclusion of the T<sub>IDLE\_WINDOW</sub> interval that is measured by the device.

### 545 **6.14 NACK window**

546 An endpoint/bridge is required to NACK an incoming packet if the device does not have input buffer

547 space available for the packet. For the NACK to be recognized by the transmitter as the NACK for a

548 packet retry, the first NACK bit shall be issued no earlier than byte two (that is, the Command Code byte)

and no later than byte 8 (the MCTP flags byte). These bytes are represented by the bold outlined bytes in

550 Figure 3 below. After the first NACK has been issued any subsequent bytes that are received for the

551 packet shall also be NACK'd until a START, STOP, or bus free condition is detected.

552 An endpoint/bridge that NACKs a packet shall continue to NACK any remaining bytes for the transaction 553 until it recognizes the next START or STOP condition on the bus.

554



555



### Figure 3 – Allowed byte range for first NACK'd byte

6.15 Fairness arbitration requirements for MCTP bridges

#### 559 MCTP bridges that support fairness arbitration shall meet the following requirements: 560 The bridge shall support FAIR IDLE detection and implement the corresponding fairness policy 561 separately for each port on the bridge. Upon device power up or initialization, a port does not need to detect a FAIR\_IDLE condition 562 before first attempting to access the bus. 563 A bridge that loses arbitration when attempting to transmit shall continue to retry the transaction 564 • when the bus becomes free for up to PN2 retries (see Table 8). If the retry limit is reached, the 565 bridge shall drop the packet data. 566 567 A bridge that receives a NACK when attempting to transmit to a given physical address shall • continue to retry the transaction when the bus becomes free for up to PN2 retries. The bridge 568 will return to attempting to arbitrate for the bus as described in the preceding requirement, 569 570 restarting its number of arbitration retries. If the retry limit is reached, the bridge shall drop the packet data. 571 572 An MCTP bridge shall provide dedicated input buffer space per port. The minimum input buffer • size is large enough to store one full baseline MTU-sized MCTP packet. It is recommended, but 573 574 not required, that a bridge also implement a dedicated output buffer per port, sized to store at least one full baseline MTU-sized MCTP packet. 575 If the MCTP bridge is the target of an MCTP packet and it does not have enough buffer space in 576 • its input buffer to store the full packet, it shall NACK the packet. If the bridge has an output 577 packet to transmit on that same port, it shall be able to issue a START within TSTART WINDOW after 578 579 issuing the retry NACK. A bridge is required to drop a received packet if it finds that the packet error code (PEC) byte for 580 • the transaction is incorrect. 581 582 An MCTP bridge is not allowed to perform "connected" transactions where the decision to ACK • or NACK an incoming packet is dependent on the bridge's ability to acquire the destination bus 583 prior to accepting the packet. 584 585 MCTP bridges are required to implement "store and forward" packet processing. That is, once a • bridge has accepted a packet for routing, it shall retain that packet until it can successfully 586 transmit it onto the target bus (except when running out of retries when trying to access the 587 588 target bus, or upon receiving a packet for a bus that is unavailable or an endpoint that is not 589 present.) 590 A bridge cannot make the acceptance of a receive packet on its upstream port (port that • 591 connects to a bus that is not owned by the bridge itself) conditional on its ability to transmit a 592 packet on its upstream port. This requirement does not apply to a downstream port on a bridge 593 (that is, a downstream port may elect to NACK an incoming packet to allow the bridge to transmit from that port). This requirement is to help avoid deadlock situations if a bridge is 594 required to route a packet back onto the bus from which the packet came. 595 596 A bridge that receives a NACK while it is performing a Master Write operation is not required to • 597 immediately conclude the Master Write operation and drop off the bus. The bridge may continue 598 the write operation through its conclusion. In either case, the master shall always conclude its 599 transaction with a STOP condition, unless some other device on the bus first produces a START or STOP condition. The latter situation is an erroneous condition on the bus, but bridges 600 shall be able to handle it. Devices shall always recognize START and STOP conditions 601 602 regardless of the transaction or bit position on which they occur.

### 603 **6.16 Fairness arbitration requirements for non-bridge endpoints**

Non-bridge/bus owner endpoints ("simple endpoints") are required to implement the MCTP fairness arbitration extensions (when enabled) as follows:

- The endpoint's port shall support FAIR\_IDLE detection and implement the corresponding fairness policy.
- Upon device power up or initialization, the endpoint does not need to detect a FAIR\_IDLE condition before first attempting to access the bus.
- The endpoint cannot make the acceptance of a receive packet conditional on its ability to transmit a packet (that is, a simple endpoint shall not NACK incoming packets because it is trying to send an outgoing packet).
- 613 Meeting this requirement may require the endpoint to have separate transmit and receive 614 buffers. This is the recommended implementation.
- 615If a device is severely limited in buffer space and cannot allocate separate space for both616transmit and received data, options are for the endpoint to allow its buffer to be over-written by617the receive packet, or in some cases the endpoint may elect to do a dummy receive of the618incoming packet (that is, ACK the incoming bytes, but internally drop them as they are coming619in.)
- Higher layer protocols shall be used to handle the case when the endpoint is targeted by more
   messages than it can process. The buffering requirement for the MCTP Control Protocol
   messages is defined in the MCTP Base Specification. Buffering requirements for other message
   types are defined in the respective specifications for the message type.
- An endpoint is allowed to NACK a packet if it is temporarily unable to accept it (for example, because of an *input* buffer-full condition). This should typically only occur if the endpoint is the target of packets from more than one source endpoint.
- There is no direct limit of how long a non-bridge endpoint is allowed to successively NACK
   incoming packets. However, there are limits on how many packet-level retries a transmitter will
   attempt before it drops the transmitted packet, as well as message type-specific limits on how
   long and how many times a given message will be retried.
- If an endpoint has an output transmit packet and it NACKs an input receive packet from lack of input buffer space, it shall be able to issue a START condition to transmit the output packet within T<sub>START\_WINDOW</sub> after the bus becomes free, unless the endpoint is waiting to detect T<sub>IDLE</sub>.
- An endpoint that receives a NACK while it is performing a Master Write operation is not required to immediately conclude the Master Write operation and drop off the bus. The endpoint may continue the write operation through its conclusion. In either case, the master shall always conclude its transaction with a STOP condition, unless some other device on the bus first produces a START or STOP condition. The latter situation is an erroneous condition on the bus, but bridges shall be able to handle it. Devices shall always recognize START and STOP conditions regardless of the transaction or bit position on which they occur.
- Endpoints that are NACK'd or lose arbitration shall retry transaction for PN1 retries (see Table 8).

### 643 6.17 Fairness arbitration timing

Figure 4, Table 5, and Table 6 present the specifications for the timing intervals for fairness arbitration on
 SMBus and I<sup>2</sup>C relative to the data (SDA) signal. Refer to <u>SMBus</u> and <u>I<sup>2</sup>C</u> for the additional specifications
 on the relationship between SCL and SDA for STOP, bus idle, and START conditions.



647



Figure 4 – Fairness arbitration timing measurement for SMBus and I<sup>2</sup>C

Table 5 – Fairness arbitration timing values for 100 kHz SMBus/l<sup>2</sup>C

| Symbol           | Min | Max | Unit | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|------------------|-----|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| T <sub>BUF</sub> | 4.7 | -   | μs   | Per <u>SMBus</u> 100 kHz specification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| Tstart_window    | _   | 20  | μs   | Window of time within which a device that is not waiting to detect a FAIR_IDLE condition shall generate START if the device is retrying to gain bus access after losing arbitration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| TIDLE_WINDOW     | 30  | 60  | μs   | Window of time within which a device that is waiting to detect a FAIR_IDLE condition shall not detect a bus busy condition. A FAIR_IDLE condition exists when bus busy is not detected within this interval.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| Tidle_delay      | 31  | _   | μs   | A device that detects FAIR_IDLE condition shall wait this delay before attempting to generate START. This delay accommodates the difference between the $T_{IDLE_WINDOW}$ intervals implemented by different devices on the bus, plus additional time to accommodate bus skews between devices that are generating START and devices that are monitoring for it. This guarantees that one party that has detected $T_{IDLE_WINDOW}$ does not generate START before other devices that are detecting FAIR_IDLE have completed checking for their $T_{IDLE_WINDOW}$ . Otherwise, the other devices would not see a FAIR_IDLE condition even though one occurred. (Therefore $T_{IDLE_DELAY}$ shall be greater than the difference between the $T_{IDLE_WINDOW}$ maximum and minimum.) |  |

Table 6 – Fairness arbitration timing values for 400 kHz l<sup>2</sup>C

| Symbol        | Min | Max | Unit | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|---------------|-----|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| TBUF          | 1.3 | -   | μs   | Per <u>I<sup>2</sup>C</u> 400 kHz specification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| Tstart_window | _   | 4   | μs   | Window of time within which a device that is not waiting to detect a FAIR_IDLE condition shall generate START if the device is retrying to gain bus access after losing arbitration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| TIDLE_WINDOW  | 5   | 20  | μs   | Window of time within which a device that is waiting to detect a FAIR_IDLE condition shall not detect a bus busy condition. A FAIR_IDLE condition exists when bus busy is not detected within this.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| Tidle_delay   | 16  | _   | μs   | Device that detects FAIR_IDLE condition shall wait for this delay before attempting to generate START. This delay accommodates the difference between the $T_{IDLE\_WINDOW}$ intervals implemented by different devices on the bus, plus additional time to accommodate bus skews between devices that are generating START and devices that are monitoring for it. This guarantees that one party that has detected $T_{IDLE}$ does not generate START before other devices that are detecting $T_{IDLE}$ have completed their $T_{IDLE}$ window. Otherwise, the other devices would not see a FAIR_IDLE condition even though one occurred. (Therefore $T_{IDLE\_DELAY}$ shall be greater than the difference between the $T_{IDLE\_WINDOW}$ maximum and minimum.) |  |

651

### Table 7 – Fairness arbitration timing values for 1MHz I<sup>2</sup>C

| Symbol           | Min | Max | Unit | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|------------------|-----|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| T <sub>BUF</sub> | 0.5 | _   | μs   | Per <u>I<sup>2</sup>C</u> 1MHz specification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| TSTART_WINDOW    | _   | 2   | μs   | Window of time within which a device that is not waiting to detect a FAIR_IDLE condition shall generate START if the device is retrying to gain bus access after losing arbitration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| Tidle_window     | 3   | 6   | μs   | Window of time within which a device that is waiting to detect a FAIR_IDLE condition shall not detect a bus busy condition. A FAIR_IDLE condition exists when bus busy is not detected within this interval.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| Tidle_delay      | 3.1 | -   | μs   | Device that detects FAIR_IDLE condition shall wait this delay before attempting to generate START. This delay accommodates the difference between the $T_{IDLE\_WINDOW}$ intervals implemented by different devices on the bus, plus additional time to accommodate bus skews between devices that are generating START and devices that are monitoring for it. This guarantees that one party that has detected $T_{IDLE\_WINDOW}$ does not generate START before other devices that are detecting FAIR_IDLE have completed checking for their $T_{IDLE}$ window. Otherwise, the other devices would not see a FAIR_IDLE condition even though one occurred. (Therefore $T_{IDLE\_DELAY}$ shall be greater than the difference between the $T_{IDLE\_WINDOW}$ maximum and minimum.) |  |

### 652 6.18 MCTP packet timing requirements

653 The timing specifications shown in Table 8 are specific to MCTP packet transfers on SMBus. Timing is 654 specified for a "point-to-point" connection. That is, timing is specified as if there were only two endpoints

in direct communication on the bus. In particular, the timing specifications assume that there is no clock
 stretching that occurs due to other parties on the bus.

### Table 8 – Timing specifications for MCTP packets on SMBus/I<sup>2</sup>C

| Timing Specification                                                                                                        | Symbol                                    | Value                                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Endpoint packet level retries                                                                                               | PN1                                       | 8                                                   | Number of times a non-bridge endpoint shall<br>retry sending an MCTP packet upon receiving a<br>NACK during the specified window (see<br>Figure 3). An endpoint that gets successive<br>NACKs shall do one retry for each NACK up to at<br>least this number of retries. This also includes<br>bridges when bridges are transmitting as an<br>endpoint (as opposed to a bridge transmitting<br>from its routing functionality). |
| Bridge packet level retries                                                                                                 | PN2                                       | 12                                                  | Number of times an MCTP bridge (when<br>transmitting packet for routing) shall retry<br>sending an MCTP packet upon receiving a<br>NACK during the specified window (see 6.14). A<br>bridge shall do one retry on each NACK up to<br>this number.                                                                                                                                                                               |
| Packet transaction originator<br>duration                                                                                   | PT1a                                      | 250 μs per<br>byte <sup>[1]</sup>                   | Overall duration shall be less than the specified<br>interval times the number of bytes in the packet,<br>starting from the byte following the slave byte<br>through and including the PEC byte. Individual<br>data byte transmissions may exceed the<br>specification provided the cumulative duration for<br>the packet is met.                                                                                               |
| Originator slave address byte duration                                                                                      | PT1b                                      | 250 µs <sup>[1]</sup>                               | Amount of time, including any clock stretching,<br>used to transmit the slave address, Wr, and ACK<br>bits on the bus.                                                                                                                                                                                                                                                                                                          |
| Slave-induced clock stretching                                                                                              | PT1c                                      | 250 µs per<br>byte <sup>[1]</sup>                   | MCTP devices that are receiving MCTP packets<br>shall not clock stretch the overall packet more<br>than the specified amount.                                                                                                                                                                                                                                                                                                   |
|                                                                                                                             |                                           |                                                     | Note that MCTP devices may share the bus with<br>non-MCTP SMBus devices that cause clock<br>stretching that exceeds this specification.                                                                                                                                                                                                                                                                                         |
| Master Write transaction if the contro<br>active. It also helps controllers know                                            | oller powers<br>when it is<br>se a contro | s up or initiali<br>acceptable to<br>ller dropped o | in determining when it is acceptable to initiate a<br>zes itself on a bus segment that may already be<br>o continue under conditions where a STOP<br>off the bus due to an error condition. An<br>a or PT2b.                                                                                                                                                                                                                    |
| Time-out waiting for bus free<br>without seeing a STOP condition<br>(Bus free determined by not<br>detecting START or STOP) | PT2a                                      | 100 ms                                              | For controllers that have hardware that can only<br>detect bus-free/busy-busy status by monitoring<br>for START and STOP conditions, the controller<br>can assume the bus is free if PT2a seconds<br>goes by without detecting a START or STOP<br>condition.                                                                                                                                                                    |
|                                                                                                                             |                                           |                                                     | If a START condition is detected, the time-out interval restarts.                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                             |                                           |                                                     | If a STOP condition is detected, the controller can assuming the bus is free following the TBUF interval specified in <u>SMBus</u> .                                                                                                                                                                                                                                                                                            |
|                                                                                                                             |                                           |                                                     | NOTE This interval effectively places an upper limit on<br>the duration of a single transaction. The byte<br>count in an MCTP packet limits the size of the<br>transaction to 260 bytes. 100 ms is more than<br>sufficient to cover this transfer.                                                                                                                                                                              |

| Timing Specification                                                                                                | Symbol       | Value                   | Description                                                                                                                                                                                                                                                     |
|---------------------------------------------------------------------------------------------------------------------|--------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Time-out waiting for bus free<br>without seeing a STOP condition<br>(Bus free determined by data/clock<br>activity) | PT2b         | 50 µs                   | The <u>SMBus</u> specification defines a bus-free (idle) condition as TBUF seconds after a STOP condition, or by the data and clock lines being high for PT2b seconds (where the value for PT2b is taken from $T_{HIGH}$ , max as defined in <u>SMBus</u> ).    |
|                                                                                                                     |              |                         | If a controller has appropriate hardware support,<br>monitoring PT2b and TBUF can be used to<br>determine the bus-free (idle) condition in lieu of<br>PT2a. This is generally the most efficient and<br>highest performance way to detect bus free on<br>SMBus. |
|                                                                                                                     |              |                         | SYSTEM IMPLEMENTATION NOTE: If "bit banged" $I^2C$ devices may be used on the same segment, it is important to ensure that those devices do not drive the clock and data high for more than $T_{HIGH}$ , max seconds during transactions.                       |
| SDA Low TImeout                                                                                                     | PT3          | 2 sec min,<br>5 sec max | Time for a bus owner to monitor the SDA low level for a "Stuck 0" before attempting to clear the condition. (See 6.20.)                                                                                                                                         |
| NOTE 1: Intervals include the ACK bit a                                                                             | associated w | ith the byte.           |                                                                                                                                                                                                                                                                 |

### 658 6.19 MCTP control message timing requirements

The following timing specifications are specific to MCTP control messages on SMBus/I<sup>2</sup>C. Timing is specified for a "point-to-point" connection. That is, timing is specified as if there were only two endpoints in direct communication on the bus. In particular, the timing specifications assume that there is no clock stretching occurs due to other parties on the bus.

663 Response specifications are given assuming that the requester is able to operate at full speed on the bus. 664 That is, clock stretching, if any, is solely generated by the requester.

665 Responses are not retried. A "try" or "retry" of a request is defined as a complete transmission of the 666 MCTP control message.

 Table 9 – Timing specifications for MCTP control messages on SMBus

| Timing Specification      | Symbol   | Min   | Max           | Description                                                                                                                                                                                                                             |
|---------------------------|----------|-------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Endpoint ID reclaim       | Treclaim | 5 sec | _             | Minimum time that a bus owner<br>shall wait before reclaiming the EID<br>for a non-responsive hot-plug<br>endpoint.                                                                                                                     |
| Number of request retries | MN1      | 2     | See<br>descr. | Total of three tries, minimum: the<br>original try plus two retries. The<br>maximum number of retries for a<br>given request is limited by the<br>requirment that all retries shall<br>occur within MT4, max of the initial<br>request. |

| Timing Specification                         | Symbol | Min                   | Мах                     | Description                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------------------------------|--------|-----------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Request-to-response time                     | MT1    | _                     | 100 ms                  | This interval is measured at the<br>responder from the end of the<br>reception of the MCTP Control<br>Protocol request to the beginning<br>of the transmission of the<br>response. This requirement is<br>tested under the condition where<br>the responder can successfully<br>transmit the response on the first<br>try.                                                                     |
| Time-out waiting for a response              | MT2    | MT1 max+<br>2*MT3 max | MT4, min <sup>[1]</sup> | This interval is measured at the<br>requester from the end of the<br>successful transmission of the<br>MCTP Control Protocol request to<br>the beginning of the reception of<br>the corresponding MCTP Control<br>Protocol response. This interval at<br>the requester sets the minimum<br>amount of time that a requester<br>should wait before retrying an<br>MCTP Control Protocol request. |
|                                              |        |                       |                         | Note: This specification does not<br>preclude an implementation from<br>adjusting the minimum time-out<br>waiting for a response to a smaller<br>number than MT2 based on<br>measured response times from<br>responders. The mechanism for<br>doing so is outside the scope of<br>this specification.                                                                                          |
| Transmission Delay                           | МТЗ    | -                     | 100 ms                  | Time to take into account<br>transmission delay of an MCTP<br>Control Protocol Message.<br>Measured as the time between the<br>end of the transmission of an<br>MCTP Control Protocol message at<br>the transmitter to the beginning of<br>the reception of the MCTP Control<br>Protocol message at the receiver.                                                                              |
| Inter-Packet delay for Multi-Packet messages | MT3a   |                       | 100ms                   | Allowed time measured from the<br>end of the transmission of an<br>MCTP packet with EOM=0 to the<br>beginning of the following MCTP<br>packet of the same Message (see<br>Message assembly in <u>DSP0236</u> ),<br>measured at the transmitter                                                                                                                                                 |
| Instance ID expiration interval              | MT4    | 5 sec <sup>[2]</sup>  | 6 sec                   | Interval after which the instance ID<br>for a given response will expire and<br>become reusable if a response has<br>not been received for the request.<br>This is also the maximum time that<br>a responder tracks an instance ID<br>for a given request from a given<br>requester.                                                                                                           |

| Timing Specification |                                                                                                 | Symbol    | Min              | Max               | Description                                                                                                             |  |  |  |
|----------------------|-------------------------------------------------------------------------------------------------|-----------|------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------|--|--|--|
| NOTE 1:              | 1: Unless otherwise specified, this timing applies to the mandatory and optional MCTP commands. |           |                  |                   |                                                                                                                         |  |  |  |
| NOTE 2:              | To guard against this, it is rec                                                                | commended | that sequence nu | mber expiration b | test as one that was previously issued.<br>be implemented. Any request from a<br>atching request should be treated as a |  |  |  |

### 669 6.20 "Stuck 0" condition handling

A possible condition exists in SMBus and I<sup>2</sup>C where a slave device that is being read or is driving ACK could be left driving a low (0) level onto the data line (SDA) of the bus. The bus uses a "wire OR'd"

approach, where the low (0) level takes precedence over the high (1) level. Therefore, if one party drives

a low (0) level onto the bus, the bus cannot go to a high (1) level until the low level is released.

This means that no other transactions can occur until this condition is cleared (because generating a START or STOP condition on the bus requires being able to drive a high-to-low or low-to-high transition on the data line, respectively).

This condition can occur due to the premature termination of a transaction from the master (as could
happen on device resets, power cycles, or firmware restarts, for example) or could occur due to the loss
of a clock due to electrical noise.

680 Effectively, what happens is that the device that was being accessed does not recognize that the

transaction has been terminated or that a clock was missed. The device continues to drive the 0 onto the
 bus because it is waiting to get more clocks from the master to conclude the transaction, but those clocks
 will never come unless some bus master takes steps to generate them.

The solution to this condition is to have a master clock the bus until the SDA line goes high, at which point the master can issue a START or STOP condition to get the bus back in synchronization.

To accomplish this, the master needs to be able to access and clock the bus without paying attention to the present state of the SDA line.

688 Many microcontrollers have the ability to have firmware dynamically reconfigure their SMBus pins as 689 general purpose I/O pins. If this is supported, it is straightforward for firmware to generate the necessary 690 clocks on the SCL line by bypassing the SMBus controller hardware and using programmed I/O to control 691 the pins instead. The firmware would then simply clock the bus until it sees a "1" condition on the SDA 692 line and then a new SMBus transaction can be launched.

NOTE It is recommended that MCTP bus owners include a provision to detect and clear Stuck 0 conditions on
 SMBus buses that they own. The controller should do this if it can detect that a constant 0 condition has
 existed on the SDA line for more than PT3 seconds.

### 696 6.21 MCTP over SMBus/I<sup>2</sup>C protocol anti-aliasing

MCTP over SMBus has been designed to allow one endpoint to support multiple protocols, such as ASF,
 IPMI, or legacy device-specific protocols with a single slave address. The following clauses describe
 provisions that can help support implement MCTP over SMBus in devices that also need to support other
 SMBus or I<sup>2</sup>C protocols.

### 701 **6.21.1 IPMI**

The IPMI protocols for SMBus (IPMI over SMBus) and I<sup>2</sup>C (Intelligent Platform Management Bus, IPMB)

use the fourth byte of the transaction as a Source Slave Address byte, as does MCTP over SMBus.

However, the IPMI protocols require the least significant bit of that byte to be 0b, whereas MCTP over

- SMBus requires the bit to be 1b. Thus, a device that needs to differentiate between MCTP over SMBus  $\$
- and the IPMI SMBus/I<sup>2</sup>C protocols can do so using that bit.

### 707 6.21.2 ASF

708 MCTP over SMBus uses the ASF specification reserved value of 0x0F for the command byte. Thus, the

- ASF-defined commands that use SMBus block-write protocol can be differentiated from MCTP over
- 710 SMBus block-write using the command byte value. If necessary, other ASF SMBus write transactions,
- such as those for legacy sensor and control access can be differentiated from MCTP packets based on
- the length of the transaction. The ASF transactions are all shorter.

### 713 6.21.3 Integrating MCTP with legacy SMBus functions

- This clause describes some possible options if MCTP is being added to a device that shall also support functions using a non-MCTP SMBus interface.
- 716 In general, there should be no problems having those functions co-exist with MCTP provided that the
- legacy SMBus operations do not require generating or accepting write transactions that use the MCTP value of  $0 \times 0$  F.
- 719 If the SMBus device currently uses the  $0 \times 0$  F MCTP command value for a device-specific purpose and it 720 wants to use the same slave address, the following can be done:
- The device-specific command can be moved to a different command value. This is generally the most straightforward approach if it can be supported.
- Depending on the device-specific command definition, it may be possible to differentiate
   between the command and MCTP packets based on other differences, such as the overall
   length of the command or differences between the values in the fourth or fifth bytes of the
   command. (MCTP always uses 1b as the least significant bit of the fourth byte, and the fifth
   byte holds a fixed 4-bit value for the Header Version.)
- The device can implement MCTP over SMBus on a separate slave address from the legacy functions.

### 730 **6.22 Well-known and reserved slave addresses**

For bus segments that support ARP-able devices, Table 10 summarizes addresses that are generally reserved by SMBus or I<sup>2</sup>C and should either be avoided by devices. In addition, some are reserved (not to be used as a general device slave address) because those addresses are related to functions that are used by MCTP.

| Slave Address<br>bits [7:1] | R/W#<br>bit [0] | Hex <sup>[7]</sup> | Comment                                                    | Disposition          |
|-----------------------------|-----------------|--------------------|------------------------------------------------------------|----------------------|
| 0000 000                    | 0               | 0x00               | I <sup>2</sup> C general call address, IPMI<br>broadcast   | avoid <sup>[1]</sup> |
| 0000 000                    | 1               | 0x01               | START byte                                                 | avoid <sup>[2]</sup> |
| 0000 001                    | x               | 0x02,<br>0x03      | CBUS address                                               | avoid <sup>[3]</sup> |
| 0000 010                    | x               | 0x04,<br>0x05      | Address reserved for different bus<br>format               | avoid                |
| 0000 011                    | x               | 0x06,<br>0x07      | Reserved for future use by I <sup>2</sup> C specifications | avoid                |

### Table 10 – Well-known and reserved slave addresses

| Slave Ac<br>bits [7:1] |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R/W#<br>bit [0]                             | Hex <sup>[7]</sup>                               | Comment                                                                                                                                                                                                                                                                                               | Disposition                                                                            |  |  |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|--|--|
| 0000                   | 1XX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | x                                           | 0x08-<br>0x0F                                    | I <sup>2</sup> C specification, high-speed mode master code                                                                                                                                                                                                                                           | avoid <sup>[4]</sup>                                                                   |  |  |
| 0001                   | 000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | x                                           | 0x10                                             | SMBus host                                                                                                                                                                                                                                                                                            | rsvd                                                                                   |  |  |
| 0001                   | 100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | x                                           | 0x18,<br>0x19                                    | SMBus Alert Response address                                                                                                                                                                                                                                                                          | rsvd                                                                                   |  |  |
| 0010                   | 000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | x                                           | 0x20,<br>0x21                                    | IPMI BMC address                                                                                                                                                                                                                                                                                      | avoid <sup>[5]</sup>                                                                   |  |  |
| 0101                   | 000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | x                                           | 0x50,<br>0x51                                    | Reserved for ACCESS.bus host                                                                                                                                                                                                                                                                          | avoid<br>(ACCESS.bus defunct)                                                          |  |  |
| 0110                   | 111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | x                                           | 0x6E,<br>0x6F                                    | Reserved for ACCESS.bus default address                                                                                                                                                                                                                                                               | avoid                                                                                  |  |  |
| 1111                   | 0XX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | x                                           | 0xF0-<br>0xF7                                    | I <sup>2</sup> C 10-bit slave addressing <sup>[1]</sup>                                                                                                                                                                                                                                               | avoid <sup>[6]</sup>                                                                   |  |  |
| 1111                   | 1XX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | x                                           | 0xF8-<br>0xFF                                    | Reserved for future use by I <sup>2</sup> C specifications                                                                                                                                                                                                                                            | avoid                                                                                  |  |  |
| 1100                   | 001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | x                                           | 0xC2,<br>0xC3                                    | SMBus Device Default address                                                                                                                                                                                                                                                                          | rsvd. Used for SMBus<br>ARP with MCTP                                                  |  |  |
| NOTE 1.                | controlle<br>portion of<br>as an op                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ers may be u<br>of an addres<br>tional mech | used on the s<br>as that is use<br>anism for a c | east address in IPMI and I <sup>2</sup> C. It should be avoide<br>ame bus segment. In I <sup>2</sup> C, it is reserved for two<br>d for devices that have a portion of their addres<br>device to master and broadcast its slave addres<br>ss for the I <sup>2</sup> C address assignment or slave add | purposes: to broadcast a<br>ss that is configurable, and<br>ss onto the bus. MCTP does |  |  |
| NOTE 2.                | I <sup>2</sup> C interf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | aces to shi<br>rarely used                  | t into polling                                   | le to the slave address that is intended to provi<br>of I <sup>2</sup> C clock and data lines after a START cond<br>C. MCTP does not support the use of the START                                                                                                                                     | ition has been detected. This                                                          |  |  |
| NOTE 3.                | CBUS is an ancestor of I <sup>2</sup> C, developed by Philips Semiconductor. It uses a data and clock signal similar to I <sup>2</sup> C, but with a third signal (SEN) used to generate the START and STOP conditions on the bus. This address range was reserved by the I <sup>2</sup> C specification to enable a degree of backward compatibility with CBUS devices sharing the I <sup>2</sup> C SCL and SDA lines as the CBUS clock and data lines, respectively. While listed as a reserved address in the I <sup>2</sup> C specification, few SMBus/I <sup>2</sup> C implementations using MCTP will have any need to also support CBUS devices. |                                             |                                                  |                                                                                                                                                                                                                                                                                                       |                                                                                        |  |  |
| NOTE 4.                | MCTP is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | not defined                                 | to support l                                     | C high-speed mode operation.                                                                                                                                                                                                                                                                          |                                                                                        |  |  |
| NOTE 5.                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                             | well known a same MCTP                           | address" for an IPMI BMC. This address should<br>segment.                                                                                                                                                                                                                                             | be avoided if an IPMI BMC                                                              |  |  |
| NOTE 6.                | addressi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ing. MCTP p                                 | rotocols and                                     | /# bit position to deliver the most-significant th<br>data structures do not support 10-bit addressi<br>7-bit addresses for MCTP and non-MCTP device                                                                                                                                                  | ng on SMBus or I <sup>2</sup> C                                                        |  |  |
| NOTE 7.                | By conve<br>treated a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ention, whe<br>is an 8-bit v                | n the 7-bit sla<br>alue where th                 | ave address field is represented as a two-digit h<br>ne 7-bit address occupies the upper 7 bits and t<br>ne SMBus/I2C Read-Write bit associated with th                                                                                                                                               | nexadecimal number, it is he least significant bit is 0b                               |  |  |

### 736 6.23 Fixed address allocation

737 One of the problems that an implementer often faces is choosing which slave address to use. For the

738 PCI<sup>™</sup> and PCI Express<sup>™</sup> bus specifications, the specifications require that devices on standard

connectors defined by those specifications have their addresses set through SMBus ARP. Therefore,

fixed address allocation is not an option for PCI add-in cards themselves. In fixed bus implementations,

however, there are many situations where it is desired or necessary to utilize fixed-address devices.

From a practical point-of-view, SMBus and I<sup>2</sup>C do not have an effective central registry or other

mechanism for avoiding conflicts in the assignment and use of slave addresses among device vendors.

- 744 While there are potential registries of device slave address usage for SMBus (under the System
- 745 Management Interface Forum) and I<sup>2</sup>C (from Philips Semiconductor), these have not generally been used
- by device vendors and there is no group or standard that works to enforce conformance to those
- 747 registries.

748 Most device vendors provide a configurable range of three or more addresses to enable an implementer 749 to reconcile address conflicts on a single segment. Because typically only a small number of fixed-

- address devices are used on a given segment, it is frequently possible to configure devices so they do
- 750 not have overlapping addresses. This approach is problematic, however, in situations where a component
- that is attached to that segment in the platform may come from several sources. Clause 6.23 provides
- 753 guidelines to allocating fixed addresses that are designed to reduce the number of conflicts that could
- occur when multiple suppliers provide different elements of a computer system (see Figure 5 for an

755 example).



756

### 757

### Figure 5 – Example system configuration

### 758 **6.24 Recommended address range allocation for computer systems**

This clause provides a recommended allocation of SMBus addresses between board, chassis, and add-in
uses that help avoid address conflicts when fixed addresses are used. It also serves as a general
guideline of what addresses a generic ARP master should use for allocation to PCI/PCIe add-in cards.

There might be cases when MCTP is used within a typical computer system application where the motherboard may come from one supplier, the chassis from another supplier, and possibly add-in modules from yet another supplier. To facilitate the mix-and-match of these elements and to help avoid the need for every system manufacturer to set up their own address allocation conventions with suppliers, MCTP recommends that system manufacturers follow the address allocation approach initially defined by the IPMI specifications (see Table 11). This approach splits the available fixed addresses (addresses other than reserved addresses) into four main usage areas:

769 B Board: An area reserved for board set manufacturer use (where *board set* would be the motherboard and other boards that accompany that motherboard from the same vendor).

- C Chassis: An area reserved for use by vendors that make chassis in which a third-party board set would be used.
- A Add-in: For third-party add-in devices (for example, modules or add-in cards that used fixed addresses and would be used in combination with a motherboard or chassis where there is a connection to a SMBus segment implementing MCTP).
- 776NOTEPCI/PCIe add-in cards that use standard PCI connectors are required to support SMBus ARP777and fixed addresses are not used.
- 778 **R** Reserved for IPMI, I<sup>2</sup>C, SMBus, or MCTP uses. Includes the *avoid* addresses from Table 10.

779 By following this convention, future motherboards can offer connections to chassis elements and third-

780 party modules where those devices can use fixed addresses, if required. It also provides a convention to avoid conflicts if legacy non-MCTP devices share the same SMBus segment.

Table 11 – Slave address allocation for computer systems

| Use | Address   | Typical Device                       | Use  | Address   | Typical Device                                                                                                                                 |
|-----|-----------|--------------------------------------|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------|
| R   | 0x00      | I <sup>2</sup> C, IPMB broadcast     | С    |           |                                                                                                                                                |
|     | 0x01      | I <sup>2</sup> C                     |      |           |                                                                                                                                                |
|     | 0x02      | l <sup>2</sup> C                     |      | 0x48      | SMBUS/I2C IO Expander, such as 8574                                                                                                            |
|     | 0x04-0x0E | l <sup>2</sup> C                     |      | 0x4A      | SMBUS/I2C IO Expander, such as 8574                                                                                                            |
|     | 0x20      | IPMB uC (BMC)                        |      | 0x4C      | SMBUS/I2C IO Expander, such as 8574                                                                                                            |
|     | 0x50      | ACCESS.bus                           |      | 0x4E      | SMBUS/I2C IO Expander, such as 8574                                                                                                            |
|     | 0x6E      | ACCESS.bus                           |      | 0x52-0x6C | 58h, 5Ah, 5Ch = Heceta                                                                                                                         |
|     | 0xF0-0xF6 | I <sup>2</sup> C                     |      |           |                                                                                                                                                |
|     | 0xF8-0xFE | I <sup>2</sup> C                     |      |           |                                                                                                                                                |
| A   | 0x10      | SMBus host (B)                       |      | 0x78      | SMBUS/I2C IO Expander, such as 8574A                                                                                                           |
|     | 0x12-0x16 |                                      |      | 0x7A      | SMBUS/I2C IO Expander, such as 8574A                                                                                                           |
|     | 0x18      | SMBus Alert Response address (B)     |      | 0x7Ch     | SMBUS/I2C IO Expander, such as 8574A                                                                                                           |
|     | 0x1A-0x1E |                                      |      | 0x7E      | SMBUS/I2C IO Expander, such as 8574A                                                                                                           |
|     | 0x30-0x3E |                                      |      | 0x9A      | TEMPERATURE SENSORS, SUCH<br>AS LM75, DS1624, DS1621                                                                                           |
|     |           |                                      |      | 0x9C      | uC (pri. HSC), DS1624, DS1621                                                                                                                  |
|     | 0xD0-0xDE |                                      |      | 0x9E      | uC (sec. HSC), DS1624, DS1621                                                                                                                  |
| В   | 0x22      | uC (FPC, ICMB) <sup>[1]</sup>        |      | 0xA0-0xA2 | FRU (Power Supply FRU or SEEPROM)                                                                                                              |
|     | 0x24      | uC (PBC) <sup>[1]</sup>              |      | 0xAC      | SEEPROMSEEPROM                                                                                                                                 |
|     | 0x26      |                                      |      | OxAE      | SEEPROM                                                                                                                                        |
|     | 0x28      | SM Card <sup>[1]</sup>               |      | 0xB0-0xB2 | Power Supply Device (PMBus)                                                                                                                    |
|     | 0x2A-0x2E |                                      |      | 0xE8-0xEE | I2C Bus Switch                                                                                                                                 |
|     | 0x40      | SMBUS/I2C IO Expander, such as 8574A | NOTE | PBC = Pow | IPMI usage. FPC = front panel controller,<br>ver Backplane Controller, ICMB = Intelligent<br>anagement Bus bridge, SM Card = System<br>nt Card |
|     | 0x42      | SMBUS/I2C IO Expander, such as 8574A |      |           |                                                                                                                                                |
|     | 0x44      | SMBUS/I2C IO Expander, such as 8574A |      |           |                                                                                                                                                |
|     | 0x46      | SMBUS/I2C IO Expander, such as 8574A |      |           |                                                                                                                                                |
|     | 0x70      | SMBUS/I2C IO Expander, such as 8574A |      |           |                                                                                                                                                |
|     | 0x72      | SMBUS/I2C IO Expander, such as 8574A |      |           |                                                                                                                                                |

| Use | Address   | Typical Device                                                | Use | Address | Typical Device |
|-----|-----------|---------------------------------------------------------------|-----|---------|----------------|
|     | 0x74      | SMBUS/I2C IO Expander, such as<br>8574A                       |     |         |                |
|     | 0x76      | SMBUS/I2C IO Expander, such as 8574A                          |     |         |                |
|     | 0x80-0x8E |                                                               |     |         |                |
|     | 0x90      | TEMPERATURE SENSORS,<br>SUCH AS LM75, DS1624, DS1621,<br>8591 |     |         |                |
|     | 0x92      | TEMPERATURE SENSORS,<br>SUCH AS LM75, DS1624, DS1621,<br>8591 |     |         |                |
|     | 0x94      | TEMPERATURE SENSORS,<br>SUCH AS LM75, DS1624, DS1621,<br>8591 |     |         |                |
|     | 0x96      | TEMPERATURE SENSORS,<br>SUCH AS LM75, DS1624, DS1621,<br>8591 |     |         |                |
|     | 0x98      | TEMPERATURE SENSORS,<br>SUCH AS LM75, DS1624, DS1621,<br>8591 |     |         |                |
|     |           |                                                               |     |         |                |
|     | 0xA4      | SEEPROM                                                       |     |         |                |
|     | 0xA6      | SEEPROM                                                       |     |         |                |
|     | 0xA8      | SEEPROM                                                       |     |         |                |
|     | OxAA      | SEEPROM                                                       |     |         |                |
|     | 0xC0      |                                                               |     |         |                |
|     | 0xC2      | SMBus Device Default address                                  |     |         |                |
|     | 0xC4-0xCE |                                                               |     |         |                |
|     | 0xE0-0xE6 | I2C Bus Switch                                                |     |         |                |

| 783<br>784 | ANNEX A<br>(informative) |
|------------|--------------------------|
| 785        |                          |
| 786        |                          |
| 787        | Notation                 |

| 788               | Notations                                                   |             |                                                                                                                                                                                                                       |  |  |  |  |
|-------------------|-------------------------------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 789               | Examples of notations used in this document are as follows: |             |                                                                                                                                                                                                                       |  |  |  |  |
| 790<br>791<br>792 | •                                                           | 2:N         | In field descriptions, this will typically be used to represent a range of byte offsets starting from byte two and continuing to and including byte N. The lowest offset is on the left, the highest is on the right. |  |  |  |  |
| 793<br>794        | •                                                           | (6)         | Parentheses around a single number can be used in message field descriptions to indicate a byte field that may be present or absent.                                                                                  |  |  |  |  |
| 795<br>796        | •                                                           | (3:6)       | Parentheses around a field consisting of a range of bytes indicates the entire range may be present or absent. The lowest offset is on the left, the highest is on the right.                                         |  |  |  |  |
| 797<br>798<br>799 | •                                                           | <u>PCle</u> | Underlined, blue text is typically used to indicate a reference to a document or specification called out in 2, "Normative References" or to items hyperlinked within the document.                                   |  |  |  |  |
| 800               | •                                                           | rsvd        | Abbreviation for "reserved." Case insensitive.                                                                                                                                                                        |  |  |  |  |
| 801<br>802        | •                                                           | [4]         | Square brackets around a number are typically used to indicate a bit offset. Bit offsets are given as zero-based values (that is, the least significant bit [LSb] offset = 0).                                        |  |  |  |  |
| 803<br>804        | •                                                           | [7:5]       | A range of bit offsets. The most significant bit is on the left, the least significant bit is on the right.                                                                                                           |  |  |  |  |
| 805<br>806        | •                                                           | 1b          | The lower case "b" following a number consisting of $0s$ and $1s$ is used to indicate the number is being given in binary format.                                                                                     |  |  |  |  |
| 807               | •                                                           | 0x12A       | A leading " $0x$ " is used to indicate a number given in hexadecimal format.                                                                                                                                          |  |  |  |  |
| 808               |                                                             |             |                                                                                                                                                                                                                       |  |  |  |  |

- 809
- 810
- 811
- 812
- 813

# ANNEX B (informative)

# Change log

| Version | Date       | Description                                    |
|---------|------------|------------------------------------------------|
| 1.0.0   | 2009-07-28 |                                                |
| 1.1.0   | 2017-02-16 | Added 1MHz speed mode                          |
|         |            | Moved NACK window to a separate clause         |
|         |            | Corrected timing parameters description        |
|         |            | Updated reserved addresses mapping in Table 11 |
|         |            | Updated Table 2                                |
|         |            | Updated revisions for the normative references |
| 1.2.0   | 2020-04-06 | Added timing parameter MT3a                    |
|         |            | Removed redundant definition of ARP term       |
|         |            | Updated hyperlink to SMBus spec                |