| <b>CPSC 410</b> | Midterm1 |
|-----------------|----------|
|-----------------|----------|

| Name:                                                   |         |
|---------------------------------------------------------|---------|
| Please rate this exam 1 – 10, with 1 being the easiest. | Rating: |

## 1. (15 pts) Match the following event with the type of interrupt it generates

| Event                                | Hardware | System Call | Exception | None of these |
|--------------------------------------|----------|-------------|-----------|---------------|
| User presses a key                   |          |             |           |               |
| Divide by 0                          |          |             |           |               |
| CPU executes a read() instruction    |          |             |           |               |
| MMU notifying CPU that data is ready |          |             |           |               |
| Page table physical address lookup   |          |             |           |               |

2. (5 pts) For a multi-level feedback queue, choose the answer that best describes where a highly user interactive process runs.

- a) In a queue with a long time slice and high priority
- b) In a queue with a short time slice and high priority
- c) In a queue with a short time slice and low priority
- d) In a queue with a long time slice and low priority
- e) In a queue with no restrictions on amount of time the process runs
- f) In the readyQ
- g) It's not g

- 3. (10 pts) In a cooperative multitasking operating system; assume a process is running the following loop.
  - int i=0;
    while (true){
    i++;
    if (i==32000)
    i=0;
    }

Choose all answers that describe the conditions under which this process yields control to the OS and, if applicable, indicate the line(s) where this occurs.

- a) when I equals 32000
- b) when the memory holding i overflows
- c) when it makes a system call for disk access
- d) when the process time slice is up
- e) it will never yield
- 4. (10 pts) The system illustrated below has 3 levels of cache with the given access times. What is the average instruction access time if;

70% of data is in T1 and 20% is in T2 and 10% is in T3?

Please show all work



5. (30 pts) A scheduler uses a preemptive Round Robin algorithm to run processes on a uniprocessor system. For the following processes, please indicate which process is running on the processor by placing its number in the blocks that follow. The time slice = 3 time units

| Process | Arrival Time | Processor time |
|---------|--------------|----------------|
| 1       | 0            | 4              |
| 2       | 1            | 2              |
| 3       | 2            | 1              |



(10 pts) Please fill each of the above boxes with the number of the currently running process.

(5 pts) How many context switches are there? Show where they occur on the above diagram.

(5 pts) What is the average response time?

(5 pts) What is the average turnaround time?

(5 pts) What is the average wait time?

6. (30 pts) For a 9 bit system using the following multilevel page table structure.



- (3 pts) What is the size of the memory?
- (3 pts) What is the size of each frame (block) in memory?
- (3 pts) How many possible outer page tables are there and how many entries (rows) per outer page table?
- (3 pts) How many possible inner page tables are there and how many entries (rows) per inner page table?
- (3 pts) What is a valid bit? What does it mean if it equals 1?

(15 pts) A process has exactly 128 instructions. 64 words at the beginning of its virtual address space and 64 words at the end. Please show all inner and outer page tables.