

# Q: SRTF

| Pno. | AT | BT | I/O BT | BT | CT | TAT | WT |
|------|----|----|--------|----|----|-----|----|
| 1    | 0  | 3  | 50     | 2  | 11 | 11  | 6  |
| 2    | 0  | 2  | 0      | 1  | 7  | 7   | 4  |
| 3    | 2  | 1  | 0      | 2  | 9  | 7   | 4  |
| 4    | 5  | 2  | 0      | 1  | 16 | 11  | 8  |



# Priority CPU Scheduling

- Non-preemptive:

*WT = RT*

| Pro. | Priority | AT |     | BT | CT |    | TAT | WT | RT |
|------|----------|----|-----|----|----|----|-----|----|----|
|      |          | 0  | 4 ✓ |    | 4  | 4  |     |    |    |
| 1    | 2 (L)    | 0  | 4 ✓ | 4  | 4  | 4  | 0   | 0  | 0  |
| 2    | 4        | 1  | 2 ✓ | 25 | 24 | 24 | 22  | 22 | 22 |
| 3    | 6        | 2  | 3 ✓ | 23 | 21 | 21 | 18  | 18 | 18 |
| 4    | 10       | 3  | 5 ✓ | 9  | 6  | 6  | 1   | 1  | 1  |
| 5    | 8        | 4  | 1 ✓ | 20 | 16 | 16 | 15  | 15 | 15 |
| 6    | 12 (H)   | 5  | 7 ✓ | 13 | 8  | 8  | 7   | 7  | 7  |
| 7    | 9        | 6  | 6 ✓ | 19 | 13 | 13 | 7   | 7  | 7  |

# Priority CPU Scheduling (Pre-emptive mode)

| Proc. | Priority | AT | BT   | CT | TAT | WT | RT |
|-------|----------|----|------|----|-----|----|----|
| 1     | 2(L)     | 0  | 130  | 25 | 25  | 21 | 0  |
| 2     | 4        | 1  | 210  | 22 | 21  | 19 | 0  |
| 3     | 6        | 2  | 320  | 21 | 19  | 16 | 0  |
| 4     | 10 ✓     | 3  | 530✓ | 12 | 9   | 4  | 0  |
| 5     | 8 ✓      | 4  | 16   | 19 | 15  | 11 | 14 |
| 6     | 12(H) ✓  | 5  | 430✓ | 9  | 9   | 0  | 0  |
| 7     | 9 ✓      | 6  | 60   | 18 | 12  | 6  | 6  |



## Pre-emptive Priority

Q:

| Pno. | AT | Priority | CPU<br>BT        | TB<br>BT | CPU<br>BT        | CT | TAT | WT |
|------|----|----------|------------------|----------|------------------|----|-----|----|
| 1    | 0  | 2        | 10               | 5✓       | <del>32</del> 10 | 10 | 10  | 6  |
| 2    | 2  | 3(L)     | <del>32</del> 10 | 3✓       | <del>10</del>    | 15 | 13  | 9  |
| 3    | 3  | 1(H)     | <del>20</del>    | 3        | <del>10</del>    | 9  | 6   | 3  |



CPU-efficiency:

$$\frac{11}{15} \times 100\%$$

CPU-inefficiency:

$$\frac{4}{15} \times 100\%$$

H/W

Consider 'm' processes sharing the CPU for P-R fashion.

If context switching time is ' $\beta$ ' units, what must be the time quantum 'q', such that, the no. of context switches are reduced but at the same time each process is guaranteed to get the turn at the CPU for every ' $t$ ' secs?