## Lecture 1 – History and Overview

CSE P567

## What is a Computer?

- Performs calculations
  - On numbers
  - But everything can be reduced to numbers
- Follows instructions (a program)
- Automatic (self-contained)
- Machine
  - But used to refer to people







- Cards with holes are the instructions
- The holes control the hooks attached to warp threads
- First machine to use punch cards to control sequencing operation of a machine
- But not a calculator











## 1942: Atanasoff-Berry Computer

- Iowa State College
- > Not fully functional, but won patent dispute

















### Hardware Design

- Ignoring scale, HW design reduces to:
  - Logic gates (AND, OR, INVERT)
  - Storage (registers)
- We can make these with *switches*
- We can make switches with:
  - Relays
  - Vacuum tubes
  - Transistors (more later)
  - Nanotubes
  - ▶ ???

### Hardware Design

- "Register Transfer"
  - Move values from register to register
  - Perform some operation on these values
- CPU Example:
  - ▶ RI = R2 + R3
  - > Values already in R2 and R3
  - Move (connect) these values from R2 and R3 to the adder

- Move (connect) the adder output to RI
- Wait for clock to store new value in RI
  - Make sure only R1 is enabled



```
FIR Filter Example
• Mix of sequencing and computation

\begin{aligned}
& for (i = 0; i < N-T+1; i++) & {y[i] = 0; for (j = 0; j < T; j++) & {y[i] += c[j] * x[i+j]; } \\ & y[i] += c[j] * x[i+j]; \\ & y \end{aligned}

• T adds and T multiplies for each y[i]
• Simple program uses at least 2T instructions
• Plus loads and stores
```





















# Hardware Systems

#### Multiple, interacting hardware components

- Multiple controller & datapaths
- Memories
- Disk controllers
- Network interfaces
- > Physical interfaces (lights, motors, sensors, etc.)
- etc.
- Connected together using interfaces and communication buses

### Communication Buses

- Point-to-point
- Single master/multiple slave
- Multiple master
- Synchronous vs. Asynchronous
- Parallel vs. Serial
- Speed constrained by electrical considerations
  - Impedencemis-match
  - Ringing and reflections
  - Crosstalk
  - Return paths
  - > Single-ended vs. differential
  - Inductive effects (di/dt)

\_\_\_\_\_





## Design Methodology

- Same flow for ASICs and FPGAs
  - > Only details are different
- We will focus on using HDLs
  - Virtually all design is done with HDLs
- Verilog vs.VHDL
  - A matter of taste they are more-or-less equivalent
  - Verilog simple syntax, easy to learn
  - VHDL more verbose, support for complex systems
  - We will use Verilog

### Verilog

- Syntax is reminiscent of C (or Java)
- Semantics is NOT!
- > All blocks execute in parallel
- Register Transfer model
  - clock ticks: all registers latch new values (if enabled)
  - all logic computes new results with new register values
  - clock ticks: all registers latch new values (if enabled)
    - all logic computes new results with new register values

• etc.







