Review Problems for CS 302 Exam 2 Spring 2005 The exam will be over chapters 6, 7 and 8 from the textbook, "Operating Systems: Internals and Design Principles", Fifth Edition, by Williams Stallings. 1. Chapter 6, Problems 6.1, 6.2, 6.4, 6.5, 6.16, 6.17. 2. Chapter 7, Problems 7.1, 7.5, 7.6, 7.11, 7.12, and 7.14. 3. Chapter 8, Problems 8.1, 8.2, 8.4, 8.5, 8.6, 8.10, 8.13, and 8.18. 4. List the steps to process a page-fault. 5. In a paged virtual memory system, why does the page-size have to be a power of two? 6. What is the advantage of using multi-level page tables in a paged virtual memory system? 7. List an advantage and a disadvantage of increasing the size of a page frame in a paged virtual memory system. 8. In a paged virtual memory system, can the computer's physical memory space be larger than a process's virtual memory space? Explain your answer. 9. In a paged virtual memory system, explain how if a process modifies an arbitrary location in its virtual memory space, the change is not reflected at the same address of other processes. 10. Does a paged virtual memory system have internal or external fragmentation? Explain your answer. 11. In a paged virtual memory system with 32 bit virtual addresses and 8KB page frames, how many bits of a virtual address are used as an offset into a page frame and at most how many page frames can a process have allocated to it? 12. In a paged virtual memory system, explain how two processes can share physical memeory. 13. Conceptually, which of the following quantities describes how many entries are there in a page table? a) |virtual address space| b) |(virtual address space)/(page size)| c) (# of page frames allocated to the process) * (page size) d) (# of page frames allocated to the process) / (page size) e) # of page frames allocated to the process 14.In a translation lookaside buffer implementation of a page table, how many entries are in the page table? a) |virtual address space| b) |(virtual address space)/(page size)| c) (# of page frames allocated to the process) * (page size) d) (# of page frames allocated to the process) / (page size) e) # of page frames allocated to the process 15. Define spatial reference locality and explain how it is related to a process's working set. 16. In a demand paged virtual memory system, what is the purpose of the replacement policy? What is the purpose of the allocation policy? Name a few different replacement and allocation policies. 17. A paged virtual memory system must have a "fetch policy" that decides when a page should be loaded into primary memory. The simplest fetch policy is to load a page only when it has been page faulted. What is another possible fetch policy and what advantage might it have over the simplest one. (Hint: prefetch) 18. Assume that a computer has only three physical pages. The following diagrams show two sequences of referenced pages. Write down in the empty slots below each reference the pages that are loaded in physical memory at each page reference. Also, write down the number of page hits and misses. Use the LRU page replacing policy in both cases. Page Referenced: 1 2 3 4 1 2 3 4 Phys Page 1 Phys Page 2 Phys Page 3 # of hits = # of misses = Page Referenced: 1 2 1 2 3 4 3 4 Phys Page 1 Phys Page 2 Phys Page 3 # of hits = # of misses = 19. Suppose a computer has 4 physical pages, and a process references its virtual pages (page 0 through page 7) in the following order: 0 2 1 3 5 4 6 3 7 4 7 3 3 5 5 3 1 1 1 7 2 3 4 1 a) Suppose the kernel uses FIFO page replacement algorithm. How many page faults would the process have? Which page references are page faults? b) Suppose the kernel uses LRU as the page replacement algorithm. Answer the above two questions. c) Suppose the kernel uses the optimal page replacement algorithm. Answer the above two questions. 20. Let w = 0,4,1,4,1,5,1,6,2,6,3,6,2,6,4,5 be a page reference stream. Given a static page frame allocation of 3 and assuming the primary memory is initially unloaded, how many page faults will the given reference stream incur using the optimal strategy? Using the LRU strategy? 21. Assume the following 2-level page table. Translate the VM addresses 0x00801B4B and 0x00C01578 to their corresponding physical address. Assume a 32-bit word size. Assume a page size of 4KB and that the first 10 bits of the VM address index the level 1 page table, the next 10 bits index the second level and the bits left are the page offset. The third column in the level 2 page tables are physical page addresses. VM Address 0x00801B4B is ______________ in Physical Memory VM Address 0x00C00578 is ______________ in Physical Memory Level 1 0 0x38000 1 0x36000 2 0x32000 3 0x40000 Level 2 at 0x38000 0 0x42000 1 0x50000 2 0x70000 Level 2 at 0x32000 0 0x56000 1 0x58000 2 0x72000 Level 2 at 0x36000 0 0x5a000 1 0x5c000 2 0x62000 at 0x40000 0 0x89000 1 0x82000 2 0x86000 22. Explain in detail the difference between the following three functions. int functionA() { static int i; i++; return i; } int functionB() { static int i = 0; i++; return i; } int functionC() { static int i; i = 0; i++; return i; } 23. In what way is a static local variable like a global variable? In what way are they different? (Hint: Lifetime and scope.) 24. What does the following functionA() do? int functionA(int i) { static int j = 0; int k; k = j; j = i; if (k > j) return k; else return j; } 25. Determine which of the following C expressions are equivalent to a[i]. The type of a[0] is denoted by . Expression a + i a + i * sizeof() &a + i *(a + i) *(a[0] + i) *(&a[0] + i) *(&a[i]) &a[i] *( *) ((char *) &a[0] + i ) *( *) ((char *)&a[0] + i * sizeof(a[0]))