







# **Pre-Requisites**

## Computer science knowledge

- ▶ Programming and data structures (at CMU, 15-211, maybe also 15-213)
- Basic complexity ideas, eg, why O(n<sup>2</sup>) is worse than O(n log n)
- Ability to write a medium size program -- 1000-2500 lines of C or C++ code -- without any hand holding from me, in about 3 weeks

# Computer engineering knowledge

- Basic digital design (gates, flip flops, Boolean algebra, Kmaps)
- Combinational and sequential design (finite state machines)

# Discrete math

- ▶ Basic sets, functions, careful notation
- Exposure to graph theory is nice but not essential (15-211 is fine)

#### © R. Rutenbar 2001





## Undergrads

Expectation is for you to keep up, absorb the "big ideas"

#### Grads

Expectation is for you to absorb it all

#### ■ Note

- Diverse class this year, as usual
- Some maybe took 18-360 (which uses versions of my 760 notes!)

© R. Rutenbar 2001

- Some folks complete rookies
- My problem to keep it all interesting for everybody...



# Buzzword Acronym Lexicon Semi-custom ASIC

- Application-specific IC when you design a chip for a specific task using mostly semi-custom techniques
- Don't expect to make a zillion of them, so can't afford full custom; OR you need a chip really quick, so can't afford full custom
- ▶ Not as dense (transistors / area) or as fast (MHz) as full custom

# ▼ Full custom IC

- Well, really a misnomer, since almost nothing is absolutely custom, completely done by hand
- Almost every custom chip has big chunks of semi-custom function since there are good tools for this stuff

© R. Rutenbar 2001

Fall 18-760 Page 9

**Examples:** your favorite microprocessor



# **Useful Components in Semi-Custom?**

# Logic gates

- Maximally useful components you can reuse
- Can design without knowing exactly what gates (type, speed, power, size) you have: technology independent design
- Later, can map technology independent design onto your specific gate library (your "technology"): technology mapping problem

## Memories

- ► Usually, a program called a *module generator* transforms specs on size (bits, words, speed, etc) into the final layout
- ► Doable since these are very structured designs

#### Datapaths

- > Again, fairly well structured to do adders, multipliers, etc
- Often not designed entirely at gate level, since need transistor hacking for best performance
- > Again, a module generator can produce them
- Even entire CPUs -- called "cores"

© R. Rutenbar 2001







































# Now What?

# **■** On to Boolean algebra...

|          | Μ  | Т  | W  | Th | F  |    |
|----------|----|----|----|----|----|----|
| Aug      | 27 | 28 | 29 | 30 | 31 | 1  |
| Sep      | 3  | 4  | 5  | 6  | 7  | 2  |
|          | 10 |    | 12 | 13 | 14 | 3  |
|          | 17 | 18 | 19 | 20 | 21 | 4  |
| [        | 24 | 25 | 26 | 27 | 28 | 5  |
| Oct      |    | 2  | 3  | 4  | 5  | 6  |
|          | 8  | 9  | 10 | 11 | 12 | 7  |
|          | 15 | 16 | 17 | 18 | 19 | 8  |
|          | 22 | 23 | 24 | 25 | 26 | 9  |
|          | 29 | 30 | 31 | 1  | 2  | 10 |
| Nov      | 5  | 6  | 7  | 8  | 9  | П  |
|          | 12 | 13 | 14 | 15 | 16 | 12 |
| Thnxgive | 19 | 20 | 21 | 22 | 23 | 13 |
|          | 26 | 27 | 28 | 29 | 30 | 14 |
| Dec      | 3  | 4  | 5  | 6  | 7  | 15 |
|          | 10 |    | 12 | 13 | 14 | 16 |
|          |    |    |    |    |    |    |

## Introduction

Advanced Boolean algebra JAVA Review Formal verification 2-Level logic synthesis Multi-level logic synthesis Technology mapping Placement Routing Static timing analysis Electrical timing analysis Geometric data structs & apps

© R. Rutenbar 2001