Linux Kernel Teaching¶
This is a collection of lectures and labs Linux kernel topics. The lectures focus on theoretical and Linux kernel exploration.
The labs focus on device drivers topics and they resemble “howto” style documentation. Each topic has two parts:
- a walk-through the topic which contains an overview, the main abstractions, simple examples and pointers to APIs
- a hands-on part which contains a few exercises that should be resolved by the student; to focus on the topic at hand, the student is presented with a starting coding skeleton and with in-depth tips on how to solve the exercises
This content is based on the Operatings Systems 2 course from the Computer Science and Engineering Department, the Faculty of Automatic Control and Computers, University POLITEHNICA of Bucharest.
You can get the latest version at http://github.com/linux-kernel-labs.
To get started build the documentation from the sources after installing docker-compose on you host:
cd tools/labs && make docker-docs
then point your browser at Documentation/output/labs/index.html.
Alternatively, you can build directly on the host (see tools/labs/docs/Dockerfile for dependencies):
cd tools/labs && make docs
Lectures
- Sisteme de operare 2
- Introduction- Lecture objectives:
- Basic operating systems terms and concepts- User vs Kernel
- Typical operating system architecture
- Monolithic kernel
- Micro kernel
- Micro-kernels vs monolithic kernels
- Address space
- User and kernel sharing the virtual address space
- Execution contexts
- Multi-tasking
- Preemptive kernel
- Pageable kernel memory
- Kernel stack
- Portability
- Asymmetric MultiProcessing (ASMP)
- Symmetric MultiProcessing (SMP)
- CPU Scalability
 
- Overview of the Linux kernel
 
- System Calls
- Interrupts
- Symmetric Multi-Processing- Lecture objectives:
- Synchronization basics
- Linux kernel concurrency sources
- Atomic operations
- Disabling preemption (interrupts)
- Spin Locks
- Cache coherency in multi-processor systems
- Optimized spin locks
- Process and Interrupt Context Synchronization
- Mutexes
- Per CPU data
- Memory Ordering and Barriers
- Read Copy Update (RCU)
 
- Debugging
Labs
- Infrastructure
- Introduction
- Kernel modules
- Kernel API
- Character device drivers
- I/O access and Interrupts
- Deferred work
- Block Device Drivers
- File system drivers (Part 1)
- File system drivers (Part 2)
- Networking
- Memory mapping
- Linux Device Model