@let@token ceng 4480 lecture 07: memory organizationbyu/ceng4480/2016fall/l07_memory1.pdf ·...
TRANSCRIPT
![Page 1: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/1.jpg)
CENG 4480Lecture 07: Memory Organization
Bei Yu
2016 Fall
1 / 37
![Page 2: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/2.jpg)
Overview
Introduction
Random Access Memory (RAM)
Non-Volatile Memory
Memory Principle
Conclusion
2 / 37
![Page 3: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/3.jpg)
Overview
Introduction
Random Access Memory (RAM)
Non-Volatile Memory
Memory Principle
Conclusion
3 / 37
![Page 4: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/4.jpg)
Why We Need Memory?
Combinational Circuit:I Always gives the same output for a given set of inputs
I E.g., adders
Sequential Circuit:I Store information
I Output depends on stored information
I E.g., counter
I Need a storage element
3 / 37
![Page 5: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/5.jpg)
Who Cares About the Memory Hierarchy?
Processor60%/yr.(2x/1.5 yr)
DRAM9%/yr.(2x/10 yrs)1
10
100
100019
8019
81
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
DRAM
CPU
1982
Processor-MemoryPerformance Gap:(grows 50% / year)
Performance
Time
“Moore’s Law”Processor Growth Curve follows
Processor-DRAM Memory Performance Gap
4 / 37
![Page 6: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/6.jpg)
Moore’s LawTransistor number on a unit area would double every 1.5 years.
*1965 paper reprint: link
5 / 37
![Page 7: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/7.jpg)
6 / 37
![Page 8: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/8.jpg)
7 / 37
![Page 9: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/9.jpg)
Memory System RevistedI Maximum size of memory is determined by addressing
scheme
E.g.
16-bit addresses can only address 216 = 65536 memorylocations
I Most machines are byte-addressableI each memory address location refers to a byteI Most machines retrieve/store data in wordsI Common abbreviations
I 1k ≈ 210 (kilo)I 1M ≈ 220 (Mega)I 1G ≈ 230 (Giga)I 1T ≈ 240 (Tera)
8 / 37
![Page 10: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/10.jpg)
Simplified ViewData transfer takes place through
I MAR: memory address registerI MDR: memory data register
Up to 2k addressableMDR
MAR
k-bitaddress bus
n -bitdata bus
Control lines( , MFC, etc.)
Processor Memory
locations
Word length = n bits
WR /
Several addressablelocations (bytes) are grouped into a word
9 / 37
![Page 11: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/11.jpg)
Big Picture
Processor usually runs much faster than main memory:I Small memories are fast, large memories are slow.I Use a cache memory to store data in the processor that is
likely to be used.
Main memory is limited:I Use virtual memory to increase the apparent size of
physical memory by moving unused sections of memory todisk (automatically).
I A translation between virtual and physical addresses isdone by a memory management unit (MMU)
I To be discussed in later lectures
10 / 37
![Page 12: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/12.jpg)
Memory Hierarchy
Taking advantage of the principle of locality:I Present the user with as much memory as is available in
the cheapest technology.I Provide access at the speed offered by the fastest
technology
Control
Datapath
SecondaryStorage(Disk)
Processor
Registers
MainMemory(DRAM)
SecondLevelCache
(SRAM)
On-C
hipC
ache
Speed:Hundreds Tera'sSize (bytes): Mega's Giga's
TertiaryStorage(Tape)
~1 ns Tens msTens ns Hundreds ns – 1 us Tens sec
11 / 37
![Page 13: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/13.jpg)
Terminology
Memory Access Time
time between start and finish of a memory request
Memory Cycle Time
minimum delay between successive memory operations
Random Access Memory (RAM)
Property: comparable access time for any memory locations
12 / 37
![Page 14: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/14.jpg)
Overview
Introduction
Random Access Memory (RAM)
Non-Volatile Memory
Memory Principle
Conclusion
13 / 37
![Page 15: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/15.jpg)
Storage based on Feedback
I What if we add feedback to a pair of inverters?
I Usually drawn as a ring of cross-coupled invertersI Stable way to store one bit of information (w. power)
13 / 37
![Page 16: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/16.jpg)
Storage based on Feedback
I What if we add feedback to a pair of inverters?
I Usually drawn as a ring of cross-coupled invertersI Stable way to store one bit of information (w. power)
13 / 37
![Page 17: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/17.jpg)
How to change the value stored?
I Replace inverter with NAND gateI RS Latch
A B A nand B
0 0 1
0 1 1
1 0 1
1 1 0
14 / 37
![Page 18: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/18.jpg)
QUESTION:Whats the Q value based on different R, S inputs?
A B A nand B
0 0 1
0 1 1
1 0 1
1 1 0
I R=S=1:
I S=0, R=1:
I S=1, R=0:
I R=S=0:
15 / 37
![Page 19: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/19.jpg)
SRAM Cell
I At least 6 transistors (6T)I Used in most commercial chipsI A pair of weak cross-coupled invertersI Data stored in cross-coupled inverters
bit bit_b
word
16 / 37
![Page 20: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/20.jpg)
DRAM CellI 1 Transistor (1T)I Requires presence of an extra capacitorI Modifications in the manufacturing process.I Higher densityI Write: Charged or discharged the capacitor (slow)I Read: Charge redistribution takes place between bit line
and storage capacitance
17 / 37
![Page 21: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/21.jpg)
SRAM v.s. DRAM
Static RAM (SRAM)I Capable of retaining the state as long as power is applied.I They are fast, low power (current flows only when
accessing the cells) but costly (require several transistors),so the capacity is small.
I They are the Level 1 cache and Level 2 cache inside aprocessor, of size 3 MB or more.
Dynamic RAM (DRAM)I store data as electric charge on a capacitor.I Charge leaks away with time, so DRAMs must be
refreshed.I In return for this trouble, much higher density (simpler
cells).
18 / 37
![Page 22: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/22.jpg)
Synchronous DRAM (SDRAM)
I The common type used today as it uses a clock tosynchronize the operation.
I The refresh operation becomes transparent to the users.
I All control signals needed are generated inside the chip.
I The initial commercial SDRAM in the1990s were designedfor clock speed of up to 133MHz.
I Todays SDRAM chips operate with clock speedsexceeding 1 GHz.
Memory modules are used to hold severalSDRAM chips and are the standard type usedin a computers motherboard, of size like 4GBor more.
19 / 37
![Page 23: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/23.jpg)
Synchronous DRAM (SDRAM)
I The common type used today as it uses a clock tosynchronize the operation.
I The refresh operation becomes transparent to the users.
I All control signals needed are generated inside the chip.
I The initial commercial SDRAM in the1990s were designedfor clock speed of up to 133MHz.
I Todays SDRAM chips operate with clock speedsexceeding 1 GHz.
Memory modules are used to hold severalSDRAM chips and are the standard type usedin a computers motherboard, of size like 4GBor more.
19 / 37
![Page 24: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/24.jpg)
Double Data Rate (DDR) SDRAM
I normal SDRAMs only operate once per clock cycle
I Double Data Rate (DDR) SDRAM transfers data on bothclock edges
I DDR-2 (4x basic memory clock) and DDR-3 (8x basicmemory clock) are in the market.
I They offer increased storage capacity, lower power andfaster clock speeds.
I For example, DDR2 can operate at clock frequencies of400 and 800 MHz. Therefore, they can transfer data ateffective clock speed of 800 and 1600 MHz.
20 / 37
![Page 25: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/25.jpg)
Performance of SDRAM
1 Hertz1 Cycle per second
RAM Type Theoretical Maximum BandwidthSDRAM 100 MHz (PC100) 100 MHz X 64 bit/ cycle = 800 MByte/sec
SDRAM 133 MHz (PC133) 133 MHz X 64 bit/ cycle = 1064 MByte/sec
DDR SDRAM 200 MHz (PC1600) 2 X 100 MHz X 64 bit/ cycle ~= 1600 MByte/sec
DDR SDRAM 266 MHz (PC2100) 2 X 133 MHz X 64 bit/ cycle ~= 2100 MByte/sec
DDR SDRAM 333 MHz (PC2600) 2 X 166 MHz X 64 bit/ cycle ~= 2600 MByte/sec
DDR-2 SDRAM 667 MHz (PC2-5400) 2 X 2 X 166 MHz X 64 bit/ cycle ~= 5400 MByte/sec
DDR-2 SDRAM 800 MHz (PC2-6400) 2 X 2 X 200 MHz X 64 bit/ cycle ~= 6400 MByte/sec
Bandwidth comparison. However, due to latencies, SDRAM does not perform as goodas the figures shown.
21 / 37
![Page 26: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/26.jpg)
Bandwidth v.s. Latency
Example
I Mary acts FAST but she’s always LATE.I Peter is always PUNCTUAL but he is SLOW.
Bandwidth:I talking about the “number of bits/bytes per second” when
transferring a block of data steadily.Latency:
I amount of time to transfer the first word of a block afterissuing the access signal.
I Usually measure in “number of clock cycles” or in ns/µs.
22 / 37
![Page 27: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/27.jpg)
Bandwidth v.s. Latency
Example
I Mary acts FAST but she’s always LATE.I Peter is always PUNCTUAL but he is SLOW.
Bandwidth:I talking about the “number of bits/bytes per second” when
transferring a block of data steadily.Latency:
I amount of time to transfer the first word of a block afterissuing the access signal.
I Usually measure in “number of clock cycles” or in ns/µs.
22 / 37
![Page 28: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/28.jpg)
Question:Suppose the clock rate is 500 MHz. What is the latency andwhat is the bandwidth, assuming that each data is 64 bits?
Clock
RowAccessStrobe
Data d0 d1 d2
23 / 37
![Page 29: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/29.jpg)
Overview
Introduction
Random Access Memory (RAM)
Non-Volatile Memory
Memory Principle
Conclusion
24 / 37
![Page 30: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/30.jpg)
Read-Only Memory (ROM)
I Memory content fixed and cannot be changed easily.I Useful to bootstrap a computer since RAM is volatile
(i.e. lost memory) when power removed.I We need to store a small program in such a memory, to be
used to start the process of loading the OS from a harddisk into the main memory.
PROM/EPROM/EEPROM
24 / 37
![Page 31: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/31.jpg)
FLASH Memory
I Flash devices have greater density, higher capacity andlower cost per bit.
I Can be read and written
I This is normally used for non-volatile storage
I Typical applications include cell phones, digital cameras,MP3 players, etc.
25 / 37
![Page 32: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/32.jpg)
FLASH CardsI Flash cards are made from FLASH chips
I Flash cards with standard interface are usable in a varietyof products.
I Flash cards with USB interface are widely used – memorykeys.
I Larger cards may hold 32GB. A minute of music can bestored in about 1MB of memory, hence 32GB can hold 500hours of music.
26 / 37
![Page 33: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/33.jpg)
Overview
Introduction
Random Access Memory (RAM)
Non-Volatile Memory
Memory Principle
Conclusion
27 / 37
![Page 34: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/34.jpg)
Memory ControllerI A memory controller is normally used to interface between
the memory and the processor.I DRAMs have a slightly more complex interface as they
need refreshing and they usually have time-multiplexsignals to reduce pin number.
I SRAM interfaces are simpler and may not need a memorycontroller.
Processor
RAS
CAS
R/ W
Clock
AddressRow/Columnaddress
Memorycontroller
R/ W
Clock
Request
CS
Data
Memory
RAS (CAS) = Row (Column) Address Strobe; CS = Chip Select
27 / 37
![Page 35: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/35.jpg)
Memory ControllerI The memory controller accepts a complete address and
the R/W signal from the processor.I The controller generates the RAS (Row Access Strobe)
and CAS (Column Access Strobe) signals.
I The high-order address bits, which select a row in the cellarray, are provided first under the control of the RAS (RowAccess Strobe) signal.
I Then the low-order address bits, which select a column,are provided on the same address pins under the control ofthe CAS (Column Access Strobe) signal.
I The right memory module will be selected based on theaddress. Data lines are connected directly between theprocessor and the memory.
I SDRAM needs refresh, but the refresh overhead is onlyless than 1 percent of the total time available to access thememory.
28 / 37
![Page 36: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/36.jpg)
Memory ControllerI The memory controller accepts a complete address and
the R/W signal from the processor.I The controller generates the RAS (Row Access Strobe)
and CAS (Column Access Strobe) signals.I The high-order address bits, which select a row in the cell
array, are provided first under the control of the RAS (RowAccess Strobe) signal.
I Then the low-order address bits, which select a column,are provided on the same address pins under the control ofthe CAS (Column Access Strobe) signal.
I The right memory module will be selected based on theaddress. Data lines are connected directly between theprocessor and the memory.
I SDRAM needs refresh, but the refresh overhead is onlyless than 1 percent of the total time available to access thememory.
28 / 37
![Page 37: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/37.jpg)
Memory ControllerI The memory controller accepts a complete address and
the R/W signal from the processor.I The controller generates the RAS (Row Access Strobe)
and CAS (Column Access Strobe) signals.I The high-order address bits, which select a row in the cell
array, are provided first under the control of the RAS (RowAccess Strobe) signal.
I Then the low-order address bits, which select a column,are provided on the same address pins under the control ofthe CAS (Column Access Strobe) signal.
I The right memory module will be selected based on theaddress. Data lines are connected directly between theprocessor and the memory.
I SDRAM needs refresh, but the refresh overhead is onlyless than 1 percent of the total time available to access thememory.
28 / 37
![Page 38: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/38.jpg)
Classical DRAM Organization
data bitdata bit
Row
Decoder
rowaddress
Column Selector &I/O Circuits
columnaddress
data bit
word (row) line
bit (data) lines
Each intersection represents a 1-T DRAM cell
Thecolumnaddressselectstherequestedbit fromtherowineachplane
RAM CellArray
29 / 37
![Page 39: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/39.jpg)
Memory Hierarchy
I Aim: to producefast, big andcheap memory
I L1, L2 cache areusually SRAM
I Main memory isDRAM
I Relies on localityof reference
Processor
Primarycache
Secondarycache
Main
Magnetic disk
memory
Increasingsize
Increasingspeed
secondarymemory
Increasingcost per bit
Registers
L1
L2
Increasinglatency
30 / 37
![Page 40: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/40.jpg)
Locality of Reference
Temporal Locality (locality in time)I If an item is referenced, it will tend to be referenced again
soon.I When information item (instruction or data) is first needed,
brought it into cache where it will hopefully be used again.
Spatial Locality (locality in space)I If an item is referenced, neighbouring items whose
addresses are close-by will tend to be referenced soon.I Rather than a single word, fetch data from adjacent
addresses as well.
31 / 37
![Page 41: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/41.jpg)
Mix-and-Match: Best of Both
By taking advantages of the principle of locality:I Present the user with as much memory as is available in
the cheapest technology.I Provide access at the speed offered by the fastest
technology.DRAM is slow but cheap and dense:
I Good choice for presenting the user with a BIG memorysystem main memory
SRAM is fast but expensive and not very dense:I Good choice for providing the user FAST access time L1
and L2 cache
32 / 37
![Page 42: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/42.jpg)
Cache UsageI Need to determine how the cache is organizedI Mapping functions determine how memory addresses are
assigned to cache locationsI Need to have a replacement algorithm to decide what to do
when cache is full (i.e. decide which item to be unloadedfrom cache).
Cache MainMemoryProcessor
BlockA set of contiguous addresses of a given size (cache block isalso called cache line)
33 / 37
![Page 43: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/43.jpg)
Cache Read Operation
I Contents of a block are read into the cache the first timefrom the memory.
I Subsequent accesses are (hopefully) from the cache,called a cache read hit.
I Number of cache entries is relatively small, need to keepmost likely used data in cache.
I When an un-cached block is required, need to employ areplacement algorithm to remove an old block and tocreate space for the new one.
34 / 37
![Page 44: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/44.jpg)
Cache Write Operation
Scheme 1: Write-Through
Cache and main memory updated at the same time.
Note that read misses and read hits can occur.
Scheme 2: Write-BackUpdate cache only and mark the entry dirty. Main memory willbe updated later when cache block is removed.
Note that write misses and write hits can occur.
35 / 37
![Page 45: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/45.jpg)
Cache Write Operation
Scheme 1: Write-Through
Cache and main memory updated at the same time.
Note that read misses and read hits can occur.
Scheme 2: Write-BackUpdate cache only and mark the entry dirty. Main memory willbe updated later when cache block is removed.
Note that write misses and write hits can occur.
35 / 37
![Page 46: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/46.jpg)
Question 2:Which write scheme is simpler? Which one has betterperformance? Why?
36 / 37
![Page 47: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/47.jpg)
Overview
Introduction
Random Access Memory (RAM)
Non-Volatile Memory
Memory Principle
Conclusion
37 / 37
![Page 48: @let@token CENG 4480 Lecture 07: Memory Organizationbyu/CENG4480/2016Fall/L07_memory1.pdf · Lecture 07: Memory Organization Bei Yu 2016 Fall byu@cse.cuhk.edu.hk 1/37. Overview Introduction](https://reader034.vdocuments.site/reader034/viewer/2022052006/601a471a8e797c456f436771/html5/thumbnails/48.jpg)
Conclusion
I Processor usually runs much faster than main memory
I Common RAM types:SRAM, DRAM, SDRAM, DDR SDRAM
I Principle of locality: Temporal and SpatialI Present the user with as much memory as is available in
the cheapest technology.I Provide access at the speed offered by the fastest
technology.
I Memory hierarchy:I Register→ Cache→ Main Memory→ Disk→ Tape
37 / 37