data:image/s3,"s3://crabby-images/7fe37/7fe37982cdeb28fec0940c16028e34193c02055e" alt="" | The concept of process
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | A process is a program in execution. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Each process has a unique identifier, which we refer to as
"process id". |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Some process identifiers are reserved for special purposes.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | 0 for scheduler, or the code for kernel activity.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The scheduler decides which processes to run and which should
wait. |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | 1 for init. created by the kernel after booting.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | init brings the UNIX to working condition, and may refer to rc
scripts in the /etc/directory. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The process is either in /etc or /sbin |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Now let's take a look at what Linux will do. |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | 2 for page daemon.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Sometimes called pager. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | A kernel process that supports virtual memory. |
|
|
|
data:image/s3,"s3://crabby-images/7fe37/7fe37982cdeb28fec0940c16028e34193c02055e" alt="" | Process information
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | getpid
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Get the process id. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | getppid
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Get the parent process id. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | getuid
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Get the user id of a process. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | geteuid
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Get the effective user id of a process. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | getgid
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Get the group id of a process. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | getegid
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Get the effective group id of a process. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Now let's write a program to print out these information. |
|
data:image/s3,"s3://crabby-images/7fe37/7fe37982cdeb28fec0940c16028e34193c02055e" alt="" | Process creation
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | fork function
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The fork function is the only way to create a process in a UNIX
environment. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The fork function is called once, but returned twice. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | A child process is created by calling the fork. The two processes
are identical except for the return value.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The parent process returns the child process id. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The child process returns 0. |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The two processes continue execution after calling fork. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The two processes DO NOT share data -- they are two copies of the
same program. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Now let's try the textbook example. fork1.c
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The variables are different copies. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The process ids are different. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | When we run it normally the "before fork" appears
only once. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | When the output is directed to a disk file, the "before
fork" appears twice. The reason is that when the disk I/O
is fully buffered, so the contents of standard I/O buffers are
copied from the parent to the child. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The write appears only once since it is not buffered (because
of write system call). |
|
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Information sharing
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Some information is shared between the parent and the child.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Open file descriptor and offsets. In that case two processes
can share a open file. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Various user and group ids. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Working directory. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Environment. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Resource limits. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Refer to table on page 192 for a complete list of entries that
the child inherits from the parent. |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Some data are different between parent and child.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Process id. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Return value from fork. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Refer to table on page 192 for a complete list of entries that
the child does not inherit from the parent. |
|
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Purpose of process creation
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | To create a duplicate copy.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | This is done by placing different sections of code after
checking the return value of the fork. |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | To run a different program.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | This is usually done by running a "exec" after the
fork. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The fork and the exec can be combined (sometimes called spawn)
to improve efficiency. |
|
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | vfork function
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | To run a program using the child. Notice that the child runs in
the addressing space of the parent and no memory copying is
necessary. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The child will run first, and the parent will wait for it. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The textbook example
vfork1.c
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Notice the values the parent prints out. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | What will happen if we replace the _exit with exit? |
|
|
|
data:image/s3,"s3://crabby-images/7fe37/7fe37982cdeb28fec0940c16028e34193c02055e" alt="" | Process termination
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | exit function
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | To terminate a process with an exit code. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Notice that this is a library, and _exit is a system call. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Normal termination
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The main program returns. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The program calls exit. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The program calls _exit. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Abnormal termination
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The program calls abort. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The program catches a signal. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | No matter how a process terminates, the same code is the kernel does
the following.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Close all open file descriptor. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Release memory. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Release process table entry. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | The exit code
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The exit code lets the child to notify the parent about the its
execution status. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The process reports exit status, to which the kernel might add
extra information and called termination status. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The termination code can be found from the wait family from the
parent. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Anomaly
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | When the parent terminates before the child, the init process
becomes the parent of this orphan process. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | When the child terminates before the parent, the child becomes a
zombie.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | A zombie is a dead entity, but not completely dead. :-) |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The child must leave sufficient information in the process
table so that later when its parent wants to fetch its status,
it is able to do so, |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The information a zombie keeps in the process table includes
process id, termination status, and accounting information. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | One can use ps to find out the status of all processes,
including zombies. |
|
|
|
data:image/s3,"s3://crabby-images/7fe37/7fe37982cdeb28fec0940c16028e34193c02055e" alt="" | Process synchronization
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | wait families
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | wait
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | A process can call wait to wait for the child process to
complete. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The wait function provides a integer buffer for receiving the
termination status. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The wait function will block if no child is available. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The return value is the process id of the child process. |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | waitpid
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | A process can call wait to wait for a particular child
process to complete. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The waitpid can be non-blocking. |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Termination status
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | There are a set of macros to retrieve information from the
termination status.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | WIFEXITED
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | true is the child terminates normally. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | WEXITSTATUS tells us the actual exit code. |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | WIFSIGNALED
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | true if the child process catches a signal and
terminates. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | WTERMSIG |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | WCOREDUMP |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | WIFSTOPPED
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | true if the process is stopped. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | WSTOPSIG |
|
|
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Now we try the textbook example wait1.c
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Can we generate the coredump file? |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Three cases are tested in this example.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | normal termination with exit. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | abnormal termination with abort. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | abnormal termination with arithmetic exception. |
|
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Another textbook example fork2.c.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The first child exits before the second, so that init will
adopt the second child. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | This is useful when the parent does not want to wait for the
child and we do not want the child to become a zombie either. |
|
|
|
data:image/s3,"s3://crabby-images/7fe37/7fe37982cdeb28fec0940c16028e34193c02055e" alt="" | Race condition
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Multiple processes running simultaneously could result very strange
errors. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | If the correctness of a program depends on the execution sequence of
consisting processes, then we have a race condition. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | The race condition is difficult to debug since the error may not
appear when we want it to. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | The (proc/fork2.c) example has a race condition.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | We cannot guarantee that the first child will exit first. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | If that happens, init will not adopt the second child. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Textbook example tellwait1.c
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The stdout is specifically changed to be unbuffered. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The outputs from parent and child are mingled together. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Process synchronization
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | To avoid race condition, we need to synchronize the processes. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | tellwait1.c gives an example of process synchronization. We will
discuss its implementation when we cover IPC and signals. |
|
|
data:image/s3,"s3://crabby-images/7fe37/7fe37982cdeb28fec0940c16028e34193c02055e" alt="" | Exec family
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | The exec family runs a specific program, which replaces the image of
the calling process. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | In Linux only the execve is a system call, and all the other are
library that were built on top of execve. See the figure on page 211 for
details. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Here is a list of all the functions.
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Here is the trick (page 209).
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | program filename
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | nothing means pathname |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | p means the file should be found from the path. |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | argument passing
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | l means the arguments are passed as argument list. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | v means the arguments are passed as a pointer array. |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | environment
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | nothing means the environment is from the environ variable. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | e means the environment is from the environment pointer array. |
|
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | When the program is given as a filename
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | No slash found
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Find it from PATH. |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Slash found
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Treated as a pathname. |
|
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Try the textbook example exec1.c
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The echoall.c echoes all command line arguments. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The main program runs the echoall program. |
|
|
data:image/s3,"s3://crabby-images/7fe37/7fe37982cdeb28fec0940c16028e34193c02055e" alt="" | Interpreter file
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | An interpreter file is the input to an interpreter. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | An interpreter file is a text file, not a binary executable. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | An interpreter file starts with "#!", then followed by the
name of the interpreter, then by the optional arguments. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | When the interpreter is a shell (in most cases it is), the interpreter
file is usually called a shell script -- namely a script that will be
run by the shell. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Try the text book example.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | We write an interpreter file testinterp, which will execute the
echoarg program.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Notice that the path name of the interpreter file is added as
the last argument (by the kernel), and passed to the interpreter
(in this case, echoarg). |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Now we compile and run exec2.c.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The exec2 executes the testinterp, which executes the echoarg. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Notice that the prompt disappeared! |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Now try to use awk as the interpreter.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | awk is a very useful script
interpreter. The basic syntax is "awk -f file", where
file is the name of the awk script. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Now we write an awk script to print the first word of every
line. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Now we try the textbook awk script that prints all the
arguments.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | There are several files here.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The interpreter program awk. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The interpreter file awkexample. |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | When the awkexample is evoked from a shell, the shell
creates a process, and executes the interpreter file. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The interpreter files then executes the interpreter (awk),
and use the '-f' mechanism to pass the name of the
interpreter file name as an arguments, along with other
command line arguments from shell. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Notice that the awk is given five parameters -- the '-f'
from the interpreter file, the pathname of the
interpreter file is given by the kernel, the last three
arguments are from the command line, then passed to
interpreter file awkexample. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | See page 220 for a complete illustration. |
|
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Reasons for using interpreter files.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Hide the fact that a command is a script, not a binary
executable. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Efficiency gain. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Write shell scripts other than for sh. |
|
|
|
data:image/s3,"s3://crabby-images/7fe37/7fe37982cdeb28fec0940c16028e34193c02055e" alt="" | system functions
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | A simple way to utilize system facility -- just like typing into a
shell. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | The return value tells whether the command is executed successfully or
not. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | system takes a command string and passes it to /bin/sh
for execution. Now exam the following implementation (system.c).
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | First we create a new process by fork. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Then we use execl to execute /bin/sh and ask it to run the command
string for us. The command string is passed to /bin/sh by way of -c
option. This option directs /bin/sh to take the command from the
string immediately after '-c' option. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Finally the system process waits for sh to complete. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Note that we use _exit instead of exit in the system process. |
|
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Now we try the textbook example (systest1.c). |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | system and setuid programs
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | A setuid program should never use system, since the effective uid
can be carried into the child process. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | Consider two files tsys and printuids.
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | tsys is a program that uses system to run the command given to
it. |
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | printuid is a program that prints the real and effective uids. |
|
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | If tsys has setuid bit on, then the printuids process will have
the effect of setuid. |
|
|
data:image/s3,"s3://crabby-images/7fe37/7fe37982cdeb28fec0940c16028e34193c02055e" alt="" | Process accounting
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | The superuser can turn the accounting on and record the accounting
information into a file. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | These information can be retrieved from the file by simple file I/O. |
|
data:image/s3,"s3://crabby-images/7fe37/7fe37982cdeb28fec0940c16028e34193c02055e" alt="" | Process times
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | The command time reports the time usage. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | The system call times retrieves the
time usage of a process and its children. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | The function returns the wall clock time each time it is called. |
data:image/s3,"s3://crabby-images/aa1e5/aa1e5cf8ecaac0e6849cdbf2f8b682b246155f69" alt="" | Now try the textbook example (times1.c).
data:image/s3,"s3://crabby-images/d5fc6/d5fc6353e3983ba8b033a9d1dcf4f2ded2ba6f11" alt="" | The function pr_times computes the difference between two tms
records and report the values. |
|
|