# Torc: Towards an Open-Source Tool Flow

Neil Steiner, <sup>1</sup> Aaron Wood, <sup>1</sup> Hamid Shojaei, <sup>1,2</sup> Jacob Couch, <sup>3</sup> Peter Athanas, <sup>3</sup> and Matthew French <sup>1</sup>

<sup>1</sup>Information Sciences Institute

neil.steiner@isi.edu, awood@isi.edu, mfrench@isi.edu

University of Wisconsin-Madison

hshojaei@wisc.edu

<sup>3</sup> Virginia Tech

jacouch@vt.edu, athanas@vt.edu

#### What is Torc?

- A C++ open-source project
- Collection of APIs and CAD tools
- Released under GNU GPL license
- Hosted on SourceForge
- Free of proprietary code or data

#### **Motivation**

- Needed a robust circuit manipulation environment
- Too many researchers rewrite their own tools
- Facilitate EDA/CAD research with real device data
- Share some of the collectively acquired knowledge

## **Uses and Applications**

- CAD tool research
- Device architecture exploration
- Hardware autonomy research
- Partial runtime reconfiguration
- Low-power CAD
- Radiation effect mitigation
- Security/anti-tamper
- Health monitoring

### **Generic API:**

- Works with unmapped netlists
- Reads, modifies, writes EDIF

# **Physical API:**

- Works with mapped netlists
- Reads, modifies, writes XDL

### **Architecture API:**

- Device wiring, logic, and package data
- Complete support for largest devices
- Built from non-proprietary XDLRC

#### **Bitstream API:**

- Read, modify, write Xilinx bitstreams
- No understanding of frame contents

#### **Router:**

PathFinder implementation

# **Unpacker:**

- Splits slices into constituent components
- Facilitates natural design manipulation

# **Supported Families (139 Devices):**

Virtex, VirtexE, Virtex2, Virtex2P, Virtex4, Virtex5, Virtex6, Virtex6L, Spartan3E, Spartan6, Spartan6L

#### **EDIF EDIF Importer** Synplify, XST, . **EDIF Exporter** Generic torc::generic **Netlist** ODIN II, **BLIF Importer BLIF Exporter** ABC, SIS, ... **Mapper Unmapper Packer** Unpacker **Physica XDL** Importer **XDL Exporter** torc::physical **Netlist Timing Model** DRC **Path Extraction Placer** Router **Device** torc::architecture **DB Reader Bitstream** torc::bitstream **BIT Reader BIT Writer**

# http://torc.isi.edu

## **Design Goals:**

- Designed for ten year shelf life
- Designed for completeness
- Optimized for very large devices
- Optimized for very large designs
- Designed for embedding
- Designed for testability
- Designed for conditional compilation
- Designed for simplicity
- Intended for researchers

## **Ongoing and Planned Work:**

- Rehost unpacker on latest code
- Develop/integrate packer, placer, BLIF import/export, timing models
- Complete all unit tests
- Complete Doxygen documentation
- Characterize performance
- Add constraint support
- Add TCL scripting
- Complete bitstream frame index mapping
- Designed for simplicity
- Intended for researchers







**OpenPR.** Third party tool. Uses Torc to rigorously prohibit ISE router from using reserved resources. Floorplan on left shows static and dynamic areas. "Blocker" route in center prevents any wiring from passing through dynamic region. Resulting static design on right.







