







### MATERIAL / PACE

- Please classify your perspective on material covered in today's class (25 respondents):
- 1-mostly review, 5-equal new/review, 10-mostly new
- Average  $6.00 (\downarrow previous 6.35)$
- Please rate the pace of today's class:
- 1-slow, 5-just right, 10-fast
- Average 5.08 (↑ previous 5.31)

May 30, 2024

TCSS422: Computer Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma

L19.7

### FEEDBACK FROM 5/28

- How do you translate a virtual address into a physical address when there is a TLB hit and a TLB miss?
- Please refer to "TLB Basic Algorithm" slides
- see L17.28 and L17.29

May 30, 2024

TCSS422: Operating Systems [Spring 2024]
School of Engineering and Technology, University of Washington - Tacoma





# OBJECTIVES - 5/30 Questions from 5/30 Assignment 2 - May 31 (June 4- no late penalty) Assignment 3: (Tutorial) Introduction to Linux Kernel Modules Memory Segmentation Activity + answers (available in Canvas) Quiz 4 - Page Tables - Due June 6 @ 11:59am Final exam - Thursday June 6 @ 3:40pm Tutorial 3 - File Systems (Optional, Extra Credit) Chapter 21/22: Beyond Physical Memory Swapping Mechanisms, Swapping Policies Ch. 36 I/O Devices, Ch. 37 Hard Disk Drives Practice Final Exam

10

### **OBJECTIVES - 5/30** • Questions from 5/30 Assignment 2 - May 31 (June 4- no late penalty) Assignment 3: (Tutorial) Introduction to Linux Kernel Modules Memory Segmentation Activity + answers (available in Canvas) Quiz 4 - Page Tables - Due June 6 @ 11:59am ■ Final exam - Thursday June 6 @ 3:40pm Tutorial 3 - File Systems (Optional, Extra Credit) ■ Chapter 21/22: Beyond Physical Memory Swapping Mechanisms, Swapping Policies ■ Ch. 36 I/O Devices, Ch. 37 Hard Disk Drives ■ Practice Final Exam TCSS422: Operating Systems [Spring 2024] May 30, 2024 11911 School of Engineering and Technology, University of Washington - Tacoma

## ASSIGNMENT 3: INTRODUCTION TO LINUX KERNEL MODULES

- Assignment 3 provides an introduction to kernel programming by demonstrating how to create a <u>Linux Kernel Module</u>
- Kernel modules are commonly used to write device drivers and can access protected operating system data structures
  - For example: Linux task\_struct process data structure
- Assignment 3 Survey select grade category:
  - Assignment category (45%)
  - Quizzes / Activities / Tutorials category (15%)
    - Lowest two grades in this category are dropped

May 30, 2024

TCSS422: Operating Systems [Spring 2024]
School of Engineering and Technology, University of Washington - Tacoma

L19.12

12

### **OBJECTIVES - 5/30**

- Questions from 5/30
- Assignment 2 May 31 (June 4- no late penalty)
- Assignment 3: (Tutorial) Introduction to Linux Kernel Modules
- Memory Segmentation Activity + answers (available in Canvas)
- Quiz 4 Page Tables Due June 6 @ 11:59am
- Final exam Thursday June 6 @ 3:40pm
- Tutorial 3 File Systems (Optional, Extra Credit)
- Chapter 21/22: Beyond Physical Memory
  - Swapping Mechanisms, Swapping Policies
- Ch. 36 I/O Devices, Ch. 37 Hard Disk Drives
- Practice Final Exam

May 30, 2024

TCSS422: Operating Systems [Spring 2024]

School of Engineering and Technology, University of Washington - Tacoma

L19.13

### OBJECTIVES - 5/30

- Questions from 5/30
- Assignment 2 May 31 (June 4- no late penalty)
- Assignment 3: (Tutorial) Introduction to Linux Kernel Modules
- Memory Segmentation Activity + answers (available in Canvas)
- Quiz 4 Page Tables Due June 6 @ 11:59am
- Final exam Thursday June 6 @ 3:40pm
- Tutorial 3 File Systems (Optional, Extra Credit)
- Chapter 21/22: Beyond Physical Memory
  - Swapping Mechanisms, Swapping Policies
- Ch. 36 I/O Devices, Ch. 37 Hard Disk Drives
- Practice Final Exam

May 30, 2024

TCSS422: Operating Systems [Spring 2024]
School of Engineering and Technology, University of Washington - Tacoma

L19.14

14

### **OBJECTIVES - 5/30**

- Questions from 5/30
- Assignment 2 May 31 (June 4- no late penalty)
- Assignment 3: (Tutorial) Introduction to Linux Kernel Modules
- Memory Segmentation Activity + answers (available in Canvas)
- Quiz 4 Page Tables Due June 6 @ 11:59am
- Final exam Thursday June 6 @ 3:40pm
- Tutorial 3 File Systems (Optional, Extra Credit)
- Chapter 21/22: Beyond Physical Memory
  - Swapping Mechanisms, Swapping Policies
- Ch. 36 I/O Devices, Ch. 37 Hard Disk Drives
- Practice Final Exam

May 30, 2024

TCSS422: Operating Systems [Spring 2024]

School of Engineering and Technology, University of Washington - Tacoma

L19.15

# FINAL EXAM – THURSDAY JUNE 6 @ 3:40PM<sup>TH</sup>

- Thursday June 6 from 3:40 to 5:40 pm
  - Final (100 points)
  - SHORT: similar number of questions as the midterm
  - 2-hours
  - Focus on new content since the midterm (~70% new, 30% before)
- Final Exam Review -
  - Complete Memory Segmentation Activity
  - Complete Quiz 4
  - Practice Final Exam Questions 2<sup>nd</sup> hour of June 1<sup>st</sup> class session
  - Individual work
  - 2 pages of notes (any sized paper), double sided
  - Basic calculators allowed
  - NO smartphones, laptop, book, Internet, group work

May 30, 2024

TCSS422: Operating Systems [Spring 2024]
School of Engineering and Technology, University of Washington - Tacoma

L19.16

16

### **OBJECTIVES - 5/30**

- Questions from 5/30
- Assignment 2 May 31 (June 4- no late penalty)
- Assignment 3: (Tutorial) Introduction to Linux Kernel Modules
- Memory Segmentation Activity + answers (available in Canvas)
- Quiz 4 Page Tables Due June 6 @ 11:59am
- Final exam Thursday June 6 @ 3:40pm
- Tutorial 3 File Systems (Optional, Extra Credit)
- Chapter 21/22: Beyond Physical Memory
  - Swapping Mechanisms, Swapping Policies
- Ch. 36 I/O Devices, Ch. 37 Hard Disk Drives
- Practice Final Exam

May 30, 2024

TCSS422: Operating Systems [Spring 2024]

School of Engineering and Technology, University of Washington - Tacoma

L19.17

# OBJECTIVES - 5/30 Questions from 5/30 Assignment 2 - May 31 (June 4- no late penalty) Assignment 3: (Tutorial) Introduction to Linux Kernel Modules Memory Segmentation Activity + answers (available in Canvas) Quiz 4 - Page Tables - Due June 6 @ 11:59am Final exam - Thursday June 6 @ 3:40pm Tutorial 3 - File Systems (Optional, Extra Credit) Chapter 21/22: Beyond Physical Memory Swapping Mechanisms, Swapping Policies Ch. 36 I/O Devices, Ch. 37 Hard Disk Drives Practice Final Exam May 30, 2024 TCSS422: Operating Systems (Spring 2024) School of Engineering and Technology, University of Washington - Tacoma

18















### **IMPLEMENTING LRU**

- Implementing last recently used (LRU) requires tracking access time for all system memory pages
- Times can be tracked with a list
- For cache eviction, we must scan an entire list
- Consider: 4GB memory system (2<sup>32</sup>), with 4KB pages (212)
- This requires 2<sup>20</sup> comparisons !!!
- Simplification is needed
  - Consider how to approximate the oldest page access

May 28, 2024

TCSS422: Operating Systems [Spring 2024]

School of Engineering and Technology, University of Washington - Tacoma

26

### **IMPLEMENTING LRU - 2**

- Harness the Page Table Entry (PTE) Use Bit
- HW sets to 1 when page is used
- OS sets to 0
- Clock algorithm (approximate LRU)
  - Refer to pages in a circular list
  - Clock hand points to current page
  - Loops around
    - IF USE\_BIT=1 set to USE\_BIT = 0
    - IF USE\_BIT=0 replace page

May 28, 2024

TCSS422: Operating Systems [Spring 2024]
School of Engineering and Technology, University of Washington - Tacoma

118 27





### WHEN TO LOAD PAGES

- On demand → demand paging
- Prefetching
  - Preload pages based on anticipated demand
  - Prediction based on locality
  - Access page P, suggest page P+1 may be used
- What other techniques might help anticipate required memory pages?
  - Prediction models, historical analysis
  - In general: accuracy vs. effort tradeoff
  - High analysis techniques struggle to respond in real time

May 28, 2024

TCSS422: Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma

30

### OTHER SWAPPING POLICIES

- Page swaps / writes
  - Group/cluster pages together
  - Collect pending writes, perform as batch
  - Grouping disk writes helps amortize latency costs
- Thrashing
  - Occurs when system runs many memory intensive processes and is low in memory
  - Everything is constantly swapped to-and-from disk

May 28, 2024

TCSS422: Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma

### **OTHER SWAPPING POLICIES - 2**

- Working sets
  - Groups of related processes
  - When thrashing: prevent one or more working set(s) from running
  - Temporarily reduces memory burden
  - •Allows some processes to run, reduces thrashing

May 28, 2024

TCSS422: Operating Systems [Spring 2024]
School of Engineering and Technology, Univ

School of Engineering and Technology, University of Washington - Tacoma

32

### **OBJECTIVES - 5/30**

- Questions from 5/30
- Assignment 2 May 31 (June 4- no late penalty)
- Assignment 3: (Tutorial) Introduction to Linux Kernel Modules
- Memory Segmentation Activity + answers (available in Canvas)
- Quiz 4 Page Tables Due June 6 @ 11:59am
- Final exam Thursday June 6 @ 3:40pm
- Tutorial 3 File Systems (Optional, Extra Credit)
- Chapter 21/22: Beyond Physical Memory
  - Swapping Mechanisms, Swapping Policies
- Ch. 36 I/O Devices, Ch. 37 Hard Disk Drives
- Practice Final Exam

May 30, 2024

TCSS422: Operating Systems [Spring 2024]

School of Engineering and Technology, University of Washington - Tacoma

33

L19.33























# INTERRUPTS VS POLLING - 3 Alternative: two-phase hybrid approach Initially poll, then sleep and use interrupts Issue: livelock problem Common with network I/O Many arriving packets generate many many interrupts Overloads the CPU! No time to execute code, just interrupt handlers! Livelock optimization Coalesce multiple arriving packets (for different processes) into fewer interrupts Must consider number of interrupts a device could generate May 30, 2024 TCSS422: Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma

## DEVICE I/O

- To interact with a device we must send/receive DATA
- Two general approaches:
  - Programmed I/O (PIO):
    - Port mapped I/O (PMIO)
    - Memory mapped I/O (MMIO)
  - Direct memory access (DMA)

TCSS422: Operating Systems [Spring 2024]
School of Engineering and Technology, University of Washington - Tacoma

46

May 30, 2024

| Transfer Modes  |                       |                              |               |
|-----------------|-----------------------|------------------------------|---------------|
| Mode \$         | # +                   | Maximum transfer rate (MB/s) | cycle time \$ |
| PIO             | 0                     | 3.3                          | 600 ns        |
|                 | 1                     | 5.2                          | 383 ns        |
|                 | 2                     | 8.3                          | 240 ns        |
|                 | 3                     | 11.1                         | 180 ns        |
|                 | 4                     | 16.7                         | 120 ns        |
| Single-word DMA | 0                     | 2.1                          | 960 ns        |
|                 | 1                     | 4.2                          | 480 ns        |
|                 | 2                     | 8.3                          | 240 ns        |
| Multi-word DMA  | 0                     | 4.2                          | 480 ns        |
|                 | 1                     | 13.3                         | 150 ns        |
|                 | 2                     | 16.7                         | 120 ns        |
|                 | 3[34]                 | 20                           | 100 ns        |
|                 | 4[34]                 | 25                           | 80 ns         |
| Ultra DMA       | 0                     | 16.7                         | 240 ns ÷ 2    |
|                 | 1                     | 25.0                         | 160 ns ÷ 2    |
|                 | 2 (Ultra ATA/33)      | 33.3                         | 120 ns ÷ 2    |
|                 | 3                     | 44.4                         | 90 ns ÷ 2     |
|                 | 4 (Ultra ATA/66)      | 66.7                         | 60 ns ÷ 2     |
|                 | 5 (Ultra ATA/100)     | 100                          | 40 ns ÷ 2     |
|                 | 6 (Ultra ATA/133)     | 133                          | 30 ns ÷ 2     |
|                 | 7 (Ultra ATA/167)[35] | 167                          | 24 ns ÷ 2     |





# PROGRAMMED I/O DEVICE (PIO) **INTERACTION** ■ Two primary PIO methods Port mapped I/O (PMIO) Memory mapped I/O (MMIO) TCSS422: Operating Systems [Spring 2024]

School of Engineering and Technology, University of Washington - Tacoma

50

May 30, 2024

## PORT MAPPED I/O (PMIO) ■ Device specific CPU I/O Instructions ■ Follows a Complex Instruction Set - CISC model (Intel): ■ Specific CPU instructions are used for device I/O ■ x86/x86-64: in and out instructions outb, outw, outl ■ 1, 2, 4 byte copy from EAX → device's I/O port TCSS422: Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma May 30, 2024 L19.51

# MEMORY MAPPED I/O (MMIO) Device's memory is mapped to standard memory addresses MMIO is common with RISC CPUs: Special CPU instructions for PIO eliminated Old days: 16-bit CPUs didn't have a lot of spare memory space Today's CPUs have LARGE address spaces: 32-bit (4GB addr space) & 64-bit (256 TB addr space) Device I/O uses regular CPU instructions usually used to read/write memory to access device Device is mapped to unique memory address reserved for I/O Address must not be available for normal memory operations.

Generally very high addresses (out of range of type addresses)
 Device monitors CPU address bus and respond to instructions

School of Engineering and Technology, University of Washington - Tacoma

TCSS422: Operating Systems [Spring 2024]

52

on their addresses

May 30, 2024



### DIRECTORY MEMORY ACCESS - 2

- Many devices use DMA
  - HDD/SSD controllers (ISA/PCI)
  - Graphics cards
  - Network cards
  - Sound cards
  - Intra-chip memory transfer for multi-core processors
- DMA allows computation and data transfer time to proceed in parallel

May 30, 2024

TCSS422: Operating Systems [Spring 2024]

School of Engineering and Technology, University of Washington - Tacoma

54

### **DEVICE INTERACTION**

- The OS must interact with a variety of devices
- Example: Consider a file system that works across a variety of types of disks:
  - SCSI, IDE, USB flash drive, DVD, etc.
- File system should be general purpose, where device specific I/O implementation details are abstracted
- Device drivers use abstraction to provide general interfaces for vendor specific hardware
- In Linux: block devices

May 30, 2024

TCSS422: Operating Systems [Spring 2024]
School of Engineering and Technology, University of Washington - Tacoma

55













### HARD DISK DRIVE (HDD)

- Primary means of data storage (persistence) for decades
  - Remains inexpensive for high capacity storage
  - **2020:** 16 TB HDD \$400, ~15.3 TB SSD \$4,380
- Consists of a large number of data sectors
- Sector size is 512-bytes
- An n sector HDD can be is addressed as an array of 0..n-1 sectors

May 30, 2024

TCSS422: Operating Systems [Spring 2024]
School of Engineering and Technology, University of Washington - Tacoma

62

### **HDD INTERFACE**

- Writing disk sectors is atomic (512 bytes)
- Sector writes are completely successful, or fail
- Many file systems will read/write 4KB at a time
  - Linux ext3/4 default filesystem blocksize 4096
- Same as typical memory page size



May 30, 2024

TCSS422: Operating Systems [Spring 2024]
School of Engineering and Technology, University of Washington - Tacoma

L19.63

### **BLOCK SIZE IN LINUX EXT4**

- mkefs.ext4 -i <bytes-per-inode>
- Formats disk w/ ext4 filesys with specified byte-to-inode ratio
- Today's disks are so large, some use cases with many small files can run out of inodes before running out of disk space
- Each inode record tracks a file on the disk
- Larger bytes-per-inode ratio results in fewer inodes
  - Default is around ~4096
- Value shouldn't be smaller than blocksize of filesystem
- Note: It is not possible to expand the number of inodes after the filesystem is created, - be careful deciding the value
- Check inode stats: tune2fs -1 /dev/sda1 (← disk dev name)

May 30, 2024

TCSS422: Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma

64

### **EXAMPLE: USDA SOIL EROSION MODEL** WEB SERVICE (RUSLE2)

- Host ~2,000,000 small XML files totaling 9.5 GB on a ~20GB filesystem on a cloud-based Virtual Machine
- With default inode ratio (4096 block size), only ~488,000 files will fit
- Drive less than half full, but files will not fit!
- HDDs support a minimum block size of 512 bytes
- OS filesystems such as ext3/ext4 can support "finer grained" management at the expense of a larger catalog size
  - Small inode ratio- inodes will considerable % of disk space

May 30, 2024

TCSS422: Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma

11965

### **EXAMPLE: USDA SOIL EROSION MODEL** WEB SERVICE (RUSLE2) - 2

■ Free space in bytes (df)

Device total size bytes-used bytes-free usage 13315844 9556412 3049188 76% / mnt /dev/vda2

■ Free inodes (df -i) @ 512 bytes / node

Device total inodes used free usage 3552528 1999823 1552705 57% /mnt /dev/vda2

TCSS422: Operating Systems [Spring 2024] May 30, 2024 School of Engineering and Technology, University of Washington - Tacoma

66

### **HDD INTERFACE - 2**

- **Torn write** 
  - When OS uses larger block size than HDD
  - Block writes not atomic they SPAN multiple HDD sectors
  - Upon power failure only a portion of the OS block is written - can lead to data corruption...
- HDD access
  - Sequential reads of sectors is fastest
  - Random sector reads are slow
  - Disk head continuously must jump to different tracks



May 30, 2024

TCSS422: Operating Systems [Spring 2024]
School of Engineering and Technology, University of Washington - Tacoma

















# HDD I/O

- Data transfer
  - Final phase of I/O: time to read or write to disk surface
- Complete I/O cycle:
  - 1. Seek (accelerate, coast, decelerate, settle)
  - 2. Wait on rotational latency (until track aligns)
  - 3. Data transfer

May 30, 2024

TCSS422: Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma

L19.77

76

### TRACK SKEW

- Sectors are offset across tracks to allow time for head to reposition for sequential reads
- Without track skew, when head is repositioned sector would have already been passed



May 30, 2024

TCSS422: Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma













# DISK SCHEDULING Disk scheduler: determine how to order I/O requests Multiple levels - OS and HW OS: provides ordering HW: further optimizes using intricate details of physical HDD implementation and state May 30, 2024 TCSS422: Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma

84



### **SSTF ISSUES**

- Problem 1: HDD abstraction
- Drive geometry not available to OS. Nearest-block-first is a comparable alternate algorithm.
- Problem 2: Starvation
- Steady stream of requests for local tracks may prevent arm from traversing to other side of platter

May 30, 2024

TCSS422: Operating Systems [Spring 2024]
School of Engineering and Technology, University of Washington - Tacoma

86

### **DISK SCHEDULING ALGORITHMS**

- SCAN (SWEEP)
- Perform single repeated passes back and forth across disk
- Issue: if request arrives for a recently visited track it will not be revisited until a full cycle completes
- F-SCAN
- Freeze incoming requests by adding to queue during scan
- Cache arriving requests until later
- Delays help avoid starvation by postponing servicing nearby newly arriving requests vs. requests at edge of sweep
- Provides better fairness
- Elevator (C-SCAN) circular scan
- Sweep only one direction (e.g. outer to inner) and repeat
- SCAN favors middle tracks vs. outer tracks with 2-way sweep

May 30, 2024

TCSS422: Operating Systems [Spring 2024]

School of Engineering and Technology, University of Washington - Tacoma

L19.87











|        |                                                                                                                               | Q1 - 2                              |   |  |  |
|--------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|---|--|--|
|        | Scenario 2                                                                                                                    |                                     | 7 |  |  |
|        | Virtual Address 300 1600                                                                                                      | Physical Address  1500 Base?  2800  |   |  |  |
|        | 1801<br>2801                                                                                                                  | ? Bounds?                           |   |  |  |
|        | Scenario 3 Virtual Address                                                                                                    | Physical Address                    |   |  |  |
|        | VII COLO PAGE 155                                                                                                             | 1000 Base? <u>1000</u>              | _ |  |  |
|        |                                                                                                                               | 2999 Bounds? <u>2000</u><br>[fault] |   |  |  |
| May 30 | May 30, 2024 TCSS422: Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma |                                     |   |  |  |

### **OUESTION 2 - SINGLE-LEVEL PAGE TABLE** Consider a computer with 4 GB (2<sup>32</sup>) of physical memory, where the page size is 4 KB (2<sup>12</sup>). For simplicity assume than 1GB=1000MB, 1MB=1000KB, 1KB=1000 bytes (a) How many pages must be tracked by a single-level page table if the computer has 4GB (232) of physical memory and the page table size is 4 KB (212)? (b) How many bits are required for the virtual page number (VPN) to address any page within this 4GB (232) memory space? (c) Assuming that the smallest addressable unit of memory within a page is a byte (8-bits), how many bits are required for the offset to refer to any byte in the 4 KB page? (d) Assuming each page table entry (PTE) requires 4 bytes of memory, how much memory is required to store the page table for one process (in MB)? TCSS422: Operating Systems [Spring 2024] May 30, 2024 School of Engineering and Technology, University of Washington - Tacoma

94







| QUESTION 4 - CACHE TRACING                                                                                                            |                                |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--|--|--|
| Consider a 3-element cache wi<br>below.                                                                                               | th the cache arrival sequences |  |  |  |
| Determine the number of cach<br>each of the following cache re                                                                        | •                              |  |  |  |
| A. Optimal policy                                                                                                                     | w                              |  |  |  |
| Arrival sequence:                                                                                                                     | Working Cache<br>Cache 1:      |  |  |  |
| 5 3 7 5 3 1 0 7 1 6 4 3 2 1 3                                                                                                         | Cache 2:                       |  |  |  |
|                                                                                                                                       | Cache 3:                       |  |  |  |
| # Hits:                                                                                                                               |                                |  |  |  |
| # Misses:                                                                                                                             |                                |  |  |  |
| May 30, 2024 TCSS422: Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma L19.101 |                                |  |  |  |

| Q4 - 2                                                                                                                        |           |               |   |  |
|-------------------------------------------------------------------------------------------------------------------------------|-----------|---------------|---|--|
|                                                                                                                               |           |               |   |  |
| B. FIFO policy                                                                                                                |           | Working Cache |   |  |
| Arrival sequence:                                                                                                             |           | Cache 1:      |   |  |
| 53753107                                                                                                                      | 1643213   | Cache 2:      |   |  |
|                                                                                                                               |           | Cache 3:      |   |  |
| # Hits:                                                                                                                       |           |               |   |  |
| # Misses:                                                                                                                     |           |               |   |  |
|                                                                                                                               | TCCC422 O |               | 7 |  |
| May 30, 2024 TCSS422: Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma |           |               |   |  |

| Q4 - 3                                                                                                                        |                        |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------|------------------------|--|--|--|--|
|                                                                                                                               |                        |  |  |  |  |
| C. LRU policy                                                                                                                 |                        |  |  |  |  |
| Arrival sequence:                                                                                                             | Working Cache Cache 1: |  |  |  |  |
| 5 3 7 5 3 1 0 7 1 6 4 3 2 1 3                                                                                                 | Cache 2:               |  |  |  |  |
|                                                                                                                               | Cache 3:               |  |  |  |  |
| # Hits:                                                                                                                       |                        |  |  |  |  |
| # Misses:                                                                                                                     |                        |  |  |  |  |
|                                                                                                                               |                        |  |  |  |  |
| May 30, 2024 TCSS422: Operating Systems [Spring 2024] School of Engineering and Technology, University of Washington - Tacoma |                        |  |  |  |  |

## **QUESTION 5 - FREE SPACE MANAGEMENT**

- Free space management involves capturing a description of the computer's free memory using a data structure, storing this data structure in memory, and OS support to rapidly use this structure to determine an appropriate location for new memory allocations. An efficient implementation is very important when scaling up the number of operations the OS is required to perform.
- Consider the use of a linked list for a free space list where each node is represented by placing the following structure in the header of the memory chunk:

```
typedef struct __node_t
{
    int size;
    struct __node_t *next;
} node_t;
```

May 30, 2024

TCSS422: Operating Systems [Spring 2024]
School of Engineering and Technology, University of Washington - Tacoma

L19.104

104





