Académique Documents
Professionnel Documents
Culture Documents
Memory
ECEN 454
Outline
Memory Arrays
SRAM Architecture
SRAM Cell
Decoders
Column Circuitry
Multiple Ports
DRAM
Serial Access Memories
ROM
1
Memory Arrays
Memory Arrays
Array Architecture
2n words of 2m bits each
If n >> m, fold by 2k into fewer rows of more columns
bitline conditioning
wordlines
bitlines
row decoder
memory cells:
2n-k rows x
2m+k columns
n-k
k column
circuitry
n column
decoder
2m bits
2
12T SRAM Cell
Basic building block: SRAM Cell
Holds one bit of information, like a latch
Must be read and written
12-transistor (12T) SRAM cell
Use a simple latch connected to bitline
46 x 75 unit cell
bit
write
write_b
read
read_b
6T SRAM Cell
Cell size accounts for most of array size
Reduce cell size at expense of complexity
6T SRAM Cell
Used in most commercial chips
Data stored in cross-coupled inverters
Read:
bit bit_b
Precharge bit, bit_b
word
Raise wordline
Write:
Drive data onto bit, bit_b
Raise wordline
3
SRAM Read
Precharge both bitlines high
Then turn on wordline
One of the two bitlines will be pulled down by the cell
bit bit_b
Ex: A = 0, A_b = 1 word
bit discharges, bit_b stays high N2
P1 P2
N4
But A bumps up slightly A A_b
N1 N3
Read stability
A must not flip A_b bit_b
1.5
1.0
word bit
0.5
A
0.0
0 100 200 300 400 500 600
time (ps)
SRAM Read
Precharge both bitlines high
Then turn on wordline
One of the two bitlines will be pulled down by the cell
Ex: A = 0, A_b = 1 bit bit_b
word
bit discharges, bit_b stays high P1 P2
N2 N4
But A bumps up slightly A A_b
N1 N3
Read stability
A must not flip A_b bit_b
N1 >> N2 1.5
1.0
word bit
0.5
A
0.0
0 100 200 300 400 500 600
time (ps)
4
SRAM Write
Drive one bitline high, the other low
Then turn on wordline
Bitlines overpower cell with new value
Ex: A = 0, A_b = 1, bit = 1, bit_b = 0 bit bit_b
word
Force A_b low, then A rises high
P1 P2
N2 N4
Writability A A_b
Must overpower feedback inverter N1 N3
A_b
1.5 A
bit_b
1.0
0.5
word
0.0
0 100 200 300 400 500 600 700
time (ps)
SRAM Write
Drive one bitline high, the other low
Then turn on wordline
Bitlines overpower cell with new value
Ex: A = 0, A_b = 1, bit = 1, bit_b = 0 bit bit_b
word
Force A_b low, then A rises high P1 P2
N2 N4
Writability A A_b
N1 N3
Must overpower feedback inverter
N2 >> P1 A_b
1.5 A
bit_b
1.0
0.5
word
0.0
0 100 200 300 400 500 600 700
time (ps)
5
SRAM Sizing
High bitlines must not overpower inverters
during reads
But low bitlines must write new value into cell
bit bit_b
word
weak
med med
A A_b
strong
SRAM Cell
bit_b_v1f
bit_v1f
H H
SRAM Cell
out_b_v1r out_v1r
write_q1
1
2
data_s1
word_q1
bit_v1f
out_v1r
6
SRAM Layout
Cell size is critical: 26 x 45
Tile cells sharing VDD, GND, bitline contacts
VDD
WORD
Cell boundary
Decoders
n:2n decoder consists of 2n n-input AND gates
One needed for each row of memory
Build AND from NAND or NOR gates
Static CMOS Pseudo-nMOS
A1 A0
A1 A0
1 1 8
word0 word 1/2 4 16
A1 1 4
word0 word
word1 2 8
A0 word1 A0 A1
1 1 1
word2
word2
word3 word3
7
Decoder Layout
Decoders must be pitch-matched to SRAM cell
Requires very skinny gates
A3 A3 A2 A2 A1 A1 A0 A0
VDD
word
GND
Large Decoders
For n > 4, NAND gates become slow
Break large gates into multiple smaller gates
A3 A2 A1 A0
word0
word1
word2
word3
word15
8
Predecoding
Many of these gates are redundant
Factor out common A3
Saves area A1
predecoders
1 of 4 hot
predecoded lines
word0
word1
word2
word3
word15
Column Circuitry
Some circuitry is required for each column
Bitline conditioning
Sense amplifiers
Column multiplexing
9
Bitline Conditioning
Precharge bitlines high before reads
bit bit_b
bit bit_b
Sense Amplifiers
Bitlines have many cells attached
Ex: 32-kbit SRAM has 256 rows x 128 cols
128 cells on each bitline
tpd (C/I) V
Even with shared diffusion contacts, 64C of
diffusion capacitance (big C)
Discharged slowly through small transistors (small
I)
10
Twisted Bitlines
Sense amplifiers also amplify noise
Coupling noise is severe in modern processes
Try to couple equally onto bit and bit_b
Done by twisting bitlines
Column Multiplexing
Recall that array may be folded for good
aspect ratio
Ex: 2 kword x 16 folded into 256 rows x 128
columns
Must select 16 output bits from the 128
columns
Requires 16 8:1 column multiplexers
11
Tree Decoder Mux
Column mux can use pass transistors
Use nMOS only, precharge outputs
One design is to use k series transistors for 2k:1 mux
No external decoder logic needed
B0 B1 B2 B3 B4 B5 B6 B7 B0 B1 B2 B3 B4 B5 B6 B7
A0 A0
A0_barA0
A1_barA1
A1 A1
A2_barA2
A2
A2
Y Y
to sense amps and write circuits
B0 B1 B2 B3
12
Ex: 2-way Muxed SRAM
More More
Cells Cells
word_q1
A0
A0
write0_q1 2 write1_q1
data_v1
Multiple Ports
We have considered single-ported SRAM
One read or one write on each cycle
Examples:
Multicycle MIPS must read two sources or write a
result on some cycles
Pipelined MIPS must read two sources and write a
third result each cycle
Superscalar MIPS must read and write many
sources and results each cycle
13
Dual-Ported SRAM
Simple dual-ported SRAM
Two independent single-ended reads
Or one differential write
bit bit_b
wordA
wordB
Multi-Ported SRAM
Adding more access transistors hurts read stability
Multiported SRAM isolates reads from state node
Single-ended design minimizes number of bitlines
bA bB bC bD bE bF bG
wordA
wordB
wordC
wordD
wordE
wordF
wordG
write
circuits
read
circuits
14
Dynamic RAM (DRAM)
Capacitor can hold charge
Transistor acts as gate
No charge is a 0
Can add charge to store a 1
Then open switch (disconnect)
Can read by closing switch
15
DRAM Characteristics
Destructive Read
When cell read, charge removed
Must be restored after a read
Refresh
Also, theres steady leakage
Charge must be restored periodically
16
Shift Register
Shift registers store and delay data
Simple design: cascade of registers
Watch your hold times!
clk
Din Dout
8
Din
clk
readaddr
counter
00...00
dual-ported
SRAM
counter
writeaddr
11...11
reset
Dout
17
Tapped Delay Line
A tapped delay line is a shift register with a
programmable number of stages
Set number of stages with delay controls to
mux
Ex: 0 63 stages of delay
clk
SR32
SR16
SR8
SR4
SR2
SR1
Din Dout
clk
Sin
P0 P1 P2 P3
18
Parallel In Serial Out
Load all N bits in parallel when shift = 0
Then shift one bit out per cycle
P0 P1 P2 P3
shift/load
clk
Sout
Queues
Queues allow data to be read and written at
different rates.
Read and write each use their own clock, data
Queue indicates whether it is full or empty
Build with SRAM and read/write counters
(pointers)
WriteClk ReadClk
FULL EMPTY
19
FIFO, LIFO Queues
First In First Out (FIFO)
Initialize read and write pointers to first
element
Queue is EMPTY
On write, increment write pointer
If write almost catches read, Queue is FULL
On read, increment read pointer
Last In First Out (LIFO)
Also called a stack
Use a single stack pointer for read and write
Read-Only Memories
Read-Only Memories are nonvolatile
Retain their contents when power is removed
20
ROM Example
4-word x 6-bit ROM
Represented with dot diagram Word 0: 010101
Dots indicate 1s in ROM Word 1: 011001
weak Word 2: 100101
A1 A0 pseudo-nMOS
pullups Word 3: 101010
2:4
DEC
ROM Array
Y5 Y4 Y3 Y2 Y1 Y0
Unit
Cell
21
PROMs and EPROMs
Programmable ROMs
Build array with transistors at every site
Burn out fuses to disable unwanted transistors
n+ n+
p bulk Si
Flash
Electrically Programmable in bytes
Electrically erasable in large blocks or entire chip (early flash)
Can be thought as a special EEPROM
NAND flash (vs. NOR flash): high density, less expensive;
mainstream for todays memory cards & USB flash drives.
22