The micro-kernel. A micro-kernel moves all non-essential OS functions to the user level. What's often left is a message passing structure that communicates info back and forth between user level processes. This message passing structure can be modified to work across a network, allowing traditional OS services to be distributed.
Context switching is when the OS stops executing one process and starts executing another. The "context" of the first processes is switched to the "context" of the second. The process table contains all the information required to switch context from one processes to another. In addition, it can holds the state of the processes that need to be updated as contexts are changed for both the old and new processes.
Multiple part question:
Gantt chart:
AAAAAAAABBBBDDDDDCCCCCCCCC / / / / 8 12 17 26
Turn around: A 8-0=8, B 12-1=11, C 26-2=24, D 17-3=14
Avg turn-around: (8 + 11 + 24 + 14) / 4 = 14.25
Waiting time: A 0, B (8-1)=7, C (17-2)=15, D (12-3)=9
Avg waiting: (0 + 7 + 15 + 9) / 4 = 7.75
SJRF:
ABBBBDDDDDAAAAAAACCCCCCCCC / / / / / 1 5 10 17 26
Avg turn-around: ((17-0) + (5-1) + (26-2) + (10-3) )/4 =
13
An operating system runs the idle process or idle thread when it has nothing to do. This is often just a tight, infinite loop (see our simple OS). It stays there until it receives and interrupt.
Here they are:
n = 7 n = 12 (7 done first) n = 5 n = 12 (5 done first) n = 5 n = 5 (clobber 7) n = 7 n = 7 (clobber 5) n = 7 n = 5 (switch before print) n = 5 n = 7 (switch before print) n = 7 (fork failed)
Preemptive scheduling algorithms interrupt the current running process before it has finished it's CPU burst. This can be because of an interrupt unrelated to the running process or because of a timer interrupt in case the quanta has expired. Preemptive algorithms achieve better utilization of computer resources by allowing the CPU the parallelize more devices. In addition, preemptive scheduling algorithms favor interactive applications by giving them more chances to run since they tend to have shorter CPU burst times.
(See Tannenbaum p. 30 or the class slides.)
A busy waiting process is in running state or ready state. It wastes cpu cycles, but no context switch is required. The block operation places a process into a waiting queue associated with the semaphore, and the state of the process is switched to the waiting state. Then, control is transferred to the CPU scheduler, which selects another process to execute. The blocked process wastes almost no CPU cycles.
No, the given solution does not work in at least two ways. Mutual exclusion can be violated if process 0 says its 1's turn. 1 says ok and starts to go in. Then process 0 comes back up and tries to enter the critical region. Progress may also be violated if 0 exits the critical region and comes back up and enters before 1 gets chance to test it and go in.
Bits:
Times are:
The physical addresses are:
(None available yet.)
(None available yet.)
(None available yet.)