An address is 32 bits, divided 9 + 11 + X; so X must be 12. Therefore, there are 212 = 4K memory addresses per page (probably bytes), and 220 = 1M pages per address space.
A 32 bit address is divided a + b + c + d, where d is the offset within a page; there are 2d memory addresses (probably bytes) per page and 2a+b+c pages per address space.
The expected address translation time is 100ns + k(500ns), where k is the probability of a miss in the translation lookaside buffer, assuming that we only begin the memory cycle if we detect a miss. If our target is an expected tranlation time of 200ns, we simply solve200ns = 100ns + k(500ns) --or-- 100ns = k(500ns) --or-- k = 0.2
So, we need a miss-rate of 1 in 5.
Note that, for some memory architectures, it may be possible to begin a memory cycle as we begin checking the lookaside buffer. If we get a hit in the lookaside buffer, we abort the memory cycle devoted to address translation. If we get a miss, we allow the memory cycle to run to completion. In this case, k = 0.4, but the hardware is harder to build.
The program text (code) is 32K, divided into 4K pages, This takes an exact 8 pages, leaving 32K to be shared between data and stack. The data is 16386 bytes (2 bytes more than 4 pages), so it takes 5 pages. The stack is 15870 (514 bytes less than 4 pages), so it takes 4 pages. Therefore, we need 17 pages, but we have only 16. It won't fit.If our page size is 0.5K, however, it fits. In that case, we have a total of 128 pages, of which the text takes 64, the data takes 33 and the stack takes 31. Everything fits!
The program generates 15,000 page faults, and each takes 2001 microsec. 15000x2001us = 30.015 seconds. Doubling the amount of memory halves the number of page faults, so with twice the memory, we will have only 7,500 page faults taking 15.0075 seconds.The program takes 60 seconds to run; 15,000 instructions in 30.015 seconds and 29,985,000 instructions in 29.985 seconds. When we halve the page fault rate, we change this to 29,992,500 instructions in 29.9925 seconds plus 7500 instructions in 15.0075 seconds. So, the total time is an even 45 seconds (demonstrating that Tannenbaum cooked his figures to make the answer come out even!)
When a page fault occurs:
- The page fault handler will probably request a write to clear out a page frame.
- The disk scheduler will include this write in its queue of pending disk requests.
- Some other process will run while the disk write is completed. (That other process may cause its own page faults).
- When the write is completed, the page fault handler will schedule a read for the page the user requested.
- The disk scheduler will include this read in its queue of pending disk requests.
- Some other process will run while the disk read is completed. (That other process may cause its own page faults).
- When the read is completed, the page fault handler will fix the user's page table and return to the user.