KEMBAR78
Assignment No # 1 Solution: 8 Hello and 8 Bye Total Process 20 | PDF | Process (Computing) | Operating System
0% found this document useful (0 votes)
993 views2 pages

Assignment No # 1 Solution: 8 Hello and 8 Bye Total Process 20

The document describes a series of events involving different processes accessing disk units over time. It then asks to identify the state of specific processes at times 22, 37, and 47 based on the events. The states identified are that at time 22, processes P1, P3, P7 are blocked for I/O and P5 is ready, at time 37 P1 and P3 are ready, P5 is suspended, and P7 is blocked for I/O, and at time 47 P1, P3, P5 are ready and P7 is blocked for I/O while P8 is terminated.

Uploaded by

Anooshay
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
993 views2 pages

Assignment No # 1 Solution: 8 Hello and 8 Bye Total Process 20

The document describes a series of events involving different processes accessing disk units over time. It then asks to identify the state of specific processes at times 22, 37, and 47 based on the events. The states identified are that at time 22, processes P1, P3, P7 are blocked for I/O and P5 is ready, at time 37 P1 and P3 are ready, P5 is suspended, and P7 is blocked for I/O, and at time 47 P1, P3, P5 are ready and P7 is blocked for I/O while P8 is terminated.

Uploaded by

Anooshay
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 2

Assignment No # 1 solution

Assume that at time= 5, no system resources are being used except for the processor
And memory. Now consider the following events:
At time 5: P1 executes a command to read from disk unit 3.
At time 15: P5 time slice expires.
At time 18: P7 executes a command to write to disk unit 3.
At time 20: P3 executes a command to read from disk unit 2.
At time 24: P5 executes a command to write to disk unit 3.
At time 28: P5 is swapped out.
At time 33: An interrupt occurs from disk unit 2: P3’s read is complete.
At time 36: An interrupt occurs from disk unit 3: P1’s read is complete.
At time 38: P8 terminates.
At time 44: P5 is swapped back in.
At time 48: An interrupt occurs from disk unit 3: P7’s write is complete.
For each time 22, 37, and 47, identify which state each process is in. If a process is blocked,
further
Identify the event on which the process has blocked.
Answer:
 At time=22, P1, P3, P7 are blocked for I/O. P5 is ready.
 At time=37, P1, P3 are ready. P5 is suspended. P7 is blocked for I/O.
 At time=47, P1, P3 P5 are ready. P7 is blocked for I/O. P8 is in terminated state.
Question no # 2: 8 hello and 8 bye total process 20
Name three ways in which the processor can transition from user mode to kernel mode?
Answer:
1) The user process can execute a trap instruction (e.g. system call). A trap is known as a
synchronous software interrupt.
2) The user process can cause an exception (divide by zero, access bad address, bad
instruction etc).
3) The processor can transition into kernel mode when receiving an interrupt.
3.2: Including the initial parent process, how many processes are created by the program
shown in Figure 3.31?
Answer:
16 processes are created.
Explain the circumstances under which which the line of code marked printf("LINE J") in
Figure 3.33 will be reached.

Answer:
The call to exec() replaces the address space of the process with the program specified as the
parameter to exec(). If the call to exec () succeeds, the new program is now running and control
from the call to exec() never returns. In this scenario, the line printf("Line J"); would never be
performed. However, if an error occurs in the call to exec(), the function returns control and
therefor the line printf("Line J"); would be performed.

Describe the actions taken by the kernel to context-switch between two processes.
Answer:
1. In response to a clock interrupt, the OS saves the PC and user stack pointer of the
currently executing process, and transfers control to the kernel clock interrupt handler.
2. The clock interrupt handler saves the rest of the registers, as well as other machine state,
such as the state of the floating point registers, in the process PCB.
3. The OS invokes the scheduler to determine the next process to execute.
4. The OS then retrieves the state of the next process from its PCB, and restores the
registers. This restore operation takes the processor back to the state in which this process
was previously interrupted, executing in user code with user mode privileges.

Would it be possible for the user to develop a new command interpreter using the system-
call interface provided by the operating system?

Yes

You might also like