



# *Introduction to Memory - Part#2*

**Yoonjin Kim**

*Full Professor*

**Division of Computer Science  
Sookmyung Women's University**





# **Memory Classification** (메모리 분류)



# Unsuitable Memory Classification for Computer Science/Engineering Major

- Criterion of classification:  
Readable/writable

⇒ 메모리를 읽을수있거나 / 쓸수있거나

↳ 메모리의 읽기만으로는 보고  
불가능한 내용



- Criterion of classification:  
Volatile/nonvolatile

⇒ 휴대성 / 비휘발성



*So What?*

# Why Most of Memory Classification Unsuitable for CSE? → computer science / engineering

Because they do not show the relationship between processor and memory.

(processor + memory 를 본때)

(CPU)

(메모리)

It's necessary to consider following 5 factors (based on two criteria) for the suitable classification

5개 요소

2가지 조건

DRAM, SRAM



[Criterion#1] Is it feasible for main/local memory directly coupled with processor?

또 예전에는 byte-level로 접근했지만

⇒ ○: register / ✕:

microprocessor 밖에

5개 요소

2가지 조건

⇒ processor (CPU) 와 직접적으로 연결될 수 있는, main/local memory 올 적합한가?

= 8 bit =  $2^3$

= 256

[Factor#1] Byte-level read & write operation: readable & writable by 1-byte

[Factor#2] Fast read & write operation: enough to communicate with processor

- 두 가지를 만족하면
- processor에 바로 접근이 가능
- ⇒ main/local memory 올 적합한가?

[Criterion#2] Is it feasible for secondary memory?: if it does not qualify for main/local memory ⇒ 2차 메모리로 적합한가? (→ 세밀한 내용은 빠져감)

[Factor#3] Nonvolatile: saving bits without electric power (비휘발성)

[Factor#4] Both readable & writable (읽고 쓰기)

[Factor#5] Large capacity (용량)

- 용량적 제약 ←
- Secondary memory.

# Suitable Memory Classification for CS/E Major

[Criterion#1] Is it feasible for main/local memory directly coupled with processor?

[Factor#1] Byte-level read & write operation: readable & writable by 1-byte

[Factor#2] Fast read & write operation: enough to communicate with processor

Why Factor#1?



# Suitable Memory Classification for CS/E Major

- [Criterion#1] Is it feasible for main/local memory directly coupled with processor?
    - [Factor#1] Byte-level read & write operation: readable & writable by 1-byte
    - [Factor#2] Fast read & write operation: enough to communicate with processor



# Suitable Memory Classification for CS/E Major

- [Criterion#1] Is it feasible for main/local memory directly coupled with processor?
- Characteristics of RAM: Volatile ↗ 읽기와 쓰기 빠른 (fast read & write) ↗ 라이트-라이트 (byte-level read & write) ↗ 고속 RAM
- 'Volatile' is not a factor for 'Criterion#1' but only a characteristic of RAM.

**Nonvolatile: saving bits without electric power**

**Volatile: losing data when power down**



# Suitable Memory Classification for CS/E Major

- [Criterion#2] Is it feasible for secondary memory?: if it does not qualify for main/local memory
  - ~~Not~~
  - ~~Temporary~~
  - ~~Large~~
  - [Factor#3] Nonvolatile: saving bits without electric power
  - [Factor#4] Both readable & writable
  - [Factor#5] Large capacity



# Suitable Memory Classification for CS/E Major

Memory matching



# Random Access Memory (RAM)

→ address를隨便하게 접근

## RAM (Random Access Memory)

random address + R/W 동시에

### Meaning of random access

→ address를 random하게해서 접근하고 쓰기도함.

means reading/writing data from/to random address immediately.

created several decades ago to contrast with sequentially-accessed storage like tape drives. → 이전에는 순차적 & 차례대로 접근해.

### The term 'Random' caused an misunderstanding

It means both readable & writable because RAM was the only one to support both read & write operation as well as the only one to support 'random access' at that time.

### Today, Strange name

→ 예전의 대체로 예전은 random access 가능할 때였음.

Nowadays, most of memories support random access.

Therefore, today, it means the random access supporting byte-level and fast read&write that are key factors of main memory/local memory.

(교수님께서 정한)

random access → byte level로 빠르게 read & write가 가능

random access 옵션.

# Random Access Memory (RAM)

작게-유연한  
R/W 동시에

## RAM (Random Access Memory)

Logically same as register file – Memory with address inputs, data inputs/outputs, and control.

- RAM usually just one address/en port
  - Register file usually two address/en ports to support read and write operation together.
- ☞ 왜 이런 차이가 발생하는가?

### RAM vs. register file

- RAM typically larger than roughly 512 or 1024 words
- RAM typically stores bits using a bit storage approach that is more efficient than a flip flop.

☞ RAM 크기가 매우

↳ flip-flop 하나는 1비트를 저장하는 회로

동작을. (storage 회로)

## Register

⇒ R/W 동시에 두 port로 CPU와 연결되며,

속도가 매우 빨라진다.

⇒ 왜 RAM은 이렇게 허지 않는가!?

register file 개수가 작을 경우에는 큰 문제가 아님

↳ decoder로 가면서 진위값으로 ↑, 2비트  
(R/W)  
(수만개) (CPU에 부합하길. (크기도 높아 커짐))

↳ decoder logic 도 유용하게 쓰임.  
buffer logic



Register file from Ch. 4



RAM block symbol

- decoder 가 위치 사용됨.
- W dataset 더 빠르게 들어감.
- enable은 각각의 맞춰쓰기 사용됨.

- RAM cell, RW는 동일.  
(en을 RW로 통합하면)  
↑ 전송이 더 쉽다.

= 1회는 저장하는 단위

# RAM Internal Structure



- Similar internal structure as register file
- Decoder enables appropriate word based on address inputs.
- rw controls whether cell is written or read.
- Let's see what's inside each RAM cell.

집적회로 SRAM > DRAM

# Static RAM (SRAM)

⊕ inverter or 2H MOS

정리 SRAM을 구성하는 브리지스의 기본은 같다. (register (D-flipflop) 예상치)

## "Static" RAM cell

SRAM cell = 6 transistors (recall inverter is 2 transistors)  
whereas a D flip-flop is composed of 38 transistors.  
 $2 \times \text{D latch}$  (18 transistors) + inverter (2 transistors)  
= 38 transistors

크기가 6개이다

### Writing this cell

word enable input comes from decoder  
When 0, value  $d$  loops around inverters  
That loop is where a bit stays stored.  
When 1, the data bit value enters the loop  
data is the bit to be stored in this cell.  
data' enters on other side  
Example shows a "1" being written into cell

### Reading this cell

Somewhat trickier.  
The electrical description of SRAM is  
necessary to explain read-operation – it's  
really beyond our scope.

Static의 의미는 무엇인가?

⇒ DRAM의 Dynamic을 알아야 알 수 있음.

## SRAM cell



## SRAM cell → write



Asynchronous  
Synchronous

개념, 차이점(속도, 대기)

→ 캐시 메모리에 사용됨. ⇒ 이렇게 사용하는데 따라 추가의 성능이 결정됨.

# SRAM Timing Diagram

## Comparison between Register File and SRAM



Register



Asynchronous Read-Operation



Synchronous Read-Operation

rw 0 en 1  
⇒ read mode  
rw 1 en 1  
⇒ write mode  
0

# Dynamic RAM (DRAM)



→ SRAM Cell과 차이점 보기

## “Dynamic” RAM cell

SRAM의  $\Rightarrow$  1 transistor (rather than 6)

$\frac{1}{6}$  이점. Relies on large capacitor to store bit.

**Write:** When word enable is 1, data voltage level gets stored on top plate of capacitor.

**Read:** Just look at value of  $d$

Problem: Capacitor discharges over time.

Must “refresh” regularly, by reading  $d$  and then writing it right back.  $\rightarrow$  수시적으로 recharge를 계속 해줘야 함.

This is the reason why its name includes ‘dynamic’.

→ 값이 사라지는 것을 방지하기 위해 동적으로 refresh 시켜줌  
( $=$ recharge)



static  $\neq$  dynamic  $\rightarrow$  recharge 허용 X



# Comparing Memory Types

- Register file – 38 transistors for 1-bit
  - Fastest
  - But biggest size
  - Very expensive
- SRAM – 6 transistors for 1-bit
  - Fast
  - More compact than register file
  - Expensive
- DRAM – 1 transistor for 1-bit
  - Slowest
  - And refreshing takes time
  - But very compact
  - Cheap
- Use register file for small items, SRAM for large items, and DRAM for huge items
  - Note: DRAM's big capacitor requires a special chip design process, so DRAM is often a separate chip.

SRAM → 빠르고, 크기에 비해 용량조절이 편리.



Size comparison for same number of bits

크기

register > SRAM > DRAM

크기

register < SRAM < DRAM

가격

가격