Memory is organized in a hierarchy with different levels providing trade-offs between speed and cost.
- Cache memory sits between the CPU and main memory for fastest access.
- Main memory (RAM) is where active programs and data reside and is faster than auxiliary memory but more expensive.
- Auxiliary memory (disks, tapes) provides backup storage and is slower than main memory but larger and cheaper.
Virtual memory manages this hierarchy through address translation techniques like paging that map virtual addresses to physical locations, allowing programs to access more memory than physically available. When data is needed from auxiliary memory a page fault occurs and page replacement algorithms determine what data to remove from main memory.
an essential componentin any general purpose computer since it
is needed to store programs and data.
memory unit that communicates directly with the CPU = main
memory
devices that provide backup storage = auxiliary memory.
Auxiliary memory devices are used to store system programs,
large data files and other backup information. Only programs
and data currently needed by the processor reside in main
memory. All other information is stored in main memory and
transferred to main memory when needed.
Memory Unit3
4.
Cache Memory
• Memorythat lies in between main memory
and CPU
Holds those parts of the program and data
that are most heavily used
• increases the overall processing speed of the
computer by providing frequently required
data to the CPU at a faster speed.
4
5.
Main Memory
• Memoryunit that communicates directly with CPU
• Programs and data currently needed by the
processor reside here
• Also known as primary memory
• RAM and ROM
5
6.
Auxiliary Memory
• Madeof devices that provide backup storage
• Magnetic tapes, Magnetic disks
• At the bottom of the hierarchy are the relatively
slow magnetic tapes used to store removable files
whereas at the top level, magnetic disks used as
backup storage
6
7.
• A classof data storage device that read their data in sequence
• Are usually a form of magnetic memory
• Typically used for secondary storage in general-purpose computers due to their higher density,
resistance to wear and non-volatility
• Eg: hard disk, CD-ROMs, magnetic tapes etc
Sequential Access Memory
• Is a form of computer data storage
• Allows stored data to be accessed in any order
• Associated with volatile types of memory
• Type: SRAM and DRAM
Random Access Memory
Memory Types7
8.
• To obtainthe highest possible access speed while minimizing the
total cost of the memory system
• Consists of all storage device in a computer system (auxiliary, cache,
main , high speed registers and processing logic)
Memory Hierarchy8
• Basic memoryof the computer
• Temprorary memory except rom
• Faster for read write operation
• Expensive internal memory so not portable.
RAM
• Volatile memory.
• Stores information required during processing
Two types of random Static Ram(SRAM) and Dynamic
Ram(DRAM)
Main memory
12
13.
• Does notlose its content until
computer is turned off
• Information is stored in form of
voltage
• faster
• Loses its content after few
seconds
• Information is stored in the
form of charge
• slower
SRAM DRAM
TYPES OF RAM13
14.
• Permanent memory
•Stores information required for computer operations
• Types of rom(PROM,EPROM,EEPROM)
ROM
14
15.
Boot Strap loader
Initial program whose function is to start the computer operating
system after the power is turned on. and it is stored in the rom
portion of the main memory .
Computer start up :starting the execution of initial program after
computer is turned on
Boot strap loader loads the portion of disk to main memory and
control is then transferred to os.
15
16.
• The mostcommon auxilliary device used in the computer system is
magnetic disk and magnetic tape.
• Store large amount of data permanantly.
• Portable
Types of auxilliary memory
Magnetic disk
Magnetic tape
Auxiliary memory(SECONDARY
MEMORY)
16
17.
• circular plate,made of metal or plastic coated with magnetize material.High
speed of rotation
• Bits are store in a concentric circle called tracks.
• Division of tracks are called sectors.
Magnetic disk17
RAM AND ROMCHIPS
RAM chip:
Used for communication with the CPU if one or
more control inputs.
requires 7-bit address and an 8-bit bidirectional
data bus.
chip select (CS) are for enabling the chip.
22
when CS1=1and (CS2)’=0, the unit in operation.
High impedance state indicates open circuit.
When CS1=1 and (CS2)’=0, the memory is places in a R/W mode.
When the RD input is enabled, the content of the selected byte is placed into the
data bus.
24
A ROM chipis unidirectional.
9 address lines to address 512 bytes.
chip select CS1=1 and (CS2)’=0 for the unit to
operate.
Otherwise, the data bus in a high-impedance
state.
26
Attempts to optimizethe use of the main memory(the high
speed portion) with the hard disk (the lower speed portion).
Technique for using the secondary storage to extend the
apparent limited size of the physical memory beyond its
physical size .
Implemented since the available physical memory will not be
enough to host all the program.
28
29.
Address space andMemory space
An address used by the programmer is virtual memory , the set
of such address is called address space.
An address in main memory is location ,the set of such location
is called memory space.
Example: consider main memory :32k words(k=1024)=2^15 and
auxiliary memory 1024k words=2^20(to address 15 bits of
physical memory and 20 bits of virtual memory is required)
29
.
In ourexample we have 20-bit address of an instruction (to refer
20-bit virtual address) but physical memory addresses are specified
with 15-bits. So a table is needed
to map a virtual address of 20-bits to a physical address of 15-bits.
Mapping is a dynamic operation, which means that every address is
translated immediately as a word is referenced by CPU.
31
.Address Mapping usingPages
Blocks (or page frame): Blocks are the groups of
equal size which are broken down from physical
memory and ranges from 64 to 4096words each.
Pages: refers to a portion of subdivided virtual
memory having same size as blocks i.e. groups
of address space.
33
34.
.
Example: consider computerwith address space = 8K and memory space = 4K.
If we spit both spaces into
groups of 1k words we get
8 pages and 4 blocks.
blocks.
34
35.
.
Page Replacement
A virtualmemory system is a combination of hardware and
software techniques. A memory management software system
handles:
Which page in main memory should be removed to make
room for a new page?
When a new page is to be transferred from auxiliary memory
to main memory?
35
36.
.
Where thepage is to be placed in main memory?
There are numerous page replacement algorithms, two of which
are:
1. First-in First-out (FIFO): replaces a page that has been in
memory longest time.
2. Least Recently Used (LRU): assumes that least recently used
page is the better candidate for
removal than the least recently loaded page.
36
37.
.
When a pagefault occurs in a virtual memory system, it
signifies that the page referenced by the program is not in
main memory. A new page is then transferred from auxiliary
memory to main memory. If main memory is full, it would be
necessary to remove a page from a memory block to make a
room for a new page. The policy for choosing pages to
remove is determined from the replacement algorithm that is
used.
GOAL: try to remove the page least likely to be referenced by
in the immediate future.
37
Basic component ofMMU
Sharing common program by multiple user
Protection of information unauthorized
40
41.
Segmented Page Mapping
Length of each segment allowed to grow and contract according need of
program execution.
Way of specifying the length of a segment by associating with it a no. of
equal sized page
Consider diagram below
41
In above fig:
Consider
LogicalAddress=Segment+page+word
segment specifies segment no.
Page field specifies page within the
segment
Word field specifies specific word
within the page
43