

Fakultät Informatik Institut für Systemarchitektur, Professur für Betriebssysteme

## OPERATING-SYSTEM CONSTRUCTION

Material based on slides by Olaf Spinczyk, Universität Osnabrück

### Introduction

https://tud.de/inf/os/studium/vorlesungen/betriebssystembau

### **HORST SCHIRMEIER**





### Overview

- Organization
- Lecture Contents
- Exercise Contents



### **Overview**

- Organization
- Lecture Contents
- Exercise Contents



## **Learning Objective**

- Deepen knowledge on operating systems
  - Functionality
  - Structure
  - Implementation
- Learning By Doing: OO-StuBS
  - Develop an OS from scratch
  - Understand HW/SW interface and PC technology

Strong recommendation: Actively participate in the lab exercises, hand in solutions!

What I cannot create, I do not understand

– Richard Feynman



### Prerequisites

- You ...
- ... have **basic knowledge on OSs** (e.g. from BuS)
- ... like programming
  - C/**C++**, Assembler (x86)

## Don't panic!

- ... like programming **close to the hardware**
- ... like concurrency problems
- ... have a certain degree of **perseverance**





## Organization

#### • Lecture

(1.5h weekly, Tue 11:10–12:40, APB/E005)

### • Exercise

(1.5h weekly, Wed 11:10–12:40, APB/E040)

- In-depth interactive discussion of lecture topics, especially technical details
- Necessary technical background for practical exercises

#### • Lab

(0-3h weekly, Tue 14:50-16:20 and/or Wed 14:50-16:20, APB/E040)

- Work on exercise tasks in groups of 2–3 students with technical support
- Hand in + discuss your solutions
   (goal: maintain a working code base that doesn't break later in the semester)



### Exam

- Oral, after the semester
  - Don't miss the exam registration deadline with the examination office!
  - Contact sandy.seifarth-haupold@tu-dresden.de for an examination appointment – as early as possible!
  - Expect delays due to second-examiner synchronization (*Komplexprüfung*), vacation period etc.
- Topics: Lecture AND exercise content
- INF-PM-ANW or INF-PM-FOR, anyone?





## Hybrid Teaching / Communication

- Mailing list (subscribe!)
- Chat (also for you to freely use!):
   #betriebssystembau:tu-dresden.de
- Lecture + exercise: hybrid via BBB
  - Questions via BBB chat (presence audience: please relay!)
  - BBB-internal recordings (best effort, no guarantees)
- Lab: in presence; additionally online support via Matrix
- Feedback: in person (interrupt me!), or using above channels, or via our Anonymous Mailbox

| Feedback | via email, Matrix, or ou | 🕞 anonymous mailbox |
|----------|--------------------------|---------------------|
|          |                          |                     |



### **Teaching Staff**

- Horst Schirmeier
  - Lecture
  - Exercise
- Robin Thunig
  - Lab
  - Technical support



### Literature

- [1] A. Silberschatz and P. B. Galvin. *Operating System Concepts*. Addison-Wesley, 1994. ISBN 0-201-59292-4.
- [2] R. Love. *Linux Kernel Development (2<sup>nd</sup> Ed.)*. Novell Press, 2005.
- [3] R. G. Herrtwich and G. Hommel. Kooperation und Konkurrenz -Nebenläufige, verteilte und echtzeitabhängige Programmsysteme.
   Springer-Verlag, 1989. ISBN 3-540-51701-4.
- [4] M. E. Russinovich and D. A. Solomon. *Microsoft Windows Internals* (4<sup>th</sup> Ed.). Microsoft Press, 2005.
- [5] H.-P. Messmer, K. Dembowski. *PC-Hardwarebuch*.Addison-Wesley, 2003. ISBN 3-8273-2014-3.
- [6] Intel Corporation. *Intel Architecture Software Developer's Manual*. http://www.intel.com/



### Overview

- Organization
- Lecture Contents
- Exercise Contents



### **Overview: Lectures**

- L 1: Introduction
- L 2: Operating-System Development 101
- L 3: Interrupts Hardware
- L 4: Interrupts Software
- L 5: Interrupts Synchronization
- L 6: Intel®64: The 32/64-Bit Intel Architecture
- L 7: Coroutines and Threads
- L 8: Scheduling
- L 9: Thread Synchronization
- L 10: Inter-process Communication
- L 11: Bus Systems
- L 12: Device Drivers



## **OS Development (Not Always Comfy)**

### • First Steps

*How to get your OS onto the target hardware?* 

- Compilation/Linking
- Boot process

### Testing and Debugging

What to do if your system doesn't respond?

- "printf debugging"
- Emulators, virtual machines
- Debuggers
- Remote Debugging
- Hardware support



### **Overview: Lectures**

- L 1: Introduction
- L 2: Operating-System Development 101
- L 3: Interrupts Hardware
- L 4: Interrupts Software
- L 5: Interrupts Synchronization
- L 6: Intel®64: The 32/64-Bit Intel Architecture
- L 7: Coroutines and Threads
- L 8: Scheduling
- L 9: Thread Synchronization
- L 10: Inter-process Communication
- L 11: Bus Systems
- L 12: Device Drivers



### Interrupts

- ... in general
  - Vector tables
  - Spurious interrupts
  - Nested interrupts
- ... in the PC
  - PIC and APIC
  - Interrupts in multi-processor systems
  - IDT



## The Intel CPU Programming Model

- x86: History and developments
- Relics
  - 8086 Real Mode,
     A20 Gate
- Protected mode, protection rings
- Task model





### **PC Bus Systems**

- Architecture and programming
- Local buses
  - PCI and PCI Express
  - AGP
  - AMD HyperTransport
  - Intel QPI





### **Overview: Lectures**

- L 1: Introduction
- L 2: Operating-System Development 101
- L 3: Interrupts Hardware
- L 4: Interrupts Software
- L 5: Interrupts Synchronization
- L 6: Intel®64: The 32/64-Bit Intel Architecture
- L 7: Coroutines and Threads
- L 8: Scheduling
- L 9: Thread Synchronization
- L 10: Inter-process Communication
- L 11: Bus Systems
- L 12: Device Drivers

2. Control flows and their interactions



## Interrupt Synchronization

 Interplay between interrupt handling and "normal" control flow

### 2. Control flows and their interactions

- Hardware mechanisms
  - "Hard synchronization"
- Software mechanisms
  - "Nonblocking synchronization"
  - Pro-/epilogue model
  - Interrupt transparency

### **Control-Flow Level Model**

- Generalization to multiple interrupt levels:
  - Control flows on L<sub>f</sub> are
    - **interrupted anytime** by control flows on  $L_g$  (for f < g)
    - **never interrupted** by control flows on  $L_e$  (for  $e \le f$ )
    - sequentialized with other control flows on L<sub>f</sub>
  - Control flows can switch levels
    - by special operations (here: modifying the status register)





### Threads

- Implementing threads on x86
  - Implementing context switches
  - Basis: Coroutines
  - Preemptive scheduling
- Thread models
  - lightweight vs.
     heavyweight vs.
     featherweight

### Control-Flow Level Model: new

• Control flows on L<sub>f</sub> are

| - | <b>interrupted anytime</b> by control flows on L <sub>g</sub>    | (for <i>f</i> < g)  |
|---|------------------------------------------------------------------|---------------------|
| - | <b>never interrupted</b> by control flows on L <sub>e</sub>      | (for e ≤ <i>f</i> ) |
| - | <b>sequentialized</b> with other control flows on L <sub>f</sub> | (for f > 0)         |
| _ | <b>preempted</b> by other control flows on L <sub>f</sub>        | (for f = 0)         |

 $\begin{array}{l} \textbf{L}_{0} \rightarrow \textbf{Thread level} \\ (interruptible, preemptible) \\ \textbf{L}_{1} \rightarrow \textbf{Epilogue level} \\ (interruptible, not preemptible) \\ \textbf{L}_{2} \rightarrow \textbf{Interrupt level} \\ (not interruptible, not preemptible) \end{array}$ 

Control flows on level L<sub>0</sub> (thread level) are **preemptible**.

2. Control flows and their

interactions

To maintain consistency on this level, we need additional mechanisms for **thread synchronization**.



### **Thread Synchronization**

Blocking vs. non-blocking

```
2. Control flows and their 
interactions
```

- Multiprocessor thread synchronization
- Semaphor the ultimate synchronization primitive?
- Specific problems
  - Interrelationship between synchronization and scheduling
  - Deadlocks revisited



### Inter-process communication (IPC)

 Abstractions beyond semaphor and message

2. Control flows and their interactions

- Relationship between IPC and synchronization
  - real-world examples
- Duality of message-oriented and procedure-oriented systems
  - Lauer & Needham



### **Overview: Lectures**

- L 1: Introduction
- L 2: Operating-System Development 101
- L 3: Interrupts Hardware
- L 4: Interrupts Software
- L 5: Interrupts Synchronization
- L 6: Intel®64: The 32/64-Bit Intel Architecture
- L 7: Coroutines and Threads

#### L 8: Scheduling

- L 9: Thread Synchronization
- L 10: Inter-process Communication
- L 11: Bus Systems

#### L 12: Device Drivers

3. OS concepts in general and in Linux/Windows



## Scheduling

- Recapitulation, deepening
  - Basic principles and classification
- Scheduling and interrupt synchronization
- Scheduling in multiprocessor systems
- Case studies: Linux and Windows

## 3. OS concepts in general and in Linux/Windows





## **Device Programming**

### 3. OS concepts in general and in Linux/Windows

- Variety of typical PC devices and problems
  - Mouse, hard disk, hardware-accelerated graphics cards
- Driver models
- real-world I/O systems
  - Windows, Linux





### Overview

- Organization
- Lecture Contents
- Exercise Contents



### **Overview: Exercise and Lab**

Structure of the "OO-StuBS" operating system:





### **Overview: Exercise and Lab**

Programming tasks:













### **Operating-System Construction**

# See you tomorrow in the first exercise!