

### **PRODUCT BRIEF**

# Pigeon Point BMR-STM32-VPX Reference Design

Board Management Reference Design for VPX and ANSI/VITA 46.11-2022

May 17, 2022

nVent
Schroff GmbH
hardware.management@nVent.com

www.pigeonpoint.com schroff.nVent.com



All nVent brands and logos are the property of nVent or its affiliated companies worldwide. nVent reserves the right to change information without prior notification.



The BMR-STM32-VPX design is one of a series of Pigeon Point Board Management Reference designs. This member of the series provides a Tier-2 or Tier-1 Intelligent Platform Management Controller (IPMC) for VPX and VITA 46.11-2022 and is based on the STM32F407 32-bit microcontroller from STMicroelectronics.

This reference design is delivered in a Pigeon Point Board Management Starter Kit (which is detailed in a separate Product Brief).

#### The Board Management Starter Kit includes:

- An STM32F407 microcontroller design that implements the core of a VITA 46.11-2022 Tier-2 or Tier-1 IPMC, working with the ARM Cortex-M4 processor and supporting peripherals. This design is ready to be adapted for your VPX plug-in module or other intelligent Field Replaceable Unit (FRU), such as a fan tray.
- Schematics for a corresponding IPMC subsystem, ready for integration into the schematic for your board, with adaptation as necessary
- Firmware for that subsystem, delivered in source form and with development tools ready for simple and quick adaptation to your requirements
- Shares much of the design with the AdvancedTCA BMR-STM32-ATCA IPMC product
- One-stop support from nVent SCHROFF for schematics, firmware and software used in developing and delivering your Pigeon Point BMR-based IPMC



The photo in the left column shows the core of a BMR-STM32-VPX IPMC. The active components are:

- The STM32F407 microcontroller.
- Dual IPMB buffers to isolate the IPMC from dual redundant System IPMB implemented on the backplane.
- An external 12 MHz crystal to provide the operating frequency and an external 32.768 kHz oscillator for the internal RTC and watchdog timer functions.

#### ANSI/VITA 46.11-2022 Tier-1 and Tier-2 IPMC

- The BMR-STM32-VPX based Tier-2 or Tier-1 IPMC complies with ANSI/VITA 46.11-2022, System Management on VPX
- PICMG HPM.1 R1.0, the Firmware Upgrade specification
- HPM.2 and HPM.3, the LAN-attached IPM Controller and DHCP-assigned Platform Management Parameters specifications (revisions R1.1 and R2.0, respectively)
- IPMI v1.5, document revision 1.1 and the relevant subset of IPMI v2.0, document revision 1.0, plus relevant errata
- HPM.2/3 and IPMI 2.0 compliance includes support for Internet Protocol version 6 (IPv6)<sup>1</sup>
- Benefits from thorough testing in ATCA context with other management components at PICMG TCA-IWs (Interoperability Workshops)
- Tested with other management components at VPX-specific VSM-IW event

#### ANSI/VITA 46.11-2022 Tier-3 IPMC

With the purchase of the Pigeon Point Board Management Starter Kit Add-on (detailed in a separate product brief) customers are able to implement an ANSI/VITA 46.11-2022 compliant Tier-3 IPMC.

 $<sup>^1</sup>$  IPv6 support is not present in ANSI/VITA 46.11; it was added to the ATCA HPM subsystem after VITA 46.11 was modeled on that subsystem. Any future IPv6 support in VITA 46.11 will likely be modeled on the ATCA support, as well



#### Full support for core hardware requirements

- 32-bit Cortex-M4 operating at 168 MHz for IPMC firmware execution
- Payload voltage monitoring (including the various power supply rails that can be delivered from a VPX backplane)
- Thermal sensors
- HPM.2-compatible direct LAN attachment interface or sideband LAN attachment interface implemented via Network Controller Sideband Interface (NC-SI), capable of handling IPMI over LAN (including Serial over LAN, HPM.1 upgrades, IPMB trace access and other HPM.2-compliant extensions)
- Dual redundant System IPMB, with VITA 46.11-compliant option to use just IPMB-A, without IPMB-B
- System IPMB supports Fast-Mode (i.e. 400 kHz) operation
- Geographic address detection from backplane
- FRU LED management
- Payload power supply controls (multiple voltage levels) using PMBus or control GPIOs, with optional persistence across IPMC resets
- Optional local System Event Log (SEL)
- Optional infrastructure for non-intelligent Rear Transition Modules
- UART-based payload interface
- UART-based serial debug interface

#### Optional support for special purpose functionality

- Telco (dry contact) alarm management
- Chassis FRU Information SEEPROM access

#### **Small footprint**

 Core IPMC can fit in the following packagedependent footprint: 33 mm x 39 mm (UFBGA176+25)

#### Comprehensive, readily adaptable firmware

- All mandatory and many optional IPMI/VPX commands supported over System IPMB
- Numerous Pigeon Point extension commands, primarily used over the payload and serial debug interfaces
- Payload alert notifications over payload interface for sensor events and receipt of reset/shutdown commands
- PICMG HPM.1 firmware upgrade support
- Simple—but highly flexible—configuration of firmware features

## Sophisticated, HPM.1-compliant support for firmware upgrades

- Firmware upgrades over any IPMI interface to the IPMC, with redundant copies and automatic fallback after failed upgrade
- IPMC is fully functional during upgrade
- Bootloader can be upgraded without using JTAG
- Framework for managing firmware upgrades that include changes in data structures that are preserved across IPMC resets to eliminate disruptive upgrades
- IPMC FRU Information implemented as additional HPM.1 component, allowing FRU Information upgrades independently of firmware
- Optional upgrades via IPMI over LAN interface
- Open source ipmitool supplied as upgrade agent
- HPM.1 compliance means that any compliant upgrade agent can upgrade any compliant IPMC

#### Optional support for non-intelligent Rear Transition Modules (RTM)

- Includes specific hardware and firmware support for interface between front board and RTM
- Allows compliance with VITA 46.11 requirements regarding how an RTM is represented by the IPMC

#### **Optional Simple Network Stack**

- Ethernet layer, including drivers for STM32F407 Ethernet MAC
- Internet Protocol (IP) layer, which cooperates with ARP module to resolve IP address to MAC addresses
- IP-based protocol layer, including UDP and ICMP
- Provides foundation for application protocols, such as RMCP and RMCP+



## Choice of serial interface protocols (SIPL variants) supported via UARTs to payload processor and serial debug interface

- SIPL-TM, based on IPMI-defined Terminal Mode of the Serial/Modem Interface,
- SIPL-BM based on IPMI-defined Basic Mode,
- Either protocol selectable individually for either serial interface
- SIPL-TM: human-oriented and ASCII-based, intended primarily for the serial debug interface
- SIPL-BM: machine-oriented and binary-based, intended primarily for the UART-based payload interface
- Both protocols use encoded forms of raw IPMI messages, which are handled by the IPMC essentially like IPMB messages

#### **Optional HPM.2 IPMI over LAN**

- Primary client of simple network stack
- IPMI 2.0 compliant implementation of extended Remote Management Control Protocol (RMCP+), including session establishment
- RMCP+ compliant authentication, integrity and confidentiality, specifically via the following algorithms (all using IPMI 2.0compliant random number generation):
  - Authentication: HMAC-SHA1
  - Integrity: HMAC-SHA1-96
  - Confidentiality: AES-CBC-128
- IPMI over LAN and SoL payload types in RMCP+, with framework for supporting further payload types
- Enables HPM.1 firmware upgrades and HPM.2 IPMI trace collection via LAN channel
- Optional HPM.3 IPv4 or IPv6 parameter assignment via direct interaction with DHCPv4 or DHCPv6 server or by Chassis Manager<sup>2</sup> or other proxy
- Supported LAN interfaces with STM32F407 RMII-equipped Ethernet MAC include:
  - NC-SI<sup>3</sup>, tested with selected Intel NCs

 Direct Ethernet, where the LAN connection is dedicated to management traffic, not shared with the payload



#### Optional HPM.2 Serial over LAN (SoL)

- Uses HPM.2 IPMI over LAN facility to support Serial over LAN via NC-SI or a direct Ethernet connection
  - Payload SoL requires separate physical UART connection between payload and IPMC
  - SoL for IPMC serial debug interface available, also
  - HPM.2 SOL extensions allow up to 15 concurrent SOL sessions, each with specific serial ports accessible to the IPMC, user chosen from up to 255 physical on-board serial ports
- Supplied open source ipmitool can be used as SoL client

<sup>&</sup>lt;sup>2</sup> The Pigeon Point Chassis Manager can be configured to assign IPv4 address parameters to LAN-attached IPMCs via HPM.3-defined mechanisms.

<sup>&</sup>lt;sup>3</sup> NC-SI is an open specification published by the Distributed Management Task Force (DMTF, www.dmtf.org) that uses the Reduced Media Independent Interface (RMII) as the physical transport between the network and management controllers.



#### **Optional local System Event Log (SEL)**

- Requires SEEPROM storage on board
- IPMI compliant System Event Log for events generated on the FRU(s) represented by the IPMC
- Can provide a useful historical record of events that have been recorded during operation of a board, perhaps for use in board diagnosis at a maintenance depot
- Events are also forwarded to Chassis Manager, as required by VITA 46.11

#### Optional support for persistent modifications to Sensor Data Records

- Non-volatile copy of SDR Repository can be configured in on-board SEEPROM
- Sensor threshold and hysteresis values can be configured dynamically via Pigeon Point extension commands, and are thereafter persistent across power cycles and resets of the board

#### Optional support for payload-controlled sensors

- Allows sensors that are implemented by the payload (e.g. an I<sup>2</sup>C sensor connected to the payload CPU) but exposed by the IPMC as its own
- Covers discrete and threshold sensors

## Optional support for persistent configuration parameters

- Parameters preserve values across IPMC power cycles and resets
- Used for most persistent data, such as serial port parameters, LAN and SoL parameters
- Framework for such treatment of other parameters, including those in custom firmware extensions

## Simple, but powerful, firmware configuration mechanisms

- Configuration variables in a single config.h source file parameterize and determine inclusion/exclusion of subsystems during firmware image build
- Binary configuration files for FRU Information and Sensor Data Records (SDR) merged into firmware image
- FRU Information and SDR files produced from textual representations by special supplied compilers

## Comprehensive Cortex-M4 development environment

- Linux- or Windows-based cross GNU C compiler and binary utilities for Cortex-M4 processor (available for download from a third-party web site)
- GNU MCU Eclipse support
- JTAG-based firmware download using ST-LINK
   JTAG programmer from STMicroelectronics

#### Numerous extensions beyond required IPMI/ VITA 46.11/HPM.1 commands and functionality

- Warm Reset
- · Get Device GUID
- Set BMC Global Enables
- Reset Watchdog Timer
- Set Watchdog Timer
- Get Watchdog Timer
- Get BMC Global Enables
- Clear Message Flags
- Get Message Flags
- Get Message
- Send Message
- Get System GUID
- Set User Name
- Get/Set Sensor Hysteresis
- Get/Set Sensor Thresholds
- Get/Set Sensor Event Enable
- Re-arm Sensor Events
- Get Sensor Event Status
- Get Sensor Type
- Activate/Deactivate Payload
- Suspend/Resume Payload Encryption
- Get Payload Activation Status
- Get Payload Instance Info
- Get/Set User Payload Access
- Get Channel Payload Support
- Get Channel Payload Version
- Get Channel OEM Payload Info Command
- Get/Set SOL Configuration Parameters
- FRU Control
  - Graceful Reboot and Issue Diagnostic Interrupt options
- Get FRU LED Properties
- Get LED Color Capabilities
- Get/Set FRU LED State
  - Lamp Test function
- Set FRU Activation
- Get FAN Speed Properties
- Get/Set Fan Level
- Get IPMB Link Info



- Get/Set FRU Persistent Control
- FRU Persistent Control Capabilities
- Get Power Supply Capabilities
- Get/Set Power Supply Status
- Abort Firmware Upgrade
- Query Self-test Results
- Query Rollback Status
- Initiate Manual Rollback

## The following VITA 46.11-2022 commands are only supported with a Pigeon Point Tier-3 IPMC:

- Get/Set Command Enables
- Get/Set Configurable Command Sub-function Enables
- Get NetFn Support
- Get OEM NetFn IANA Support
- Get FRU Hash
- Get Payload Mode Capabilities
- Set Payload Mode
- Get Write Protect Capabilities
- Get/Set Write Protect Enables
- Get Control Bits Capabilities
- Get/Set Control Bits
- Get/Set Bridged Command Enables
- Get/Set Bridged Command Sub-function Enables
- Get Bridged NetFn Support
- Get/Set Bridged NetFn Policy

#### **Rich set of Pigeon Point extension commands**

- All extension commands implemented as IPMI-compliant OEM messages
- Get Status
- Get/Set Serial Interface Properties
- Get/Set Debug Level
- Get/Set Hardware Address
- Get/Set Payload Communication Timeout
- Disable/Enable Payload Control
- Reset IPMC
- Hang IPMC<sup>4</sup>
- Graceful Reset
- Diagnostic Interrupt Results
- Set/Clear Telco Alarm
- Get Telco Alarm Sensor Number
- Get/Set Payload Shutdown Timeout
- Get/Set Local FRU LED State
- Update Discrete Sensor
- Update Threshold Sensor
- Set EEPROM SDR Data
- Set EEPROM SDR Hysteresis
- Set EEPROM SDR Thresholds
- Reset EEPROM SDR Repository
- Get/Set GPIO Signal State
- Reset Non-Volatile Parameters and Reboot
- Get/Set FRU Info Write-Protect State

#### **Reference Implementation**

A bench top implementation called the BMR-STM32-IPMC-BTR is shown on the next page. In addition to the BMR-STM32-VPX core, the board includes implementations of optional IPMC features and numerous LEDs, switches and headers to allow lab experimentation with the behavior of the IPMC. This board is also used with BMR-STM32-ATCA solutions and contains components supporting those solutions that are not used in a VPX context. Below the photo is a block diagram of a BMR-STM32-VPX based IPMC.

Pigeon Point BMR-STM32-VPX Reference Design

<sup>&</sup>lt;sup>4</sup> This function is used to test the IPMC watchdog.





