

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

# Summary and Outlook

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

**HORST SCHIRMEIER** 



# **Agenda**

- Summary
- Evaluation
- Exam
- Outlook
- Get Involved



# **Agenda**

- Summary
- Evaluation
- Exam
- Outlook
- Get Involved



#### What We've Covered

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



## What We've Covered

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

1. An expedition through the architecture of the x86 PC



#### **Three Core Areas**





## What We've Covered

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



## What We've Covered

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

- Generalization to multiple interrupt levels:
  - Control flows on L<sub>f</sub> are
    - interrupted anytime by control flows on L<sub>a</sub>
    - never interrupted by control flows on L<sub>e</sub>
    - sequentialized with other control flows on
  - Control flows can switch levels
    - by special operations (here: modifying the s



2. Control flows and their interactions

#### Control-Flow Level Model: new

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

(for f < g)

(for  $e \le f$ )

- **interrupted anytime** by control flows on  $L_{\sigma}$  (for f < g)
- **never interrupted** by control flows on  $L_a$  (for  $e \le f$ )
- sequentialized with other control flows on L<sub>f</sub> (for f > 0)
- **preempted** by other control flows on  $L_f$  (for f = 0)

#### L<sub>a</sub> → Thread level

(interruptible, preemptible)

L₁ → Epilogue level

(interruptible, not preemptible)

L<sub>2</sub> → Interrupt level

(not interruptible, not preemptible)

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

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



#### **Three Core Areas**





## What We've Covered

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



#### **Three Core Areas**





# ... Altogether Quite A Lot!

Structure of the "OO-StuBS" operating system:





# **Agenda**

- Summary
- Evaluation
- Exam
- Outlook
- Get Involved



#### **Evaluation Results**

• [switch to evaluation PDF]

#### You have more to say?

→ Contact me

→ Use our "Anonymer Briefkasten"



# **Agenda**

- Summary
- Evaluation
- Exam
- Outlook
- Get Involved



## **Exam (1)**

#### Contents / Preparation

- All three core areas
- Exercises + lab tasks are also relevant
  - e.g. explain concepts from core areas 1 + 2 with implementation in OOStuBS
  - C++, x86 assembler
- Concepts are more important than learning stuff by heart

#### Exam appointments

- From Aug 5<sup>th</sup>
- Appointments: e-mail to sandy.seifarth-haupold@tu-dresden.de
   including module name and preferred appointment time frame
- (Withdrawal: until 14 days before the appointment)



## **Exam (2)**

#### Exam Procedure

- Closely **listen** to the question (ask if it was unclear!)
- Answer the question as completely and precisely as possible
- Feel free to anticipate follow-up questions
- If applicable: Use pen & paper (provided by us), make examples, refer to your OOStuBS implementation, ...
- Language: German or English (or, if necessary, a mix)



# **Agenda**

- Summary
- Evaluation
- Exam
- Outlook
- Get Involved



# **Challenge: New Memory Technologies**

NVRAM: New class of memory between SSD & RAM

- Almost as fast as DRAM
- Maintains its state if turned off
- Available for servers since 2019
  - Optane DCPMMs





#### **Research Questions:**

- File abstraction vs. direct, byte-wise access?
- Persistent data structures, processes, systems?
- Reliability? Reboot doesn't "fix" the system anymore!
- 1D memory hierarchy? *Demand Paging*?

#### Other emerging technologies:

Processing-in-memory (PIM)
High-bandwidth Memory (HBM)

OSC: L13 Summary and Outlool



**Challenge: Hardware Heterogeneity** 



- Common control-flow abstraction?
- How does scheduling work here?



## **Challenge: Manycore Hardware**

- Example: Fujitsu A64FX (#1 top500.org)
  - 48+4 cores (2.7 Tflops) per chip
  - 4 High-Bandwidth Memories (1 TB/s); 4 NUMA regions
  - 7.299.072 cores in the supercomputer
  - Remote DMA (RDMA) for communication



Fugaku supercomputer (Source: Fujitsu)

Processor structure (Source: heise.de)

13 cores



#### **Research Questions:**

- Do we still need CPU multiplexing?
- How to place control flows and data objects?



## Research Topics at the OS Chair

- Dealing with complexity
  - constructively (projects L4, M³)
  - analytically (project LockDoc)



- Non-functional properties
  - Security
  - Safety/fault tolerance (projects DanceOS, FAIL\*)



- Timing behavior
- Energy (project TETRiS)
- Hardware developments
  - Disruptive memory technologies (projects VAMPIR, FOSSIL)



## Complexity: Monolith vs. Microkernel



- Fine-grained locking is error-prone: LockDoc project
- Security: Take over a kernel component = Game Over
- but: Performance, lots of legacy code



- **L4Re** project
- Minimal, application specific
   Trusted Computing Base
- Constructive complexity control (divide & conquer)



# **Fault-Tolerant Operating Systems**

- Soft Errors can cause e.g. bit-flips in memory or the CPU
- How can we extend operating systems or design them ground-up – so that they still work?
  - DanceOS project



- How can we (systematically)
   determine whether we were
   successful?
  - Fault injection: FAIL\* project





Dealing with heterogeneous memories: VAMPIR project

- Latency, throughput, persistency, fault tolerance, wearout, energy

consumption, PIM capabilities, ...

Use case: databases

Predictions much easier!



MCDRAN

connected by 2D Mesh



VAMPIR project

```
struct fptree_leaf *p =
   nfp_malloc(N * sizeof(struct fptree_leaf),

   MP_PERSISTENT | MP_THROUGHPUT_HIGH | MP_FAULT_TOLERANT, WP_READ_90,
   usage_time(0, 30)
);
```

- Memory management for heterogeneous memories
- Harness application knowledge on future memory needs:

Memory Scheduling





- VAMPIR project
- Intel Xeon Max 9468 "Sapphire Rapids"
- per socket: 48 cores / 96 threads, 8 channel DDR-5 DRAM,
   4x HBM2e, 4x DSA







VAMPIR project \$\square{\qquare}\$





# **Agenda**

- Summary
- Evaluation
- Exam
- Outlook
- Get Involved



#### **Other Lectures**





## **Thesis Topics**

{Bachelor, Master, Diploma} theses, Beleg, Forschungsprojekt, ...

Empirical work → Build, measure, evaluate



#### We Need: Student Assistants

- **Tutors** for "Betriebssysteme und Sicherheit" (WS 24/25)
  - Duties:
    - Lead exercise sessions, discuss + collectively solve work sheets
    - Attend weekly staff meeting
    - Help prepare materials
  - Benefits:
    - Get to know the OS team better
    - Earn some €.
- Assistant in a Research Project
  - As required: Programming, literature research, measurements, etc.



#### That's It!

Thank you!
I hope we'll meet again.



tomorrow, Wednesday 2024-07-17 11:10 (E023)

Voting only possible in presence.