

# DRAM - Basic Knowledge

Purdue SoCET - AI Hardware - DRAM Controller team. Studied with [this webpage](#).

## Basic IO



- Dual Function Address Bits
  - **RAS\_n**: Row Address Strobe
  - **CAS\_n**: Column Address Strobe
  - **WE\_n**: Write Enable Strobe
  - During Activation (**ACT\_n**=0). They are used as row addressing, **A0-16**
  - During R/W/Pre (**ACT\_n**=1). They combinationally define what function is operating. At the same time, other address bits will determine the column selection
- Posedge of **CK\_t** and negedge of **CK\_c**: All address & control signals are sampled at crossing to have exact timing
- Posedge of **DQS\_t** and negedge of **DQS\_c**: also differential property as **CK**. Data is sampled at both edges, into **DQ**
- **DQ**: Carry actual data bits. Same width as column width. **x4** means **DQ[3:0]**; **x8** means **DQ[7:0]**; **x16** means **DQ[15:0]**
- **CAS Latency**: latency from read to **DQ**. **CAS Write Latency** is for write

## Bankgroups and Banks



- cmd/addr: select address and commands
- local IO: communicate with sense amplifier
- global IO: connect **BG#** into **DQ**

## Single Storage Structure

- wordline: row; bitline: column
- Need to be refreshed: why it is called **Dynamic RAM**
- Steps:
  1. Activate; row select
  2. R/W; column select
  3. Pre-charge: close the row
  4. RDA (Read Auto-Precharge) / WRA (Write Auto-Precharge): can combine 2 & 3
- Write / Read are **Burst Oriented**

## Total DRAM Capacity Calculation

- **Total\_Capacity** = num\_row \* num\_col \* width\_col \* num\_BG \* num\_bank
- **Page\_size** = num\_col \* width\_col = number of bits per row

Example: row=A0-16; column=A0-A9; Width\_col: x4; BG=4; num\_bank=4.

We can calculate:

$$\begin{aligned}\text{Total_Capacity} &= 2^{16} * 2^{10} * 4 * 4 * 4 = 4 \text{ GB} \\ \text{Page_Size} &= 2^{10} * 4 = 4 \text{ KB}\end{aligned}$$

## DRAM Sub-system



- User Logic: send logic address and R/W request
- Controller: parse the logic address to physical address, and issue commands (like basic IO above) to DDR PHY
- PHY: actual signal send to DRAM

## ZQ Calibration

This can be used to calibrate internal banks of 240 ohm resistor, connected to DQ# pins, with external reference resistor.

## Vref DQ Calibration

## Standard Reference (JEDEC)

- 2.7 Pinout Description
- 3.# Functions
  - 3.1 Functional State Diagram
  - 3.3 Initialization Process
  - 3.5 Mode Register: set up different things
- 4.1 Commands