Parallel Programming in C for Linux and POSIX Platforms (LNXPR3)
Unix-like systems, Linux - programming
Linux and UNIX platforms provide comprehensive support for multiprocessing and multithreading, along with tools for synchronization, communication, and resource sharing. While the ISO C library focuses primarily on threading, the UNIX environment traditionally supports parallelism through processes. Many POSIX features are available for both processes and threads, enabling the development of high-performance, parallel applications.
This course offers an in-depth exploration of operating system features related to network connections, inter-process communication, and shared memory. Participants will learn how to effectively utilize these tools and understand how kernel-provided mechanisms integrate to deliver powerful parallel programming capabilities.
Location, current course term
Contact us
The course:
Hide detail
-
High-performance parallel applications
-
Varying approaches to parallelism
-
UNIX application development with POSIX.1-2024
-
Cross-platform parallelism in C11 and C23
-
Inter-process communication
-
Multiprocessing with POSIX API
-
Mechanisms provided by the operating system
-
Custom solutions for IPC
-
Sockets and message queues
-
Talking to forked processes
-
Local client-server architecture
-
Cluster and remote communications
-
Shared memory communication
-
Bypassing the kernel with POSIX and SystemV
-
Forking and client-server variants
-
Memory access synchronization via semaphores
-
Threaded communication
-
Why are people afraid of threads
-
Advantages of threaded applications
-
Thread synchronization
-
Hybrid synchronization mechanisms
-
Mechanisms for both threads and processes
-
Linux inter-task communication
-
Real-time consideration
-
Locking and blocking
-
Mutexes, condition variables
-
Semaphores and Linux futexes
-
Deadlocks and other issues
-
Lock-free synchronization
-
Atomic operations and variables
-
Memory ordering and fencing
-
Data structure examples
-
High-performance operation
-
Large numbers of file descriptors
-
Event multiplexing mechanisms
-
Playing nice with the scheduler
-
Debugging parallel applications
-
Debugging threads and processes
-
Data access coherence and heisenbugs
-
Memory allocation coherence
-
Assumed knowledge:
-
Knowledge of the C language, basic orientation in programming in Unix systems and user knowledge of working with the Unix/Linux systém
-
Recommended previous course:
-
Operating System Interface on Linux and POSIX Platforms (LNXPR2)
-
Schedule:
-
3 days (9:00 AM - 5:00 PM )
-
Language:
-