# **Internal Memory**



### **Semiconductor Memory**



- RAM Memory
  - <u>wired-in addressing logic</u> are used to access individual words
  - rapid reading & writing is possible
  - volatile constant power supply required
  - temporary storage
- ROM/PROM Memory (read only, programmable read-only)
  - o read-only
  - o non-volatile
  - permanent storage
- EPROM Memory (erasable & programmable)
  - o mostly read-only
  - o erasable & writable via UV light source (off-line)
  - o non-volatile
  - permanent storage
  - **EEPROM Memory (electronically erasable & programmable)** 
    - o mostly read-only
    - electronically erasable & writable (on-line)
    - non-volatile
    - permanent storage
- Flash Drive Memory
  - block-level read & write slow (storage device)
  - mixed features of both main memory & disk storage
  - electronically erasable & writable (on-line)
  - o non-volatile
  - o permanent storage

## **RAM Memory -- used for Main Memory**

#### DRAM – dynamic RAM

- DRAM cells store a charge on a capacitor
  - presence of a charge indicates 1
  - absence of a charge indicates 0
- capacitors have a natural tendency to discharge → require periodic recharging
- tendency of the stored charge to leak away → <u>dynamic</u>

**DRAM Address Line** 

analog device, i.e., Sense Amplifier <u>measures</u> the Storage Capacitors contents



whether it represents a zero or a one, i.e., the capacitor may hold any charge value within a specified range

### SRAM – static RAM – used for Cache Memory

- digital device
- flip-flop logic-gate
- holds data as long as power supply exists
- no refresh is required to hold data



| T₁ & T₄ off                         |
|-------------------------------------|
| T <sub>2</sub> & T <sub>3</sub> on  |
|                                     |
| T₁ & T₄ on                          |
| T <sub>2</sub> & T <sub>3</sub> off |
|                                     |

SRAM address line is used to open/close the transistor switches  $T_5 \& T_6$  which allows a read/write operation

#### Write Operation

- desired bit value is supplied to bit line B and the complement value is supplied to bit line B....
- the four transistors  $T_1$ ,  $T_2$ ,  $T_3$ ,  $T_4$  are forced into proper state to hold the desired bit value

#### **Read Operation**

• bit value is read from bit line B

### **DRAM versus SRAM**

- DRAM cells main memory
  - o are simpler & smaller than SRAM cells
  - o can be more can be tightly packed together than SRAM cells
  - o inexpensive
  - require refresh circuitry
- SRAM -- cache memory
  - o faster than DRAM do not require rewriting upon reading

### **ROM Memory**

- · data is permanently in main memory, i.e., read-only
- · program permanently in main memory
- nonvolatile
- no power source required
- information is "burned", i.e., "hard-wired" into chip during fabrication
- chip creation must be exact an error in a single bit invalidates the entire chip run
- high-volume production runs

#### Usage:

- microprogramming •
- library subroutines •
- system programs •
- function tables •

### **PROM Memory – programmable ROM**

- data is permanently in main memory, i.e., read-only after write-once
- program permanently in main memory
- nonvolatile
- no power source required
- information is electronically inserted into the chip after fabrication using special equipment while the chip is off-line
- · low or medium volume production runs

#### Write-Mostly Memory

- EPROM erasable programmable ROM http://en.wikipedia.org/wiki/EPROM
  - o optical media
  - 0 all storage cells on the chip are erased to an initial state by exposure to an intense ultra-violet light
  - erasure may be done repeatedly
  - erasure may take 10-20 minutes to perform 0
  - one transistor per cell 0
  - more expensive than PROM
- EEPROM electronically erasable programmable ROM http://en.wikipedia.org/wiki/EEPROM • rewritable at the byte level without prior erasure
  - writable in place, i.e., on-line, using ordinary bus control, address & data lines
  - o field-effect transistors http://en.wikipedia.org/wiki/Field\_effect\_transistor
  - write operation takes several hundred microseconds per byte, i.e.,  $\approx$  0.5 0.01 milliseconds
  - completion time: read operation « write operation
  - more expensive than EPROM
  - less dense than EPROM
- Flash Memory
  - o rewritable at the **block level** without prior erasure
  - one transistor per cell

Flash memory is not byte addressable

- o entire blocks of memory cells are erased in a single flash
- 0 erasure of entire flash memory can be accomplished in a few seconds

**Chip Organization & Functional Logic** 

- Organizational Principle -- number of bits of data read/written at a time
  - Physical arrangement of cells in the array is the same as the logical arrangement of words in memory, i.e., array contains W words of B bits each, e.g., 16-Mbit chip organized as 1M of 16 bit words
  - o One bit per chip arrangement, data is written 1 bit at a time



- A0, A1, ..., A10 are used to pass both row & column address information
  - i. A0, A1, ..., A10 are used to pass row address information with the <u>Row Address Select</u> line as well as either the <u>Write Enable</u> **line or the** <u>Output Enable</u> **line set**
  - ii. A0, A1, ..., A10 are used to pass column address information with the <u>Column Address</u> <u>Select</u> line as well as either the <u>Write Enable</u> **line or the** <u>Output Enable</u> **line set**
- Using one more address line, e.g., A0, A1, ..., A10, A11 doubles the number of rows and columns thus quadrupling the amount of memory on an array, i.e., output rows 2<sup>12</sup> == 4096 and output columns 2<sup>12</sup> == 4096 yields an array 4096 x 4096 x 4
   Note: 4096 x 4096 x 4 → 67,108,864 whereas 2048 x 2048 x 4 → 16,777,216 16,777,216 x 4 → 67,108,864

Refresh Circuitry

- i. disable DRAM chip
- ii. the refresh counter selects the row values one at a time; the selected values are supplied to the row decoder and the <u>Row Address Select</u> line is activated. The data is read out and rewritten into the same location thus each cell in the row is refreshed.

- Chip Packaging
  - EPROM chip pg 166 fig 5.4 8 Mbit chip
  - DRAM chip pg 167 fig 5.5 16 Mbit chip

organized as 1M x 8 one word/chip package organized as 4M x 4 4 arrays 2048 x 2048  $2^{11} \times 2^{11} \Rightarrow 2^{22} \Rightarrow 4M$ NC pin ("no connect" provided to provide even number of pins)

Module Organization

- RAM chip contains 1 bit per word  $\rightarrow$  n RAM chips required for n bit word,
  - e.g., 8 RAM chips required for byte addressable memory
- other configurations become more complex
- interleaved memory
  - main memory composed of a collection of DRAM chips
  - chips are grouped into **memory banks**
  - each bank may independently service a memory request; i.e.,
  - o system composed of K banks can simultaneously service K requests
  - consecutive words stored in different banks → transfer times for memory blocks will be increased

Error Correction

- Hard Failure permanent physical defect in the cell
- Soft Failure random, nondestructive event, alters content without damaging the cell
  - power supply fluctuations
  - alpha particles radioactive decay
- procedure



Hamming Code <to be discussed later>

#### SDRAM (Synchronous DRAM)

• SDRAM moves data under the control of the system clock, i.e., synchronous access

#### **DRAM** operation

- CPU sends addresses & control information to DRAM
- During access time delay, DRAM activates the high capacitance of the row & column lines, senses the data and routes the data to output buffers
- CPU must wait during the access time delay
- Processor, or surrogate, issues instructions and address information which is latched by the SDRAM
- SDRAM responds after a <u>specified number of clock cycles</u>
- CPU can engage in other tasks while the SDRAM responds to the request
- SDRAM provides a mechanism to enable customization of chip operation to meet specific needs of system builders
- SDRAM performs best when transferring large blocks of data, e.g., multimedia, spreadsheets, word processing

# DDR-SDRAM (Double Data Rate SDRAM) <u>http://en.wikipedia.org/wiki/DDR\_SDRAM</u>

• Sends data to the processor twice per clock cycle – one on the leading edge, another on the following edge

### DDR2-SDRAM http://en.wikipedia.org/wiki/DDR2\_SDRAM

DDR3-SDRAM <u>http://en.wikipedia.org/wiki/DDR3\_SDRAM</u>

### RDRAM (Rambus DRAM) http://en.wikipedia.org/wiki/Rambus DRAM

- special RDRAM bus asynchronous block-oriented protocol
- defines impedances, clocking, signals very precisely
- receives memory requests over a high-speed bus
- o request contains address, type of operation (read/write) and number of bytes desired
- RDRAM bus connects to the controller at on end and is terminated at the other end
- Clock signal originates at the terminated end, propagates to the controller end and is then reflected back to the terminated end
- bits are sent at both the <u>leading</u> and the <u>following</u> edge of each clock signal going toward the controller

   signal rate 800 Mbps (cycling twice the clock rate)
   standard usage is send bits online

standard usage is send bits only at one of the edges of a clock signal

- RDRAM module sends data to the controller synchronously to the master on the forward direction
- Controller send data to the RDRAM synchronously with the clock signal in the opposite direction
- initial 480 nanosec access time, it produces a 1.6 GBps data rate

CD-DRAM Integration of a small SRAM cache (16 Bb) onto a generic DRAM chip

- used as cache memory
- used as a buffer to support serial access of a block of data

Embedded Systems Architecture: A Comprehensive Guide for Engineers and Programmers (Embedded Technology) by Tammy Noergaard (Feb 24, 2005)

Flash Memory Bez, R. et. al. Introduction To Flash Memory Proceedings of the IEEE, April 2003

see page 175 figure 5.12 for internal logic diagram

see page 176 figure 5.13 for timing chart activity

Intel Pentium & Itanium processors