Professional Documents
Culture Documents
2
Processes and Threads
Part 1 (2 slots)
Chapter 2- part 1
Processes
Threads
InterProcess Communication (IPC)
OS
Introduction
2.1- Processes
– Definition
– The process model
– Process creation
– Process hierarchies
– Process Termination
– Process States
– Transition States
– Implementation of Processes
– Degree of multiprogramming
0 1 2 …. … … … … n-1
PCBs
Implementation of Processes …
• Interrupt handling and scheduling are summarized
– Definition
– The process model
– Process creation
– Process hierarchies
– Process Termination
– Process States
– Transition States
– Implementation of Processes
– Degree of multiprogramming
Threads: Overview…
• It is desirable to have multiple threads of control in the same
address space running in quasi-parallel (gần như song song), as
though they were separate processes.
• Having multiple threads running concurrently within a process is
analogous to having multiple processes running in parallel in one
computer (mutithreading technique).
Thread
switching
Threads: Multithreading
• A support of OSs that allows multiple threads of
execution within a single process.
• MS-DOS supports a single-thread process.
• UNIX supports multiple user processes but only
supports one thread per process.
• Windows 2000, Solaris, Linux, Mach, and OS/2
support multiple threads.
• Multithread is really effective in multiprocessors
because the thread can execute in concurrently.
• …
Processes - Threads - Part1 (80 slides) 28
OS
2.2.3- Threads: Models
• Advantages
– Faster: Thread switching and scheduling is faster (because it’s
done at user mode) than to trapping the kernel mode.
– Flexible, scale better: Each process can have its own
customized scheduling algorithm. It can vary the table space
and stack space in flexibility.
• Disadvantages
– The implementation of blocking system calls is complexity
→ instead of blocking thread, the process is blocked
– The need that a thread voluntarily gives up the CPU → The
OS doesn’t know this, so if any user-level thread is
blocked, the entire process is blocked
– Developers want threads precisely in applications → make
system call constantly.
• Advantages
– The kernel can switch between threads belonging to
different processes No problem with blocking
system calls.
– Useful if multiprocessor support is available
(multiple CPUs).
• Disadvantages
– Greater cost (time and resources to manage threads
create and terminate).
– Thread creation, saving is slow (needs system call).
• Combine the
advantages of
user-level
threads with
kernel-level
threads.
Tanenbaum, Fig. 2-17.
Scheduler Activations…
• The runtime system maintains a list of threads.
• Scheduler Activation mechanism in Kernel
(OS maintains a list of threads in kernel)
– When a thread has blocked, the kernel make the upcall to the
process’s runtime system (in user mode) to inform this event.
– Later, when the blocked thread, that has marked, is ready and can
run again, the kernel make another upcall.
– The runtime system can either restart the blocked thread
immediately or put in on the ready list to be run later.
• The user mode can re-schedule its threads by
(The runtime system maintains a list of threads)
– Marking the current thread as blocked.
– Taking another thread from ready list, loading and restarting it.
The scheduler is activated whenever a change occurs in
the process table or in the thread table
Processes - Threads - Part1 (80 slides) 39/79
OS
Scheduler Activations…
Single-Threaded Multithreaded..
• Solutions
– Prohibit global variables altogether → conflicts with much existing
software (modifying is impossible)
– Assign each thread its own private global variables using private
copy (parametered fuctions) → allocate a chunk of memory for
global variables and pass it to each procedure in the thread as an
extra parameter
– Use the library procedures with some methods as create_global,
set_global, read_global (serial accessing, synchronized methods in
Java) → many libraries are not reentrant
• Provide each procedure with a jacket that sets a bit to mark the library as in use
→ eliminates potential parallelism.
• Consider signals → are difficult to enough to manage a single threaded
environment.
Stack management with many stack that can be grown.
Processes - Threads - Part1 (80 slides) 42/79
OS
Threads Summary
– Definitions: Thread, Multi-Threading
– Properties
– Models
– Benefit
– Implementing threads in User Space
– Implementing threads in the Kernels
– Hybrid Implementations
– Pop-up Threads
– Scheduler Activations
– Pop-Up threads
– Making Single Threaded Code Multithreaded
• Correctness requirements:
– Never more than one person buys milk .
– Someone buys if needed.
• This solution of this case (mutual exclusion) is called an
synchronization.
Processes - Threads - Part1 (80 slides) 52/79
OS
Busy Waiting: Disabling Interrupts
Interrupt: A signal is sent to CPU from an IO device to
announce that an IO operation terminated.
// Code of a thread
while(TRUE) {
while (lock == 1); //waiting until lock is set to 0
lock = 1; // set the flag on to enter the CR
critical_region(); // enter the CR
lock = 0; // clear the flag just before going out the CR
nonCritical_region(); // going out the CR
}
Code of
the Code of
Process 0 the
Process 1
Uses 3 semaphores
– full: counting the full
slots (0)
– empty: counting the
empty slots (n slots)
– mutex: make sure the
producer and
consumer do not
access the buffer (1)
2.3.7- Mutexes
• Mutex: Binary flag (binary semaphore. Good for managing
mutual exclusion to some shared resource or piece of code (it is
easy and efficient to implement using thread in user mode)
• A mutex is a variable that can be in one of two states
– unlocked (0): the calling threads is free to enter the critical region
– locked (1): the calling thread is blocked until the thread in the critical
region is finished (busy)
• Two procedures are used
– mutex_lock: is called when a thread needs access to a critical region
– mutex_unlock: is called when a thread in the critical region is finished
2.3.8- Monitors
• Is a proposal of Brinch Hansen (1973) and Hoare (1974)
• Is a collection of procedures, variables, and data structures that are
all grouped together in a special kind of module or package
• Processes may call the procedures in a monitor whenever they
want to, but they cannot directly access monitor‘s internal data
structures from procedures declared outside the monitor
(encapsulation)
• Only one process can be active in a monitor at any moment
(mutual exclusion)
• Monitors are programming language constructs
• When a process calls a monitor procedure, it must check to see if
any other procedure in currently active within monitor. If so, the
calling process is suspended until the other leaves. Otherwise, it enters the
monitor
• Monitor are implemented using
– Mutual exclusion in monitor is ensured by the compiler
– Condition variables: provide the possibility of waiting
Processes - Threads - Part1 (80 slides) 70/79
OS
Monitors: Condition Variables
Encapsulation
2.3.10- Barriers
• Is intended for groups of processes rather than two process
producer-consumer type situations
• The applications are divided into phases and have the rule that
no process may proceed into the next phase until all processes
are ready to proceed to the next phase.
• This behavior may be archived by placing a barrier at the end
of each phase. When a process reaches the barrier, it is blocked
until all processes have reached the barrier.
Tanenbaum,
Processes - Threads Fig.slides)
- Part1 (80 2-37. 76/79
OS
InterProcess Communication (IPC)
Summary
– Overview
– Race Conditions
– Critical Regions
– Mutual Exclusion with Busy Waiting:
(Disable Interrupts, Lock Variables, Strict Alternative, Peterson’s
solution, TSL instructions)
– Sleep and wakeup
– Semaphores
– Mutexes
– Monitors
– Message Passing
– Barriers
Summary
• Processes
• Threads
• InterProcess Communication
Q&A