High Performance Spacecraft Computing (HPSC) Middleware Update by Cudmore, Alan
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
National Aeronautics and
Space Administration
www.nasa.gov/spacetech
High-Performance Spaceflight Computing 
(HPSC) Middleware Update
Alan Cudmore
NASA Goddard Space Flight Center
Flight Software Systems Branch (Code 582)
Alan.P.Cudmore@nasa.gov
This is a non-ITAR presentation, for public 
release and reproduction from FSW website. 
https://ntrs.nasa.gov/search.jsp?R=20190033894 2020-03-11T13:41:06+00:00Z
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
• High Performance Spaceflight Computing (HPSC) Overview 
 HPSC Project Overview
 HPSC Chiplet Architecture
 HPSC Software Architecture
• Middleware Overview
 Middleware Project Overview
 Middleware Architecture
 Middleware Schedule/Milestones 
• Middleware Release 2
 Middleware Release 2 Overview
 High Performance Fault-Tolerant Embedded Computing (HPFEC) 
Mission Use Case
 Core Flight System (cFS) Mission Use Case
• Future Middleware Releases
 Middleware Release 3
 Middleware Release 4 and Beyond
Agenda
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
High Performance Spaceflight 
Computing (HPSC) Overview
3
HPSC Program Goals
• Dramatically advance the state of the art for spaceflight computing
• HPSC will provide a nearly two orders-of-magnitude improvement above the current 
state of the art for radiation hardened spaceflight processors, while also providing an 
unprecedented flexibility to tailor performance, power consumption, and fault 
tolerance to meet widely varying mission needs
• These advancements will provide game changing improvements in computing 
performance, power efficiency, and flexibility, which will significantly improve the 
onboard processing capabilities of future NASA and Air Force space missions
HPSC Program Funding/Management
• HPSC is funded by NASA’s Space 
Technology Mission Directorate (STMD), 
Science Mission Directorate (SMD), and 
the United States Air Force
• The HPSC project is managed by Jet 
Propulsion Laboratory (JPL), and the HPSC 
contract is managed by NASA Goddard 
Space Flight Center (GSFC)
HPSC Program Deliverables
Under the base contract, Boeing will provide:
• Prototype radiation hardened multi-core computing 
processors (Chiplets), both as bare die and as 
packaged parts
• Prototype system software which will operate on 
the Chiplets
• Evaluation boards to allow Chiplet test and 
characterization
• Chiplet emulators to enable early software 
development
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
HPSC Chiplet Architecture
4
Cortex-R52
Neon SIMD
Real Time Processing
Cortex-A53
512KB L2
FPU, 
NEON SIMD
32KB I$
32KB D$
Dual 
Cortex-R52
Neon SIMD
SP
I
PC
Ie
DD
R 
3/
4
1MB TCM
EthernetPCIe
A53 Cluster 2
A53 Cluster 1
Quad Cortex A53
FPU, NEON SIMD
L1 Cache
(64KB I$, 64KB D$)
2MB L2 Cache
High Speed Processing
Spacewire TTESRIO
I2C, SPIGPIOUARTUART
High Speed I/O
1MB 
SRAM
Power Mgmt.
PLL
Clk Gen TMR Block
Cortex M4F
Timers
Coresight
Clock Mgmt.
Interrupt 
Mgmt.
Boot Rom
Timing, Reset, 
Configuration and Health 
Low Speed I/O
JTAG NVM 
DDR 
3/4
System Bus 4MB L3 Cache
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Cortex-R52
Neon SIMD
Real Time Processing
Cortex-A53
512KB L2
FPU, 
NEON SIMD
32KB I$
32KB D$
Dual 
Cortex-R52
Neon SIMD
SP
I
PC
Ie
DD
R 
3/
4
1MB TCM
EthernetPCIe
A53 Cluster 2
A53 Cluster 1
Quad Cortex A53
FPU, NEON SIMD
L1 Cache
(64KB I$, 64KB D$)
2MB L2 Cache
High Speed Processing
Spacewire TTESRIO
I2C, SPIGPIOUARTUART
High Speed I/O
1MB 
SRAM
Power Mgmt.
PLL
Clk Gen TMR Block
Cortex M4F
Timers
Coresight
Clock Mgmt.
Interrupt 
Mgmt.
Boot Rom
Timing, Reset, 
Configuration and Health 
Low Speed I/O
JTAG NVM 
DDR 
3/4
System Bus 4MB L3 Cache
HPSC Chiplet Architecture
5
Real Time Processing Subsystem (RTPS)
• SMP or Dual lockstep R52 ARM v8-R (600 hz)
• Three 1MB Tightly Coupled Memories 
(TCM)
• FPU and NEON SIMD
• Single A53 ARM v8 compliant core(600Mhz)
• A53 w/512KB Level 2, 32KB Instruction & 
32KB Data cache
• FPU and NEON SIMD
• Separate PCIe and DDR3/DDR4 interfaces
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Cortex-R52
Neon SIMD
Real Time Processing
Cortex-A53
512KB L2
FPU, 
NEON SIMD
32KB I$
32KB D$
Dual 
Cortex-R52
Neon SIMD
SP
I
PC
Ie
DD
R 
3/
4
1MB TCM
EthernetPCIe
A53 Cluster 2
A53 Cluster 1
Quad Cortex A53
FPU, NEON SIMD
L1 Cache
(64KB I$, 64KB D$)
2MB L2 Cache
High Speed Processing
Spacewire TTESRIO
I2C, SPIGPIOUARTUART
High Speed I/O
1MB 
SRAM
Power Mgmt.
PLL
Clk Gen TMR Block
Cortex M4F
Timers
Coresight
Clock Mgmt.
Interrupt 
Mgmt.
Boot Rom
Timing, Reset, 
Configuration and Health 
Low Speed I/O
JTAG NVM 
DDR 
3/4
System Bus 4MB L3 Cache
HPSC Chiplet Architecture
6
High Performance Processing Subsystem (HPPS)
• 8 A53 ARM v8 compliant cores (800Mhz)
• Per HPPS Shared 4MB L3 cache
• Per Quad Cluster shared 2 B L2 x 2
• Per core 64KB Instruction & 64KB Data cache
• Includes FPU and NEON SI D
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Cortex-R52
Neon SIMD
Real Time Processing
Cortex-A53
512KB L2
FPU, 
NEON SIMD
32KB I$
32KB D$
Dual 
Cortex-R52
Neon SIMD
SP
I
PC
Ie
DD
R 
3/
4
1MB TCM
EthernetPCIe
A53 Cluster 2
A53 Cluster 1
Quad Cortex A53
FPU, NEON SIMD
L1 Cache
(64KB I$, 64KB D$)
2MB L2 Cache
High Speed Processing
Spacewire TTESRIO
I2C, SPIGPIOUARTUART
High Speed I/O
1MB 
SRAM
Power Mgmt.
PLL
Clk Gen TMR Block
Cortex M4F
Timers
Coresight
Clock Mgmt.
Interrupt 
Mgmt.
Boot Rom
Timing, Reset, 
Configuration and Health 
Low Speed I/O
JTAG NVM 
DDR 
3/4
System Bus 4MB L3 Cache
HPSC Chiplet Architecture
7
High Speed I/O
• 6 SRIO high speed interfaces w/4 la es per port for 
41.24Gb/s per port
• Total of 59.1GB/s of IO bandwidth 
• Embedded SRIO switch with 2 internal endpoints
• 2 Gen2 PCIe ports at 2 lanes per port 10Gb/s per port
• Total of 20Gb/s of IO bandwidth 
• 3 Time Triggered Ethernet ports at 10/100/1000Mb/s each
• 2 SpaceWire ports at 400Mb/s each
• 1 general purpose Ethernet port at 10/100/1000Mb/s
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
HPSC Software Architecture
• Middleware Layer 
 Allocate and manage processor cores, devices 
and resources to dynamically trade computational 
performance, energy management and fault 
tolerance objectives of the mission
 Provides for mission and platform configurability
 Allows Mission Integration Engineers (MIE) to 
reason about interactions between applications 
and the system
• System Software Layer
 RTOS/OS, hypervisor and low level device drivers 
for the Chiplet are provided by HPSC vendor 
University of Southern California Information 
Sciences Institute (USC-ISI)
8
System Software
Chiplet Hardware
Application Software
Middleware Software
• Layered Architecture
 Provides separation of concerns with well-defined interfaces
 Provides application developers with tools, abstractions and methodologies to 
make use of lower level HPSC SW services and Chiplet HW in a consistent 
manner
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
HPSC Software Architecture
9
Middleware Service Applications
ENET TTE SpWSRIO
A53A53A53A53
Quad Cortex-A53 Cluster
A53A53A53A53
Quad Cortex-A53 Cluster
R52R52
Cortex-R52 Cluster
A53
RTPS
TRCH
Controller
Operating System
Application A Application B Application N
Device Drivers
Yocto
LinuxRTEMS Mailbox Flash
Watch
-dog
Shared
Memory SRIO
Early Boot
U-Boot ATF BIST ...
Multicore
Machine 
InformationBoot
Timing
MemoryInterrupt Messaging ResourceArbitration
Multi-Chiplet
PowerDebug &Trace
Fault &
Redundancy
Peripheral 
IO
Application C
Deployment ChipletFDIR
External
Comms
System
Resources
Multi-Chiplet
FDIR Diagnostics
Applications
Middleware
Library
Middleware
Service Apps
System SW
/OS APIs
Chiplet
Hardware
RTOS
NOR
MRAM
DDR
RAM SRAM NAND
Power
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
System Software Layer
• Provided by vendor USC - Information Sciences Institute (USC-ISI)
 Runtime Components:
 Bootloaders:
 Custom TRCH Bootloader
 U-boot for RTPS and HPPS
 RTOS:
 RTEMS for TRCH and RTPS/R52
 Linux: 
 Yocto based Linux with KVM hypervisor for HPPS
 Chiplet Device drivers
 Memory controllers, DMA, peripheral I/O devices, GIC…
 Software Build-In System Tests (BIST(s))
 Memory test, core-cache path, cores, …
 Software-Implemented fault tolerance framework
 Development Tools:
 A software Chiplet emulator: based on QEMU
 Eclipse-based IDE with advanced performance profiling
10
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Middleware Overview
• Middleware Project Information
 A joint project between NASA Jet Propulsion Lab (JPL) and NASA Goddard Space 
Flight Center (GSFC)
 Funded by the Air Force Research Lab (AFRL)
• Middleware Objectives
 Provide applications with an efficient and consistent functions to utilize features of the 
Chiplet multicore platform for
 Resource allocation and management (e.g., cores, memories, peripheral devices)
 Configuration management
 Power and Performance management
 Fault tolerance and redundancy management
 Sharing hardware resources using a common middleware library and services
 Messaging Services
 Facilitate deployment of applications for execution with different characteristics and 
resource needs (e.g., computational needs, mission criticality, timing criticality, …)
11
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Middleware Architecture
• Middleware Service Libraries
 Middleware service library consists of building block functions with APIs that 
provide a set of application services.
 MW service library has no runtime thread context on its own.
 MW service library is called in user application context for invoking MW 
services that interacts with Chiplet devices, RTOS, OS and other services.
• Middleware Service Applications
 MW Service Applications provide a set of MW services to meet specific 
system needs once deployed. 
 MW Service Applications are executable programs with runtime context. 
Each service program is configured to a specific deployment need / 
environment via a user specified configuration file at boot time.
12
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Middleware Service Conceptual Patterns
13
Deployment
& Multicore
Programming
Machine 
Information
Services
Boot, Load
and System
Configuration
Timing
Services
Memory
Management
Interrupt
Services
Messaging
Services
Resource
Management
& Arbitration
Multi-Chiplet
Management
Power
Management
Debug &
Trace
Fault &
Redundancy
Management
Peripheral 
IO Services
Middleware Service Applications
1) Service app-specific configuration
2) Requested resources and mapping
3) MW Library service configuration 
4) SSW/OS API service configuration
5) Access to Chiplet-HW configuration
Middleware Configuration File
Middleware Service Application User Application
MW
Library
User Applications
SSW/OS
APIs
MEM
Access
1) User app-specific configuration
2) Requested resources and mapping
3) MW Library service configuration
4) SSW/OS API service configuration
5) Access to Chiplet-HW configuration
Application Configuration File
MW
Service
Apps
MW
Library
SSW/OS
APIs
Middleware Service Libraries
SSW/OS
APIs
MW
Service
Apps
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Middleware Service Libraries
14
Service Name Service Function
Deployment and Multicore Programming Support different deployment configurations on multi-core systems
Machine Information Get information about cores, clusters, Chiplets, and system
Resource Management/Arbitration Manage configuration files and assign available resources to software clients
Memory Management MMU configuration, memory allocation to applications
Interrupt Configure Interrupt controller to route interrupts to specific cores at runtime
Timing Establish, synchronize, and distribute time
Messaging Send/receive messages between tasks on the same or different cores and 
Chiplets
Power Management Power on/off setting for cores/clusters/Chiplets, and set clock rates
Debug and Trace Support software debugging and performance metrics
Boot and Load Process Provide an Initial Program Loader (IPL) and support various boot 
types/processes
Peripheral IO Allocate and configure Chiplet Peripheral I/O to software clients
Multi-Chiplet Management Configure and manage Inter-Chiplet interfaces (e.g., boot, messaging, 
resources)
Fault and Redundancy Management Fault detection (HW/SW faults) and recovery
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Middleware Service Applications
15
MW Service Application System-Level Function
Deployment Set up the system and start applications
Hardware Resource Arbitrate access to common pool of hardware
Power Apply power management policy
Diagnostics Centralize information available in system
Communications Share access to external communications device
Multiple Chiplet FDIR Coordinate FDIR activity across chiplets
Single Chiplet FDIR Coordinate FDIR activity within chiplet
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Middleware Schedule / Milestones
16
May 
2018
February
2019
October
2019
December
2019
Mid 2020 Early 2021
System 
Requirements
Review
Middleware
R1 Release
Middleware
R2 Release
Architecture
Review
Middleware
R3 Release
Middleware
R4 Release
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Middleware Release 2
• Middleware Release 2 was completed in October 2019
• Uses the HPSC System Software Release 4 from ISI:
 RTPS/R52 (AArch32) and HPPS/A53 (AArch64) tool chains
 QEMU emulation of HPPS and RTPS to support MW testing and demonstration
 RTEMS in RTPS/R52 and Yocto Linux for HPPS/A53 to run MW applications
 System software drivers to implement MW use cases (Watchdog Timer (WDT), 
mailbox, shared memory)
• Built upon the capabilities from R1
 Implemented Application Programming Interfaces (APIs) for 10 of 13 defined 
Middleware (MW) service libraries
 Started implementation on 5 new service libraries
 Improved on 5 existing service libraries
 Not all functions defined for the 10 services are implemented
 Not all MW service libraries are ported to R52/RTEMS yet
• Worked on two reference missions using MW functions for execution in 
QEMU
 JPL HPFEC application to use additional MW capabilities
 Ported the GSFC core Flight System (cFS) framework and sample applications 
to work with MW on HPPS Yocto Linux and RTPS RTEMS
17
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
JPL HPFEC Reference Mission
This JPL reference mission models 
elements found in applications for 
guidance, navigation and control 
(GNC) of aircraft and spacecraft.
The reference mission is implemented 
with six processes that use 
middleware in the following ways:
Manage start-up for processes 
and set CPU affinity
Synchronize process workloads 
on time slots
Communicate between 
processes
Time Slot 
5
Process 
7:
Camera 
Pointer
Time Slot 
4
Process 
6:
Kalman 
Filter
Time Slot 
3
Process 5:
Image 
Correlator
Time Slot 
2
Process 4:
DEM 
Constructor
Time Slot 
1
Process 2:
Pose 
Interpolator
Image 
Assembler
Time Slot 
0
Process 1:
Pose 
Updater
CPU 0 CPU 1 CPU 2 CPU 3 CPU 4 CPU 5
Manage start-up and CPU affinity
Ti
m
e 
Sy
nc
hr
on
iza
tio
n
High Performance, Fault-Tolerant Embedded Computing 
(HPFEC) Synthetic Application
18
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Network Interface to Host Ground System
cFE Core Service
cFS Reuse Application
Mission Application
cFS on HPPS/A53/Yocto Linux
Software 
Bus Network 
Middleware 
Module
Reduced Set of cFS Applications for initial HPSC Integration and Demo
cFS on 
RTPS/R52/RTEMS
Middleware Service
Middleware
Messaging
Service
(cFS Detail not shown)
Middleware
Watchdog
Service
Middleware
Timer
Service
Middleware
Machine 
Info
Service
Middleware
Power 
Mgmt
Service
Middleware
Debug/Trace
Service
Event
Services
Table
Services
Time
Services
Executive
Services
Software
Bus
Stored
Command
Software
Bus
Network
Health
&
Safety
Telemetry
Output
(Lab)
Command
Ingest
(Lab)
Scheduler
(Lab)
HPSC
cFS
App
GSFC cFS Reference Mission
19
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Middleware Release 3
• Middleware Release 3 planning will be influenced by HPSC Re-plan (Fall 
2019)
• Middleware R3 activity will include:
 Scrub and enhance MW requirements for future releases
 Specify updated requirements for R3 implementation
 Design and implement R3 release requirements
 Fault Tolerance and Redundancy Service
 Multi-Chiplet communication, timing & synchronization, boot up and 
initialization
 API for Deployment Configuration
 Enhance services from R1, R2
 Install and exercise delivered capabilities of SSW R5+ releases
 RTEMS
 Eclipse IDE
20
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Middleware Release 4 and Beyond
• Middleware Release 4 work to complete
 Complete all 13 Middleware Service Libraries
 Complete all 6 Middleware Service Applications
 Continue to test and integrate new System Software features
 Continue refining requirements
 Improve and complete documentation
• Potential deployment Tools*
 Application Characteristics Template
 Configuration Checker
 Interaction Modeling
 Schedule Generator
• Potential diagnostic Tools*
 Improved Event Visualization
 View Live Statistics
 Blackbox Recorder
21
*may depend on schedule and/or additional funding
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Acknowledgements
22
• HPSC Middleware Team:
 John Lai/JPL, Brent Morin/JPL, Dennis Kou/JPL, Joseph 
Kochocki/JPL, Sergio Maldonado/GSFC, Jonathan Wilmot/GSFC
• HPSC Project Team: 
 Rich Doyle/JPL, Rafi Some/JPL, Jim Butler/JPL, Irene 
Bibyk/GSFC, Wes Powell/GSFC
• Boeing / ISI:
 Jon Ballast/Boeing, J.P. Walters/USC-ISI
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Acronyms (1)
23
Acronym Meaning Acronym Meaning
AFRL Air Force Research Laboratory DRAM Dynamic Random Access Memory
AMBA Advanced Microcontroller Bus Architecture FCR Fault Containment Region
API Application Programmer Interface FDIR Fault Detection, Isolation, and Recovery
ARM Advanced RISC Machines FPGA Field programmable Gate Array
ATF Arm Trusted Firmware FPU Floating Point Unit
BIST Built In Self Test GNC Guidance Navigation and Control
BSP Board Support Package GOPS Giga Operations Per Second
C&DH Command and Data Handling GPIO General Purpose Input Output
cFS core Flight System GPU Graphics Processing Unit
CPU Central Processing Unit GSFC Goddard Space Flight Center
DDR Double Data Rate HEO Human Exploration and Operations
DMIPS Dhrystone Millions of Instructions per Second HPFEC High Performance Fault-tolerant Embedded Computing
DMR Dual Modular Redundancy HPPS High Performance Processing Subsystem
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Acronyms (2)
24
Acronym Meaning Acronym Meaning
HPSC High Performance Spacecraft Computing MIE Mission Integration Engineer
HW Hardware MIPS Millions of Instructions per Second
I/O Input / Output MMU Memory Management Unit
I2C Inter-Integrated Circuit MPI Message Passing Interface
IDE Integrated Development Environment MRAM Magnetoresistive Random Access Memory
IPL Initial Program Loader MW Middleware
ISA Instruction Set Architecture NAND NOT-AND logic
ISI Information Sciences Institute NASA National Aeronautics and Space Administration
ITAR International Traffic In Arms Regulations NEON Single Instruction Multiple Data architecture
JPL Jet Propulsion Laboratory NVRAM Non Volatile Random Access Memory
JTAG Joint Test Action Group (Debug interface) PCIe Peripheral Component Interconnect express
KVM Kernel Based Virtual Machine QEMU Quick Emulator
MB Megabyte R1, R2, R3 Release 1, Release 2, Release 3
This is a non-ITAR presentation, for public release and reproduction from FSW website. 
Acronyms (3)
25
Acronym Meaning Acronym Meaning
RTEMS Real Time Executive for Multiprocessor Systems SW Software
RTOS Real Time Operating System TBD To Be Determined
RTPS Real Time Processing Subsystem TMR Triple Modular Redundancy
SCP Self Checking Pair TRCH Timing, Reset, Configuration, and Health
SIMD Single Instruction Multiple Data TTE Time Triggered Ethernet
SMD Science Mission Directorate UART Universal Asynchronous Receiver Transmitter
SPI Serial Peripheral Interface USC University of Southern California
SPW Spacewire VMC Vehicle Management Computer
SRAM Static Random Access Memory
SRIO Serial Rapid Input Output
SSR Solid State Recorder
SSW System Software
STMD Space Technology Mission Directorate
