

# Welcome to 6.111!

- Introductions, course mechanics
- Course overview
- Digital signaling
- Combinational logic
- 4 Handouts: slides, LP #1, info form, kit signout with safety information

Lecture material: Prof Anantha Chandrakasan and Dr. Chris Terman.







#### Introductions







ΤА



Gim Hom Lectures

Joe Steinmeyer Weston Braun Lectures

Madeline Waller ΤА









Mitchell Gu

Elizabeth Mittman

LA's

James Noraky

Diana Wofk

2

4

## 6.111 in lieu of 6.UAP

- Under the pre-2015 EECS curriculum, a department CI-M lab can be used to meet the 6.UAP requirement. With the change to the new EECS curriculum, 6.111 will continue to be a AUS/AUS2 Lab subject but not a CI-M. However, EECS and SOCR (Subcommittee on Communications Requirements) have approved 6.111 Fall 2017 as a substitution for 6.UAP via petition.
- 6.111 will continue to be a 12 unit subject. Credit as AUS2, DLAB2, II.
- Prior to add date, will submit a list of students to have this substitution approved.

Lecture 1

#### Assignments



**Project Presentation & Report (13%)** 

• Design proposal (2%)

6.111 Fall 2017

• Design presentation (6%)

#### • Final Report (5%)

#### Labs: learning the ropes

Lecture 1

#### • Lab 1 (2%)

6.111 Fall 2017

5

- Experiment with gates, design & implement some logic
- Learn about lab equipment in the Digital Lab (38-600): oscilloscopes and logic analyzers
- Lab 2 (5%)
  - Introduction to Verilog, ModelSim & the labkit

subject can lead to a disappointing grade.

- Serial communications
- Lab 3 (8%)
  - Video circuits: a simple Pong game
    - Use Verilog to program an FPGA
- Lab 4 (11%)
  - Design and implement a Finite State Machine (FSM) Car Alarm
- Lab 5 (8%)
  - Design a complicated system with multiple FSMs (Major/Minor FSM)
    - Voice recorder using AC97 codec and SRAMs or
    - Build your own remote control \*
- You must have a non-zero score for each of the labs and all the labs must be checked off as a prerequisite for passing the course. A missing lab will result in a failing grade.

## **Final Project**

- Done in groups of two or three; one person project by exception
- Open-ended
- You and the staff negotiate a project proposal
  - Must emphasize digital concepts, but inclusion of analog interfaces (e.g., data converters, sensors or motors) common and often desirable
  - Proposal Conference, several Design Reviews
  - Have fun!
- Design presentation to staff
- Staff will provide help with project definition and scope, design, debugging, and testing
- It is extremely difficult for a student to receive an A without completing the final project. Sorry, but we don't give incompletes.

# Virtual Pool - La PC Na



Fall 2017 Matt Basile Zareen Choudhury

| FPGA Beethoven  |           |   |                 | Collaboration |    |
|-----------------|-----------|---|-----------------|---------------|----|
|                 |           |   |                 |               |    |
|                 |           |   |                 |               |    |
| 6.111 Fall 2017 | Lecture 1 | 9 | 6.111 Fall 2017 | Lecture 1     | 10 |

#### FPGA Beethoven



Fall 2016: Henry Love, Mark Yang

#### 6.111 Fall 2017

• Labs must be done independently but students may

• Work submitted for review must be their own

seek help from other students.



## The First Computer



The Babbage Difference Engine (1834) 25,000 parts cost: £17,470

• The first digital systems were mechanical and used base-10 representation.

Lecture 1

• Most popular applications: arithmetic and scientific computation

#### Meanwhile, in the World of Theory...



GEORGE BOOLE

- 1854: George Boole shows that logic is math, not just philosophy!
- Boolean algebra: the mathematics of binary values

## Key Link Between Logic and Circuits



- Despite existence of relays and introduction of vacuum tube in 1906, <u>digital</u> electronics did not emerge for thirty years!
- Claude Shannon notices similarities between Boolean algebra and electronic telephone switches
- Shannon's 1937 MIT Master's Thesis introduces the world to binary digital electronics

6.111 Fall 2017

Lecture 1

15

6.111 Fall 2017

6.111 Fall 2017

## **Evolution of Digital Electronics**

Transistors

#### Vacuum Tubes







UNIVAC, 1951 1900 adds/sec

IBM System/360, 1964



**VLSI** Circuits

Intel Broadwell Xeon 2016 - 22 Cores >>7 Billion 14nm

#### Digital Systems Thru the Ages











6.111 Fall 2017

DEC PDP 11 Circa 1980

Lecture 1

#### 6.111 Thru the Ages



Labkit 2005



## The trouble with analog signaling



The real world is full of continuous-time continuousvalue (aka "analog") signals created by physical processes: sound vibrations, light fields, voltages and currents, phase and amplitudes, ...

But if we build processing elements to manipulate these signals we must use non-ideal components in real-world environments, so some amount of error (aka "noise") is introduced. The error comes from component tolerances, electrical phenomenon (e.g., IR and LdI/dt effects), transmission losses, thermal noise, etc. Facts of life that can't be avoided...

And the more analog processing we do, the worse it gets: signaling errors accumulate in analog systems since we can't tell from looking at signal which wiggles were there to begin with and which got added during processing. Lecture 1

Lab kit 1990

Nexys 4 - 2016

Lecture 1

6,111 Fall 2017

19

6.111 Fall 2017

## **Building Digital Systems**

• Goal of 6.111: Building binary digital solutions to computational problems



### Building Digital Systems with HDLs

• Logic synthesis using a Hardware Description Language (HDL) automates the most tedious and error-prone aspects of design



# Verilog and VHDL

| <u>VHDL</u>                                                                                     | <u>Verilog</u>                                                                                           |
|-------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| <ul> <li>Commissioned in 1981 by<br/>Department of Defense;<br/>now an IEEE standard</li> </ul> | <ul> <li>Created by Gateway Design<br/>Automation in 1985;<br/>now an IEEE standard</li> </ul>           |
| <ul> <li>Initially created for ASIC<br/>synthesis</li> </ul>                                    | <ul> <li>Initially an interpreted<br/>language for gate-level<br/>simulation</li> </ul>                  |
| <ul> <li>Strongly typed; potential for<br/>verbose code</li> </ul>                              | <ul> <li>Less explicit typing (e.g.,<br/>compiler will pad arguments of<br/>different widths)</li> </ul> |
| <ul> <li>Strong support for package<br/>management and large<br/>designs</li> </ul>             | <ul> <li>No special extensions for large<br/>designs</li> </ul>                                          |

Hardware structures can be modeled effectively in either VHDL and Verilog. Verilog is similar to c and a bit easier to learn.

#### Verilog HDL

#### Misconceptions

- The coding style or clarity does not matter as long as it works
- Two different Verilog encodings that simulate the same way will synthesize to the same set of gates
- Synthesis just can't be as good as a design done by humans
  - Shades of assembly language versus a higher level language
- What can be Synthesized
  - Combinational Functions
    - Multiplexors, Encoders, Decoders, Comparators, Parity Generators,
      - Adders, Subtractors, ALUs, Multipliers
    - Random logic
  - Control Logic
    - FSMs
- What can't be Synthesized
  - Precise timing blocks (e.g., delay a signal by 2ns)
  - Large memory blocks (can be done, but very inefficient)
- Understand what constructs are used in simulation vs. hardware mapping

### The FPGA: A Conceptual View

- An FPGA is like an electronic breadboard that is wired together by an automated synthesis tool
- Built-in components are called macros



# Solution: go digital!



# Synthesis and Mapping for FPGAs

• Infer macros: choose the FPGA macros that efficiently implement various parts of the HDL code



• Place-and-route: with area and/or speed in mind, choose the needed macros by location and route the interconnect

| М | Μ | Μ | М | Μ | М | М |
|---|---|---|---|---|---|---|
| М | М | М | М | М | М | Μ |
| М | М | М | М | М | М | Μ |
| М | М | М | М | М | М |   |
| М | м | м | М | М | M | M |

"This design only uses 10% of the FPGA. Let's use the macros in one corner to minimize the distance between blocks.

```
6.111 Fall 2017
```

6,111 Fall 2017

Lecture 1

26

# The Digital Abstraction

Noise and inaccuracy are inevitable; we can't reliably engineer perfect components - we must design our system to tolerate some amount of error if it is to process information reliably.



Keep in mind that the world is not digital, we would simply like to engineer it to behave that way. Furthermore, we must use real physical phenomena to implement digital designs!

## Digital Signaling: sending

To ensure we can distinguish signal from noise, we'll encode information using a fixed set of discrete values called <u>symbols</u>.

Given a bound N on the size of possible errors, if the analog representations for the symbols are chosen to be at least 2N apart, we should be able to detect and eliminate errors of up to  $\pm N$ .

|       | "A         | "  | "В   | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |  | "C | ,,, |     | "C | )" |     | "  | E" |
|-------|------------|----|------|-----------------------------------------|--|----|-----|-----|----|----|-----|----|----|
|       | <b>-</b> N | +N | -N   | +N                                      |  | -N | +N  |     | -N | +N |     |    | +N |
| IDEAL |            | +  | <br> |                                         |  |    | - I | + + |    | +  | + + | +- |    |

Since we will use non-ideal components in the sender, we allow each transmitted symbol to be represented by a (small) range of analog values.



# Digital processing elements



Digital processing elements *restore* noisy input values to legal output values - signaling errors don't accumulate in digital systems. So the number of processing elements isn't limited by noise problems!

The "trick" is that we've defined our signaling convention so that we <u>can</u> tell from looking at a signal which wiggles were there to begin with and which got added during processing.

# Digital Signaling: receiving

Since the channel/wire is imperfect and we will use non-ideal components in the receiver, we require the receiver to accept a (larger) range of analog values for each symbol.



To avoid hard-to-make decisions at the boundaries between symbol representations, insert a "forbidden zone" between symbols so that some ranges of received values are not required to be mapped to a specific symbol.

Lecture 1

Using voltages to encode binary values

We'll keep things simple by designing our processing elements to use voltages to encode binary values (0 or 1). To ensure robust operation we'd like to make the noise margins as large as possible.



29

6.111 Fall 2017

## **Digital Signaling Specification**

Digital input:  $V_{IN} < V_{IL}$  or  $V_{IN} > V_{IH}$ 

Digital output:  $V_{OUT} < V_{OL}$  or  $V_{OUT} > V_{OH}$ 

Noise margins:  $V_{\rm IL} – V_{\rm OL}$  and  $V_{\rm OH} – V_{\rm IH}$ 

Where  $V_{OL},\,V_{IL},\,V_{IH}$  and  $V_{OH}$  are part of the specification for a particular family of digital components.

Now that we have a way of encoding information as a signal, we can define what it means to be *digital device*.

## Sample DC (signaling) Specification

| I/O Standard           | VIL    |                      | VI                   | VIH                    |                      | V <sub>OH</sub>         | IOL     | I <sub>OH</sub> |
|------------------------|--------|----------------------|----------------------|------------------------|----------------------|-------------------------|---------|-----------------|
| 1/O Standard           | V, Min | V, Max               | V, Min               | V, Max                 | V, Max               | V, Min                  | mA      | mA              |
| LVTTL                  | -0.3   | 0.8                  | 2.0                  | 3.45                   | 0.4                  | 2.4                     | Note(3) | Note(3          |
| LVCMOS33,<br>LVDCI33   | -0.3   | 0.8                  | 2.0                  | 3.45                   | 0.4                  | V <sub>CCO</sub> - 0.4  | Note(3) | Note(3)         |
| LVCMOS25,<br>LVDCI25   | -0.3   | 0.7                  | 1.7                  | V <sub>CCO</sub> + 0.3 | 0.4                  | V <sub>CCO</sub> - 0.4  | Note(3) | Note(3)         |
| LVCMOS18,<br>LVDCI18   | -0.3   | 35% V <sub>CCO</sub> | 65% V <sub>CCO</sub> | V <sub>CCO</sub> + 0.3 | 0.45                 | V <sub>CCO</sub> - 0.45 | Note(4) | Note(4          |
| LVCMOS15,<br>LVDCI15   | -0.3   | 35% V <sub>CCO</sub> | 65% V <sub>CCO</sub> | V <sub>CCO</sub> + 0.3 | 25% V <sub>CCO</sub> | 75% V <sub>CCO</sub>    | Note(4) | Note(4          |
| LVCMOS12               | -0.3   | 35% V <sub>CCO</sub> | 65% V <sub>CCO</sub> | V <sub>CCO</sub> + 0.3 | 25% V <sub>CCO</sub> | 75% V <sub>CCO</sub>    | Note(6) | Note(6          |
| PCI33_3 <sup>(5)</sup> | -0.2   | 30% V <sub>CCO</sub> | 50% V <sub>CCO</sub> | V <sub>cco</sub>       | 10% V <sub>CCO</sub> | 90% V <sub>CCO</sub>    | Note(5) | Note(5          |
| PCI66_3 <sup>(5)</sup> | -0.2   | 30% V <sub>CCO</sub> | 50% V <sub>CCO</sub> | V <sub>CCO</sub>       | 10% V <sub>CCO</sub> | 90% V <sub>CCO</sub>    | Note(5) | Note(5          |
| PCI-X <sup>(5)</sup>   | -0.2   | 35% V <sub>CCO</sub> | 50% V <sub>CCO</sub> | Vcco                   | 10% V <sub>CCO</sub> | 90% V <sub>CCO</sub>    | Note(5) | Note(5          |

#### Source: Xilinx Virtex 5 Datasheet

6.111 Fall 2017 Lecture 1 33 6.111 Fall 2017 Lecture 1

# A Digital Processing Element

A combinational device is a processing element that has

- one or more digital *inputs* 

One of two discrete values

- one or more digital outputs
- a functional specification that details the value of each output for every possible combination of valid input values
- a timing specification consisting (at minimum) of an upper bound t<sub>pd</sub> on the required time for the device to compute the specified output values from an arbitrary set of stable, valid input values



## Why have processing blocks?

• The goal of modular design:

#### ABSTRACTION

- What does that mean anyway:
  - Rules simple enough for a 6-3 to follow...
  - Understanding BEHAVIOR without knowing IMPLEMENTATION
  - Predictable composition of functions
  - Tinker-toy assembly
  - Guaranteed behavior under REAL WORLD circumstances

Static

discipline

## A Combinational Digital System

- A set of interconnected elements is a *combinational device* if
  - each circuit element is a combinational device
  - every input is connected to exactly one output or a constant (e.g., some vast supply of 0's and 1's)
  - the circuit contains no directed cycles
- Why is this true?
  - Given an acyclic circuit meeting the above constraints, we can derive functional and timing specs for the input/output behavior from the specs of its components!
  - We'll see lots of examples soon. But first, we need to build some combinational devices to work with...

#### Example Device: An Inverter

0 - 2 - 1



Voltage Transfer Characteristic: Plot of  $V_{OUT}$  vs.  $V_{IN}$  where each measurement is taken after any transients have died out.

> Note: VTC does not tell vou anything about how fast a device is—it measures static behavior not dvnamic behavior

1 - 2 - 0

Static Discipline requires that we avoid the shaded regions (aka "forbidden zones"), which correspond to valid inputs but invalid outputs. Net result: combinational devices must have GAIN > 1 and be NONLINEAR.  $\partial V_{OUT}$ 

| 6.111 Fall 2017 | Lecture 1 | 37 | 6.111 Fall 2017 | Lecture 1 | $\partial V_{IN}$ | 38 |
|-----------------|-----------|----|-----------------|-----------|-------------------|----|
|                 |           |    |                 |           |                   |    |

## **Combinational Device Wish List**



- ✓ Design our system to tolerate some amount of error
  - $\Rightarrow$  Add positive noise margins  $\Rightarrow$  VTC: gain>1 & nonlinearity
- $\checkmark$  Lots of gain  $\Rightarrow$  big noise margin
- ✓ Cheap, small
- ✓ Changing voltages will require us to dissipate power, but if no voltages are changing, we'd like zero power dissipation
- Want to build devices with useful functionality (what sort of operations do we want to perform?)

## Wishes Granted: CMOS



6.111 Fall 2017

39

6.111 Fall 2017

### **MOSFETS:** Gain & Non-linearity



MOSFETs (metal-oxide-semiconductor field-effect transistors) are four-terminal voltage-controlled switches. Current flows between the diffusion terminals if the voltage on the gate terminal is large enough to create a conducting "channel", otherwise the mosfet is off and the diffusion terminals are not connected.

### **Digital Integrated Circuits**



Mosfet (under polysilicon gate)

6.111 Fall 2017 Lecture 1 41 6.111 Fall 2017 42 Lecture 1



#### **Functional Specifications**



An concise, unambiguous technique for giving the functional specification of a combinational device is to use a truth table to specify the output value for each possible combination of input values (N binary inputs -> 2<sup>N</sup> possible combinations of input values).

6,111 Fall 2017



| <ul> <li><b>Dektronix Logic Analyzer -Demo</b></li> <li>4 Sets of 16 channels plus clock = 68 channels</li> <li>Align probes with flying leads correctly</li> <li>Screen capture</li> <li>redundant keyboard/cursor/mouse controls</li> <li>cursor1/2 locator</li> <li>fastest sampling rate is 2ghz, magniview is 8ghz</li> <li>sampling can be clocked externally or internally (select judiciously)</li> <li>triggering modes - simple events, complex multiple events</li> <li>waveforms - customize via right mouse click: expand channels, change radix, rename, delete, add</li> <li>Future labs will have LA directly connected via analyzer ports.</li> </ul> |    | Ba              | Hand in<br>ckground Information |    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----------------|---------------------------------|----|
| 6.111 Fall 2017 Lecture 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 49 | 6.111 Fall 2017 | Lecture 1                       | 50 |