

## 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 1

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





ΤA



Introductions



Shawn Jain Gim Hom Lectures

Weston Braun UTA

Alex Sloboda UTA

Mitchell Gu

UTA

Valerie Sarge







Joe Steinmeyer Course Assistant

LA's

Madeline Waller

6931 0 69.57pa5/635E

Lecture 1

David Gomez

2

4

Introductions - The Hardware



6.111 Labkit 6M-gate FPGA + audio + video + memories + ...



Nexys 4 -DDR Analog Input ,PWM Audio, ADX362 3-axisaccelerometer, ADI temp sensor ...

38-600





6.111 Fall 2016

1

6.111 Fall 2016

Lecture 1



### Assignments



A large number of students do "A" level work and are, indeed, rewarded with a grade of "A". The corollary to this is that, since average performance levels are so high, punting any part of the subject can lead to a disappointing grade.

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

- Design proposal (2%)
- Design presentation (6%)
- Final Report (5%)

#### Labs: learning the ropes

• Lab 1

- Experiment with gates, design & implement some logic
- Learn about lab equipment in the Digital Lab (38-600): oscilloscopes and logic analyzers
- Lab 2
  - Introduction to Verilog, ModelSim & the labkit
- Lab 3
  - Video circuits: a simple Pong game
  - Use Verilog to program an FPGA
- Lab 4
  - Design and implement a Finite State Machine (FSM) Car Alarm \*
- Lab 5
  - Design a complicated system with multiple FSMs (Major/Minor FSM)
    - · Voice recorder using AC97 codec and SRAMs or
    - Build your own remote control \*
- All labs must be completed before starting final project.

#### \* 6.111 labkit or Nexys 4 implementation



Open-ended

(e.g., data converters, sensors or motors) common and often desirable

**Final Project** 

• Done in groups of two or three; one person project by exception

- Proposal Conference, several Design Reviews
- 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.



## Collaboration

- Labs must be done independently but students may seek help from other students.
- Work submitted for review must be their own



## 6.111 Evolution

Fall 1969

#### Fall 2016

<text><text><text><text>

#### 6.111 Introductory Digital Systems Laboratory

♥(\$) ♣ Prereq: 6.002, 6.071, or 16.004 Units: 3-7-2 Lecture: *TR2.30-4* (32-124) Lab: *TBA* 

Lectures and labs on digital logic, flip flops, PALs, FPGAs, counters, timing, synchronization, and finitestate machines prepare students for the design and implementation of a final project of their choice: games, music, digital filters, wireless communications, video, or graphics. Extensive use of Verilog for describing and implementing digital logic <u>designs</u>

## 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.
- Most popular applications: arithmetic and scientific computation

| 6.111 Fall 2016 | Lecture 1 | 13 | 6.111 Fall 2016 | Lecture 1 | 14 |
|-----------------|-----------|----|-----------------|-----------|----|
|                 |           |    |                 |           |    |

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



GEORGE DOOLE

- 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 2016

15

6.111 Fall 2016

## **Evolution of Digital Electronics**

Transistors

#### Vacuum Tubes





UNIVAC, 1951 1900 adds/sec



IBM System/360, 1964 500,000 adds/sec



## 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.

6.111 Fall 2016

## **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



6.111 Fall 2016

## Verilog and VHDL

| <u>VHDL</u>                                                                                     | Verilog                                                                                                  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| <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                                        |                                                                                                          |  |  |  |  |  |

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 VHDL and Verilog. Verilog is similar to c and a bit easier to learn. 21 6.111 Fall 2016 22 Lecture 1 Lecture 1

## 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



## Synthesis and Mapping for FPGAs

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

a counter. My FPGA has some

always @ (posedge clk) begin count <= count + 1;</pre> end

HDL Code

"This section of code looks like counter

Inferred Macro

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

of those ...

| 1 | м | М | М | М | М | М | М |
|---|---|---|---|---|---|---|---|
|   | м | М | М | М | М | М | М |
|   | м | М | М | М | М | М | М |
|   | М | М | М | М | М | М | M |
|   | м | М | Μ | Μ | М | 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 2016



## 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.



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 Signaling: receiving

Lecture 1

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!

The Digital Abstraction

"Ideal"

Digital World

0/1

Bits

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.

Manufacturing Variations

Volts or Electrons or

Ergs or Gallons

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.

27

## Digital processing elements



6.111 Fall 2016

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.

### 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.



## **Digital Signaling Specification**

Lecture 1

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    |                      | VIH                  |                        | VOL                  | V <sub>OH</sub>         | IOL     | I <sub>OH</sub> |
|------------------------|--------|----------------------|----------------------|------------------------|----------------------|-------------------------|---------|-----------------|
|                        | 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

29



## 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



#### <sup>1</sup> <sup>V</sup>oυ⊤ 0−1 1−∞−0

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 you anything about how fast a device is—it measures static behavior not dynamic behavior

> > $\partial V_{IN}$

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.

Lecture 1

35

6.111 Fall 2016

#### Combinational Device Wish List Wishes Granted: CMOS ✓ Design our system to tolerate some amount of error $V_{IN}$ VOUT $\Rightarrow$ Add positive noise margins $V_{\rm IN}$ $V_{OUT}$ $\Rightarrow$ VTC: gain>1 & nonlinearity V<sub>OUT</sub> $\checkmark$ Lots of gain $\Rightarrow$ big noise margin ✓ Cheap, small V<sub>OH</sub> ✓ Changing voltages will require us VIL 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 Vol operations do we want to $V_{OUT} \leq V_{OL}$ $V_{OUT} \ge V_{OH}$ $V_{IN} \leq V_{II}$ $V_{IN} \ge V_{IH}$ perform?) $V_{\rm IL}$ $V_{\rm IH}$ V<sub>OUT</sub> eventually OUT eventually reaches VDD reaches GND 6.111 Fall 2016 37 6.111 Fall 2016 Lecture 1 l ecture i

### **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)



## **Timing Specifications**

Propagation delay (t<sub>PD</sub>): An <u>upper bound</u> on the delay from valid inputs to valid outputs (aka "t<sub>PD,MAX</sub>")



#### Contamination Delay an optional, additional timing spec Contamination delay(t<sub>CD</sub>): A <u>lower bound</u> on the delay from invalid inputs to invalid outputs (aka "t<sub>PD,MIN</sub>") $V_{TN}$ Do we really need V<sub>T</sub> †<sub>CD</sub>? V. Usually not... it'll be important when we design circuits with VOUT $\dagger_{CD}$ registers (coming r<sub>cd</sub> soon!) Vo If $t_{CD}$ is not specified, safe to V. assume it's 0

Lecture 1

### The Combinational Contract



### Summary

- Use voltages to encode information
- "Digital" encoding
  - valid voltage levels for representing "0" and "1"
  - forbidden zone avoids mistaking "0" for "1" and vice versa
- Noise
  - Want to tolerate real-world conditions: NOISE.
  - Key: tougher standards for output than for input
  - devices must have gain and have a non-linear VTC
- Combinational devices
  - Each logic family has Tinkertoy-set simplicity, modularity
  - predictable composition: "parts work  $\rightarrow$  whole thing works"
  - static discipline
    - digital inputs, outputs; restore marginal input voltages
    - complete functional spec, e.g., a truth table
    - valid inputs lead to valid outputs in bounded time ( $< t_{PD}$ )

| 111 Fall 2016 | Lecture 1 | 45 | 6.111 Fall 2016 | Lecture 1 | 46 |
|---------------|-----------|----|-----------------|-----------|----|
|               |           |    |                 |           |    |

### Tektronix Logic Analyzer -Demo

- 4 Sets of 16 channels plus clock = 68 channels
- Align probes with flying leads correctly
- Screen capture
- redundant keyboard/cursor/mouse controls
- cursor1/2 locator
- fastest sampling rate is 2ghz, magniview is 8ghz
- sampling can be clocked externally or internally (select judiciously)
- triggering modes simple events, complex multiple events
- waveforms customize via right mouse click: expand channels, change radix, rename, delete, add ...
- Future labs will have LA directly connected via analyzer ports.

## Hand in Background Informatin