

### LAB HOURS THIS WEEK

- Eren will not be holding lab hours this Tuesday evening.
- Monica still has hours on Wednesday from 11am-1pm (unless no one is planning to show up...)

# MEMORY DEFINITIONS

- Size (Kbytes, Mbytes, Gbytes, Tbytes)
- Timing parameters
  - Read Access delay between read request and the data available
  - Write Access delay between write request and writing data to memory
  - (Read or Write) Cycle min. time required between read/writes



# MEMORY DEFINITIONS Function – functionality, nature of the storage mechanism static and dynamic; volatile and nonvolatile Access pattern – random, serial, content addressable Input-output architecture – number of data input and output ports (multi-ported memories) Application – embedded, secondary, tertiary

| RWM                         |                   | NVRWM  | ROM               |
|-----------------------------|-------------------|--------|-------------------|
| Random Access               | Non-Random Access | EPROM  | Mask-programmed   |
| SRAM (cache, register file) | FIFO, LIFO        | EEPROM |                   |
| DRAM (main memory)          | Shift Register    | FLASH  | Electrically-     |
|                             | CAM               |        | programmed (PROM) |

- Mostly read and rarely written
  - Much faster to read than write
- Non-volatile, e.g., flash memory

- powered off
- SRAM, DRAM





# USING ROMS FOR COMBINATIONAL LOGIC



## ROM AS A "RANDOM-LOGIC" CIRCUIT

- ROM advantages
  - Design time is short
  - Can implement any function of n inputs
- ROM disadvantages
  - Size doubles for each additional input
  - Cannot exploit logic minimization (e.g., don't cares)

# READ ONLY MEMORIES (ROMS)

- A memory that can only be read and never altered
  - Programs for fixed applications that, once developed and debugged, never need to be changed (only read)
  - Fixing the contents at manufacturing time leads to small and fast implementations.







### 3



# **READ/WRITE MEMORIES (RAMS)**

### Static – SRAM

- data is stored as long as voltage supply is enabled
- large cells (6 FETs/cell) → fewer bits/chip
- fast  $\rightarrow$  used where speed is important (e.g., caches)
- Dynamic DRAM
- periodic refresh required (every 1 to 4 ms)
- small cells (I to 3 FETs/cell) → more bits/chip
- slower  $\rightarrow$  used for main memories













