740 likes | 886 Views
Chapter 4 Processes. Outline. Process Concept Process Scheduling Operations on Processes Cooperating Processes Interprocess Communication Communication in Client-Server Systems. Process Concept (1). Process ( job ): a program in execution (informally). the unit of work in most systems
E N D
Outline • Process Concept • Process Scheduling • Operations on Processes • Cooperating Processes • Interprocess Communication • Communication in Client-Server Systems os4
Process Concept (1) • Process (job): a program in execution (informally). • the unit of work in most systems • A system consists of a collection of processes (system processes and user processes) executing concurrently, with CPU multiplexed among them • A process is more than the program code (known as the text section). It also includes: (more formal definition) • current activity (program counter, content of registers) • stack containing temporary data (e.g., parameters) • data sectioncontaining global variables • a set of associated resources. os4
Process Concept (2) • program counter: next instruction to be executed • A program is a passive entity but a process is an active entity • Two processes may be associated with the same program, they are considered asseparate execution sequences. • They have the same text section, but their data section will vary. e.g., several users may running the copies of the mail/editorprogram. • A process may spawn many processes as it runs. os4
Process State • Process state • new: the process is being created • running: instructions are being executed • waiting: the process is waiting for some event to occur (such as an I/O completion or reception of a signal) • ready: The process is waiting to be assigned to a processor • terminated: The process has finished execution • Only one process is running on any processor at any instant. However, many processes may be ready or waiting. os4
Diagram of Process State terminated interrupt admitted new exit ready running scheduler dispatch I/O or event completion I/O or event wait waiting os4
. . . Process Control Block (PCB) to next PCB • Each process control block (task control block) represents a process. It includes • process state (N, R, T, W, Run) • program counter • CPU registers • CPU scheduling information (e.g., priority) • memory-management information (e.g., base/limit register) • accounting information • I/O status information process pointer state process number program counter registers memory limits list of open files os4
CPU Switching process P0 operating system process P1 interrupt or system call executing . . . . . save state into PCB0 . . . . . . . . . . . idle . . . . . reload state from PCB1 . . . executing . idle interrupt or system call . . . . . . . save state into PCB1 . . . . . . idle . . . . executing reload state from PCB0 os4
Threads • Thread • Sometimes is called a lightweight process: is a basic unit of CPU utilization; it comprises a thread ID, a program counter, a register set, and a stack. • It shares with other threads belonging to the same process its code section, data section, and other OS resources, such as open files and signals. • A web browser might have one thread display images or text while another thread retrieves data from the network. • Modern OS has extend the process concept to allow a process to have multiple threads of execution. os4
Process Scheduling • Objective of multiprogramming: CPU runs process at all times to maximize CPU utilization. • Objective of time sharing: switch CPU frequently such that users caninteract with each program while it is running. • For a uni-processor system, there is only one running process. The rest should wait until CPU free and is rescheduled. os4
Scheduling Queues • Scheduling queues • job queue: containing all processes • ready queue • usually, stored as a linked list • device queues: each containing processes waiting for it • Queuing diagram: a common representation for process scheduling • rectangle: queue • circle: server for a queue • arrow: flow os4
ready queue PCB7 PCB2 head registers registers tail mag tape head unit 1 tail PCB8 PCB3 PCB14 disk head registers registers registers unit 0 tail PCB6 terminal head registers unit 0 tail Ready queue and various I/O device queues os4
time slice expired child Child fork a child terminates executes interrupt wait for an INT occurs Queuing-diagram Representation of Process Scheduling CPU ready queue each device has one I/O queue I/O I/O request os4
Schedulers (1) • Long-term Scheduler (job Scheduler): selecting processes from the job pool and loads them into memory for execution. • Execute less frequently (e.g., once several minutes) • Control the degreeof multiprogramming • Select a good process mixof I/O-bound processes and CPU-boundprocesses • Some system, such as time-sharing system, do not have. Their multiprogramming degree are controlled by hardware limitation (e.g., # of terminals) or on the self-adjusting nature of users. os4
end long-term short-term CPU ready queue I/O queue(s) I/O Schedulers (2): Short-term scheduler (CPU scheduler) • selecting one of the ready processes, and allocates the CPU to it. • Execute quite frequently (e.g., once per 100ms) • must be very fast e.g., if it takes 10 ms, then 10/(100+10) percent of CPU is wasted. os4
swap out swap in partially executed swapped-out processes CPU ready queue I/O waiting I/O Schedulers (3): Medium-term Scheduler (Swapping) • swap out: removing processes from memory to reduce the degree of multiprogramming. • swap in: reintroducing swap-out processes into memory • for improving process mix or for memory not enough medium-term os4
Schedulers (4) • context switch: saving the state of the old process and loading the saved state of the new process. • This is a pure overhead • switch time (about 1~1000 ms) depends on • memory speed • number of registers • existence of special instructions e.g., a single instruction to save/load all registers • hardware support e.g., multiple sets of registers os4
P1 P2 P3 P4 P4 P5 Operation on Processes: Creation and Termination • Process creation • A parent process creates children processes via a system call (such as fork in UNIX) • A child process may obtain resource by 1. ask new ones from OS, or 2. use a subset of its parent’s J: prevent system overloading (by too many sub-processes) process graph (a tree) os4
Two possibilities of execution • parent execute concurrently • parent waits until some/all children terminate. • Two possibilities of the address space of the new process • The child process is a duplicate of the parent process. (communication via sharing variables) • The child process has a program loaded into it. (communication via message passing) e.g., UNIX : both (fork, execve) DEC VMS: load Windows/NT: both os4
Process termination • two termination system calls • exit (parent can use wait to get the output) • abort: usually only the parent can abort a child (except OS). The reasons may be: • the child has exceeded its usage of some resources • the assigned task is no longer required • the parent is exiting, and OS does not allow its children to continue cascading termination (initiated by OS): a terminated process causes all its children (and their children in turn) to terminate. os4
Cooperating Processes • Two type of processes • independent process: not affect or be affected by others • cooperating processes • reasons: • information sharing (a shared file) • computation speedup (CPUs, I/O channels) • modularity (construct a system in a modular fashion) • convenience (A user can performs several tasks at one time (editing, printing, compiling)) • need communication/synchronization mechanisms os4
An Example: The producer-consumer problem • producer produces items (into buffer) for consumer e.g., print program printer driver compiler assembler loader • unbounded-buffer problem • producer: no wait • consumer: wait when buffer is empty • bounded-buffer problem • producer: wait when buffer is full • consumer: wait when buffer is empty os4
A shared-memory solution for synchronization • implement the buffer as a circular array var buffer: array[1..n] of item; in, out: 0..n-1; (initialized to 0) • next free: in • first full: out • empty: in=out • at most n-1 items out in os4
Shared-memory solution for the producer-consumer problem Import java.util.*; Public class BoundedBuffer { public BoundedBuffer () { // Buffer in initially empty count = 0; in = 0; out = 0; buffer = new Object[BUFFER_SIZE]; } // producer calls this method public void enter (Object item) { // in next slice} // consumer calls this method public Object remove() { // in next slice} public static final int NAP_TIME = 5; private static final int BUFFER_SIZE = 5; private volatile int count; private volatile int in; //points to the next free position private volatile int out; //points to the next free position private Object [] buffer; os4
public Object remove () { Object item; while (count == 0) ; // do nothing // remove an item from the buffer - -count; item == buffer[out]; out = (out + 1) % BUFFER_SIZE; if (count == 0) system.out.println(“Consumer Consumed “ + item + “ Buffer EMPTY”); else system.out.println(“Consumer Consumed “ + item + “ Buffer Size” + count); return item; } public void enter(Object item) { while (count == BUFFER_SIZE) ; // do nothing // add an item to the buffer ++count; buffer[in] = item; in = (in + 1) % BUFFER_SIZE; if (count == BUFFER_SIZE) system.out.println(“Producer Entered “ + item + “ Buffer FULL”); else system.out.println(“Producer Entered “ + item + “ Buffer Size” + count); } remove() os4 enter()
Inter-process Communication (IPC) • Two ways for communication • shared-memory (e.g., thread facility) • IPC (e.g., message-passing system) • An IPC provides a mechanism to allow processes to communicate and to synchronize their actions without sharing the same address space. • An IPC is particularly useful in a distributed environment where communicating processes may reside on different computers connected with a network. chat on WWW. • An IPC facility provides at least two operations: send(message) receive(message) os4
Naming • Several methods for logically implementing a link and the send/receive operations: • Direct or indirect communication • Symmetric or asymmetric communication • Automatic or explicit buffering • Send by copy or send by reference • Fixed-sized or variable-sized messages Buffering os4
Naming: direct communication • Use process identities (symmetry in addressing) send(P, message) receive(Q, message) • Asymmetry (receiving from any process) send(P, message) receive(id, message) • Properties • A link is established automatically between every pair of processes. • A link is associated with exactly two processes. • Between each pair of processes, there exists exactly one link. identity from whom os4
The producerprocess The consumer process repeat ... produce an item in nextp ... send(consumer,nextp); until false; repeat receive(producer,nextc); ... consume the item in nextc ... until false; • The link may be unidirectional, but is usually bidirectional. • Example: a solution to the producer-consumer problem • L: limited modularity: if the name of a process is changed, all old names should be found. It is not easy for separate compilation. os4
Naming: indirect communication • Use mailboxes(or calledports, each has a unique id). send(A, message) receive(A, message) • Properties of such a link: • A link is established between every pair of processes only if they have a shared mailbox. • A link may be associated with more than two processes. • Between each pair of communicating processes, there may be a number of different links, each corresponding to one mailbox. os4
The link may be either unidirectional or bidirectional. • One Problem: Which process, P2 or P3, will receive the message sent by P1? Solutions: • Allow a link to be associated with at most two processes. • At most one process at a time to execute a receive operation. • The OS arbitrarily selects one (not both). receive P2 send P1 (2) mailbox A (1) receive P3 os4
Synchronization • Message passing may be either blocking or nonblocking – and also as synchronous and asynchronous. • Blocking send: SP is blocked until the message is received by RP or by the mailbox. • Nonblocking send: SP sends the message and resumes operation. • Blocking receive: RP is blocked until the message is available. • Nonblocking receive: RP receives a valid message or a null. os4
Buffering No buffering • Capacity of a link: the number of messages that can reside (queued) temporarily. • Three ways for implementation: • zero capacity:queue length = 0. • The sender must wait until the recipient receives the message. • This synchronization is called arendezvous. • bounded capacity: queue length = n. • Sender should wait if queue is full. • unbounded capacity. • The sender is never delayed. Automatic buffering os4
In nonzero-capacity cases, two processes communicateasynchronously. • For asynchronous communication, one way to make sure (or to wait) that the receiver has received the sent message is as follows. process P (sender) send(Q, message) receive (Q, message) process Q (receiver) receive(P, message) send(P,acknowledgement") os4
The buffer is implemented using the java.util.Vector class (unbounded capacity) Note: both the send() and receive() are nonblocking A multi-thread version is discussed in Chapter 5. import java.util.*; public class MessageQueue { public MessageQueue() { queue = new Vector (); } //This implements a nonblocking send public void send(Object item) { queue.addElement(item); } //This implements a nonblocking receive public void receive() { object item; if (queue.size() == 0) return null; else { item = queue.firstElelemt(); queue.removeElementAt(0); return item; } } private Vector queue; } Production-Consumer Example –Mailbox for message passing os4
MessageQueue mailBox; While (true) { Date message = new Date(); mailBox.send (message); } The producer process MessageQueue mailBox; While (true) { Date message = (Date) mailBox.receive (); if (message != null) //consume the message } The consumer process os4
An Example: Mach • Developed at Carnegie Mellon University • Most communications are carried out by messages. Message are sent to and received from mailboxes, called ports. • Even system calls are made by messages. When each task is created, two special mailboxes – the Kernel mailbox and the Notify mailbox – are also created. • The Kernel mailbox is used by the kernel to communication with the task. The kernel sends notification of event occurrences to the Notify port. os4
Three system calls using message transfer • msg_send: sends a message to a mailbox • msg_receive • msg_rpc: Remote Procedure Calls (PRCs) • port_allocate: creates a new mailbox and allocates space for its queue of messages. The task that creates the mailbox is that mailbox’s owner. • Messages are copied into mailbox. Multiple messages from the same sender are queued in FIFO order. • If the mailbox is full, the sending thread has 4 options: • Wait indefinitely until there is a room in the mailbox. • Wait at most n milliseconds. • Do not wait at all, but rather return immediately. • Temporarily cache a message. os4
The receive operation must specify from which mailbox or mailbox set to receive a message. • port_status: returns # of messages in a given mailbox. • If no message is waiting to be received, the receiving thread may wait, wait at most n milliseconds, or not wait. • The Mach message system attempts to avoid double copy operations by using virtual-memory management techniques. Mach maps the address space containing the sender’s message into the receiver’s address space. os4
Process Control Block (PCB) Information associated with each process. • Process state • Program counter • CPU registers • CPU scheduling information • Memory-management information • Accounting information • I/O status information os4
Process Scheduling Queues • Job queue – set of all processes in the system. • Ready queue – set of all processes residing in main memory, ready and waiting to execute. • Device queues – set of processes waiting for an I/O device. • Process migration between the various queues. os4
Schedulers • Long-term scheduler (or job scheduler) – selects which processes should be brought into the ready queue. • Short-term scheduler (or CPU scheduler) – selects which process should be executed next and allocates CPU. os4
Schedulers (Cont.) • Short-term scheduler is invoked very frequently (milliseconds) (must be fast). • Long-term scheduler is invoked very infrequently (seconds, minutes) (may be slow). • The long-term scheduler controls the degree of multiprogramming. • Processes can be described as either: • I/O-bound process– spends more time doing I/O than computations, many short CPU bursts. • CPU-bound process– spends more time doing computations; few very long CPU bursts. os4
Context Switch • When CPU switches to another process, the system must save the state of the old process and load the saved state for the new process. • Context-switch time is overhead; the system does no useful work while switching. • Time dependent on hardware support. os4