

| Document Number: DSP0256 |
|--------------------------|
| Date: 2010-07-21         |
| Version: 1.0.0           |

## Management Component Transport Protocol (MCTP) Host Interface Specification

7

1

- 8 Document Type: Specification
- 9 Document Status: DMTF Standard
- 10 Document Language: en-US

11

12 Copyright Notice

13 Copyright © 2010 Distributed Management Task Force, Inc. (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.

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

#### CONTENTS

| 40       | Forv          | vard                                                   | . 5 |  |  |  |  |
|----------|---------------|--------------------------------------------------------|-----|--|--|--|--|
| 41       | Introduction6 |                                                        |     |  |  |  |  |
| 42       | 1             | Scope                                                  | .7  |  |  |  |  |
| 43       | 2             | Normative References                                   | .7  |  |  |  |  |
| 44       | 3             | Terms and Definitions                                  | .7  |  |  |  |  |
| 45       | 4             | Symbols and Abbreviated Terms                          | . 8 |  |  |  |  |
| 46       | 5             | Conventions                                            | . 8 |  |  |  |  |
| 47       |               | 5.1 Reserved and Unassigned Values                     | . 8 |  |  |  |  |
| 48       |               | 5.2 Byte Ordering                                      | 8   |  |  |  |  |
| 49       | 6             | MCTP Host Interface                                    | . 8 |  |  |  |  |
| 50       |               | 6.1 Host Interface Discovery                           | .8  |  |  |  |  |
| 51       |               | 6.2 Multiple Host Interfaces                           | .9  |  |  |  |  |
| 52       | 7             | 0.5 Transport-Specific Commanus                        | . 9 |  |  |  |  |
| 53<br>54 | 1             | 7.1 Protocol Identifier and Protocol-Specific Data     | 10  |  |  |  |  |
| 55       | 8             | Locating MCTP Host Interfaces with PCI / PCIe          | 10  |  |  |  |  |
| 56       | 9             | Locating MCTP Host Interfaces with ACPI                | 11  |  |  |  |  |
| 57       | -             | 9.1 MCHI Description Table and ACPI Control Methods1   | 11  |  |  |  |  |
| 58       |               | 9.2 Locating MCTP Host Interfaces in ACPI Name Space 1 | 14  |  |  |  |  |
| 59       |               | 9.3 Example MCTP Definition ASL Code 1                 | 16  |  |  |  |  |
| 60       | ANN           | IEX A (informative) Notation and Conventions1          | 18  |  |  |  |  |
| 61       | ANN           | IEX B (informative) Change Log 1                       | 19  |  |  |  |  |
| 62       |               |                                                        |     |  |  |  |  |

#### 63 Tables

| 64 | Table 1 – SMBIOS Type 42 Management Controller Host Interface Structure | 10 |
|----|-------------------------------------------------------------------------|----|
| 65 | Table 2 – SMBIOS Type 42 Protocol Record Data                           | 10 |
| 66 | Table 3 – Management Controller Host Interface Description Table Format | 11 |
| 67 | Table 4 – MCTP Device Object Control Methods                            | 15 |

#### **MCTP Host Interface Specification**

68

Forward
Forward
The Management Component Transport Protocol (MCTP) KCS Transport Binding Specification (DSP0256) was prepared by the PMCI Subgroup of the Pre-OS Working Group.
DMTF is a not-for-profit association of industry members dedicated to promoting enterprise and systems management and interoperability. For information about the DMTF, see <a href="http://www.dmtf.org">http://www.dmtf.org</a>.

#### Introduction

76 The Management Component Transport Protocol (MCTP) defines a communication model intended to 77 facilitate communication between:

- Management controllers and other management controllers
- Management controllers and management devices
- 80 The communication model includes a message format, transport description, message exchange
- 81 patterns, and configuration and initialization messages. The MCTP Base Specification (DSP0236)
- describes the protocol and commands used for communication within and initialization of an MCTP
   network
- This *MCTP Host Interface Specification* (DSP0256) describes how MCTP packets are delivered over host interfaces (interfaces between a management controller and host software).

### Management Component Transport Protocol (MCTP) KCS Transport Binding Specification

#### 88 **1 Scope**

This document provides the specifications for the Management Component Transport Protocol (MCTP)host interface.

#### 91 2 Normative References

- 92 The following referenced documents are indispensable for the application of this document. For dated
- references, only the edition cited applies. For undated references, the latest edition of the referenceddocument (including any amendments) applies.
- 95 DMTF DSP0134, System Management BIOS Reference Specification 2.6,
- 96 <u>http://www.dmtf.org/standards/published\_documents/DSP0134\_2.6.pdf</u>
- 97 DMTF DSP0236, Management Component Transport Protocol (MCTP) Base Specification 1.0,
   98 <u>http://www.dmtf.org/standards/published\_documents/DSP0236\_1.0.pdf</u>
- 99 DMTF DSP0239, Management Component Transport Protocol (MCTP) IDs and Codes Specification 1.0,
   100 <u>http://www.dmtf.org/standards/published\_documents/DSP0239\_1.0.pdf</u>
- Hewlett-Packard, Intel, Microsoft, Phoenix, and Toshiba, Advanced Configuration and Power Interface
   Specification, 4.0a, <u>http://www.acpi.info/spec.htm</u>
- 103 IPMI Consortium, Intelligent Platform Management Interface Specification, v1.5 Revision 1.1 February 20,
   2002, <u>http://download.intel.com/design/servers/ipmi/IPMIv1\_5rev1\_1.pdf</u>
- 105 PCI-SIG, *PCI Express Base Specification v1.1*, PCIe v1.1, March 28, 2005,
- http://www.pcisig.com/login?back=http%3A//www.pcisig.com/members/downloads/specifications/pciexpre
   ss/PCI\_Express\_Base\_11.pdf
- 108 PCI-SIG, PCI Express Base Specification v2.0, PCIe v2.0, December 20, 2006,
- <u>http://www.pcisig.com/login?back=http%3A//www.pcisig.com/members/downloads/specifications/pciexpre</u>
   ss/PCI\_Express\_Base\_Rev\_2.0\_20Dec06a.pdf
- 111 PCI-SIG, PCI Local Bus Specification v3.0, PCI v3.0, February 3, 2004,
- 112 http://www.pcisig.com/login?back=http%3A//www.pcisig.com/members/downloads/specifications/conventi
- 113 <u>onal/PCI\_LB3.0-2-6-04.pdf</u>

#### **114 3 Terms and Definitions**

- 115 Refer to <u>DSP0236</u> for terms and definitions that are used across the MCTP specifications. For the
- 116 purposes of this document, the following terms and definitions apply.

#### 117 4 Symbols and Abbreviated Terms

118 Refer to <u>DSP0236</u> for symbols and abbreviated terms that are used across the MCTP specifications. For 119 the purposes of this document, the following additional symbols and abbreviated terms apply.

#### 120 **5** Conventions

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

#### 122 5.1 Reserved and Unassigned Values

- 123 Unless otherwise specified, any reserved, unspecified, or unassigned values in enumerations or other 124 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.

#### 127 5.2 Byte Ordering

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

#### 130 6 MCTP Host Interface

- 131 The MCTP Host Interface defines how MCTP packets are delivered over a host interface. This
- specification describes the host interface discovery and commands for registering software endpointssuch as BIOS, UEFI or system software.

#### 134 6.1 Host Interface Discovery

- Host Interface discovery applies to industry standard architecture (PC) systems. Having a single "active"
   management controller is a restriction from the defined discovery mechanisms and not a restriction on the
   host interface definition per se.
- A Management Controller may make available multiple host interfaces, but only one management controller is allowed to be the "active" Management Controller that provides Management controller
- 140 functionality for the system (in the case of a "partitioned" system, there can only one active Management
- 141 Controller per partition). Only the host interface(s) for the active Management Controller are allowed to
- respond to the *Get MCTP Version Support* command as defined in the *MCTP Base Specification*
- 143 (DSP0236). If other Management Controller devices are present, but not being used, they must not
- respond to the *Get MCTP Version Support* command.
- 145 MCTP host interface can be discovered with PCI/PCIe class codes, ACPI or SMBIOS structure tables.
- 146 Maintaining consistency between these structures is outside the scope of this specification.
- 147 When multiple ways of discovering host interfaces are available, the driver can discover the MCTP host148 interface using the approach described in this section.
- 149 Drivers should not switch host interfaces during system operation or else unexpected results could occur.
- 150 The Get MCTP Version Support command is required to execute correctly across multiple interfaces to a
- 151 management controller, but other commands are not. Once the driver has chosen to use a given
- 152 interface, all commands beyond Get MCTP Version Support should be delivered to that interface. If it is
- desired to change the choice of host interfaces, a warm or cold reset of the platform should be done to
- ensure that the system can re-initialize the management controller operation.

- 155 It is recommended that run-time drivers support the MCTP Host interfaces in the following order:
- A driver should preferentially use the management controller on PCI/PCIe, via the OS's native support, if available. (A "Plug and Play" OS will typically locate and load the appropriate driver for devices it finds on PCI/PCIe.) Clause 8 summarizes the PCI/PCIe Class codes for MCTP Host interfaces.
- If the desired interface is not available on PCI/PCIe, or the system is in a state where OS
   support for PCI/PCIe is unavailable the next step should be to look for the host interface as a
   static resource described in ACPI using the control methods described in clause 9.
- If the operating environment does not include a mechanism to support executing ACPI control methods, then look for the host interface at the location described by the MCHI (Management Controller Host Interface) Table(s) through the ACPI Description Table mechanisms. (There is one instance of MCHI table per host interface. The MCHI Table approach supports systems that include more than one host interface. Therefore, there can be more than one instance of the MCHI Table.) The MCHI Table is described in clause 9.
- If the MCHI Table is not present, the driver should look for the SMBIOS Type 42 table (see clause 7) and use the interface described there. There is one instance of the Type 42 record per physical interface. Therefore, in order to discover whether there are multiple non-plug-and-play host interfaces, the driver will need to see if the SMBIOS table has multiple Type 42 records.

#### 173 6.2 Multiple Host Interfaces

Multiple host interfaces may exist in a given system implementation. Refer to the "MCTP Overview"
 clause in <u>DSP0236</u> for details on identifying whether multiple host interfaces connect to common or
 separate MCTP networks.

#### 177 6.3 Transport-Specific Commands

In order for a transport to be an MCTP host interface it must have a transport-specific command to
 register system firmware or system software in order to obtain a MCTP EID. The details of this command
 are described in the transport-binding specifications.

#### **7 Locating MCTP Host Interfaces via SMBIOS Tables**

182 The System Management BIOS Reference Specification (<u>DSP0134</u>) includes the following optional

- record for identifying the initial location of MCTP host interfaces and interrupts. This is summarized in
   Table 1. See DSP0134 for other application information on SMBIOS.
- 185 Note that the settings that this structure reports may be over-ridden by "Plug-and-Play" reassignment by
- the OS. Therefore, this structure should be used only when the interface cannot be discovered via "Plug-
- 187 and-Play" discovery mechanisms incorporated in interfaces such as PCI and ACPI.

| 188 |  |
|-----|--|
|-----|--|

| Offset  | Name                               | Length     | Value  | Description                                              |
|---------|------------------------------------|------------|--------|----------------------------------------------------------|
| 00h     | Туре                               | BYTE       | 42     | Management Controller Host Interface structure indicator |
| 01h     | Length                             | BYTE       | Varies | Length of the structure, a minimum of 0x09h.             |
| 02h     | Handle                             | WORD       | Varies |                                                          |
| 04h     | Interface type                     | BYTE       | ENUM   | Management Controller (MC) interface type                |
| 05h     | Interface specific data length (n) | BYTE       | Varies | Number of bytes of interface specific data               |
| 06h     | Interface specific data            | n<br>BYTEs | Varies | Defined by interface specification                       |
| 06h + n | Protocol count (m)                 | BYTE       | ENUM   | Number of protocols supported on this interface          |
| 07h + n | Protocol records                   | M Bytes    | Varies | Protocol record data (see Table 2)                       |

#### 189 **7.1** Protocol Identifier and Protocol-Specific Data

190 The protocol identifier describes the protocol used over the Management Controller Host Interface. These

identifiers are defined in <u>DSP0239</u>, Management Component Transport Protocol (MCTP) IDs and Codes
 Specification.

193 The protocol specific data describes certain data that is required by the protocol, such as protocol revision

194 numbers. This protocol-specific data for MCTP is defined in <u>DSP0236</u>, *Management Component* 

195 *Transport Protocol (MCTP) Base Specification* Management Controller Host Interface Protocol Specific

196 Data Requirements.

197 Table 2 shows the Type 42 protocol record data.

198

Table 2 – SMBIOS Type 42 Protocol Record Data

| Offset | Name                             | Length     | Value  | Description                               |
|--------|----------------------------------|------------|--------|-------------------------------------------|
| Х      | Protocol Identifier              | BYTE       | ENUM   | Protocol Identifier                       |
| X + 1  | Protocol specific data<br>length | BYTE       | Varies | Number of bytes of protocol specific data |
| X + 2  | Protocol specific data           | n<br>BYTEs | Varies | Defined by protocol specification         |

#### **8 Locating MCTP Host Interfaces with PCI / PCIe**

The MCTP host interface uses the PCI SIG (<u>http://www.pcisig.com</u>) class codes for IPMI Host interfaces defined in Appendix D of the <u>PCI Local Bus Specification</u>. PCI-based implementations of the IPMI Host interfaces should use the appropriate PCI configuration space and the class code definition there to

202 report the presence and type of host interface for driver loading purposes.

The first base address register of the PCI function that implements the MCTP host interface holds the base address for the MCTP Host Interface registers. The MCTP Host Interfaces can be I/O or memory mapped, as indicated by read-only bits in the base address register.

Unless otherwise specified, MCTP Host interfaces on PCI must be byte aligned and located at offset 0
 with respect to the base address register.

#### **9 Locating MCTP Host Interfaces with ACPI**

210 This specification introduces the option of describing the presence of the MCTP Host Interface as a static

- 211 (non-"Plug and Play") resource using ACPI. The MCTP Host interface can also be implemented as a 212 relocate able resource on PCI (refer to clause 8)
- 212 relocate-able resource on PCI (refer to clause 8).
- 213 There are two ACPI-based mechanisms that work together when the MCTP Host interface is
- 214 implemented as a static resource: the Management Controller Host Interface (MCHI) Description Table
- and ACPI Control Methods.

#### 216 9.1 MCHI Description Table and ACPI Control Methods

The MCHI Description Table is an optional table that describes the processor-relative, translated, fixed resources of a host interface at system boot time. The purpose of the MCHI Description Table is to provide a mechanism that can be used by the OSPM (an ACPI term for "OS Operating System-directed configuration and Power Management" essentially meaning an ACPI-aware OS or OS loader) very early in the boot process, for example, before the ability to execute ACPI control methods in the OS is available.

The MCHI Description Table is similar to the SMBIOS Type 42 (MC Device Information) record. The main difference between the two is that the MCHI Table is identified in the ACPI Specification as a table that has the reserved signature "MCHI". The SMBIOS Type 42 record type is from the DMTF SMBIOS specifications. See DSP0134.

The MCHI Description Table can be used to describe the location of either fixed resource or PCI implementations of the host interface. For host interfaces on PCI, the table can only describe the location of the host interface at the time that the boot process is initiated. An OS may relocate these resources. Therefore, whether or not a PCI-based host interface remains at the MCHI addresses is OS-dependent. During normal run-time operation, software should locate the host interface directly on PCI and/or use the OS's support for PCI instead of the MCHI Table.

A management controller device may present more than one host interface for messaging to the
 Management Controller. For example, a Management Controller may simultaneously support the KCS
 and the Serial interfaces. A unique MCHI Table should be provided for each of these interfaces. This
 allows the OS to select an interface that it is able to communicate and hence maximize the supportability.

Per <u>ACPI</u>, unless otherwise specified, numeric values for the table and any blocks or structures are always encoded in little Endian format. Signature values are stored as fixed-length strings.

239

Table 3 – Management Controller Host Interface Description Table Format

| Field     | Byte<br>Length | Byte<br>Offset | Description                                                                                              |  |
|-----------|----------------|----------------|----------------------------------------------------------------------------------------------------------|--|
| Header    |                |                |                                                                                                          |  |
| Signature | 4              | 0              | 'MCHI'. Signature for the Management Controller Host Interface Table.                                    |  |
| Length    | 4              | 4              | Length, in bytes, of the entire Management Controller Host Interface Table.                              |  |
| Revision  | 1              | 8              | 1                                                                                                        |  |
| Checksum  | 1              | 9              | Two's complement of the 16 bit sum of all the bytes in the table excluding the checksum byte, modulo 256 |  |
| OEMID     | 6              | 10             | OEM ID. Per the <u>ACPI Specification</u> . An OEM-supplied string that identifies the OEM.              |  |

| Field                  | Byte<br>Length | Byte<br>Offset | Description                                                                                                                                                                                                                                      |  |  |
|------------------------|----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| OEM Table ID           | 8              | 16             | For the Management Controller Host Interface Table, the table ID is the manufacturer model ID (assigned by the OEM identified by "OEM ID").                                                                                                      |  |  |
| OEM Revision           | 4              | 24             | OEM revision of Management Controller Host Interface<br>Table for supplied the given OEM Table ID. Per the <u>ACPI</u><br><u>Specification</u> , this is "An OEM-supplied revision number.<br>Larger numbers are assumed to be newer revisions." |  |  |
| Creator ID             | 4              | 28             | Vendor ID of utility that created the table. For the tables containing Definition Blocks, this is the ID for the ASL Compiler.                                                                                                                   |  |  |
| Creator Revision       | 4              | 32             | Revision of utility that created the table. For the tables containing Definition Blocks, this is the revision for the ASL Compiler.                                                                                                              |  |  |
| Interface Type         | 1              | 36             | Indicates the type of Host interface:                                                                                                                                                                                                            |  |  |
|                        |                |                | 0 Reserved                                                                                                                                                                                                                                       |  |  |
|                        |                |                | 1 Reserved                                                                                                                                                                                                                                       |  |  |
|                        |                |                | 2 Keyboard Controller Style (KCS)                                                                                                                                                                                                                |  |  |
|                        |                |                | 3 Serial (8250 Compatible)                                                                                                                                                                                                                       |  |  |
|                        |                |                | 4 Serial (16450 Compatible)                                                                                                                                                                                                                      |  |  |
|                        |                |                | 5 Serial (16450/16550A Compatible)                                                                                                                                                                                                               |  |  |
|                        |                |                | 6 Serial (16550/16C550 Compatible)                                                                                                                                                                                                               |  |  |
|                        |                |                | 7 Serial (16650/16C650 Compatible)                                                                                                                                                                                                               |  |  |
|                        |                |                | 8 Serial (16750/16C750 Compatible)                                                                                                                                                                                                               |  |  |
|                        |                |                | 9-255 Reserved                                                                                                                                                                                                                                   |  |  |
| Protocol Identifier    | 1              | 37             | Indicates the protocol of Host Interface:                                                                                                                                                                                                        |  |  |
|                        |                |                | 0 Unspecified                                                                                                                                                                                                                                    |  |  |
|                        |                |                | 1 Management Controller Transport Protocol (MCTP)                                                                                                                                                                                                |  |  |
|                        |                |                | 2 Intelligent Platform Management Interface (IPMI)                                                                                                                                                                                               |  |  |
|                        |                |                | 3-254 Reserved                                                                                                                                                                                                                                   |  |  |
|                        |                |                | 255 OEM defined (OEM is identified by OEM ID field)                                                                                                                                                                                              |  |  |
| Protocol Specific Data | 8              | 38             | Indicates protocol specific data such as specification<br>revision of version plus other protocol specific data defined<br>by the protocol specification                                                                                         |  |  |
| Interrupt Type         | 1              | 46             | Interrupt type(s) used by the interface:                                                                                                                                                                                                         |  |  |
|                        |                |                | [7:2] – Reserved (must be 0)                                                                                                                                                                                                                     |  |  |
|                        |                |                | [1] – I/O APIC/SAPIC interrupt (Global System Interrupt)                                                                                                                                                                                         |  |  |
|                        |                |                | [0] – SCI triggered through GPE                                                                                                                                                                                                                  |  |  |
|                        |                |                | 0 = not supported                                                                                                                                                                                                                                |  |  |
|                        |                |                | 1 = supported                                                                                                                                                                                                                                    |  |  |

| Field                                    | Byte<br>Length | Byte<br>Offset | Description                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|------------------------------------------|----------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| GPE                                      | 1              | 47             | The bit assignment of the SCI interrupt within the GPEx_STS register of a GPE described if the FADT that the interface triggers. (Note: This field is valid only if Bit[0] of the Interrupt Type field is set. Otherwise set to 00h.)                                                                                                                                                                                                  |  |  |
| PCI Device Flag                          | 1              | 48             | [7:1] – Reserved                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|                                          |                |                | [0] – PCI Device Flag. For PCI devices, this bit is set. For<br>non-PCI devices, this bit is cleared. When this bit is cleared,<br>the PCI Segment Group, Bus, Device and Function Number<br>fields combined corresponds to the ACPI _UID value of the<br>device whose _HID or _CID contains DMT0001 plug and<br>play IDUID must be an integer. Byte 60 contains the least<br>significant byte of the _UID value. Set to 0b for SMBus. |  |  |
| Global System Interrupt                  | 4              | 49             | The I/O APIC or I/O SAPIC Global System Interrupt[1] used<br>by the interface. (Note: This field is valid only if Bit[1] of the<br>Interrupt Type field is set. Otherwise set to 00h.)                                                                                                                                                                                                                                                 |  |  |
| Base Address                             | 12             | 53             | The base address of the interface register set described<br>using the Generic Address Structure (GAS, see <u>ACPI</u> for<br>the definition). The Address_Space_ID field in the GAS can<br>only be of the value of 0 (System Memory), 1 (System IO),<br>and 4 (SMBus). All other values are not permitted.                                                                                                                             |  |  |
|                                          |                |                | For SMBus:                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|                                          |                |                | The Address_Space_ID = 4 and the address field of the GAS holds the 7-bit slave address of the MC on the host SMBus in the least significant byte. Note that the slave address is stored with the 7-bit slave address in the least significant 7-bits of the byte, and the most significant bit of the byte set to 0b.                                                                                                                 |  |  |
|                                          |                |                | Register_Bit_Width = 0                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|                                          |                |                | Register_Bit_Offset = 0                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                                          |                |                | Address_Size field = 1 (Byte access)                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|                                          |                |                | Address = 7-bit SMBus address of BMC SSIF                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| PCI Segment Group<br>Number / UID byte 1 | 1              | 65             | PCI Segment Group Number, if the device is a PCI device.<br>Otherwise, this field is byte 1 of a UID. See description for<br>PCI Device Flag, above.                                                                                                                                                                                                                                                                                   |  |  |
| PCI Bus Number / UID                     | 1              | 66             | PCI Bus Number, if the device is a PCI device.                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| byte 2                                   |                |                | Otherwise, this field is byte 2 of a UID. See description for PCI Device Flag, above.                                                                                                                                                                                                                                                                                                                                                  |  |  |
| PCI Device Number /<br>UID byte 3        | 1              | 67             | PCI Device fields or byte 3 of a UID. Per PCI Device Flag, above.                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|                                          |                |                | For PCI Device Flag = 1b:                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|                                          |                |                | [7:5] – Reserved                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|                                          |                |                | [4:0] – PCI Device Number: The PCI device number if the device is a PCI device.                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                                          |                |                | For PCI Device Flag = 0b:                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|                                          |                |                | [7:0] – byte 3 of UID                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |

| Field                               | Byte<br>Length | Byte<br>Offset | Description                                                                         |  |  |
|-------------------------------------|----------------|----------------|-------------------------------------------------------------------------------------|--|--|
| PCI Function Number /<br>UID byte 4 | 1              | 68             | PCI Device fields or byte 4 of a UID. Per PCI Device Flag, above.                   |  |  |
|                                     |                |                | For PCI Device Flag = 1b:                                                           |  |  |
|                                     |                |                | [7] – Reserved                                                                      |  |  |
|                                     |                |                | [6] – Interrupt Flag:                                                               |  |  |
|                                     |                |                | 0b = interrupt not supported                                                        |  |  |
|                                     |                |                | 1b = interrupt supported                                                            |  |  |
|                                     |                |                | [5:3] – Reserved                                                                    |  |  |
|                                     |                |                | [2:0] – PCI Function Number: The PCI function number if the device is a PCI device. |  |  |
|                                     |                |                | For PCI Device Flag = 0b:                                                           |  |  |
|                                     |                |                | [7:0] – byte 4 of UID                                                               |  |  |

 ACPI represents all interrupts as "flat" values known as global system interrupts. Therefore, to support APICs or SAPICs on an ACPI-enabled system, each used APIC or SAPIC interrupt input must be mapped to the global system interrupt value used by ACPI. See the "Global System Interrupts" section in <u>ACPI</u> for a description of Global System Interrupts.

#### **9.2 Locating MCTP Host Interfaces in ACPI Name Space**

The MCHI Description Table provides a mechanism that can be used before the ability to execute ACPI control methods in the OS is available. This table is not, however, intrinsically supported in the OS as a way of discovering and reporting system resources. Therefore, it is recommended that non-PCI MCTP Host interfaces on the baseboards be described in the ACPI name space. This makes it possible for the OS to enumerate the IPMI Host interface as a device. In addition, the ACPI name space description is more flexible and friendly in hot-plug scenarios.

Note that to be ACPI compatible, the fixed resources for MCTP Host interfaces must still be accounted for in accordance with the <u>ACPI Specification</u>. If the device is not formally described in the ACPI Name Space, its resources must be described as fixed system resources or the resources appended to some other fixed resource system device in order to ensure that the OS does not attempt to allocate those resources to some other device.

To formally describe the MCTP Host interface in ACPI Name Space, an MCTP device is created using the named device object. The MCTP device object can have the following elements:

| Table 4 | 4 – MCTE | P Device | Object | Control  | Methods  |
|---------|----------|----------|--------|----------|----------|
| Table . |          | DCVICC   | Object | 00111101 | Michious |

| Object | Description                                                                                                                                                                                                                                                                                                                                                                                                   | Support Level                                                                           |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| _ADR   | Named object that evaluates to the interface's address on its parent busADR is a standard device configuration control method defined in the <u>ACPI Specification</u> .                                                                                                                                                                                                                                      | Required only for<br>devices on a bus<br>that has standard<br>enumeration<br>mechanism. |
| _HID   | Named object that provides the interface's Plug and Play identifier. This value can be vendor specific but must set to DMT0001 <sup>1</sup> if no CID object is providedHID is a standard device configuration control method defined in the <u>ACPI</u> <u>Specification</u> .                                                                                                                               | Required                                                                                |
| _CID   | Named object that provides the interface's compatible Plug and Play identifier.<br>This object is required and contains the value of DMT0001 if _HID contains<br>vendor specific identifier. Otherwise, this object is optional.                                                                                                                                                                              | See the<br>"Description"<br>column for this<br>object                                   |
| _STR   | Named object that evaluates to a Unicode string that may be used by an OS to provide information to an end user describing the deviceSTR is a standard device configuration control method defined in the <u>ACPI Specification</u> .                                                                                                                                                                         | Required                                                                                |
| _UID   | Named object that specifies a device's unique persistent ID, or a control method that generates itUID is a standard device configuration control method defined in the <u>ACPI Specification</u> .                                                                                                                                                                                                            | Required if more than one device                                                        |
| _CRS   | Named object that returns the interface's current resource settings. System Processor Management Interfaces are considered static resources; hence only return their defined resources. The address region definition is interface type/subtype dependentCRS is a standard device configuration control method defined in the <u>ACPI Specification</u> .                                                     | Required                                                                                |
| _STA   | Object that returns the status of the device: enabled, disabled or removed, as defined in the <u>ACPI Specification</u> . If this method is not present, the device is assumed to be enabled.                                                                                                                                                                                                                 | Recommended                                                                             |
| _IFT   | Object that specifies the interface type, as defined in the MCHI Table. (Note: _IFT and _SRV, following, have been reserved in ACPI 3.0 as names for control methods defined for MCHI.)                                                                                                                                                                                                                       | Required                                                                                |
| _SRV   | Object that specifies the specification revision, as defined in the MCHI Table.                                                                                                                                                                                                                                                                                                                               | Required                                                                                |
| _GPE   | Named object that evaluates to either an integer or a package. If _GPE evaluates to an integer, the value is the bit assignment of the SCI interrupt within the GPEx_STS register of a GPE block described in the FADT that the Service Processor Management Interface will trigger.                                                                                                                          | Required if<br>interrupt through<br>GPE is supported                                    |
|        | If _GPE evaluates to a package, then that package contains two elements. The first is an object reference to the GPE Block device that contains the GPE register that will be triggered by the interface. The second element is numeric (integer) that specifies the bit assignment of the SCI interrupt within the GPEx_STS register of the GPE Block device referenced by the first element in the package. |                                                                                         |
|        | (Note: This object is only provided if the interface supports a GPE.)                                                                                                                                                                                                                                                                                                                                         |                                                                                         |

258 259 NOTE: Normally PCI based devices are not described in ACPI name space. OS / driver should use the PCI enumeration mechanism to locate MCTP interfaces (see clause 8).

<sup>&</sup>lt;sup>1</sup> DMTF has registered the DMT0001 PNP ID with Microsoft for describing all DMTF related devices. DMTF has granted the use of DMT0001 to describe the generic Management Controller Device as defined in this specification.

#### **MCTP Host Interface Specification**

260 If the MCTP interface supports interrupts, the interrupt descriptor in \_CRS is used if the interrupt is

supported via IO (S)APIC, while \_GPE object is used if the interrupt is supported through the GPE
 register. Having both the interrupt descriptor in \_CRS and the \_GPE object in the MCTP device scope is

263 not permitted by this specification.

If the MCTP interface does not support interrupts, neither the interrupt descriptor in the \_CRS nor the
 \_GPE object will be present.

In a multi-node system where there may be more than one MCTP device in an OS domain, it is highly
 recommended that all MCTP devices be described in the ACPI name space with the \_STA returning
 enabled for the active MCTP device(s).

#### 269 9.3 Example MCTP Definition ASL Code

270 Example ASL code that defines MCTP Host interfaces is provided in the following subclauses.

#### 271 9.3.1 Example 1: KCS Interface in 64-bit Address Space

Example ASL for describing a memory-mapped KCS host interface, located in a 64-bit address space at address 0x80000FFFFC020CA2:

```
274
      Device(MI0) {
275
          Name(_HID, EISAID("DMT0001"))
276
          Name(_STR, Unicode("MCTP_KCS"))// Optional, but recommended
277
                                // for identifying MCTP host interface.
278
                                // The strings "MCTP_KCS" and "MCTP_Serial",
279
                                 // are recommended for
280
                                 // identifying the KCS and Serial
281
                                 // interfaces, respectively.
282
283
          Name(_UID, 0)
                          // UID for the primary MCTP host interface in the system
284
285
          // Returns the "Current Resources"
286
          Name(_CRS,
287
          ResourceTemplate() {
288
               QWordMemory(
289
               ResourceConsumer,
                                     11
290
               PosDecode,
                                     11
291
               MinFixed,
                                     11
292
               MaxFixed.
                                     11
293
                                     11
               NonCacheable,
294
               ReadWrite,
                                     11
295
                   // _GRA, Address granularity.
296
                                          // E.g. All 64-bits decoded.
297
                                          // _MIN, Address range minimum
                   0x80000FFFFC020CA2,
298
                                          // (System I/F base addr.)
299
                   0x80000FFFFC020CA4,
                                         // _MAX, Address range max
300
                   0x00000000000000000,
                                         // _TRA, Translation.
301
                                          // 0 for non-bridge devices
302
                   0x000000000000000002,
                                          // _LEN, Address range length
303
                                          // Resource Source Index
                        ,
304
                                          // Resource Source Name
305
                                          // A name to refer back to this resource
                        ,
306
                                          // _MTP, Nothing=>AddressRangeMemory
                        ,
307
                                          // _TTP, Translation. Nothing=>TypeStatic
```

| 308 | // TypeTranslation: This resource, which is memory            |
|-----|---------------------------------------------------------------|
| 309 | // on the secondary side of the bridge is I/O on              |
| 310 | // the primary side of the bridge.                            |
| 311 | // TypeStatic: This resource, which is memory on              |
| 312 | <pre>// the secondary side of the bridge is also memory</pre> |
| 313 | // on the primary side of the bridge.                         |
| 314 | )                                                             |
| 315 | }                                                             |
| 316 | )                                                             |
| 317 |                                                               |
| 318 | // Returns the interface type                                 |
| 319 | Method(_IFT) {                                                |
| 320 | Return(0x01) // MCTP KCS                                      |
| 321 | }                                                             |
| 322 |                                                               |
| 323 | // Returns the interface specification revision               |
| 324 | Method(_SRV) {                                                |
| 325 | Return(0x0100) // MCTP Base Specification Revision 1.0        |
| 326 | }                                                             |
| 327 |                                                               |
| 328 | // This interface does not support interrupt                  |
| 329 |                                                               |
| 330 | }                                                             |
| 331 |                                                               |

| 332               |                                                             |             |                                                                                                                                                                                                                       |  |
|-------------------|-------------------------------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 333               |                                                             |             | (informative)                                                                                                                                                                                                         |  |
| 334               |                                                             |             |                                                                                                                                                                                                                       |  |
| 335               |                                                             |             | Notation and Conventions                                                                                                                                                                                              |  |
|                   |                                                             |             |                                                                                                                                                                                                                       |  |
| 336               | Examples of notations used in this document are as follows: |             |                                                                                                                                                                                                                       |  |
| 337<br>338<br>339 | •                                                           | 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. |  |
| 340<br>341        | •                                                           | (6)         | Parentheses around a single number can be used in message field descriptions to indicate a byte field that may be present or absent.                                                                                  |  |
| 342<br>343        | •                                                           | (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.                                         |  |
| 344<br>345        | •                                                           | <u>PCle</u> | Underlined, blue text is typically used to indicate a reference to a document or specification called out in clause 2 or to items hyperlinked within the document.                                                    |  |
| 346               | •                                                           | rsvd        | Abbreviation for "reserved." Case insensitive.                                                                                                                                                                        |  |
| 347<br>348        | •                                                           | [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$ ).                                     |  |
| 349<br>350        | •                                                           | [7:5]       | A range of bit offsets. The most significant bit is on the left, the least significant bit is on the right.                                                                                                           |  |
| 351<br>352        | •                                                           | 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.                                                                                         |  |
| 353               | •                                                           | 0x12A       | A leading " $0x$ " is used to indicate a number given in hexadecimal format.                                                                                                                                          |  |
| 354               |                                                             |             |                                                                                                                                                                                                                       |  |

# 355<br/>356ANNEX B<br/>(informative)357358359Change Log

| Version | Date       | Description               |
|---------|------------|---------------------------|
| 1.0.0   | 2010-07-21 | Released as DMTF Standard |
|         |            |                           |

360