

# Chapter 10 Memory and Storage

# Outline

- Fundamentals of Semiconductor Memory
- Random-Access Memories (RAM)
- Read-Only Memories (ROM)
- Programmable ROMs (PROMs)
- Flash Memories
- Memory Expansion
- Special Types of Memories

# 10.1 Fundamentals of Semiconductor Memory

- Units of binary data
  - Bits: the smallest unit of binary data
  - Bytes: 8-bit units
  - Nibbles: 4-bit units
  - Words: a complete unit of information; one or more bytes

**Figure 10–1** A 64-cell memory array organized in three different ways.



(a)  $8 \times 8$  array



(b)  $16 \times 4$  array



(c)  $64 \times 1$  array

# Notes

- A memory is identified by the number of words it can store times the word size
  - $16K \times 8$  : 16384 words of eight bits each
- The actual number of words is always a power of 2
  - $2^{16} = 65536$

# Memory Address and Capacity



(a) The address of the blue bit  
is row 5, column 4.



(b) The address of the blue byte  
is row 3.

**Figure 10–2** Examples of memory address in a 2-dimensional array.

Figure 10–3 Example of memory address in a 3-dimensional array.



The address of the blue byte is row 5, column 8.

- The location of a unit of data in a memory array is called its **address**.
- The **capacity** of a memory: the total number of data units that can be stored.

# Basic memory operation



(a) 2-dimensional memory array



(b) 3-dimensional memory array

# Write Operation



- ① Address code 101 is placed on the address bus and address 5 is selected.
- ② Data byte is placed on the data bus.
- ③ Write command causes the data byte to be stored in address 5, replacing previous data.

# Read Operation



- ① Address code 011 is placed on the address bus and address 3 is selected.
- ② Read command is applied.
- ③ The contents of address 3 is placed on the data bus and shifted into data register.  
The contents of address 3 is not erased by the read operation.

# 10.2 Random-Access Memories (RAMs)

- RAMs are read/write memories in which data can be written into or read from any selected address in any sequence.
- Two categories of RAM
  - Static RAM (SRAM)
    - use latches as storage element
    - Store data indefinitely as long as dc power is applied
  - Dynamic RAM (DRAM)
    - Use capacitors as storage elements
    - Need being recharged by a process called refreshing

# SRAMs and DRAMs

- Data can be read much faster from SRAMs than from DRAMs
- DRAMs can store much data than SRAMs for a given physical size and cost
- CPU Cache: SRAM, Computer Memory: DRAM

**Figure 10–7** The RAM family.



# Static RAMs (SRAMs)



A typical SRAM latch memory cell.

# Basic SRAM array.



# Logic diagram for an asynchronous 32k x 8 SRAM.



**Figure 10–11** Basic organization of an asynchronous 32k x 8 SRAM.



Figure 10–12 Basic read and write cycle timing for the SRAM in Figure 10–11.



(a) Read cycle ( $\overline{WE}$  HIGH)



(b) Write cycle ( $\overline{WE}$  LOW)

# Dynamic RAM (DRAM) Memory Cells



# Basic operation of a DRAM cell.



(a) Writing a 1 into the memory cell



(b) Writing a 0 into the memory cell



(c) Reading a 1 from the memory cell



(d) Refreshing a stored 1

# Simplified block diagram of a 1M x 1 DRAM.



# Normal read and write cycle timing.



(a) Read cycle



(b) Write cycle

## 10.3 Read-Only Memories (ROMs)

- Store data permanently or semi-permanently
- Stored data can be read from the memory
- Stored data can not be changed at all or cannot be changed without specialized equipment.



# ROM cells



# A representation of a 16 x 8-bit ROM array.



**Figure 10–26** A 256 x 4 ROM logic symbol. The  $A \frac{0}{255}$  designator means that the 8-bit address code selects addresses 0 through 255.



Figure 10–27 A 1024-bit ROM with a  $256 \times 4$  organization based on a  $32 \times 32$  array.



Figure 10–28 ROM access time ( $t_a$ ) from address change to data output with chip enable already active.



# 10.4 Programmable ROMs

- PROMs
- EEPROMs
- EEPROMs

Figure 10–29 MOS PROM array with fusible links. (All drains are commonly connected to  $V_{DD}$ .)



After the programming process, the link is left intact for a stored '1'.

# EPROM : Erasable PROM (by ultraviolet)

## EEPROM: Erasable by electrical pulses



Ultraviolet erasable PROM package



The logic symbol for a 2048 x 8 UV EPROM

# 10.5 Flash Memories



Many electrons = more charge = stored 0.



Few electrons = less charge = stored 1.

The storage cell in a flash memory.

# 10.6 Memory Expansion

- Word-length expansion
- Word-capacity expansion

**Figure 10–38** Expansion of two  $65,536 \times 4$  ROMs into a  $65,536 \times 8$  ROM to illustrate word-length expansion.



(a) Two separate  $65,536 \times 4$  ROMs



(b) One  $65,536 \times 8$  ROM from two  $65,536 \times 4$  ROMs

Example: Expand the 65536 x 4 ROM to form a 64k x 8 ROM and a 64k x 16 ROM





a 64k x 8 ROM



a 64k x 16 ROM

# Word-capacity Expansion



(a) Individual memories each store 1,048,576 8-bit words



(b) Memories expanded to form a  $2M \times 8$  RAM requiring a 21-bit address bus

# Use 512k x 4 RAM to implement a 1M x 4 memory



# 10.7 Special Types of Memories

- FIFO memories
- LIFO memories

# Comparison of conventional shift register and FIFO register operation

| Conventional shift register |   |   |   |   |        |
|-----------------------------|---|---|---|---|--------|
| Input                       | X | X | X | X | Output |
| 0                           | 0 | X | X | X | →      |
| 1                           | 1 | 0 | X | X | →      |
| 1                           | 1 | 1 | 0 | X | →      |
| 0                           | 0 | 1 | 1 | 1 | →      |

X = unknown data bits.

In a conventional shift register, data stay to the left until “forced” through by additional data.

| FIFO shift register |   |   |   |   |        |
|---------------------|---|---|---|---|--------|
| Input               | - | - | - | - | Output |
| 0                   | — | — | — | — | 0 →    |
| 1                   | — | — | 1 | 0 | →      |
| 1                   | — | 1 | 1 | 0 | →      |
| 0                   | 0 | 1 | 1 | 0 | →      |

— = empty positions.

In a FIFO shift register, data “fall” through (go right).

Figure 10–49 Block diagram of a typical FIFO serial memory.



**Figure 10–50** Examples of the FIFO register in data-rate buffering applications.



(a) Irregular telemetry data can be stored and retransmitted at a constant rate.



(b) Data input at a slow keyboard rate can be stored and then transferred at a higher rate for processing.



(c) Data input at a constant rate can be stored and then output in bursts.



(d) Data in bursts can be stored and reformatted into a constant-rate output.

# Register Stack (LIFO: Last In First Out)



**Figure 10–52** Simplified illustration of pushing data onto the stack.

First data byte pushed onto stack



Second data byte pushed onto stack



Third data byte pushed onto stack



Figure 10–53 Simplified illustration of pulling data from the stack.

Initially storing 3 data bytes.  
The last byte in is at top-of-stack.



After third byte is pulled  
from stack, the second byte  
that was stored pops up to  
the top-of-stack.



After second byte is pulled  
from stack, the first byte  
that was stored pops up to  
the top-of-stack.



# Application: arithmetic expression calculation in computer

Example:  $a+b*c/d = ?$

**number stack**

(1)



**operator stack**



(2)



Example:  $a+b*c/d = ?$



Example:  $a+b*c/d = ?$

**number stack**



**operator stack**



(6)



(7)



# Summary

- Basics of Semiconductor Memory
- RAM: SRAM and DRAM
- ROM
  - PROM, EPROM, EEPROM, Flash ROM
- Memory Expansion
- FIFO and Stack

# HW

- 10<sup>th</sup> Page 409-411

- 9
- 10
- 11
- 17

- 11<sup>th</sup> Page 377-378

- 9
- 10
- 11
- 18