## SYNCHRONOUS DRAM (SDRAM)

- Access is synchronized with an external clock
- Address is presented to RAM
- RAM finds data (CPU waits in conventional DRAM)
- Since SDRAM moves data in time with system clock, CPU knows when data will be ready
- CPU does not have to wait, it can do something else
- Burst mode allows SDRAM to set up stream of data and fire it out in block
- DDR-SDRAM sends data twice per clock cycle (leading & trailing edge)



# **RAMBUS or RDRAM**

#### Characteristics:

- Suggests transfer rates from 1.6 to 10.7 • GBytes per second.
- Subsystem consists of the memory array, the RAM controller, and a well-defined bus
- Bus definition includes all components • including the microprocessor and any other devices that may use it
- Vertical package (all pins on one side) called Rambus in-line memory modules (RIMMs)
- Adopted by Intel for Pentium & Itanium ٠

#### **Bus Definition:**

- Data exchange over 28 wires
- Different definitions require bus lengths less than 12 cm long (some definitions are longer up to 25 cm long)
- Bus addresses up to 320 RDRAM chips
- Communication protocol is packet-based
- Implements pipelined operation overlapping command and data
- 800 to 1200 MHz operation
- Inititial access time = 480ns
- After that, 1.6 GBps Suggests transfer rates from 1.6 to 10.7 GBytes per second.

# DON'T FORGET CHIP SELECTS TO ALLOW FOR MULTIPLE MEMORIES



### **DYNAMIC RAM (DRAM)**

### **POINTS OF INTEREST**

- Bits stored as charge in capacitors
- Simpler construction
- Smaller per bit
- Less expensive
- Slower than SRAM (maintenance and read overhead explained later)
- Requires refreshing of data
- Typical application is main memory
- Essentially analogue -- level of charge determines value

## **SCHEMATIC**



## **OPERATION**

- Address line active when bit read or written
- Logic '1' closes transistor switch (i.e., current flows)
- Write •
  - Voltage to bit line High for 1 low for 0 0
  - Signal address line Controls transfer of 0 charge to capacitor
- Read •
  - Address line selected transistor turns on 0
  - Charge from capacitor fed via bit line to 0 sense amplifier
  - 0 Compares with reference value to determine stored value of 0 or 1



- Address line transistors o T5 & T6 act as switches connecting cell
- Write apply value to B & compliment to B
- Read value is on line B

#### DRAM ORGANIZATION

ADDRESSING EXAMPLE: Assume we have a memory device with 32 pins: 8 data, 1 chip select, 1 write enable, 1 read enable, 1 power, 1 electrical ground. That leaves 32 - 13 = 19 pins for addressing giving us  $2^{19} = 512$  K addresses or memory locations. Not very much.

What if we gave the memory device its address in two stages? During the first stage, the upper half of the address is presented and stored in the memory device. The second stage presents the lower half of the address is presented and the memory device can return the data.

| Address lines: | Address (upper half) | Address (lower half) |                  |
|----------------|----------------------|----------------------|------------------|
| Data lines:    | No valid data        | No valid data        | RAM returns data |

This could effectively double the bits of our address. The above example now becomes  $19 \times 2 = 38$  address bits giving us a memory space of  $2^{38} = 256$  Gig.

#### DRAM ADDRESSING PROCESS

- Total number of address lines is half that of the total needed for the addressable locations
- A single addressable memory location has the address divided in half, e.g., the MSB half representing the row address and the LSB half representing the column address. This saves on pins.



- RAS (row address select) strobes the row address in to its buffer or latch.
- CAS (column address select) strobes the column address into its buffer or latch.

RETURN TO ADDRESSING EXAMPLE: This means that 2 additional pins are taken away from our earlier example leaving us with 17 pins  $\rightarrow$  17 × 2 = 34 address bits giving us a memory space of 2<sup>34</sup> = 16 Gig.

- Note: one more pin on the address guadruples the size of the matrix (doubles rows and doubles columns) for an increase by factor of four)
- If DRAM has 4-bit data bus, to make 16-bit data bus, we need four modules wired in parallel on the bus.

YEAH, BUT... doesn't it slow up the memory process by having two cycles?

#### FAST PAGE MODE (FPM)

If the processor needs a block from memory, the first half of the address should be the same for all addresses, right? In this case, start the memory process with the first half of the address, then only use the last half for subsequent retrievals. For example, FPM for a memory block of size 4 would look like this.

| Address: | Hi Half   | Lo Half  |        | Lo Half  |        | Lo Half  |        | Lo Half  |        |
|----------|-----------|----------|--------|----------|--------|----------|--------|----------|--------|
|          | Blck Addr | Addr. 0  |        | Addr. 1  |        | Addr. 2  |        | Addr. 3  |        |
| Data:    | No valid  | No valid | Data   |
|          | data      | data     | Word 0 | data     | Word 1 | data     | Word 2 | data     | Word 3 |

The data of a single row is referred to as a "page".

| Address: | Hi Half     | Lo Half  | Lo Half | Lo Half | Lo Half |        |
|----------|-------------|----------|---------|---------|---------|--------|
|          | Block Addr. | Addr. 0  | Addr. 1 | Addr. 2 | Addr. 3 |        |
| Data:    | No valid    | No valid | Data    | Data    | Data    | Data   |
|          | data        | data     | Word 0  | Word 1  | Word 2  | Word 3 |

EDO results in a savings of approximately 10 ns for each read within a single page.

- Two things discharge a DRAM capacitor o Data read
  - Leakage current
- Need refreshing even when powered and idle (once every few milliseconds)
- Refresh circuit included on chip Even with added cost, still cheaper than SRAM cost •
- Refresh process involves disabling chip, then reading data and writing it back
- Performed by counting through "rows" •
- Takes time Slows down apparent performance





Basic DRAM is unchanged since first RAM chips, so alternate techniques are used to improve performance.

- Use FPM or EDO to improved access time
- or CDRAM)

# **EXTENDED DATA-OUT (EDO)**

EDO allows the processor to overlap the data read cycle with the write for the next column address.

## **REFRESHING A DRAM**

## SPEEDING UP A DRAM

Can speed effective access time of by adding a cache between processor and DRAM (CACHE DRAM