Computer Science Dept. University of Cailfornia, Riverside Riverside CA 92521 Phone: 909-800-7316 E-mail: gstitt@cs.ucr.edu Web: http://www.cs.ucr.edu/~gstitt

# **Greg Stitt**

| Research Interests     | Embedded systems: emphasis in synthesis, compilers, reconfigurable computing, hardware/software co-design, low power-design, system-on-a-chip multi-core architectures, real-time systems, and run-time optimizations.                                                                                                                                        |                                                                                                                                                                                                                                                                    |                                                                                                                                                      |  |  |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Education              | 2000-June 2007                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                    | University of California, Riverside                                                                                                                  |  |  |
|                        | Ph.D. Computer Science                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                    |                                                                                                                                                      |  |  |
|                        | <ul> <li>Advisor: Dr. Frank Vahid</li> </ul>                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                    |                                                                                                                                                      |  |  |
|                        | 1996-2000                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                    | University of California, Riverside                                                                                                                  |  |  |
|                        | B.S. Computer Science                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                    |                                                                                                                                                      |  |  |
|                        | GPA: 3.953, Graduated Summa Cum Laude                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                    |                                                                                                                                                      |  |  |
| Teaching<br>experience | <ul> <li>CS 161L (Computer Architecture) - Lecturer (Spring 2005)</li> <li>CS 161 (Computer Architecture) - Teaching assistant (Fall 2001)</li> <li>CS 122A (Embedded Systems) - Teaching assistant (Fall 2000, 2003)</li> <li>CS 122B (Advanced Embedded Systems) - Teaching assistant (Winter 2003, 2004)</li> <li>Computer science tutor (1999)</li> </ul> |                                                                                                                                                                                                                                                                    |                                                                                                                                                      |  |  |
| Patents                | 1.                                                                                                                                                                                                                                                                                                                                                            | <ol> <li>Warp Processor for Dynamic Hardware/Software Partitioning</li> <li>F. Vahid, R. Lysecky, G. Stitt. Patent Pending, 2004.</li> </ol>                                                                                                                       |                                                                                                                                                      |  |  |
| Publications           | Journal Publications                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                    |                                                                                                                                                      |  |  |
|                        | 1.<br>2.                                                                                                                                                                                                                                                                                                                                                      | <ul> <li>Warp Processing: Dynamic Translation of Binaries to FPGA Circuits</li> <li>F. Vahid, G. Stitt, R. Lysecky</li> <li>Submitted to Special Issue of IEEE Computer on High-Performance Reconfigurable</li> <li>Computing</li> <li>Binary Synthesis</li> </ul> |                                                                                                                                                      |  |  |
|                        | 3.                                                                                                                                                                                                                                                                                                                                                            | G. Stitt, F. Vahid<br>To appear in ACM Transactions o<br><b>Warp Processors</b><br>R. Lysecky, G. Stitt, F. Vahid.<br>ACM Transactions on Design Auto<br>11. Number 3, pp. 659 - 681                                                                               | n Design Automation of Electronic Systems (TODAES)<br>omation of Electronic Systems (TODAES), 2006, Volume                                           |  |  |
|                        | 4.                                                                                                                                                                                                                                                                                                                                                            | Energy Savings and Speedups<br>Hardware in Embedded System<br>G. Stitt, F. Vahid, S. Nematbakhsh<br>Transactions on Embedded Comp                                                                                                                                  | From Partitioning Critical Software Loops to<br>s.<br>buting Systems (TECS), February 2004, Volume 3, Issue                                          |  |  |
|                        | 5.                                                                                                                                                                                                                                                                                                                                                            | Highly Configurable Platforms f<br>F. Vahid, R. Lysecky, C. Zhang, G                                                                                                                                                                                               | or Embedded Computing Systems<br>. Stitt                                                                                                             |  |  |
|                        | 6.                                                                                                                                                                                                                                                                                                                                                            | Improving Software Performance<br>J. Villarreal, D. Suresh, G. Stitt, F.<br>Kluwer Journal on Design Automa                                                                                                                                                        | er 2003, Volume 34, Issue 11, pp. 1025-1029.<br>ze with Configurable Logic<br>Vahid, W. Najjar<br>tion of Embedded Systems, November 2002, Volume 7, |  |  |
|                        | 7.                                                                                                                                                                                                                                                                                                                                                            | The Energy Advantages of Micr<br>Logic<br>G. Stitt, F. Vahid                                                                                                                                                                                                       | oprocessor Platforms with On-Chip Configurable                                                                                                       |  |  |
|                        | 8.                                                                                                                                                                                                                                                                                                                                                            | IEEE Design and Test of Compute<br>Propagating Constants Past So                                                                                                                                                                                                   | ers, November 2002, Volume 19, Issue 6, pp. 36-43.<br>ftware to Hardware Peripherals in Fixed-Application                                            |  |  |

#### Embedded Systems

F. Vahid, R. Patel, G. Stitt Special Issue of ACM SIGARCH Newsletter, Dec. 2001. Selected for special issue from earlier version of paper in Compilers and Operating Systems for Low Power (COLP'01).

### **Book Chapters**

1. Hardware/Software Partitioning

F. Vahid, G. Stitt To be published in Reconfigurable Computing: The Theory and Practice of FPGA-Based Computation

 Propagating Constants Past Software to Hardware Peripherals in Fixed-Application Embedded Systems
 G. Stitt, F. Vahid

Compilers and Operating Systems for Low Power. Kluwer Academic Publishers, 2002.

#### Conference Publications

- 1. Expandable Logic
  - G. Stitt, F. Vahid

Submitted to IEEE/ACM Conference on Design Automation (DAC), 2007.

- 2. Recursion Flattening for Improved High-Level Synthesis
  - G. Stitt, J. Villarreal, D. Sheldon, F. Vahid To be submitted to IEEE/ACM/IFIP International Conference on Hardware/Software Codesign and System Synthesis (CODES/ISSS), 2007.
- 3. Multithreaded Warp Processing: Dynamic Synthesis of Custom Processors for Threads
  - G. Stitt, F. Vahid

To be submitted to IEEE/ACM International Symposium on Microarchitecture (MICRO), 2007.

4. Hardware Software Partitioning with Multi-Version Implementation Exploration G. Stitt, F. Vahid

To be submitted to IEEE/ACM/IFIP International Conference on Hardware/Software Codesign and System Synthesis (CODES/ISSS), 2007.

5. A Code Refinement Methodology for Performance-Improved Synthesis from C G. Stitt, F.Vahid, W. Najjar

IEEE/ACM International Conference on Computer Aided Design (ICCAD), 2006.
 New Decompilation Techniques for Binary-level Co-processor Generation

- G. Stitt, F. Vahid IEEE/ACM International Conference on Computer Aided Design (ICCAD), 2005, pp. 547-554.
- 7. A Decompilation Approach to Partitioning Software for Microprocessor/FPGA Platforms
  - G. Stitt, F. Vahid

IEEE/ACM Design Automation and Test in Europe (DATE), 2005, pp. 396-397.

8. Techniques for Synthesizing Binaries to an Advanced Register/Memory Structure G. Stitt, Z. Guo, F. Vahid, W. Najjar

ACM/SIGDA International Symposium on Field Programmable Gate Arrays (FPGA), 2005, pp. 118-124.

- Hardware/Software Partitioning of Software Binaries: A Case Study of H.264 Decode G.Stitt, F. Vahid, G. McGregor, B. Einloth IEEE/ACM/IFIP International Conference on Hardware/Software Codesign and System Synthesis (CODES/ISSS), 2005, pp. 285-290.
- 10. Dynamic Hardware/Software Partitioning: A First Approach G. Stitt, R. Lysecky and F. Vahid
- IEEE/ACM Conference on Design Automation (DAC), 2003, pp. 250-255.
   Profiling Tools for Hardware/Software Partitioning of Embedded Applications

   D. Suresh, W. Najjar, F. Vahid, J. Villarreal, G. Stitt
   ACM Conference on Languages, Compilers and Tools for Embedded Systems (LCTES),
  - ACM Conterence on Languages, Compilers and Tools for Embedded Systems (LCTES), 2003, pp. 189-198.
- 12. Hardware/Software Partitioning of Software Binaries G. Stitt, F. Vahid IEEE/ACM International Conference on Computer Aided Design

IEEE/ACM International Conference on Computer Aided Design (ICCAD), 2002, pp. 164-170.

13. Codesign-Extended Applications

B. Grattan, G. Stitt, F. Vahid

IEEE/ACM International Symposium on Hardware/Software Codesign (CODES), 2002, pp. 1-6.

|                            | 14.                                                                                                                                                                                                                                                                                    | Using On-Chip Configurable Logic to Reduce Embedded System Software Energy<br>G. Stitt, B. Grattan, J. Villarreal, F. Vahid<br>IEEE Symposium on Field-Programmable Custom Computing Machines (FCCM), 2002, p                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                            | 15.                                                                                                                                                                                                                                                                                    | A First-step Towards an Architecture Tuning Methodology for Low Power<br>G. Stitt, F. Vahid, T. Givargis, R. Lysecky<br>IEEE/ACM Conference on Compilers, Architectures, and Synthesis for Embedded Systems<br>(CASES) 2000, pp. 187-192                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                            | Technical Reports                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                            | 1.                                                                                                                                                                                                                                                                                     | Binary-Level Hardware/Software Partitioning of MediaBench, NetBench, and EEMBC<br>Benchmarks<br>G. Stitt, F. Vahid<br>Technical Report UCR-CSE-03-01. January 2003.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| Professional<br>activities | •                                                                                                                                                                                                                                                                                      | Presentation at UC Berkeley ESD Seminar. Warp processors. March 2004.<br>Presentation at NEC. Hardware/software partitioning of software binaries. July 2001.<br>Presented papers at ICCAD 2002, DAC 2003, FCCM 2002, FPGA 2005,<br>CODES/ISSS 2005, ICCAD 2005, ICCAD 2006.<br>Particular ISEE/ICCM Intermetional Conference on Computer Aided Design (ICCAD)                                                                                                                                                                                                                                                                                                                          |  |  |
|                            | • • • • • •                                                                                                                                                                                                                                                                            | Reviewer, IEEE/ACM International Conference on Computer Aided Design (ICCAD),<br>2006.<br>Reviewer, IEEE/ACM International Conference on Compilers, Architecture, and<br>Synthesis for Embedded Systems (CASES), 2003, 2005.<br>Reviewer, IEEE/ACM/IFIP International Conference on Hardware/Software Codesign<br>and System Synthesis (CODES+ISSS), 2003, 2005.<br>Reviewer, ACM Conference on Languages, Compilers, and Tools for Embedded<br>Systems (LCTES), 2003.<br>Reviewer, International Symposium on High-Performance Computer Architecture<br>(HPCA), 2007.<br>Reviewer, IEEE Transactions on Parallel and Distributed Systems Manuscript<br>(TPDS), 2006.<br>Member of IEEE |  |  |
| Computer skills            | • • •                                                                                                                                                                                                                                                                                  | Languages: C/C++, Java, Perl, VHDL, SystemC, Visual Basic<br>Operating Systems: Windows, Linux, Unix, VxWorks<br>Tools: Synopsis Design Compiler, Synopsis Behavioral Compiler, Keil, Xilinx ISE,<br>Xilinx Platform Studio, Xilinx Xpower, Tornado, Triscend E5/A7 Fast Chip, Synplicity<br>Synplify, SimpleScalar, Wattch<br>Platforms: Xilinx Virtex II Pro, Triscend E7/A7                                                                                                                                                                                                                                                                                                          |  |  |
| Awards received            | •<br>•<br>•<br>•                                                                                                                                                                                                                                                                       | GAANN Fellowship<br>UCR Chancellor's Fellowship<br>Summa Cum Laude<br>Travel Grant (CASES 2003)<br>Dean's List<br>Golden Key National Honor Society<br>Scholastic Achievement Award for GPA over 3.9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Projects                   | Sy                                                                                                                                                                                                                                                                                     | nthesis/Partitioning Tool for Software Binaries                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                            | Juni<br>Univ<br>Des<br>bina<br>synt<br>crea                                                                                                                                                                                                                                            | e 2002 to current<br>versity of California, Riverside<br>igned a synthesis tool that creates register-transfer level hardware based on a software<br>ry. The tool first decompiles the software binary to recover high-level information suitable for<br>hesis. The tool then performs behavioral synthesis on the decompiled representation,<br>iting a register-transfer representation in VHDL.                                                                                                                                                                                                                                                                                      |  |  |
|                            | Су                                                                                                                                                                                                                                                                                     | cle-Accurate MIPS Microprocessor Simulator                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|                            | Fall 2001<br>University of California, Riverside<br>Created a cycle-accurate simulator for a pipelined processor. The processor's instruction set w<br>similar to a MIPS. Simulator provided statistics such as CPI (cycles per instruction), cach<br>performance, and execution time. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |

# Optimizations for Intel 8051 VHDL Soft Core

June 2000 to June 2001

University of California, Riverside

Performed architectural optimizations to Intel 8051 VHDL soft core to reduce power/energy consumption. Architectural modifications included controller partitioning, guarded evaluations, bus encoding, state encoding, and clock gating.

#### E-book

January 1999 to March 1999 Dr. Frank Vahid University of California, Riverside Designed electronic book that allows text documents to be stored and read. Documents can be downloaded from any PC using the serial port. An LCD displayed the stored text. Designed to be cheap and to consume very little power. Involved embedded system design, 8051 microprocessor programming, VHDL programming, FPGA prototyping, and serial communication.

Professional experience

Lecturer

Spring 2005 University of California, Riverside Lecturer for undergraduate class on computer architecture. Developed homework assignments, lab projects, tests, and programming assignments. Received excellent evaluations averaging 6.4 out of 7, compared to a department average of 5.9 and a campus average of 6.0.

# **Graduate Student Researcher**

June 2000 to current University of California, Riverside Performed research in hardware/software partitioning and synthesis of software binaries. Researched architecture and on-chip tools for Warp processors, which are capable of dynamically optimizing software by performing hardware/software partitioning at run time.

# **Teaching Assistant**

Fall 2000 to Winter 2004 University of California, Riverside Instructed students during labs for classes dealing with computer architecture and embedded systems. Responsible for developing labs, grading assignments, and occasionally giving lectures.

#### **Software and Multimedia Designer**

April 1998 to January 1999 Automated Pathology Systems Grand Terrace, CA Programmed medical software products. Provided quality assurance testing and customer technical support. Also, provided web site and multimedia design, including full CD demos of the company's products.

#### Tutor

September 1998 to June 1999 University of California Riverside Learning Center Responsible for tutoring college students in Physics, Math, and Computer Science. Provided services to computer science students with regard to basic programming fundamentals, data structures, algorithms, and digital design.

#### **Computer Science Grader**

September 1999 to June 2000 University California at Riverside Responsible for grading programming assignments, homework, and tests in undergraduate computer science classes.