# System-on-a-Chip (SoC) Design

EE382V, Unique: 17450, Fall 2014

Lectures: TTh 12:30-2:00pm, BUR 134

Instructor: Andreas Gerstlauer <gerstl@ece.utexas.edu>, Office hours: TW 2-3pm, POB 6.118

Teaching Assistant: Seogoo Lee <<u>sglee@utexas.edu</u>>, Office hours: TBD

Guest Lecturers (tentative): David Black (Doulos, Inc.), Steven Smith, Mark McDermott

Class website: Canvas and http://www.ece.utexas.edu/~gerstl/ee382v\_f14/

## Description

With technological advances that allow us to integrate complete multi-processor systems on a single die, Systems-on-Chip (SoCs) are at the core of most embedded computing and consumer devices, such as cell phones, media players and automotive, aerospace or medical electronics. This course will provide an understanding of the concepts, issues, and process of designing highly integrated SoCs following systematic hardware/software co-design & co-verification principles. Specifically, the class project involves taking public domain C++ code for a DRM (<u>Digital Radio Mondiale</u>) PC-based software-defined radio (SDR) system and mapping it to an ARM-based virtual and FPGA prototyping platform using state-of-the-art synthesis and verification tools and design flows.

## Goals

This course is designed for students to learn and be able to:

- Analyze the functional and nonfunctional performance of the system early in the design process to support design decisions.
- Analyze hardware/software tradeoffs, algorithms, and architectures to optimize the system based on requirements and implementation constraints.
- Describe architectures for control-dominated and data-dominated systems and real-time systems.
- Understand hardware, software, and interface synthesis.
- Understand issues in interface design.
- Use co-simulation to validate system functionality.
- Describe examples of applications and systems developed using a co-design approach.
- Appreciate issues in system-on-a-chip design associated with co-design, such as intellectual property, reuse, and verification.

# Topics

Likely to be covered in class:

- System-level and SoC design methodologies and tools;
- HW/SW co-design: analysis, partitioning, real-time scheduling, hardware acceleration;
- Virtual platform models, co-simulation and FPGAs for prototyping of HW/SW systems;
- Transaction-Level Modeling (TLM), Electronic System-Level (ESL) languages: SystemC;
- High-Level Synthesis (HLS): allocation, scheduling, binding, resource sharing, pipelining;
- SoC and IP integration, verification and test.

## **Prerequisites**

- Working knowledge of C and C++, including software development and debugging (e.g. EE322C Data Structures, or equivalent);
- Embedded real-time system design and hardware/software interfacing (e.g. EE345M Embedded & Real-time Systems, or equivalent);
- Digital hardware design and hardware description languages (e.g. EE360M Digital System Design using VHDL, or equivalent);
- It is helpful to have some basic knowledge of communication systems.

## Textbooks

No required textbook. Optional textbooks:

- P. Marwedel, <u>Embedded System Design: Embedded Systems Foundations of Cyber-Physical</u> <u>Systems</u>, Springer, 2011.
- D. Black, J. Donovan, SystemC: From the Ground Up, Second Edition, Springer, 2010.
- G. De Micheli, <u>Synthesis and Optimization of Digital Circuits</u>, McGraw-Hill, 1994.

#### Grading

| Homework: | 15% |
|-----------|-----|
| Exam:     | 20% |
| Labs:     | 30% |
| Project:  | 35% |

Late penalty: 20% per day (24 hours).

Oral discussion of homework problems is encouraged but solutions have to be submitted individually and independently. Labs and the final project will be done in teams.

## **Electronic Mail Notification Policy**

In this course e-mail will be used as a means of communication with students. You will be responsible for checking your e-mail regularly for class work and announcements. The complete text of the University electronic mail notification policy and instructions for updating your e-mail address are available at <a href="http://www.utexas.edu/its/policies/emailnotify.html">http://www.utexas.edu/its/policies/emailnotify.html</a>.

## Use of Canvas and Class Web Site

This course uses the class web page and Canvas to distribute course materials, to communicate and collaborate online, to submit assignments and to post solutions and grades. You will be responsible for checking the class web page and the Canvas course site regularly for class work and announcements. As with all computer systems, there are occasional scheduled downtimes as well as unanticipated disruptions. Notification of disruptions will be posted on the Canvas login page. Scheduled downtimes are not an excuse for late work. However, if there is an unscheduled downtime for a significant period of time, I will make an adjustment if it occurs close to the due date.

#### **Students with Disabilities**

The University of Texas at Austin provides upon request appropriate academic accommodations for qualified students with disabilities. For more information, contact the Office of the Dean of Students at 471-6259, 471-4641 TTY or the College of Engineering Director of Students with Disabilities at 471-4382.

## **Religious Holidays**

Religious holy days sometimes conflict with class and examination schedules. If you miss an examination, work assignment, or other project due to the observance of a religious holy day you will be given an opportunity to complete the work missed within a reasonable time after the absence. It is the policy of The University of Texas at Austin that you must notify each of your instructors at least fourteen days prior to the classes scheduled on dates you will be absent to observe a religious holy day.

**Tentative Course Outline and Schedule** 

| Week                       | Lecture Topic                                                           |  |
|----------------------------|-------------------------------------------------------------------------|--|
| <b>1</b><br>(Aug 28)       | Class Overview and Introduction                                         |  |
| <b>2</b><br>(Sep 2/4)      | SystemC Tutorial                                                        |  |
| <b>3</b><br>(Sep 9/11)     | Project Overview & DRM Tutorial                                         |  |
| <b>4</b><br>(Sep 16/18)    | SoC Design Methodology                                                  |  |
| <b>5</b><br>(Sep 23/25)    | Electronic System-Level (ESL) Design & Transaction-Level Modeling (TLM) |  |
| <b>6</b><br>(Sep 30/Oct 2) | Application Mapping & Real-Time Task Scheduling                         |  |
| <b>7</b><br>(Oct 7/9)      | HW/SW Co-Design                                                         |  |
| <b>8</b><br>(Oct 14/16)    | C-to-RTL High-Level Synthesis                                           |  |
| <b>9</b><br>(Oct 21/23)    | Datapath Synthesis (Operator Scheduling and Binding)                    |  |
| <b>10</b><br>(Oct 28/30)   | Advanced High-Level Synthesis                                           |  |
| <b>11</b><br>(Nov 4/6)     | Review, <b>Exam</b>                                                     |  |
| <b>12</b><br>(Nov 11/13)   | Emulation & FPGA Prototyping                                            |  |
| <b>13</b><br>(Nov 18/20)   | System Integration, Verification and Testing                            |  |
| <b>14</b><br>(Nov 25/27)   | Wrapup, Thanksgiving                                                    |  |
| <b>15</b><br>(Dec 2/4)     | Project Design Reviews                                                  |  |
| <b>Finals</b><br>(TBD)     | Project Presentations                                                   |  |