# Card Management Solution Subsystem v1.0

# **Product Guide**

Vivado Design Suite

PG348 (v1.0) May 22, 2019





# Table of Contents

| Chapter 1: Introduction                  | 4  |
|------------------------------------------|----|
| Features                                 | 6  |
| IP Facts                                 | 6  |
| Chapter 2: Overview                      | 7  |
| Applications                             | 7  |
| Unsupported Features                     | 7  |
| Licensing and Ordering                   | 8  |
| Chapter 3: Product Specification         | 9  |
| Performance                              | 9  |
| Resource Utilization                     | 9  |
| Port Descriptions                        | 10 |
| Register Space                           |    |
| Chapter 4: Designing with the Subsystem  | 17 |
| Clocking                                 | 17 |
| Resets                                   | 17 |
| Addressing                               |    |
| Chapter 5: Design Flow Steps             |    |
| Customizing and Generating the Subsystem |    |
| Constraining the Subsystem               | 19 |
| Simulation                               |    |
| Synthesis and Implementation             | 20 |
| Appendix A: Upgrading                    |    |
| Appendix B: Debugging                    | 22 |
| Finding Help on Xilinx.com               | 22 |
| Debug Tools                              |    |
| Hardware Debug                           | 24 |



| Appendix C: Additional Resources and Legal Notices | 25 |
|----------------------------------------------------|----|
| Xilinx Resources                                   | 25 |
| Documentation Navigator and Design Hubs            | 25 |
| References                                         | 25 |
| Revision History                                   |    |
| Please Read: Important Legal Notices               |    |





# Introduction

The Card Management Solution Subsystem (CMS Subsystem) is a MicroBlaze<sup>™</sup> based design compatible with U200 and U250 Alveo<sup>™</sup> Acceleration Boards. CMS Firmware autonomously reads sensor information from the TI MSP432 satellite controller over UART and write instantaneous, maximum and average values to a shared memory for collection by host software. Sensor information is monitored and gathered for:

- Voltages
- Currents
- Temperatures
- Fan Speed

The CMS solution includes the following functions:

- A MicroBlaze<sup>™</sup> microprocessor and firmware solution. Software configuration of the CMS subsystem is not required (the CMS is fixed function).
- CMS firmware polls for sensor information (100ms poll) from the satellite controller (TI MSP432) over a UART interface with GPIO handshake lines.
- CMS firmware processes sensor information and writes instantaneous, maximum and average values to a shared memory (memory mapped) for collection by host software.
- Host software polls shared memory for updated sensor information. (CMS does not interrupt the host.)





#### Figure 1: Card Management Solution Subsystem Block Diagram

PG348 (v1.0) May 22, 2019 CMS Subsystem Product Guide



### **Features**

- Voltage Monitoring: Reports key voltage rails from Satellite Controller.
- Current Monitoring: Reports key current values from Satellite Controller.
- Temperature Monitoring: Reports key temperatures from Satellite Controller.
- Fan Speed Monitoring: Reports fan speed from local fan via Satellite Controller.

Note: Fan speed is reported only for active cards with local fans - Passive cards do not contain fans.

|                                                   | LogiCORE™ IP Facts Table                                                    |  |
|---------------------------------------------------|-----------------------------------------------------------------------------|--|
|                                                   | Subsystem Specifics                                                         |  |
| Supported Device Family <sup>1</sup> UltraScale+™ |                                                                             |  |
|                                                   | <i>Note</i> : This solution is targeted to the U200 and U250 boards.        |  |
| Supported User Interfaces                         | AXI4-Lite                                                                   |  |
| Resources                                         | Performance and Resource Use web page                                       |  |
|                                                   | Provided with Subsystem                                                     |  |
| Design Files                                      | IP integrator HIP Subsystem                                                 |  |
| Example Design                                    | Not Provided                                                                |  |
| Test Bench                                        | Not Provided                                                                |  |
| Constraints File                                  | nstraints File Xilinx Constraints File                                      |  |
| Simulation Model                                  | imulation Model Not Provided                                                |  |
| Supported S/W Driver N/A                          |                                                                             |  |
|                                                   | Tested Design Flows <sup>2</sup>                                            |  |
| Design Entry                                      |                                                                             |  |
| Simulation                                        | For supported simulators, see the Xilinx Design Tools: Release Notes Guide. |  |
| Synthesis                                         |                                                                             |  |
|                                                   | Support                                                                     |  |
|                                                   | Provided by Xilinx at the Xilinx Support web page                           |  |

### **IP Facts**

Notes:

1. For a complete list of supported devices, see the Vivado® IP catalog.

2. For the supported versions of the tools, see the Xilinx Design Tools: Release Notes Guide.



# Overview

# **Applications**

The CMS Subsystem subsystem is designed for in-band card management systems for plug-in PCIe<sup>®</sup> cards for servers typically deployed in data centers.

A typical configuration deployment configuration is shown in the following figure.

#### Figure 2: CMS Subsystem Typical Configuration



X22661-050219

### **Unsupported Features**

The following features of the standard are not supported in the subsystem:

- Firmware upgrade.
- Watchdog.



## **Licensing and Ordering**

This Xilinx<sup>®</sup> LogiCORE<sup>™</sup> IP module is provided at no additional cost with the Xilinx Vivado<sup>®</sup> Design Suite under the terms of the Xilinx End User License.

Information about other Xilinx<sup>®</sup> LogiCORE<sup>™</sup> IP modules is available at the Xilinx Intellectual Property page. For information about pricing and availability of other Xilinx<sup>®</sup> LogiCORE IP modules and tools, contact your local Xilinx sales representative.



# **Product Specification**

### Performance

For full details about performance and resource use, visit the Performance and Resource Use web page.

### **Resource Utilization**

For full details about performance and resource use, visit the Performance and Resource Use web page.





## **Port Descriptions**

The CMS Subsystem ports are shown in the following figure.

Figure 3: CMS Subsystem IP Symbol



### I/O Signal Description

| Table 1: | CMS Subsystem | <b>I/O Descriptions</b> |
|----------|---------------|-------------------------|
|----------|---------------|-------------------------|

| Port Name         | I/O | Clock          | Description                                                                                                             |
|-------------------|-----|----------------|-------------------------------------------------------------------------------------------------------------------------|
| s_axi_ctrl_mgmt   | I/O | aclk_ctrl_mgmt | AXI4-Lite Control Management Slave interface                                                                            |
| aclk_ctrl_mgmt    | Ι   | N/A            | AXI4-Lite Control Management Clock Pin (50MHz)                                                                          |
| aresetn_ctrl_mgmt | Ι   | aclk_ctrl_mgmt | AXI4-Lite Control Management Reset Pin. Active-<br>Low reset.                                                           |
| clk_cmc           | Ι   | clk_cmc        | Card Management Controller Clock (50MHz). This port should be connected to a free running clock available in the design |
| clk_cmc_locked    | I   | N/A            | Card Management Controller Clock MMCM<br>'Locked' Signal                                                                |
| satellite_gpio    | 0   | clk_cmc        | GPIO signals to/from MSP432 Satellite Controller                                                                        |
| satellite_uart    | 0   | clk_cmc        | UART interface to MSP432 Satellite Controller                                                                           |

# **Register Space**

| Table 2: | CMS Subsystem | <b>Register</b> A | ddress Space |
|----------|---------------|-------------------|--------------|
|----------|---------------|-------------------|--------------|

| Address (hex)     | Name     | Access Type                         | Description                   |
|-------------------|----------|-------------------------------------|-------------------------------|
| 0x000000-0x3FFFC  | Reserved | N/A                                 | Reserved                      |
| 0x040000-0x04FFFC | REG_MAP  | See REG_MAP Register<br>Definitions | Host/CMS shared memory<br>map |
| 0x050000-0x07FFFC | Reserved | N/A                                 | Reserved                      |





#### Table 2: CMS Subsystem Register Address Space (cont'd)

| Address (hex) | Name          | Access Type | Description                               |
|---------------|---------------|-------------|-------------------------------------------|
| 0×080000      | MB_RESETN_REG | RW          | Microblaze reset register.<br>Active low. |

#### Table 3: REG\_MAP Register Definitions (0x040000)

| Address (hex) | Name            | Access Type | Description                                                                                                                                                                                 |
|---------------|-----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0000        | REG_MAP_ID_REG  | RO          | Register Map ID. (0x74736574)                                                                                                                                                               |
| 0x0004        | FW_VERSION_REG  | RO          | Firmware Version (0x001ECF1C)                                                                                                                                                               |
| 0x0008        | STATUS_REG      | RO          | CMS Status Register<br>31:28 MSP432 Mode (Normal = 1)<br>27:0 Reserved                                                                                                                      |
| 0x000C        | ERROR_REG       | RO          | CMS Error Register<br>31:28 Reserved<br>27 MSP432 Communication Error (1=Error, use<br>CONTROL_REG to clear)<br>26:0 Reserved                                                               |
| 0x0010-0x0014 | Reserved        | N/A         | N/A                                                                                                                                                                                         |
| 0x0018        | CONTROL_REG     | RW          | CMS Control Register<br>31:7 Reserved<br>6 Set to reboot Microblaze<br>5:2 Reserved<br>1 Set to Reset ERROR_REG self clearing<br>0 Set to reset MAX and AVG sensor values, self<br>clearing |
| 0x001C        | Reserved        | N/A         | N/A                                                                                                                                                                                         |
| 0x0020        | 12V_PEX_MAX_REG | RO          | 12V_PEX Max Voltage.<br>Unsigned 32b int (mV)                                                                                                                                               |
| 0x0024        | 12V_PEX_AVG_REG | RO          | 12V_PEX Average Voltage.<br>Unsigned 32b int (mV)                                                                                                                                           |
| 0x0028        | 12V_PEX_INS_REG | RO          | 12V_PEX Instantaneous Voltage.<br>Unsigned 32b int (mV)                                                                                                                                     |
| 0x002C        | 3V3_PEX_MAX_REG | RO          | 3V3_PEX Max Voltage.<br>Unsigned 32b int (mV)                                                                                                                                               |
| 0x0030        | 3V3_PEX_AVG_REG | RO          | 3V3_PEX Average Voltage.<br>Unsigned 32b int (mV)                                                                                                                                           |
| 0x0034        | 3V3_PEX_INS_REG | RO          | 3V3_PEX Instantaneous Voltage.<br>Unsigned 32b int (mV)                                                                                                                                     |
| 0x0038        | 3V3_AUX_MAX_REG | RO          | 3V3_AUX Max Voltage.<br>Unsigned 32b int (mV)                                                                                                                                               |
| 0x003C        | 3V3_AUX_AVG_REG | RO          | 3V3_AUX Average Voltage.<br>Unsigned 32b int (mV)                                                                                                                                           |
| 0x0040        | 3V3_AUX_INS_REG | RO          | 3V3_AUX Instantaneous Voltage.<br>Unsigned 32b int (mV)                                                                                                                                     |



| Table 3: | <b>REG_MAP</b> | Register | Definitions | (0x040000) | (cont'd) |
|----------|----------------|----------|-------------|------------|----------|
|----------|----------------|----------|-------------|------------|----------|

| Address (hex) | Name                    | Access Type           | Description                         |                                   |
|---------------|-------------------------|-----------------------|-------------------------------------|-----------------------------------|
| 0×0044        | 12V ALIX MAX REG        | RO                    | 12V_AUX Max Voltage.                |                                   |
| 0X0044        |                         | ĸŎ                    | Unsigned 32b int (mV)               |                                   |
| 0x0048        | 12V ALIX AVG REG        | RO                    | 12V_AUX Average Voltage.            |                                   |
| 0,0040        | 120_404_404_600         | KO                    | Unsigned 32b int (mV)               |                                   |
| 0×004C        | 12V ALIX INS REG        | RO                    | 12V_AUX Instantaneous Voltage.      |                                   |
| 0,0040        | 124_AOA_1145_REG        | KO                    | Unsigned 32b int (mV)               |                                   |
| 0×0050        |                         | PO                    | DDR4 VPP BTM Max Voltage.           |                                   |
| 0,0050        |                         | KO                    | Unsigned 32b int (mV)               |                                   |
| 0,0054        |                         | PO                    | DDR4 VPP BTM Average Voltage.       |                                   |
| 0X0034        |                         | ĸŎ                    | Unsigned 32b int (mV)               |                                   |
| 0,0005.8      |                         | DO                    | DDR4 VPP BTM Instantaneous Voltage. |                                   |
| 0X0058        | DDR4_VPP_BTM_INS_REG    | ĸŬ                    | Unsigned 32b int (mV)               |                                   |
| 0,005.0       |                         | DO                    | SYS_5V5 Max Voltage.                |                                   |
| UXUUSC        | STS_SVS_WAA_REG         | ĸŬ                    | Unsigned 32b int (mV)               |                                   |
| 0.0000        |                         |                       | SYS_5V5 Average Voltage.            |                                   |
| 0x0060        | SYS_SVS_AVG_REG         | RU                    | Unsigned 32b int (mV)               |                                   |
| 0.00004       |                         |                       | SYS_5V5 Instantaneous Voltage.      |                                   |
| 0X0064        | SYS_SVS_INS_REG         | RU                    | Unsigned 32b int (mV)               |                                   |
| 00000         |                         |                       | VCC1V2_TOP Max Voltage.             |                                   |
| 0X0068        | VCCTV2_TOP_IMAX_REG     | RU                    | Unsigned 32b int (mV)               |                                   |
| 0.00000       |                         |                       |                                     | VCC1V2_TOP Average Voltage.       |
| 0x006C        | VCCTV2_TOP_AVG_REG      | RU                    | Unsigned 32b int (mV)               |                                   |
| 00070         |                         |                       |                                     | VCC1V2_TOP Instantaneous Voltage. |
| 0x0070        | VCCTV2_TOP_INS_REG      | RU                    | Unsigned 32b int (mV)               |                                   |
| 0.0074        |                         | 50                    | VCC1V8 Max Voltage.                 |                                   |
| 0x0074        | VCC1V8_MAX_REG          | RO                    | Unsigned 32b int (mV)               |                                   |
| 00070         |                         |                       | VCC1V8 Average Voltage.             |                                   |
| 0X0078        | VCCTV8_AVG_REG          | RU                    | Unsigned 32b int (mV)               |                                   |
| 0.0076        |                         | 50                    | VCC1V8 Instantaneous Voltage.       |                                   |
| 0x007C        | VCCTV8_INS_REG          | RU                    | Unsigned 32b int (mV)               |                                   |
| 00000         |                         |                       | VCC0V85 Max Voltage.                |                                   |
| 0x0080        | VCC0V85_MAX_REG         | RU                    | Unsigned 32b int (mV)               |                                   |
| 0.0004        |                         | 50                    | VCC0V85 Average Voltage.            |                                   |
| 0x0084        | VCC0V85_AVG_REG         | RO                    | Unsigned 32b int (mV)               |                                   |
| 00000         |                         |                       | VCC0V85 Instantaneous Voltage.      |                                   |
| 0X0088        | VCCUV85_INS_REG         | RO                    | Unsigned 32b int (mV)               |                                   |
| 0.0000        |                         | 50                    | DDR4_VPP_TOP Max Voltage.           |                                   |
| UXUU&C        | DDK4_VPP_IOP_MAX_KEG    | RO                    | Unsigned 32b int (mV)               |                                   |
| 00000         |                         |                       | DDR4_VPP_TOP Average Voltage.       |                                   |
| 0x0090        | DDR4_VPP_TOP_AVG_REG RO | Unsigned 32b int (mV) |                                     |                                   |
| 00001         |                         |                       | DDR4_VPP_TOP Instantaneous Voltage. |                                   |
| 0X0094        | DDK4_VPP_IOP_INS_REG    | RO                    | Unsigned 32b int (mV)               |                                   |



| Address (hex) | Name                 | Access Type                           | Description                         |
|---------------|----------------------|---------------------------------------|-------------------------------------|
| 0x0098        | MGTOV9AVCC MAX REG   | RO                                    | MGT0V9AVCC Max Voltage.             |
| 0,0050        |                      |                                       | Unsigned 32b int (mV)               |
| 0x009C        | MGT0V9AVCC AVG REG   | RO                                    | MGT0V9AVCC Average Voltage.         |
|               |                      |                                       | Unsigned 32b int (mV)               |
| 0x00A0        | MGTOV9AVCC INS REG   | RO                                    | MGT0V9AVCC Instantaneous Voltage.   |
|               |                      | i i i i i i i i i i i i i i i i i i i | Unsigned 32b int (mV)               |
| 0×0044        | 12V SW/ MAX REG      | RO                                    | 12V_SW Max Voltage.                 |
|               | 124_544_100 00_1020  |                                       | Unsigned 32b int (mV)               |
| 0×0048        | 12V SW AVG REG       | PO                                    | 12V_SW Average Voltage.             |
| 0,0000        | 120_300_400_600      | ĸo                                    | Unsigned 32b int (mV)               |
| 0×004C        | 12V SWI INS DEC      | PO                                    | 12V_SW Instantaneous Voltage.       |
| UXUUAC        | 12V_SW_1NS_REG       | RO                                    | Unsigned 32b int (mV)               |
| 0,00000       |                      | PO                                    | MGTAVTT Max Voltage.                |
| 0X00B0        | MGTAVIT_MAX_REG      | ĸŬ                                    | Unsigned 32b int (mV)               |
| 0.00004       |                      | PO                                    | MGTAVTT Average Voltage.            |
| 0X00B4        | MGTAVTT_AVG_REG      | RO                                    | Unsigned 32b int (mV)e              |
| 0.0050        |                      | 50                                    | MGTAVTT Instantaneous Voltage.      |
| 0x00B8        | MGTAVTT_INS_REG      | RO                                    | Unsigned 32b int (mV)               |
| 0.0000        |                      | 50                                    | VCC1V2_BTM Max Voltage.             |
| 0X00BC        | VCC1V2_BIM_MAX_REG   | RO                                    | Unsigned 32b int (mV)               |
| 0.0050        |                      |                                       | VCC1V2_BTM Average Voltage.         |
| 0x00C0        | VCC1V2_BTM_AVG_REG   | RO                                    | Unsigned 32b int (mV)               |
| 0.0054        |                      |                                       | VCC1V2_BTM Instantaneous Voltage.   |
| 0x00C4        | VCC1V2_BTM_INS_REG   | RO                                    | Unsigned 32b int (mV)               |
|               |                      | 2.0                                   | 12VPEX_I_IN Max Current.            |
| 0x00C8        | 12VPEX_I_IN_MAX_REG  | RO                                    | Unsigned 32b int (mA)               |
|               |                      | 2.0                                   | 12VPEX_I_IN Average Current.        |
| UXUUCC        | 12VPEX_I_IN_AVG_REG  | RO                                    | Unsigned 32b int (mA)               |
|               |                      |                                       | 12VPEX_I_IN Instantaneous Current.  |
| 0x00D0        | 12VPEX_I_IN_INS_REG  | RO                                    | Unsigned 32b int (mA)               |
| 0.005/        |                      |                                       | 12V_AUX_I_IN Max Current.           |
| 0x00D4        | 12V_AUX_I_IN_MAX_REG | RO                                    | Unsigned 32b int (mA)               |
|               |                      |                                       | 12V_AUX_I_IN Average Current.       |
| 0x00D8        | 12V_AUX_I_IN_AVG_REG | RO                                    | Unsigned 32b int (mA)               |
|               |                      |                                       | 12V_AUX_I_IN Instantaneous Current. |
| 0x00DC        | 12V_AUX_I_IN_INS_REG | RO                                    | Unsigned 32b int (mA)               |
|               |                      |                                       | VCCINT Max Voltage.                 |
| 0×00E0        | VCCINT_MAX_REG       | RO                                    | Unsigned 32b int (mV)               |
|               |                      |                                       | VCCINT Average Voltage.             |
| 0x00E4        | VCCINT_AVG_REG       | RO                                    | Unsigned 32b int (mV)               |
|               |                      |                                       | VCCINT Instantaneous Voltage.       |
| 0x00E8        | VCCINT_INS_REG       | RO                                    | Unsigned 32b int (mV)               |

| Table 3: | REG_MAP | Register | Definitions | (0x040000) | (cont'd) |
|----------|---------|----------|-------------|------------|----------|
|----------|---------|----------|-------------|------------|----------|



| Table 3: | <b>REG_MAP</b> | Register | Definitions | (0x040000) | (cont'd) |
|----------|----------------|----------|-------------|------------|----------|
|----------|----------------|----------|-------------|------------|----------|

| Address (hex) | Name               | Access Type                           | Description                           |
|---------------|--------------------|---------------------------------------|---------------------------------------|
| 0x00EC        | VCCINT_I_MAX_REG   | RO                                    | VCCINT_I Max Current.                 |
|               |                    |                                       | Unsigned 32b int (mA)                 |
| 0x00F0        | VCCINT I AVG REG   | RO                                    | VCCINT_I Average Current.             |
|               |                    | _                                     | Unsigned 32b int (mA)                 |
| 0x00F4        | VCCINT I INS REG   | RO                                    | VCCINT_I Instantaneous Current.       |
|               |                    | i i i i i i i i i i i i i i i i i i i | Unsigned 32b int (mA)                 |
| 0×0058        | EDGA TEMP MAY PEG  | PO                                    | FPGA_TEMP Max Temperature.            |
| 0,001.0       |                    | KO                                    | Unsigned 32b int (C)                  |
| 0.0055        |                    | RO                                    | FPGA_TEMP Average Temperature.        |
| UXUUFC        | FPGA_TEMP_AVG_REG  |                                       | Unsigned 32b int (C)                  |
|               |                    |                                       | FPGA_TEMP Instantaneous Temperature.  |
| 0x0100        | FPGA_TEMP_INS_REG  | RO                                    | Unsigned 32b int (C).                 |
|               |                    |                                       | FAN TEMP Max Temperature.             |
| 0x0104        | FAN_TEMP_MAX_REG   | RO                                    | Unsigned 32b int (C)                  |
|               |                    |                                       | FAN TEMP Average Temperature.         |
| 0x0108        | FAN_TEMP_AVG_REG   | RO                                    | Unsigned 32b int (C)                  |
|               |                    |                                       | FAN TEMP Instantaneous Temperature    |
| 0x010C        | FAN_TEMP_INS_REG   | RO                                    | Unsigned 32h int (C)                  |
|               |                    |                                       |                                       |
| 0x0110        | DIMM_TEMP0_MAX_REG | RO                                    | Unsigned 32b int (C)                  |
|               |                    |                                       |                                       |
| 0x0114        | DIMM_TEMP0_AVG_REG | RO                                    | Unsigned 32b int (C)                  |
|               |                    |                                       |                                       |
| 0x0118        | DIMM_TEMP0_INS_REG | RO                                    | DIMM_TEMPO Instantaneous Temperature. |
|               |                    |                                       |                                       |
| 0x011C        | DIMM_TEMP1_MAX_REG | RO                                    | DIMM_TEMP1 Max Temperature.           |
|               |                    |                                       | Unsigned 32b int (C)                  |
| 0x0120        | DIMM_TEMP1_AVG_REG | RO                                    | DIMM_TEMP1 Average Temperature.       |
|               |                    |                                       | Unsigned 32b int (C)                  |
| 0x0124        | DIMM TEMP1_INS_REG | RO                                    | DIMM_TEMP1 Instantaneous Temperature. |
|               |                    |                                       | Unsigned 32b int (C).                 |
| 0x0128        | DIMM TEMP2 MAX REG | RO                                    | DIMM_TEMP2 Max Temperature.           |
|               |                    |                                       | Unsigned 32b int (C)                  |
| 0x012C        | DIMM TEMP2 AVG REG | RO                                    | DIMM_TEMP2 Average Temperature.       |
| 0,0120        |                    |                                       | Unsigned 32b int (C)                  |
| 0x0130        | DIMM_TEMP2_INS_REG | RO                                    | DIMM_TEMP2 Instantaneous Temperature. |
|               |                    |                                       | Unsigned 32b int (C).                 |
| 0x0134        | DIMM_TEMP3_MAX_REG | RO                                    | DIMM_TEMP3 Max Temperature.           |
|               |                    |                                       | Unsigned 32b int (C)                  |
| 0x0129        | DIMM_TEMP3_AVG_REG | RO                                    | DIMM_TEMP3 Average Temperature.       |
| 0X0138        |                    |                                       | Unsigned 32b int (C)                  |
| 0.0125        |                    | 52                                    | DIMM_TEMP3 Instantaneous Temperature. |
| UXU13C        | DIMM_TEMP3_INS_REG | RO                                    | Unsigned 32b int (C).                 |



| Table 3: | <b>REG_MAP Register Definitions (0x040000)</b> (cont'd) |  |
|----------|---------------------------------------------------------|--|
|----------|---------------------------------------------------------|--|

| Address (hex) | Name                     | Access Type          | Description                           |
|---------------|--------------------------|----------------------|---------------------------------------|
| 0×0140        | SEOR TEMPO MAY DEC       | PO                   | SE98_TEMP0 Max Temperature.           |
| 0X0140        | SL96_I LIVIF 0_IVIAA_REG | RU                   | Unsigned 32b int (C)                  |
| 0x0144        |                          | RO                   | SE98_TEMP0 Average temperature.       |
| 0,0144        | 5250_12Mil 0_X/0_X20     | KÖ                   | Unsigned 32b int (C)                  |
| 0x0148        | SEON TEMPO INS DEC       | RO                   | SE98_TEMP0 Instantaneous temperature. |
|               | 5250_12.00 0_1105_120    |                      | Unsigned 32b int (C).                 |
| 0x014C        | SE98 TEMP1 MAX REG       | RO                   | SE98_TEMP1 Max Temperature.           |
|               |                          |                      | Unsigned 32b int (C)                  |
| 0x0150        | SE98 TEMP1 AVG REG       | BO                   | SE98_TEMP1 Average Temperature.       |
|               | 5236_72MR 1_3 W 6_N20    |                      | Unsigned 32b int (C)                  |
| 0x0154        | SE98 TEMP1 INS REG       | RO                   | SE98_TEMP1 Instantaneous Temperature. |
|               | 3E90_1EMR 1_1105_KEG     |                      | Unsigned 32b int (C).                 |
| 0x0158        | SE98 TEMP2 MAX REG       | RO                   | SE98_TEMP2 Max Temperature.           |
|               |                          |                      | Unsigned 32b int (C)                  |
| 0x015C        | SE98 TEMP2 AVG REG       | RO                   | SE98_TEMP2 Average Temperature.       |
|               | 5236_72.00 2,000_020     |                      | Unsigned 32b int (C)                  |
| 0x0160        | SE98 TEMP2 INS REG       | RO                   | SE98_TEMP2 Instantaneous Temperature. |
|               | 3E90_1EMI 2_1105_11E0    |                      | Unsigned 32b int (C).                 |
| 0x0164        | EAN SPEED MAX PEG        | RO                   | FAN_SPEED Max Speed.                  |
|               |                          |                      | Unsigned 32b int (RPM)                |
| 0x0168        | EAN SPEED AVG REG        | RO                   | FAN_SPEED Average Speed.              |
|               |                          |                      | Unsigned 32b int (RPM)                |
| 0x016C        | FAN SPEED INS REG        | RO                   | FAN_SPEED Instantaneous Speed.        |
|               |                          |                      | Unsigned 32b int (RPM).               |
| 0×0170        | CAGE TEMP0 MAX REG       | RO                   | CAGE_TEMP0 Max Temperature.           |
|               |                          |                      | Unsigned 32b int (C)                  |
| 0x0174        | CAGE TEMP0 AVG REG       | RO                   | CAGE_TEMP0 Average Temperature.       |
|               |                          |                      | Unsigned 32b int (C)                  |
| 0x0178        | CAGE TEMP0 INS REG       | RO                   | CAGE_TEMP0 Instantaneous Temperature. |
|               |                          | _                    | Unsigned 32b int (C).                 |
| 0x017C        | CAGE TEMP1 MAX REG       | RO                   | CAGE_TEMP1 Max Temperature.           |
|               |                          |                      | Unsigned 32b int (C)                  |
| 0x0180        | CAGE TEMP1 AVG REG       | RO                   | CAGE_TEMP1 Average Temperature.       |
|               |                          | Unsigned 32b int (C) |                                       |
| 0x0184        | CAGE_TEMP1_INS_REG       | RO                   | CAGE_TEMP1 Instantaneous Temperature. |
| -             |                          |                      | Unsigned 32b int (C).                 |
| 0x0188        | CAGE TEMP2 MAX REG       | RO                   | CAGE_TEMP2 Max Temperature.           |
|               |                          |                      | Unsigned 32b int (C)                  |
| 0x018C        | CAGE_TEMP2_AVG_REG       | RO                   | CAGE_TEMP2 Average Temperature.       |
|               |                          | _                    | Unsigned 32b int (C)                  |
| 0x0190        | CAGE TEMP2 INS REG       | RO                   | CAGE_TEMP2 Instantaneous Temperature. |
| 0,0190        |                          |                      | Unsigned 32b int (C).                 |



| Address (hex) | Name               | Access Type | Description                                                    |
|---------------|--------------------|-------------|----------------------------------------------------------------|
| 0x0194        | CAGE_TEMP3_MAX_REG | RO          | CAGE_TEMP3 Max Temperature.<br>Unsigned 32b int (C)            |
| 0x0198        | CAGE_TEMP3_AVG_REG | RO          | CAGE_TEMP3 Average Temperature.<br>Unsigned 32b int (C)        |
| 0x019C        | CAGE_TEMP3_INS_REG | RO          | CAGE_TEMP3 Instantaneous Temperature.<br>Unsigned 32b int (C). |
| 0x01A0-0x025C | Reserved           | N/A         | N/A                                                            |
| 0x0260        | HBM_TEMP_MAX_REG   | RO          | HBM_TEMP Max Temperature.<br>Unsigned 32b int (C)              |
| 0x0264        | HBM_TEMP_AVG_REG   | RO          | HBM_TEMP Average Temperature.<br>Unsigned 32b int (C)          |
| 0x0268        | HBM_TEMP_INS_REG   | RO          | HBM_TEMP Instantaneous Temperature.<br>Unsigned 32b int (C).   |

#### Table 3: **REG\_MAP Register Definitions (0x040000)** (cont'd)





# Designing with the Subsystem

This section includes guidelines and additional information to facilitate designing with the subsystem.

# Clocking

#### Table 5: Clocks

| Clock          | Description                                                                                                                                                   |  |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| clk_cmc        | This clock pin should be connected to a free-running clock available in the design. The clock drives the CMS Subsystem MicroBlaze and associated peripherals. |  |  |
| aclk_ctrl_mgmt | This clock pin should be connected to the AXI clock used in the design.                                                                                       |  |  |

### Resets

The CMS Subsystem uses a single active-low reset pin, aresetn\_ctrl\_mgmt. This reset should be synchronous to aclk\_ctrl\_mgmt.

## Addressing

The CMS Subsystem requires 1M of Address space ( $0 \times 10_{-}000$ ). The selected address segment offset must be in the range  $0 \times 0000000 - 0 \times 01F00000$  at a 1M boundary ( $0 \times 00_{-}000$ ,  $0 \times 10_{-}000$ ,  $0 \times 20_{-}000$  ...).





# **Design Flow Steps**

This section describes customizing and generating the subsystem, constraining the subsystem, and the simulation, synthesis, and implementation steps that are specific to this IP subsystem. More detailed information about the standard Vivado<sup>®</sup> design flows and the IP integrator can be found in the following Vivado Design Suite user guides:

- Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994)
- Vivado Design Suite User Guide: Designing with IP (UG896)
- Vivado Design Suite User Guide: Getting Started (UG910)
- Vivado Design Suite User Guide: Logic Simulation (UG900)

### **Customizing and Generating the Subsystem**

This section includes information about using Xilinx<sup>®</sup> tools to customize and generate the subsystem in the Vivado<sup>®</sup> Design Suite.

If you are customizing and generating the subsystem in the Vivado IP integrator, see the Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994) for detailed information. IP integrator might auto-compute certain configuration values when validating or generating the design. To check whether the values do change, see the description of the parameter in this chapter. To view the parameter value, run the validate\_bd\_design command in the Tcl console.

You can customize the IP for use in your design by specifying values for the various parameters associated with the IP subsystem using the following steps:

- 1. Select the IP from the IP catalog.
- 2. Double-click the selected IP or select the Customize IP command from the toolbar or rightclick menu.

For details, see the Vivado Design Suite User Guide: Designing with IP (UG896) and the Vivado Design Suite User Guide: Getting Started (UG910).



### **Output Generation**

For details, see the Vivado Design Suite User Guide: Designing with IP (UG896).

### **Constraining the Subsystem**

#### **Required Constraints**

The following constraints are required for this subsystem

#### Alveo U200/U250 IO Constraints

• Satellite UART:

```
set_property PACKAGE_PIN BA19 [get_ports satellite_uart_rxd]
set_property -dict {IOSTANDARD LVCMOS12} [get_ports satellite_uart_rxd]
set_property PACKAGE_PIN BB19 [get_ports satellite_uart_txd]
set_property -dict {IOSTANDARD LVCMOS12 DRIVE 4} [get_ports
satellite_uart_txd]
```

• Satellite GPIO:

```
set_property PACKAGE_PIN AR20 [get_ports satellite_gpio_tri_io[0]]
set_property -dict {IOSTANDARD LVCMOS12 DRIVE 4} [get_ports
satellite_gpio_tri_io[0]]
set_property PACKAGE_PIN AM20 [get_ports satellite_gpio_tri_io[1]]
set_property -dict {IOSTANDARD LVCMOS12 DRIVE 4} [get_ports
satellite_gpio_tri_io[1]]
set_property PACKAGE_PIN AM21 [get_ports satellite_gpio_tri_io[2]]
set_property -dict {IOSTANDARD LVCMOS12 DRIVE 4} [get_ports
satellite_gpio_tri_io[2]]
set_property PACKAGE_PIN AM21 [get_ports satellite_gpio_tri_io[3]]
set_property PACKAGE_PIN AM21 [get_ports satellite_gpio_tri_io[3]]
set_property -dict {IOSTANDARD LVCMOS12 DRIVE 4} [get_ports
satellite_gpio_tri_io[3]]
```

#### Device, Package, and Speed Grade Selections

This section is not applicable for this IP subsystem.

#### **Clock Frequencies**

This section is not applicable for this IP subsystem.

#### **Clock Management**

This section is not applicable for this IP subsystem.



#### **Clock Placement**

This section is not applicable for this IP subsystem.

#### Banking

This section is not applicable for this IP subsystem.

#### **Transceiver Placement**

This section is not applicable for this IP subsystem.

#### I/O Standard and Placement

This section is not applicable for this IP subsystem.

## Simulation

For comprehensive information about Vivado<sup>®</sup> simulation components, as well as information about using supported third-party tools, see the *Vivado Design Suite User Guide: Logic Simulation* (UG900).

## **Synthesis and Implementation**

For details about synthesis and implementation, see the Vivado Design Suite User Guide: Designing with IP (UG896).





## Appendix A

# Upgrading

This appendix is not applicable for the first release of the subsystem.





## Appendix B

# Debugging

This appendix includes details about resources available on the Xilinx<sup>®</sup> Support website and debugging tools.

If the IP requires a license key, the key must be verified. The Vivado<sup>®</sup> design tools have several license checkpoints for gating licensed IP through the flow. If the license check succeeds, the IP can continue generation. Otherwise, generation halts with an error. License checkpoints are enforced by the following tools:

- Vivado Synthesis
- Vivado Implementation
- write\_bitstream (Tcl command)

**Note:** IP license level is ignored at checkpoints. The test confirms a valid license exists. It does not check IP license level.

# Finding Help on Xilinx.com

To help in the design and debug process when using the subsystem, the Xilinx Support web page contains key resources such as product documentation, release notes, answer records, information about known issues, and links for obtaining further product support. The Xilinx Community Forums are also available where members can learn, participate, share, and ask questions about Xilinx solutions.

### Documentation

This product guide is the main document associated with the subsystem. This guide, along with documentation related to all products that aid in the design process, can be found on the Xilinx Support web page or by using the Xilinx<sup>®</sup> Documentation Navigator. Download the Xilinx Documentation Navigator from the Downloads page. For more information about this tool and the features available, open the online help after installation.





### **Solution Centers**

See the Xilinx Solution Centers for support on devices, software tools, and intellectual property at all stages of the design cycle. Topics include design assistance, advisories, and troubleshooting tips.

### **Answer Records**

Answer Records include information about commonly encountered problems, helpful information on how to resolve these problems, and any known issues with a Xilinx product. Answer Records are created and maintained daily ensuring that users have access to the most accurate information available.

Answer Records for this subsystem can be located by using the Search Support box on the main Xilinx support web page. To maximize your search results, use keywords such as:

- Product name
- Tool message(s)
- Summary of the issue encountered

A filter search is available after results are returned to further target the results.

### **Technical Support**

Xilinx provides technical support on the Xilinx Community Forums for this LogiCORE<sup>™</sup> IP product when used as described in the product documentation. Xilinx cannot guarantee timing, functionality, or support if you do any of the following:

- Implement the solution in devices that are not defined in the documentation.
- Customize the solution beyond that allowed in the product documentation.
- Change any section of the design labeled DO NOT MODIFY.

To ask questions, navigate to the Xilinx Community Forums.

### **Debug Tools**

There are many tools available to address CMS Subsystem design issues. It is important to know which tools are useful for debugging various situations.



### Vivado Design Suite Debug Feature

The Vivado<sup>®</sup> Design Suite debug feature inserts logic analyzer and virtual I/O cores directly into your design. The debug feature also allows you to set trigger conditions to capture application and integrated block port signals in hardware. Captured signals can then be analyzed. This feature in the Vivado IDE is used for logic debugging and validation of a design running in Xilinx<sup>®</sup> devices.

The Vivado logic analyzer is used to interact with the logic debug LogiCORE IP cores, including:

- ILA 2.0 (and later versions)
- VIO 2.0 (and later versions)

See the Vivado Design Suite User Guide: Programming and Debugging (UG908).

## **Hardware Debug**

Hardware issues can range from link bring-up to problems seen after hours of testing. This section provides debug steps for common issues. The Vivado<sup>®</sup> debug feature is a valuable resource to use in hardware debug. The signal names mentioned in the following individual sections can be probed using the debug feature for debugging the specific problems.

### **General Checks**

Ensure that all the timing constraints for the core were properly incorporated from the example design and that all constraints were met during implementation.

- Does it work in post-place and route timing simulation? If problems are seen in hardware but not in timing simulation, this could indicate a PCB issue. Ensure that all clock sources are active and clean.
- If using MMCMs in the design, ensure that all MMCMs have obtained lock by monitoring the locked port.
- If your outputs go to 0, check your licensing.



# Appendix C

# Additional Resources and Legal Notices

### **Xilinx Resources**

For support resources such as Answers, Documentation, Downloads, and Forums, see Xilinx Support.

### **Documentation Navigator and Design Hubs**

Xilinx<sup>®</sup> Documentation Navigator (DocNav) provides access to Xilinx documents, videos, and support resources, which you can filter and search to find information. To open DocNav:

- From the Vivado<sup>®</sup> IDE, select Help → Documentation and Tutorials.
- On Windows, select Start → All Programs → Xilinx Design Tools → DocNav.
- At the Linux command prompt, enter docnav.

Xilinx Design Hubs provide links to documentation organized by design tasks and other topics, which you can use to learn key concepts and address frequently asked questions. To access the Design Hubs:

- In DocNav, click the **Design Hubs View** tab.
- On the Xilinx website, see the Design Hubs page.

Note: For more information on DocNav, see the Documentation Navigator page on the Xilinx website.

# References

These documents provide supplemental material useful with this guide:





- 1. Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994)
- 2. Vivado Design Suite User Guide: Designing with IP (UG896)
- 3. Vivado Design Suite User Guide: Getting Started (UG910)
- 4. Vivado Design Suite User Guide: Logic Simulation (UG900)

### **Revision History**

The following table shows the revision history for this document.

| Section                 | Revision Summary |  |
|-------------------------|------------------|--|
| 05/22/2019 Version 1.0  |                  |  |
| Initial Xilinx release. | N/A              |  |

### **Please Read: Important Legal Notices**

The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of Xilinx's limited warranty, please refer to Xilinx's Terms of Sale which can be viewed at https:// www.xilinx.com/legal.htm#tos; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx. Xilinx products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for use of Xilinx products in such critical applications, please refer to Xilinx's Terms of Sale which can be viewed at https://www.xilinx.com/legal.htm#tos.



#### AUTOMOTIVE APPLICATIONS DISCLAIMER

AUTOMOTIVE PRODUCTS (IDENTIFIED AS "XA" IN THE PART NUMBER) ARE NOT WARRANTED FOR USE IN THE DEPLOYMENT OF AIRBAGS OR FOR USE IN APPLICATIONS THAT AFFECT CONTROL OF A VEHICLE ("SAFETY APPLICATION") UNLESS THERE IS A SAFETY CONCEPT OR REDUNDANCY FEATURE CONSISTENT WITH THE ISO 26262 AUTOMOTIVE SAFETY STANDARD ("SAFETY DESIGN"). CUSTOMER SHALL, PRIOR TO USING OR DISTRIBUTING ANY SYSTEMS THAT INCORPORATE PRODUCTS, THOROUGHLY TEST SUCH SYSTEMS FOR SAFETY PURPOSES. USE OF PRODUCTS IN A SAFETY APPLICATION WITHOUT A SAFETY DESIGN IS FULLY AT THE RISK OF CUSTOMER, SUBJECT ONLY TO APPLICABLE LAWS AND REGULATIONS GOVERNING LIMITATIONS ON PRODUCT LIABILITY.

#### Copyright

© Copyright 2019 Xilinx, Inc. Xilinx, the Xilinx logo, Alveo, Artix, Kintex, Spartan, Versal, Virtex, Vivado, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. PCI, PCIe, and PCI Express are trademarks of PCI-SIG and used under license. All other trademarks are the property of their respective owners.

