# Chapter 4

#### Memory Management

- 4.1 Basic memory management
- 4.2 Swapping
- 4.3 Virtual memory
- 4.4 Page replacement algorithms
- 4.5 Modeling page replacement algorithms
- 4.6 Design issues for paging systems
- 4.7 Implementation issues
- 4.8 Segmentation

#### Memory Management

- Ideally programmers want memory that is
  - large
  - fast
  - non volatile
- Memory hierarchy
  - small amount of fast, expensive memory cache
  - some medium-speed, medium price main memory
  - gigabytes of slow, cheap disk storage
- Memory manager handles the memory hierarchy

Basic Memory Management
Monoprogramming without Swapping or Paging



Three simple ways of organizing memory

3

- an operating system with one user process

# Multiprogramming with Fixed Partitions



- Fixed memory partitions
  - separate input queues for each partition
  - single input queue

!

# Modeling Multiprogramming



CPU utilization as a function of number of processes in memory

iiciiioi y

### **Relocation and Protection**

- Cannot be sure where program will be loaded in memory
  - address locations of variables, code routines cannot be absolute
  - must keep a program out of other processes' partitions
- Use base and limit values
  - address locations added to base value to map to physical addr
  - address locations larger than limit value is an error

# Analysis of Multiprogramming System Performance



- Arrival and work requirements of 4 jobs
- CPU utilization for 1 4 jobs with 80% I/O wait
- Sequence of events as jobs arrive and finish
  - note numbers show amout of CPU time jobs get in each interval

# Swapping (1)



#### Memory allocation changes as

- processes come into memory
- leave memory

Shaded regions are unused memory

# Swapping (2)



- Allocating space for growing data segment
- Allocating space for growing stack & data segment

# Memory Management with Bit Maps



- Part of memory with 5 processes, 3 holes
  - tick marks show allocation units
  - shaded regions are free
- Corresponding bit map
- Same information as a list

10

#### Memory Management with Linked Lists



Four neighbor combinations for the terminating process X

### Virtual Memory Paging (1)



The position and function of the MMU

11

# Paging (2)

The relation between virtual addresses and physical memory addresses given by page table



### Page Tables (1)



Internal operation of MMU with 16 4 KB pages 14

# Page Tables (2)



- 32 bit address with 2 page table fields
- Two-level page tables

### Page Tables (3)



Typical page table entry

16

#### TLBs – Translation Lookaside Buffers

| Valid | Virtual page | Modified | Protection | Page frame |
|-------|--------------|----------|------------|------------|
| 1     | 140          | 1        | RW         | 31         |
| 1     | 20           | 0        | RX         | 38         |
| 1     | 130          | 1        | RW         | 29         |
| 1     | 129          | 1        | RW         | 62         |
| 1     | 19           | 0        | RX         | 50         |
| 1     | 21           | 0        | RX         | 45         |
| 1     | 860          | 1        | RW         | 14         |
| 1     | 861          | 1        | RW         | 75         |

A TLB to speed up paging

#### **Inverted Page Tables**



Comparison of a traditional page table with an inverted page table

17

19

### Page Replacement Algorithms

- Page fault forces choice
  - which page must be removed
  - make room for incoming page
- Modified page must first be saved
  - unmodified just overwritten
- Better not to choose an often used page
  - will probably need to be brought back in soon

#### Optimal Page Replacement Algorithm

- Replace page needed at the farthest point in future
  - Optimal but unrealizable
- Estimate by ...
  - logging page use on previous runs of process
  - although this is impractical

18

#### Not Recently Used Page Replacement Algorithm

- Each page has Reference bit, Modified bit
  - bits are set when page is referenced, modified
- Pages are classified
  - not referenced, not modified
  - 2. not referenced, modified
  - 3. referenced, not modified
  - 4. referenced, modified
- NRU removes page at random
  - from lowest numbered non empty class

#### FIFO Page Replacement Algorithm

- Maintain a linked list of all pages
  - in order they came into memory
- Page at beginning of list replaced
- Disadvantage
  - page in memory the longest may be often used

21

22

#### Second Chance Page Replacement Algorithm



- Operation of a second chance
  - pages sorted in FIFO order
  - Page list if fault occurs at time 20, <u>A</u> has R bit set (numbers above pages are loading times)

#### The Clock Page Replacement Algorithm



When a page fault occurs, the page the hand is pointing to is inspected. The action taken depends on the R bit:

R = 0: Evict the page

R = 1: Clear R and advance hand

### Least Recently Used (LRU)

- Assume pages used recently will used again soon
  - throw out page that has been unused for longest time
- Must keep a linked list of pages
  - most recently used at front, least at rear
  - update this list every memory reference!!
- Alternatively keep counter in each page table entry
  - choose page with lowest value counter
  - periodically zero the counter

25

#### Simulating LRU in Software (1)



LRU using a matrix – pages referenced in order 0,1,2,3,2,1,0,3,2,3

26

# Simulating LRU in Software (2)



- The aging algorithm simulates LRU in software
- Note 6 pages for 5 clock ticks, (a) (e)

#### The Working Set Page Replacement Algorithm (1)



- The working set is the set of pages used by the *k* most recent memory references
- w(k,t) is the size of the working set at time, t

#### The Working Set Page Replacement Algorithm (2)



The working set algorithm

#### The WSClock Page Replacement Algorithm



Operation of the WSClock algorithm

#### 30

### Review of Page Replacement Algorithms

| Algorithm                  | Comment                                        |  |  |
|----------------------------|------------------------------------------------|--|--|
| Optimal                    | Not implementable, but useful as a benchma     |  |  |
| NRU (Not Recently Used)    | Very crude                                     |  |  |
| FIFO (First-In, First-Out) | Might throw out important pages                |  |  |
| Second chance              | Big improvement over FIFO                      |  |  |
| Clock                      | Realistic                                      |  |  |
| LRU (Least Recently Used)  | Excellent, but difficult to implement exactly  |  |  |
| NFU (Not Frequently Used)  | Fairly crude approximation to LRU              |  |  |
| Aging                      | Efficient algorithm that approximates LRU well |  |  |
| Working set                | Somewhat expensive to implement                |  |  |
| WSClock                    | Good efficient algorithm                       |  |  |

#### Modeling Page Replacement Algorithms Belady's Anomaly



- FIFO with 3 page frames
- FIFO with 4 page frames
- P's show which page references show page faults

### Stack Algorithms



State of memory array, M, after each item in reference string is processed

The Distance String



Probability density functions for two hypothetical distance strings

The Distance String



- Computation of page fault rate from distance string
  - the C vector
  - the F vector

#### Design Issues for Paging Systems Local versus Global Allocation Policies (1)





- Original configuration
- Local page replacement
- Global page replacement

34

#### Local versus Global Allocation Policies (2)



Page fault rate as a function of the number of page frames assigned

37

#### **Load Control**

- Despite good designs, system may still thrash
- When PFF algorithm indicates
  - some processes need more memory
  - but <u>no</u> processes need less
- Solution : Reduce number of processes competing for memory
  - swap one or more to disk, divide up pages they held
  - reconsider degree of multiprogramming

38

# Page Size (1)

#### Small page size

- Advantages
  - less internal fragmentation
  - better fit for various data structures, code sections
  - less unused program in memory
- Disadvantages
  - programs need many pages, larger page tables

# Page Size (2)

• Overhead due to page table and internal fragmentation



- Where
  - s = average process size in bytes
  - p = page size in bytes
  - e = page entry

Optimized when

$$p = \sqrt{2se}$$

### Separate Instruction and Data Spaces



- One address space
- Separate I and D spaces

**Shared Pages** Data 1 Page tables

Two processes sharing same program sharing its page table

# **Cleaning Policy**

- Need for a background process, paging daemon
  - periodically inspects state of memory
- When too few frames are free
  - selects pages to evict using a replacement algorithm
- It can use same circular list (clock)
  - as regular page replacement algorithmbut with diff ptr

### Implementation Issues

Operating System Involvement with Paging

#### Four times when OS involved with paging

- **Process creation** 
  - determine program size
  - create page table
- **Process** execution
  - MMU reset for new process
  - TLB flushed
- Page fault time
  - determine virtual address causing fault
  - swap target page out, needed page in
- Process termination time
  - release page table, pages

# Page Fault Handling (1)

- 1. Hardware traps to kernel
- 2. General registers saved
- 3. OS determines which virtual page needed
- 4. OS checks validity of address, seeks page frame
- 5. If selected frame is dirty, write it to disk

#### Page Fault Handling (2)

- 6. OS brings schedules new page in from disk
- 7. Page tables updated
- Faulting instruction backed up to when it began
- 6. Faulting process scheduled
- 7. Registers restored
- Program continues

45

4

# **Instruction Backup**

An instruction causing a page fault

#### Locking Pages in Memory

- Virtual memory and I/O occasionally interact
- Proc issues call for read from device into buffer
  - while waiting for I/O, another processes starts up
  - has a page fault
  - buffer for the first proc may be chosen to be paged out
- Need to specify some pages locked
  - exempted from being target pages

# **Backing Store**



- (a) Paging to static swap area
- (b) Backing up pages dynamically

#### Separation of Policy and Mechanism



Page fault handling with an external pager

50

# Segmentation (1)



• One-dimensional address space with growing tables

51

• One table may bump into another

# Segmentation (2)



Allows each table to grow or shrink, independently

# Segmentation (3)

| Consideration                                                      | Paging                                                                                        | Segmentation                                                                                                                             |  |
|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|
| Need the programmer be aware that this technique is being used?    | No                                                                                            | Yes                                                                                                                                      |  |
| How many linear address spaces are there?                          | 1                                                                                             | Many                                                                                                                                     |  |
| Can the total address space exceed the size of physical memory?    | Yes                                                                                           | Yes                                                                                                                                      |  |
| Can procedures and data be distinguished and separately protected? | No                                                                                            | Yes                                                                                                                                      |  |
| Can tables whose size fluctuates be accommodated easily?           | No                                                                                            | Yes                                                                                                                                      |  |
| Is sharing of procedures between users facilitated?                | No                                                                                            | Yes                                                                                                                                      |  |
| Why was this technique invented?                                   | To get a large<br>linear address<br>space without<br>having to buy<br>more physical<br>memory | To allow programs<br>and data to be broken<br>up into logically<br>independent address<br>spaces and to aid<br>sharing and<br>protection |  |

Comparison of paging and segmentation

53

### Implementation of Pure Segmentation



- (a)-(d) Development of checkerboarding
- (e) Removal of the checkerboarding by compaction

#### Segmentation with Paging: MULTICS (1)



- Descriptor segment points to page tables
- Segment descriptor numbers are field lengths 55

### Segmentation with Paging: MULTICS (2)



A 34-bit MULTICS virtual address

#### Segmentation with Paging: MULTICS (3)



Conversion of a 2-part MULTICS address into a main memory address

Segmentation with Paging: MULTICS (4)

|   | Compa             |              |               |              |     | s this<br>entry<br>used? |
|---|-------------------|--------------|---------------|--------------|-----|--------------------------|
| , | Segment<br>number | Virtual page | Page<br>frame | Protection   | Age | <u> </u>                 |
|   | 4                 | 1            | 7             | Read/write   | 13  | 1                        |
|   | 6                 | 0            | 2             | Read only    | 10  | 1                        |
|   | 12                | 3            | 1             | Read/write   | 2   | 1                        |
|   |                   |              |               |              |     | 0                        |
|   | 2                 | 1            | 0             | Execute only | 7   | 1                        |
|   | 2                 | 2            | 12            | Execute only | 9   | 1                        |
|   |                   |              |               |              |     |                          |

- Simplified version of the MULTICS TLB
- Existence of 2 page sizes makes actual TLB more complicated

Segmentation with Paging: Pentium (1)



A Pentium selector

Segmentation with Paging: Pentium (2)



- Pentium code segment descriptor
- Data segments differ slightly

#### Segmentation with Paging: Pentium (3)



Conversion of a (selector, offset) pair to a linear address

#### Segmentation with Paging: Pentium (4)



Mapping of a linear address onto a physical address

61

### Segmentation with Paging: Pentium (5)



Protection on the Pentium