Process Management I
CS 351: Systems Programming Michael Saelee <lee@iit.edu>
1
Process Management I CS 351: Systems Programming Michael Saelee - - PowerPoint PPT Presentation
Process Management I CS 351: Systems Programming Michael Saelee <lee@iit.edu> 1 Computer Science Science Creating Processes 2 Computer Science Science #include <unistd.h> pid_t fork (); 3 Computer Science Science fork
CS 351: Systems Programming Michael Saelee <lee@iit.edu>
1
Computer Science Science
2
Computer Science Science
3
Computer Science Science
4
Computer Science Science
5
Computer Science Science
int main () { fork(); foo(); }
6
Computer Science Science
int main () { fork(); foo(); }
7
Computer Science Science
int main () { fork(); foo(); }
int main () { fork(); foo(); }
creates
8
Computer Science Science
int main () { fork(); foo(); }
int main () { fork(); foo(); }
9
Computer Science Science
10
Computer Science Science
int main () { fork(); printf("Hello world!\n"); } Hello world! Hello world!
11
Computer Science Science
int main () { fork(); fork(); printf("Hello world!\n"); } Hello world! Hello world! Hello world! Hello world!
12
Computer Science Science
int main () { fork(); fork(); fork(); printf("Hello world!\n"); } Hello world! Hello world! Hello world! Hello world! Hello world! Hello world! Hello world! Hello world!
13
Computer Science Science
int main() { while(1) fork(); }
14
Computer Science Science
# processes waiting to be scheduled
15
Computer Science Science
16
Computer Science Science
void fork0() { int pid = fork(); if (pid == 0) printf("Hello from Child!\n"); else printf("Hello from Parent!\n"); } main() { fork0(); } Hello from Child! Hello from Parent! Hello from Parent! Hello from Child!
17
Computer Science Science
18
Computer Science Science
void fork1 () { int x = 1; if (fork() == 0) { printf("Child has x = %d\n", ++x); } else { printf("Parent has x = %d\n", --x); } } Parent has x = 0 Child has x = 2
19
Computer Science Science
20
Computer Science Science
void fork2() { printf("L0\n"); fork(); printf("L1\n"); fork(); printf("Bye\n"); } L0 L1 L1 Bye Bye Bye Bye
21
Computer Science Science
void fork2() { printf("L0\n"); fork(); printf("L1\n"); fork(); printf("Bye\n"); }
22
Computer Science Science
void fork2() { printf("L0\n"); fork(); printf("L1\n"); fork(); printf("Bye\n"); } L1 L0 L1 Bye Bye Bye Bye
Which are possible?
L0 L1 Bye Bye L1 Bye Bye L0 L1 Bye Bye Bye L1 Bye L1 Bye Bye L0 L1 Bye Bye L0 Bye Bye L1 L1 Bye Bye
A. B. C. D. E.
23
Computer Science Science
main() { fork(); fork(); while(1) ; } $ ./a.out & [1] 8198 $ pstree -p 8198 a.out(8198)a.out(8199)a.out(8201) a.out(8200)
24
Computer Science Science
void fork3() { printf("L0\n"); fork(); printf("L1\n"); fork(); printf("L2\n"); fork(); printf("Bye\n"); }
25
Computer Science Science
void fork4() { printf("L0\n"); if (fork() != 0) { printf("L1\n"); if (fork() != 0) { printf("L2\n"); fork(); } } printf("Bye\n"); } L0 L1 L2 Bye Bye Bye Bye L0 L1 Bye Bye L2 Bye Bye Bye L0 Bye L1 Bye L2 Bye L0 Bye L1 Bye L2 Bye Bye L0 L1 Bye Bye Bye L2 Bye
A. B. C. D. E.
26
Computer Science Science
void fork4() { printf("L0\n"); if (fork() != 0) { printf("L1\n"); if (fork() != 0) { printf("L2\n"); fork(); } } printf("Bye\n"); }
27
Computer Science Science
void fork5() { printf("L0\n"); if (fork() == 0) { printf("L1\n"); if (fork() == 0) { printf("L2\n"); fork(); } } printf("Bye\n"); }
28
Computer Science Science
29
Computer Science Science
30
Computer Science Science
#include <errno.h> extern int errno; /* get error string */ char *strerror(int errnum); /* print error string w/ message */ void perror(const char *s);
31
Computer Science Science
int fd = open("/etc/shadow", O_RDONLY); if (fd == -1) { perror("Uh-oh"); exit(1); } $ ./errtest Uh-oh: Permission denied
32
Computer Science Science
$ man errno NAME errno - number of last error SYNOPSIS #include <errno.h> DESCRIPTION ... E2BIG Argument list too long (POSIX.1) EACCES Permission denied (POSIX.1) EADDRINUSE Address already in use (POSIX.1) EADDRNOTAVAIL Address not available (POSIX.1) EAFNOSUPPORT Address family not supported (POSIX.1) EAGAIN Resource temporarily unavailable (may be the same value as EWOULDBLOCK) (POSIX.1) EALREADY Connection already in progress (POSIX.1) EBADE Invalid exchange ...
33
Computer Science Science
34
Computer Science Science
int main () { return 0; }
35
Computer Science Science
36
Computer Science Science
void foo() { exit(1); /* no return */ } int main () { foo(); /* no return */ return 0; }
37
Computer Science Science
38
Computer Science Science
void foo() { exit(1); } int main () { ... foo(); release(resource); /* cleanup */ return 0; } /* $^@#%!! */
39
Computer Science Science
40
Computer Science Science
41
Computer Science Science
void cleanup() { printf("Cleaning up\n"); } void foo() { printf("Self-destructing\n"); exit(1); } int main() { atexit(cleanup); foo(); /* no return */ return 0; } Self-destructing Cleaning up
42
Computer Science Science
void cleanup() { printf("Cleaning up\n"); } void foo() { fork(); exit(1); } int main() { atexit(cleanup); foo(); /* no return */ return 0; } Cleaning up Cleaning up
43
Computer Science Science
44
Computer Science Science
void fork7() { if (fork() == 0) { printf("Terminating Child, PID = %d\n", getpid()); exit(0); } else { printf("Running Parent, PID = %d\n", getpid()); while (1) ; /* Infinite loop */ } }
45
Computer Science Science
46
Computer Science Science
47
Computer Science Science
48