Current Projects
Past Projects

The RSSL conducts research in a number of different areas, broadly related to computer engineering, computer architecture, embedded systems, fault tolerance and reliability, security, and machine learning. Most research at RSSL combines some set of system architecture, system modeling, and optimization.

Current Projects

Aerospace Cybersecurity

In the aerospace industry, a new communications protocol built on top of CAN has been proposed: the Aeronautics Radio, Incorporated 825 Specification. We believe that the ARINC-825 protocol suffers from the same vulnerabilities as CAN (widely used in automotive and aerospace applicaitons). In our work to date, we have developed a hardware-in-the-loop testbed for simulation of the protocol at the link-layer (where CAN messages are exchanged between transceivers) using realistic data (from the FlightGear flight simulator). In this context, we are working on developing new attacks, and related mitigation strategies.

Hardware-Software Optimization of Machine Learning Algorithms

Conventionally, artificial neural networks (ANN) are designed for classification accuracy, and the more the better, but the resulting systems are often large and expensive, and unsuitable for low-cost applications. Furthermore, until recently, ANN optimization was a laborious, manual process.

We believe that the computer engineering principles of models, metrics, and automated optimization, are needed to support the deployment of ANN to hardware platforms from the cloud to the edge to mobile or ultra-low-power devices; without multi-objective optimization, efforts to improve accuracy are unlikely to be as efficient as possible. Our research in this area includes automated optimization of neural networks (using sequential model-based optimization), and other techniques.

Multi-granularity Redundancy for Parallel Architectures

Recent research as suggested that as more processor cores are incorporated on single chips, the appropriate granularity of redundancy for the purpose of failure and defect mitigation is at the system-level. In this project, we investigate the relationship between parallel application, parallel architecture (and single-instruction, multiple-thread architectures in particular), and redundancy allocation, based on the observation that as the demand for types of parallel resources changes (e.g., from many narrow cores to few wide cores), so ought the mix of redundant components (e.g., from redundant cores to cores with redundant lanes). We find that redundancy can be a win for cost (as a function of yield), performance, power, and lifetime, depending on the application and system composition.

VoltSpot: Power-delivery Network Modeling and Optimization

VoltSpot is an architecture-level model of the on-chip power delivery nework, including C4 pads, with a simple interface for use in other architecture-level tools. VoltSpot, when integrated with a performance simulator (such as gem5) and power estimation tool (such as McPAT), provides architects with the tools necessary to explore the effect of PDN design, including C4 pad allocation to VDD, GND and I/O and PDN metal width. VoltSpot also supports the exploration of run-time IR drop and Ldi/dt noise prediction, avoidance, and mitigation. Recent work has begun to explore design techniques for system lifetime, 3D-ICs and simulation techniques for accelerating the process of solving for on-chip voltage noise.

Past Projects

ArchFP: Architectural Floorplanning for Early Design Analysis

ArchFP is a simple, easy to use, architect-directed floorplanning tool. Floorplanning tools grew out of a need to automate the placement of standard cells and module in large, complex designs. Floorplans are often needed in order to estimate design area, performance, power, temperature, and therefore reliability. System architects need a way to generate floorplans for the same reason but system-level floorplans, which often consist of only a handful of blocks, often placed in some regular way (e.g., tiled cores), are poorly explored by tools designed to manage the complexity of thousands of blocks. ArchFP gives a system architect a tool that leverages their knowledge of the system and quickly produces a floorplan that can be used for further analysis.

Design-space Exploration for Embedded MPSoCs

Embedded system designers rely on automation approaches to meet time-to-market constraints, but to date few tools have been developed to assist with optimizing system cost, lifetime. To this end, we have developed (a) techniques to accelerate lifetime estimation and (b) lifetime-aware design space exploration. Earlier, we developed a system synthesis approach that, given an application, hardware/software partitioning and communication architecture, selects and organizes system resources, allocating and distributing slack to jointly optimize system cost and lifetime. Additional research has explored the effect of task mapping on lifetime in this context. Recently, we have developed novel models for abstracting behavior observed in atomistic models of negative-bias temperature instability to the level of standard cell libraries. Other work explore a new approaches to quickly estimating system lifetime using multi-armed bandits.

Internet Packet Classification

ISPs and network administrators use Internet Packet Classification (IPC) to categorize packets into flows (traffic sharing IP addresses, ports, and protocol), and thereby the application classes generating them. Distinguishing between safe and malicious traffic aids in network intrusion interception. Likewise, categorizing applications into classes is useful for traffic management for better service. Traditional IPC based on port numbers and payload pattern recognition are no longer effective because current applications can dynamically change port numbers and cipher their contents. Recent machine learning (ML) IPC solutions have speed-bounded accuracy, and complex implementation due to their dependence on packet sizes and order of arrival. We propose a new IPC approach that uses associative memory (AM) based on sparse-clustered network with selective decoding, dramatically reducing the memory for hardware implementation of IPC, while significantly improving classification throughput.