# Sistemi Operativi I

Corso di Laurea in Informatica 2025-2026



#### Gabriele Tolomei

Dipartimento di Informatica Sapienza Università di Roma

tolomei@di.uniroma1.it

### Useful Information

#### Class schedule

• Tuesday: 1 PM - 4 PM

• Thursday: 1 PM - 3 PM

#### Useful Information

#### Class schedule

- Tuesday: 1 PM 4 PM
- Thursday: 1 PM 3 PM

#### Contacts

- email: tolomei@di.uniroma1.it
- website: <a href="https://github.com/gtolomei/operating-systems">https://github.com/gtolomei/operating-systems</a>
- moodle: <a href="https://elearning.uniroma1.it/course/view.php?id=20049">https://elearning.uniroma1.it/course/view.php?id=20049</a>

#### Useful Information

#### Class schedule

- Tuesday: 1 PM 4 PM
- Thursday: 1 PM 3 PM

#### Contacts

- email: tolomei@di.uniroma1.it
- website: <a href="https://github.com/gtolomei/operating-systems">https://github.com/gtolomei/operating-systems</a>
- moodle: <a href="https://elearning.uniroma1.it/course/view.php?id=20049">https://elearning.uniroma1.it/course/view.php?id=20049</a>

#### Office hours

- Arranged via email
- in-person or remotely
- Room 106, 1<sup>st</sup> floor Building E (map)

### Class Material

- Released on the class website
- Suggested books (though not mandatory!):
  - "Operating System Concepts" Ninth Edition Silberschatz, Galvin, Gagne
  - "Modern Operating Systems" Fourth Edition Tanenbaum, Bos
  - "Operating Systems: Three Easy Pieces" Remzi and Andrea Arpaci-Dusseau [available online]
- Any additional resource available on the Web!

#### Moodle

- Provides native support for:
  - Sharing news and messages (forum)
  - Additional class material (e.g., exercises)
  - Exam simulations (e.g., quizzes)
  - ...

Remember to enroll in the course from the moodle web page!

#### Exam

- Moodle Quiz:
  - 20 multiple-answer questions (max. 45 minutes)
  - Marks: +3 (correct answer), O (no answer), -1 (wrong answer)
    - score  $<= 14/30 \rightarrow FAIL$
    - 15/30 <= score <= 17/30 → ORAL REQUIRED
    - score  $\Rightarrow$  18/30  $\rightarrow$  PASS (oral upon request by the student)

#### Exam

#### Moodle Quiz:

- 20 multiple-answer questions (max. 45 minutes)
- Marks: +3 (correct answer), O (no answer), -1 (wrong answer)
  - score  $\leftarrow$  14/30  $\rightarrow$  FAIL
  - 15/30 <= score <= 17/30 → ORAL REQUIRED
  - score  $\Rightarrow$  18/30  $\rightarrow$  PASS (oral upon request by the student)

#### Oral Session:

 Questions and exercises on the subjects covered during the whole semester

• Part I: Introduction

- Part I: Introduction
- Part II: Process Management

- Part I: Introduction
- Part II: Process Management
- Part III: Process Synchronization

- Part I: Introduction
- Part II: Process Management
- Part III: Process Synchronization
- Part IV: Memory Management

- Part I: Introduction
- Part II: Process Management
- Part III: Process Synchronization
- Part IV: Memory Management
- Part V: Storage Management

- Part I: Introduction
- Part II: Process Management
- Part III: Process Synchronization
- Part IV: Memory Management
- Part V: Storage Management
- Part VI: File System

- Part I: Introduction
- Part II: Process Management
- Part III: Process Synchronization
- Part IV: Memory Management
- Part V: Storage Management
- Part VI: File System
- Part VII: Advanced Topics(?)

### Part I: Introduction

## Language and Naming Conventions

- OS → Operating System
- HW → Hardware
- SW → Software
- VM → Virtual Machine
- ...
- Other shortcuts/acronyms may appear here and there without notice! Please, ask if anything is not clear!

# What is an Operating System?

## What is an Operating System?

• There exists no universally accepted definition!

# What is an Operating System?

- There exists no universally accepted definition!
- However, the definition below is quite appropriate:

Implementation of a virtual machine that is (hopefully) easier to program than bare hardware

# Computer System Overview



# Computer System Overview



• Again, no single answer to this question!

- Again, no single answer to this question!
- It is a system design choice to decide what to include in the OS

- Again, no single answer to this question!
- It is a system design choice to decide what to include in the OS
- Different systems may have different requirements:
  - general-purpose, real-time, mobile, etc.

- Again, no single answer to this question!
- It is a system design choice to decide what to include in the OS
- Different systems may have different requirements:
  - general-purpose, real-time, mobile, etc.
- Typically, we distinguish between:
  - kernel → the "core" of the OS (always up and running)
  - system programs → everything else which is still part of the OS

#### • Referee (Resource Manager)

 Manages shared physical resources: CPUs, memory, I/O, etc.



- Referee (Resource Manager)
  - Manages shared physical resources: CPUs, memory, I/O, etc.
  - To achieve fairness and efficiency



- Illusionist (Virtual Machine)
  - Virtualize any physical resource



- Illusionist (Virtual Machine)
  - Virtualize any physical resource
  - To give applications/users the illusion of infinite resources available



- Glue (HW/SW Interface)
  - Provides a set of common services
     (APIs) to separate HW from SW



- Glue (HW/SW Interface)
  - Provides a set of common services
     (APIs) to separate HW from SW
  - To allow applications/users to interact with the system without talking directly to the HW



# Computer System Organization

# High-Level View of a Computer



# High-Level View of a Computer



#### **CPU**

- The processor that performs the actual computation
- Multiple cores are now common in modern architectures

## High-Level View of a Computer



#### Main Memory

- Stores data and instructions used by the CPU
- Shared between CPU and I/O

# High-Level View of a Computer



#### I/O devices

- terminal, keyboard, disks, etc.
- Associated with specific device controllers

# High-Level View of a Computer



#### System Bus

 Communication medium between CPU, memory, and peripherals

### Computer Architecture Model

- Conceptually, the same architectural model for many computing devices:
  - PCs/laptops
  - High-end servers
  - Smartphones/Tablets
  - etc.

# Computer Architecture Model

- Conceptually, the same architectural model for many computing devices:
  - PCs/laptops
  - High-end servers
  - Smartphones/Tablets
  - etc.
- Based on stored-program concept (as opposed to fixed-program)



John von Neumann

### von Neumann Architecture



### von Neumann Architecture



23/09/2025 42

### von Neumann Architecture



# Central Processing Unit (CPU)

• The CPU performs the following 5 stages cyclically:

23/09/2025 45

- The CPU performs the following 5 stages cyclically:
  - Instruction Fetch (IF) → retrieves an instruction from a specific memory address whose value is contained in a special CPU register, called Program Counter (PC)

- The CPU performs the following 5 stages cyclically:
  - Instruction Fetch (IF) → retrieves an instruction from a specific memory address whose value is contained in a special CPU register, called Program Counter (PC)
  - 2. Instruction Decode & Register Fetch (ID) → interprets the fetched instruction

- The CPU performs the following 5 stages cyclically:
  - Instruction Fetch (IF) → retrieves an instruction from a specific memory address whose value is contained in a special CPU register, called Program Counter (PC)
  - 2. Instruction Decode & Register Fetch (ID) → interprets the fetched instruction
  - 3. Execute (EX) → runs the actual decoded instruction through ALU operations, address calculation, etc.

23/09/2025 48

- The CPU performs the following 5 stages cyclically:
  - Instruction Fetch (IF) → retrieves an instruction from a specific memory address whose value is contained in a special CPU register, called Program Counter (PC)
  - 2. Instruction Decode & Register Fetch (ID) → interprets the fetched instruction
  - 3. Execute (EX) → runs the actual decoded instruction through ALU operations, address calculation, etc.
  - **4.** Memory Access (MEM) → load from/store to main memory (*if needed*)

- The CPU performs the following 5 stages cyclically:
  - Instruction Fetch (IF) → retrieves an instruction from a specific memory address whose value is contained in a special CPU register, called Program Counter (PC)
  - 2. Instruction Decode & Register Fetch (ID) → interprets the fetched instruction
  - 3. Execute (EX) → runs the actual decoded instruction through ALU operations, address calculation, etc.
  - **4.** Memory Access (MEM) → load from/store to main memory (*if needed*)
  - 5. Write Back (WB) → update register with result (if needed)

- The CPU performs the following 5 stages cyclically: FETCH
  - 1. Instruction Fetch (IF) → retrieves an instruction from a specific memory address whose value is contained in a special CPU register, called Program Counter (PC)
  - 2. Instruction Decode & Register Fetch (ID) → interprets the fetched instruction
  - 3. Execute (EX) → runs the actual decoded instruction through ALU operations, address calculation, etc.
  - **4.** Memory Access (MEM) → load from/store to main memory (*if needed*)
  - 5. Write Back (WB) → update register with result (if needed)

- The CPU performs the following 5 stages cyclically:
  - 1. Instruction Fetch (IF) → retrieves an instruction from a specific memory address whose value is contained in a special CPU register, called Program Counter (PC)
    DECODE
  - 2. Instruction Decode & Register Fetch (ID) → interprets the fetched instruction
  - 3. Execute (EX) → runs the actual decoded instruction through ALU operations, address calculation, etc.
  - **4.** Memory Access (MEM) → load from/store to main memory (*if needed*)
  - 5. Write Back (WB) → update register with result (if needed)

- The CPU performs the following 5 stages cyclically:
  - Instruction Fetch (IF) → retrieves an instruction from a specific memory address whose value is contained in a special CPU register, called Program Counter (PC)
  - 2. Instruction Decode & Register Fetch (ID) → interprets the fetched instruction
    EXECUTE
  - 3. Execute (EX) → runs the actual decoded instruction through ALU operations, address calculation, etc.
  - **4.** Memory Access (MEM) → load from/store to main memory (*if needed*)
  - 5. Write Back (WB) → update register with result (if needed)

### Instruction Cycle: Non-Pipelined



4 instructions: I1,... I4

### Instruction Cycle: Non-Pipelined



4 instructions: I1,... I4

Each stage runs sequentially

the first stage of Ij will start only after the last stage of Ij-1 is completed

### Instruction Cycle: Non-Pipelined



4 instructions: I1,... I4

Each stage runs sequentially

the first stage of Ij will start only after the last stage of Ij-1 is completed

#### Assumption:

Each stage takes one clock cycle (may not always be the case!)

5 Cycles per Instruction (CPI)

# Instruction Cycle: Pipelined



4 instructions: I1,... I4

### Instruction Cycle: Pipelined



4 instructions: I1,... I4

Each stage runs in parallel

the i-th stage of Ij is overlapped with the (i+1)-th stage of Ij-1

### Instruction Cycle: Pipelined



4 instructions: I1,... I4

Each stage runs in parallel

the i-th stage of Ij is overlapped with the (i+1)-th stage of Ij-1

#### Assumption:

Each stage takes one clock cycle (may not always be the case!)

1 Cycle per Instruction (CPI) on average

23/09/2025

59

### Instruction Cycle: Pipelined (v.2)



4 instructions: I1,... I4

Each stage runs in parallel whenever possible or wait

Each stage may take more than one clock cycle (e.q., EX takes two!)

2 Cycles per Instruction (CPI) on average

• Defines the set of **elementary instructions** the CPU is able to execute directly (i.e., on the HW)

- Defines the set of **elementary instructions** the CPU is able to execute directly (i.e., on the HW)
- The machine language is represented by binary numeral system

- Defines the set of elementary instructions the CPU is able to execute directly (i.e., on the HW)
- The machine language is represented by binary numeral system
- Each instruction is encoded as a sequence of bits
  - A single bit is the smallest unit of (digital) information
  - It takes on two possible values: O or 1

- Defines the set of **elementary instructions** the CPU is able to execute directly (i.e., on the HW)
- The machine language is represented by binary numeral system
- Each instruction is encoded as a sequence of bits
  - A single bit is the smallest unit of (digital) information
  - It takes on two possible values: O or 1
- A word is the unit of data the CPU can directly operate on
  - today ranging from 32 to 64 bits

### A Side Note on Units



# Instruction Set (Architecture)

• The collection of instructions defined by the machine language

### Instruction Set (Architecture)

- The collection of instructions defined by the machine language
- Machine language instructions are made of 2 parts:
  - An operator (op code)
  - Zero or more **operands** representing either CPU internal registers or memory addresses

### Instruction Set (Architecture)

- The collection of instructions defined by the machine language
- Machine language instructions are made of 2 parts:
  - An operator (op code)
  - Zero or more **operands** representing either CPU internal registers or memory addresses
- An **abstraction** of the underlying physical (hardware) architecture (e.g., x86, ARM, SPARC, MIPS, etc.)

# CPU Registers

• On-chip storage whose size typically coincides with the CPU word size

### CPU Registers

- On-chip storage whose size typically coincides with the CPU word size
- General-purpose (x86):
  - eax, ebx, ecx, etc.

### CPU Registers

- On-chip storage whose size typically coincides with the CPU word size
- General-purpose (x86):
  - eax, ebx, ecx, etc.
- Special-purpose (x86):
  - esp → Stack pointer for top address of the stack
  - ebp → Stack base pointer for the address of the current stack frame
  - eip → Instruction pointer, holds the program counter (i.e., the address of next instruction)

### Single- vs. Multi-Processor

#### Single-Processor Systems

- One main CPU for executing programs
- Other dedicated processors that do not run programs (e.g., disk controllers, GPUs, etc.)

#### Single- vs. Multi-Processor

#### Single-Processor Systems

- One main CPU for executing programs
- Other dedicated processors that do not run programs (e.g., disk controllers, GPUs, etc.)

#### Multi-Processor Systems

- Multiple CPUs to increase throughput (even if not linearly!)
- Higher resiliency to failures

#### Single- vs. Multi-Processor

#### Single-Processor Systems

- One main CPU for executing programs
- Other dedicated processors that do not run programs (e.g., disk controllers, GPUs, etc.)

Our main focus!

#### Multi-Processor Systems

- Multiple CPUs to increase throughput (even if not linearly!)
- Higher resiliency to failures

#### Multi-Processor Systems: Examples

# Symmetric Multiprocessing Architecture



#### Multicore Architecture



# Memory

### Memory Hierarchy



### Memory Hierarchy



## Memory Hierarchy



• Essentially, a sequence of cells

- Essentially, a sequence of cells
- Each cell is logically organized in groups of 8 bits (1 byte) or multiple of it (e.g., 32 bits = 4 bytes)

- Essentially, a sequence of cells
- Each cell is logically organized in groups of 8 bits (1 byte) or multiple of it (e.g., 32 bits = 4 bytes)
- Each cell has its own address

- Essentially, a sequence of cells
- Each cell is logically organized in groups of 8 bits (1 byte) or multiple of it (e.g., 32 bits = 4 bytes)
- Each cell has its own address
- CPU (and I/O devices) read from/write to main memory referencing memory location addresses

- Essentially, a sequence of cells
- Each cell is logically organized in groups of 8 bits (1 byte) or multiple of it (e.g., 32 bits = 4 bytes)
- Each cell has its own address
- CPU (and I/O devices) read from/write to main memory referencing memory location addresses
- The smallest addressable unit is usually 1 byte

# Memory Cell (1)



23/09/2025

85

## Memory Cell (2)



# Memory Address (Single Byte)



# Computer Buses

• Initially, a single bus to handle all the traffic

- Initially, a single bus to handle all the traffic
- Combines the functions of:
  - Data bus → to actually carry information
  - Address bus → to determine where information should be sent
  - Control bus → to indicate which operation should be performed

- Initially, a single bus to handle all the traffic
- Combines the functions of:
  - Data bus → to actually carry information
  - Address bus → to determine where information should be sent
  - Control bus → to indicate which operation should be performed
- More dedicated buses have been added to manage CPUto-memory and I/O traffic
  - PCI, SATA, USB, etc.



# I/O Devices

• Each I/O device is made of 2 parts:

- Each I/O device is made of 2 parts:
  - the physical device itself
  - the **device controller** (chip or set of chips controlling a family of physical devices)

- Each I/O device is made of 2 parts:
  - the physical device itself
  - the **device controller** (chip or set of chips controlling a family of physical devices)
- Can be categorized as:
  - storage, communications, user-interface, etc.

- Each I/O device is made of 2 parts:
  - the physical device itself
  - the **device controller** (chip or set of chips controlling a family of physical devices)
- Can be categorized as:
  - storage, communications, user-interface, etc.
- OS talks to a device controller using a specific device driver

#### Device Drivers: OS Abstraction



#### Device Drivers: OS Abstraction



#### Device Drivers: OS Abstraction



#### Device Controllers

- Every device controller has a number of dedicated registers to communicate with it:
  - Status registers → provide status information to the CPU about the I/O device (e.g., idle, ready for input, busy, error, transaction complete)

#### Device Controllers

- Every device controller has a number of dedicated registers to communicate with it:
  - Status registers → provide status information to the CPU about the I/O device (e.g., idle, ready for input, busy, error, transaction complete)
  - Configuration/Control registers → used by the CPU to configure and control the device

#### Device Controllers

- Every device controller has a number of dedicated registers to communicate with it:
  - Status registers → provide status information to the CPU about the I/O device (e.g., idle, ready for input, busy, error, transaction complete)
  - Configuration/Control registers → used by the CPU to configure and control the device
  - Data registers → used to read data from or send data to the I/O device

## Modern Computer Systems







IDE
(code development)



## Many User Applications Running



## Many System Programs Running



# Not Just Laptops/PCs...



#### Why Do We Care About All This?



Any computerized system executes programs loaded in main memory

From time to time, computation must be suspended to perform I/O tasks

Modern systems keep several "programs" loaded into main memory (multiprogramming)

## Multiprogramming Systems (1960s)



- Keep several jobs loaded in memory
- Multiplex CPU between jobs
- OS responsibilities:
  - job scheduling
  - memory protection
  - I/O operations
- Problem: CPU is left idle while blocking I/O operations take place

# Blocking System I/O



# Non-Blocking System I/O

```
I/O Device
                                                      OS
                        Job i
                                                                        Job i
              main() {
                Instr 2:-
                Instr k: READ_FROM_FILE() -
                                            → READ FROM FILE() (
                                                  start IO() -
                                                  job schedule()
                                                                       main() {
                                                  end IO()
                                                                                     interrupt
                                                  job schedule()
              Instr k+1:
23/09/2025
```

## Time-sharing Systems (1970s)



- Many users connected to the same CPU via cheap consoles
- Timer interrupt used to multiplex CPU between jobs
- Illusion of parallelism (pseudo-parallelism)
- Ken Thompson&Dennis Ritchie → UNIX OS

#### Pseudo-parallelism



## New Trends in OS Design

- Active field of research
  - OS demand is growing (many computing devices are available)
  - New application settings (Web, Cloud, mobile, cars, etc.)
  - Hardware is rapidly changing (new CPUs coming out)

#### New Trends in OS Design

- Active field of research
  - OS demand is growing (many computing devices are available)
  - New application settings (Web, Cloud, mobile, cars, etc.)
  - Hardware is rapidly changing (new CPUs coming out)
- Open-source OS (Linux)
  - Allows developers to contribute to OS development
  - Excellent research platform to experiment with

## Why Study OSs?

- To learn important concepts of computer science
  - Abstraction
    - Virtualize any physical resource (CPUs, memory, I/O, etc.)

## Why Study OSs?

- To learn important concepts of computer science
  - Abstraction
    - Virtualize any physical resource (CPUs, memory, I/O, etc.)
  - Systems Design Tradeoffs
    - Performance vs. Cost of OS abstractions
    - Performance vs. Complexity of OS design
    - HW vs. SW implementation of key features

## Why Study OSs?

- To learn important concepts of computer science
  - Abstraction
    - Virtualize any physical resource (CPUs, memory, I/O, etc.)
  - Systems Design Tradeoffs
    - Performance vs. Cost of OS abstractions
    - Performance vs. Complexity of OS design
    - HW vs. SW implementation of key features
  - How computers work

## Large Computer Systems

- The world is increasingly dependent on computer systems
  - Large, complex, interconnected, distributed, etc.

## Large Computer Systems

- The world is increasingly dependent on computer systems
  - Large, complex, interconnected, distributed, etc.
- Huge demand for experts who deeply understand and can build such systems, which need to be:
  - Reliable, effective, efficient, secure, etc.

## Large Computer Systems

- The world is increasingly dependent on computer systems
  - Large, complex, interconnected, distributed, etc.
- Huge demand for experts who deeply understand and can build such systems, which need to be:
  - Reliable, effective, efficient, secure, etc.

OS is a great example of a large computer system

#### Linux Kernel Size (Lines of Code)



## OS as Large Computer System

- Designing large computer systems requires you to know
  - Each computer:
    - Architectural details
    - High-level programming language (mostly, C/C++)
    - Memory management
    - Concurrency and scheduling
    - File system and I/O

## OS as Large Computer System

- Designing large computer systems requires you to know
  - Each computer:
    - Architectural details
    - High-level programming language (mostly, C/C++)
    - Memory management
    - Concurrency and scheduling
    - File system and I/O
  - Across clusters of computers:
    - Server architectures
    - Distributed file systems and computing frameworks

## OS Design Issues (1)

- Structure → How the whole system is organized
- Concurrency → How parallel tasks are managed
- Sharing → How resources are shared
- Naming → How resources are identified by users
- Protection → How critical tasks are protected from each other
- Security → How to authenticate, authorize, and ensure privacy
- Performance → How to make it more efficient (quick, compact)

## OS Design Issues (2)

- Reliability → How to deal with failures
- Portability → How to write once and run anywhere
- Extensibility → How to add new features/capabilities
- Communication → How to exchange information
- Scalability → How to scale up as demand increases
- Persistency → How to save task's status
- Accounting → How to claim on control resource usage

#### Architectural Trends: CPU

\*Million Instructions Per Second

\*\*1 MHz = 1,000,000 clock cycles per second

|                                      | 1971<br>(Intel<br>4004) | Today<br>(Intel Core i9) | Δ<br>(orders of<br>magnitude) |
|--------------------------------------|-------------------------|--------------------------|-------------------------------|
| MIPS*                                | ~0.09                   | ~400,000+                | +7                            |
| Instructions per clock cycle (1/CPI) | ~0.12                   | ~100+                    | +3                            |
| Clock frequency (MHz)**              | 0.74                    | ~5,000                   | +4                            |
| Cheap size (µm)                      | 10                      | 0.014                    | -3                            |

#### Architectural Trends: CPU

\*Million Instructions Per Second
\*\*1 MHz = 1,000,000 clock cycles per second

|                                      | 1971<br>(Intel<br>4004) | Today<br>(Intel Core i9) | Δ<br>(orders of<br>magnitude) |
|--------------------------------------|-------------------------|--------------------------|-------------------------------|
| MIPS*                                | ~0.09                   | ~400,000+                | +7                            |
| Instructions per clock cycle (1/CPI) | ~0.12                   | ~100+                    | +3                            |
| Clock frequency (MHz)**              | 0.74                    | ~5,000                   | +4                            |
| Cheap size (µm)                      | 10                      | 0.014                    | -3                            |

Moore's law: the number of transistors in a dense integrated circuit doubles about every two years

# Architectural Trends: Main Memory

|               | 1973<br>(DEC PDP-8) | Today<br>(Samsung DDR4) | Δ<br>(orders of<br>magnitude) |
|---------------|---------------------|-------------------------|-------------------------------|
| Capacity (kB) | 12                  | 128,000,000             | +7                            |
| Cost (\$/MB)  | ~400,000            | ~0.005                  | -8                            |

#### Architectural Trends: Disk

|               | 1956<br>(IBM RAMAC 305) | Today<br>(Western Digital) | Δ<br>(orders of<br>magnitude) |
|---------------|-------------------------|----------------------------|-------------------------------|
| Capacity (MB) | 5                       | 15,000,000                 | +7                            |
| Size (inch)   | 24 (x50)                | 3.5                        | -3                            |
| Cost (\$/MB)  | 640 (per month)         | ~0.000018                  | -9                            |

#### What's Next?

- Moore's law has hit its limit(?)
  - chip size has physical constraints
  - power vs. heat tradeoff
  - alternatives have already pushed forward the end of it:
    - multicore-manycore processors
  - other approaches are subject of research:
    - molecular/DNA transistors
    - quantum computing

• Basic roles of an Operating System

- Basic roles of an Operating System
- A brief recap of how computer systems are organized

- Basic roles of an Operating System
- A brief recap of how computer systems are organized
- Operating Systems as large and complex computer systems

- Basic roles of an Operating System
- A brief recap of how computer systems are organized
- Operating Systems as large and complex computer systems
- New architectural trends open up novel opportunities and challenges in Operating System design