Nuvoton iBMC boards (*-bmc, npcm750-evb, quanta-gsj)
The Nuvoton iBMC chips (NPCM7xx) are a family of ARM-based SoCs that are designed to be used as Baseboard Management Controllers (BMCs) in various servers. They all feature one or two ARM Cortex-A9 CPU cores, as well as an assortment of peripherals targeted for either Enterprise or Data Center / Hyperscale applications. The former is a superset of the latter, so NPCM750 has all the peripherals of NPCM730 and more.
The NPCM750 SoC has two Cortex-A9 cores and is targeted for the Enterprise segment. The following machines are based on this chip :
- npcm750-evbNuvoton NPCM750 Evaluation board
The NPCM730 SoC has two Cortex-A9 cores and is targeted for Data Center and Hyperscale applications. The following machines are based on this chip :
- quanta-gbs-bmcQuanta GBS server BMC
- quanta-gsjQuanta GSJ server BMC
- kudo-bmcFii USA Kudo server BMC
- mori-bmcFii USA Mori server BMC
There are also two more SoCs, NPCM710 and NPCM705, which are single-core variants of NPCM750 and NPCM730, respectively. These are currently not supported by QEMU.
Supported devices
SMP (Dual Core Cortex-A9)
Cortex-A9MPCore built-in peripherals: SCU, GIC, Global Timer, Private Timer and Watchdog.
SRAM, ROM and DRAM mappings
System Global Control Registers (GCR)
Clock and reset controller (CLK)
Timer controller (TIM)
Serial ports (16550-based)
DDR4 memory controller (dummy interface indicating memory training is done)
OTP controllers (no protection features)
Flash Interface Unit (FIU; no protection features)
Random Number Generator (RNG)
USB host (USBH)
GPIO controller
Analog to Digital Converter (ADC)
Pulse Width Modulation (PWM)
SMBus controller (SMBF)
Ethernet controller (EMC)
Tachometer
Peripheral SPI controller (PSPI)
Missing devices
LPC/eSPI host-to-BMC interface, including
Keyboard and mouse controller interface (KBCI)
Keyboard Controller Style (KCS) channels
BIOS POST code FIFO
System Wake-up Control (SWC)
Shared memory (SHM)
eSPI slave interface
Ethernet controller (GMAC)
USB device (USBD)
SD/MMC host
PECI interface
PCI and PCIe root complex and bridges
VDM and MCTP support
Serial I/O expansion
LPC/eSPI host
Coprocessor
Graphics
Video capture
Encoding compression engine
Security features
Boot options
The Nuvoton machines can boot from an OpenBMC firmware image, or directly into
a kernel using the -kernel option. OpenBMC images for quanta-gsj and
possibly others can be downloaded from the OpenBMC jenkins :
The firmware image should be attached as an MTD drive. Example :
$ qemu-system-arm -machine quanta-gsj -nographic \
    -drive file=image-bmc,if=mtd,bus=0,unit=0,format=raw
The default root password for test images is usually 0penBmc.