Virtual Page #

\[(v + p)\] bits in virtual address

\[(m + p)\] bits in physical address

\[2^v\] number of virtual pages

\[2^m\] number of physical pages

\[2^p\] bytes per physical page

\[2^{v+p}\] bytes in virtual memory

\[2^{m+p}\] bytes in physical memory

\[(m+2)2^v\] bits in the page table

Look in TLB: VPN→PPN cache

Page fault (handled by SW)
Note: A subset of problems are marked with a red star (★). We especially encourage you to try these out before recitation.

Problem 1. ★

The micro-RISC has a 12-bit virtual address, an 11-bit physical address and uses a page size of $256 = 2^8$ bytes. The micro-RISC has been running for a while and at the current time the page table has the contents shown on the right. Assume all physical pages are currently in use.

(A) Assuming each page table entry contains the usual dirty (D) and resident (R) bits, what is the total size of the page table in bits?

\[
\text{Size of page table (bits): } \underline{__________}
\]

(B) The following load instruction, located at virtual address 0x0BC, is about to be executed.

\[
\text{id} x1, \, 0x2C8(x0)
\]

When the instruction is executed, what main memory locations are accessed by the instruction fetch and then the memory access initiated by the LW? Use the page table shown to the right. Assume the LRU page is virtual page 0xE.

\[
\text{Physical address for instruction fetch: } 0x\underline{__________}
\]

\[
\text{Physical addr for data read by LW instruction: } 0x\underline{__________}
\]

(C) A few instructions later, the following instruction, located at virtual address 0x0CC, is executed:

\[
\text{id} x1, \, 0(x2) \quad // \text{current value of } x2 = SP = 0x600
\]

Please mark up the page table to show its contents after the SW has been executed. Use the page table shown to the right. Assume the LRU page is virtual page 0xE.

Remember to show any changes to the dirty and resident control bits as well as updates to the physical page numbers. If an entry in the page table no longer matters, please indicate that by replacing it with “— 0 — “ for the D, R and PPN entries.

Show updated contents of page table
Problem 2.

Consider a RISC-V processor that includes a 40-bit virtual address, an MMU that supports 4096 (2^{12}) bytes per page, 2^{32} bytes of physical memory, and a large Flash memory that serves as a disk. The MMU and the page fault handler implement an LRU replacement strategy.

Note that in the RISC-V processor we have been building in class, the word size is 32 bits. In order to support a 40-bit virtual address space, this problem is referring to a RISC-V processor that uses a larger (>= 40 bit) word size.

(A) What is the size of the page table for this processor? Assuming the page table includes the standard dirty and resident bits, specify the width of each page table entry in bits, and number of entries in the page table.

Size of page table entry in bits: 

Number of entries in the page table: 

(B) The following test program is running on this RISC-V processor. The first 8 locations of the page table, just before executing this test program, are shown below; the least-recently-used page (“LRU”) and next least-recently-used page (“next LRU”) are as indicated. This RISC-V processor also has a 4 element, fully associative, Translation Lookaside Buffer (TLB) that caches page table translations from VPN to PPN.

```
= 0x0
lui x3, 2
lw x5, 0x600(x3)
lui x3, 4
sw x5, 0x100(x3)
```

![Page Table](image)

For each virtual page that is accessed by this program, specify the VPN, whether or not it results in a TLB hit on the first access to that page, whether or not it results in a page fault, and the PPN that the page ultimately maps to. You may not need to use all rows of the table.

<table>
<thead>
<tr>
<th>VPN</th>
<th>TLB Hit (Yes/No)</th>
<th>Page Fault (Yes/No)</th>
<th>PPN</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
(C) Which physical pages, if any, need to be written to disk during the execution of the test program in part B?

**Physical page numbers written to disk or NONE: _________**

(D) What is the physical address of the LW instruction?

**Physical address of LW instruction: 0x________**

**Problem 3.**

Consider a RISC-V processor that includes a 32-bit virtual address, an MMU that supports 4096 \(2^{12}\) bytes per page, \(2^{24}\) bytes of physical memory, and a large Flash memory that serves as a disk. The MMU and the page fault handler implement an LRU replacement strategy.

(A) The designers are thinking about implementing the page table using a separate SRAM memory with \(L \) entries, where each entry has \(B \) bits. If the page table includes the standard dirty and resident bits, what are the appropriate values for the parameters \(L \) and \(B \)?

**Appropriate value for the parameter \(L \): __________**

**Appropriate value for the parameter \(B \): __________**

(B) If the designers decide to decrease the page size to 2048 \(2^{11}\) bytes but keep the same size virtual and physical addresses, what affect will the change have on the following architectural parameters? Use a letter “a” through “e” to indicate how the new value of the parameter compares to the old value of the parameter:

(a) doubled      (b) increased by 1      (c) stays the same     (d) decreased by 1     (e) halved

**Size of page table entry in bits: _____**

**Number of entries in the page table: _____**

**Maximum percentage of virtual memory that can be resident at any given time: _____**
(D) A test program has been running on the RISC-V with a page size of $2^{12}$ bytes and has been halted just before execution of the following instruction at location 0x1234. Assume the current contents of x2 are 0x3000.

```
sw x1, 0x4C8(x2) | PC = 0x1234
```

The first 8 locations of the page table at the time execution was halted are shown to the right; the least-recently-used page ("LRU") and next least-recently-used page ("next LRU") are as indicated. Assume that all the pages in physical memory are in use. Execution resumes and the SW instruction is executed.

Please show the contents of the page table after the SW instruction has completed execution by crossing out any values that changed and writing in their new values. Note that the D and PPN fields for a non-resident page do not need to be specified.

(E) Which physical pages, if any, need to be written to disk during the execution of the SW instruction in part (D)?

Physical page numbers written to disk or NONE: ________

**Problem 4.** ★

Consider a virtual memory system that uses a single-level page table to translate virtual addresses into physical addresses. Each of the questions below asks you to consider what happens when just ONE of the design parameters (page size, virtual memory size, physical memory size) of the original system is changed. **Circle the correct answer.**

(A) If the physical memory size (in bytes) is **doubled**, the number of entries in the page table
   (a) stays the same
   (b) doubles
   (c) is reduced by half
   (d) increases by one
   (e) decreases by one

(B) If the page size (in bytes) is **halved**, the number of entries in the page table
   (a) stays the same
   (b) doubles
   (c) is reduced by half
   (d) increases by one
   (e) decreases by one

(C) If the virtual memory size (in bytes) is **doubled**, the number of bits in each entry of the page table
   (a) stays the same
   (b) doubles
   (c) is reduced by half
   (d) increases by one
   (e) decreases by one

(D) If the page size (in bytes) is **doubled**, the number of bits in each entry of the page table
   (a) stays the same
   (b) doubles
   (c) is reduced by half
   (d) increases by one
   (e) decreases by one
Consider a virtual memory system for a new processor with 4096 \(2^{12}\) virtual pages and 16384 \(2^{14}\) physical pages where each page contains 1024 \(2^{10}\) bytes. The first 8 entries of the current page table are shown below:

<table>
<thead>
<tr>
<th>index</th>
<th>D</th>
<th>R</th>
<th>PPN</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
<td></td>
<td>0x22</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0x01</td>
</tr>
<tr>
<td>2</td>
<td>--</td>
<td>0</td>
<td>--</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>1</td>
<td>0x02</td>
</tr>
<tr>
<td>4</td>
<td>1</td>
<td>1</td>
<td>0x03</td>
</tr>
<tr>
<td>5</td>
<td>--</td>
<td>0</td>
<td>--</td>
</tr>
<tr>
<td>6</td>
<td>1</td>
<td>1</td>
<td>0x15</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>...</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

(E) What is the total number of bits in the page table?

**Total number of bits in the page table:**

(F) Which address bits from the CPU are used to choose an entry from the page table?

**Address bits used to choose page table entry:** \(A[ _____ : _____ ]\)

(G) What is the physical address for the word at virtual location 0x1234? Write “not resident” if the location is not currently present in physical memory.

**Physical address for byte at virtual address 0x1234 or “not resident”:**

(H) Briefly explain what action caused the D bit for page 6 to be 1.

**Briefly explain.**
Problem 5.

(A) A particular RISC-V implementation has 32-bit virtual addresses, 32-bit physical addresses and a page size of $2^{12}$ bytes. A test program has been running on this RISC-V and has been halted just before execution of the following instruction at location 0x1F FC. Assume $x2 = 0x3000$ and $x3 = 0x6000$ just prior to executing these instructions.

\[
\begin{align*}
&\text{l}w \ x1, \ 0x4C8(x2) \quad | \quad \text{PC} = 0x1\text{FFC} \\
&\text{s}w \ x1, \ 0x4(x3) \quad | \quad \text{PC} = 0x2\text{000} \\
\end{align*}
\]

The first 8 locations of the page table at the time execution was halted are shown below; the least recently used page (“LRU”) and next least recently used page (“next LRU”) are as indicated. Assume that all the pages in physical memory are in use. Execution resumes and both the LW and SW instructions are executed.

Please show the contents of the page table after the SW instruction has completed execution by crossing out any values that changed and writing in their new values.

<table>
<thead>
<tr>
<th>VPN</th>
<th>D</th>
<th>R</th>
<th>PPN</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0x1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0x0</td>
</tr>
<tr>
<td>LRU→ 2</td>
<td>1</td>
<td>1</td>
<td>0x6</td>
</tr>
<tr>
<td>3</td>
<td>--</td>
<td>0</td>
<td>--</td>
</tr>
<tr>
<td>Next LRU→ 4</td>
<td>0</td>
<td>1</td>
<td>0x4</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>1</td>
<td>0x2</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>1</td>
<td>0x7</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>1</td>
<td>0x3</td>
</tr>
</tbody>
</table>

(B) Which physical pages, if any, needed to be written to disk during the execution of the LW and SW instructions?

Physical page numbers written to disk or NONE: __________

(C) Please give the 32-bit physical memory addresses used for the four memory accesses associated with the execution of the LW and SW instruction.

32-bit physical memory address of LW instruction: 0x______________

32-bit physical memory address of data read by LW: 0x______________

32-bit physical memory address of SW instruction: 0x______________

32-bit physical memory address of data written by SW: 0x______________
Problem 6. ★

Consider a system with 40-bit virtual addresses, 36-bit physical addresses, and 64 KB \( (2^{16}) \) pages. The system uses a page table to translate virtual addresses to physical addresses; each page table entry include dirty (D) and resident (R) bits.

Note that in the RISC-V processor we have been building in class, the word size is 32 bits. In order to support a 40-bit virtual address space, this problem is referring to a processor that uses a larger \((\geq 40 \text{ bit})\) word size.

(A) (2 points) Assuming a flat page table, what is the size of each page table entry, and how many entries does the page table have?

- Size of page table entry in bits: __________
- Number of entries in the page table: __________

(B) (1 point) If you changed the system to use 16 KB \( (2^{14}) \) bytes pages instead of 64 KB pages, how would the number of entries in the page table change? Please give the ratio of the new size to the old size.

\[
\frac{\text{(# entries with 16 KB pages)}}{\text{(# entries with 64 KB pages): __________}}
\]

Assume 64 KB pages for the rest of this exercise.

(C) (6 points) The contents of the page table and TLB are shown to the right. The page table uses an LRU replacement policy, and the LRU page (shown below) will be chosen for replacement. For each of these four accesses, compute its corresponding physical address and indicate whether the access causes a TLB miss and/or a page fault. Assume each access starts with the TLB and Page Table state shown to the right.

To fill in the table below:

<table>
<thead>
<tr>
<th>Virt Addr (in hex)</th>
<th>PPN (in hex)</th>
<th>Phys Addr (in hex)</th>
<th>TLB Miss?</th>
<th>Page Fault?</th>
</tr>
</thead>
<tbody>
<tr>
<td>1. 0x06004</td>
<td>__________</td>
<td>__________</td>
<td>Y / N</td>
<td>Y / N</td>
</tr>
<tr>
<td>2. 0x30286</td>
<td>__________</td>
<td>__________</td>
<td>Y / N</td>
<td>Y / N</td>
</tr>
<tr>
<td>3. 0x68030</td>
<td>__________</td>
<td>__________</td>
<td>Y / N</td>
<td>Y / N</td>
</tr>
<tr>
<td>4. 0x4BEEF</td>
<td>__________</td>
<td>__________</td>
<td>Y / N</td>
<td>Y / N</td>
</tr>
</tbody>
</table>

TLB

<table>
<thead>
<tr>
<th>VPN (tag)</th>
<th>V</th>
<th>D</th>
<th>PPN</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x0</td>
<td>1</td>
<td>0</td>
<td>0xBE7A</td>
</tr>
<tr>
<td>0x3</td>
<td>0</td>
<td>0</td>
<td>0x7</td>
</tr>
<tr>
<td>0x5</td>
<td>1</td>
<td>1</td>
<td>0xFF</td>
</tr>
<tr>
<td>0x2</td>
<td>1</td>
<td>0</td>
<td>0x900</td>
</tr>
</tbody>
</table>

Page Table

<table>
<thead>
<tr>
<th>VPN</th>
<th>R</th>
<th>D</th>
<th>PPN</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0xBE7A</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>---</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td>0</td>
<td>0x900</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
<td>0</td>
<td>0x8</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>---</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td>1</td>
<td>0xFF</td>
</tr>
<tr>
<td>6</td>
<td>1</td>
<td>0</td>
<td>0x70</td>
</tr>
</tbody>
</table>

...
Problem 7. (SP’20 Quiz 3 Problem 3)

For the following questions, assume a processor with 64-bit virtual addresses, 40-bit physical addresses and page size of 4096 \(2^{12}\) bytes per page. The Page Table of this processor uses an LRU replacement strategy, and handles missing pages using a page fault handler.

A) What is the size of the page table? Assume that each page table entry includes a dirty bit and a resident bit. Specify the number of page table entries and the width of each entry.

Number of entries in the page table: __________

Width of each page table entry (bits): __________

B) What is the maximum fraction of virtual memory that can be resident in physical memory at any given time (assuming the page table is not in physical memory)?

Max fraction of virtual memory that can be resident in physical memory: __________

C) If we half the size of virtual memory but keep the same physical address length and page size \(2^{12}\) bytes per page), what effect will the change have on the size of a page table entry and on the number of entries in the page table? Use a letter “a” through “e” to indicate how the new value of the parameter compares to the old value of the parameter:

(a) doubled      (b) increased by 1      (c) stays the same     (d) decreased by 1     (e) halved

Number of entries in the page table: __________

Width of each page table entry in bits: __________
D) The following program fragment is executed and a record is made of the inputs and outputs of the Memory Management Unit. The record is shown in the table below.

\[ \text{sw } x11, 0(x10) \]
\[ \text{lw } x11, 4(x13) \]
\[ \text{lui } x12, 4 \]

<table>
<thead>
<tr>
<th>Access type</th>
<th>Virtual address</th>
<th>Physical address</th>
</tr>
</thead>
<tbody>
<tr>
<td>Inst. fetch</td>
<td>0x60FF8</td>
<td>0x10FF8</td>
</tr>
<tr>
<td>Data write</td>
<td>0x04600</td>
<td>0x74600</td>
</tr>
<tr>
<td>Inst. fetch</td>
<td>0x60FFC</td>
<td>0x10FFC</td>
</tr>
<tr>
<td>Data read</td>
<td>0x18410</td>
<td>0x169410</td>
</tr>
<tr>
<td>Inst. fetch</td>
<td>0x61000</td>
<td>0x09000</td>
</tr>
</tbody>
</table>

Using information from the program and the table above, please deduce the contents of as many entries as possible in the page table. Assume the original address sizes of 64-bit virtual addresses, 40-bit physical addresses, and page size of 4096 (2^{12}) bytes per page. **Assume that pages holding instructions are read-only.**

**Please make an entry in the table below for each page table entry we learn about after** the execution of the program fragment. Note that the table below is not an actual page table, it is just a list of entries from the page table that you can infer from this problem. For each entry provide the VPN, the dirty (D) and resident (R) bits, and the PPN if they are known. If you can’t deduce the value of a field, enter a ‘?’ for that field. You may not need to use all the rows of the table below.

<table>
<thead>
<tr>
<th>VPN</th>
<th>D</th>
<th>R</th>
<th>PPN</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
E) At some later point in time, suppose that the contents of the page table and its corresponding fully associative TLB are as shown to the right. As previously mentioned, the page table uses an LRU replacement policy, and the LRU page (shown below) will be chosen for replacement if necessary. For each of these four accesses, compute its corresponding physical address and indicate whether the access causes a TLB miss and/or a page fault. **Assume each access below is independent of the others and starts with the TLB and page table state shown to the right.**

\[
\begin{array}{|c|c|c|c|}
\hline
\text{VPN} & \text{V} & \text{D} & \text{PPN} \\
\hline
0x0 & 1 & 0 & 0x1337 \\
0x1 & 0 & 0 & 0x7 \\
0x6 & 1 & 1 & 0x33 \\
0x3 & 1 & 0 & 0x534 \\
\hline
\end{array}
\]

\[
\begin{array}{|c|c|c|c|}
\hline
\text{VPN} & \text{R} & \text{D} & \text{PPN} \\
\hline
0 & 1 & 0 & 0x1337 \\
1 & 0 & 0 & --- \\
2 & 1 & 0 & 0x450 \\
3 & 1 & 0 & 0x534 \\
4 & 0 & 0 & --- \\
5 & 1 & 1 & 0xAB5 \\
6 & 1 & 1 & 0x33 \\
\hline
\end{array}
\]

**Fill in table below**

<table>
<thead>
<tr>
<th>Virt Addr</th>
<th>PPN (in hex)</th>
<th>Phys Addr (in hex)</th>
<th>TLB Miss?</th>
<th>Page Fault?</th>
</tr>
</thead>
<tbody>
<tr>
<td>1. 0x6004</td>
<td>_______</td>
<td>_______</td>
<td>Y / N</td>
<td>Y / N</td>
</tr>
<tr>
<td>2. 0x6030</td>
<td>_______</td>
<td>_______</td>
<td>Y / N</td>
<td>Y / N</td>
</tr>
<tr>
<td>3. 0x1234</td>
<td>_______</td>
<td>_______</td>
<td>Y / N</td>
<td>Y / N</td>
</tr>
<tr>
<td>4. 0x2008</td>
<td>_______</td>
<td>_______</td>
<td>Y / N</td>
<td>Y / N</td>
</tr>
</tbody>
</table>
Problem 8. (OS & Virtual Memory Fa’19 Quiz 3 Problem 1)

(A) A RISC-V system with segmentation-based virtual memory is currently running two processes, A and B, with segment base and bound registers listed below:

**Process A:** base register = 0x1000  bound register = 0x4000  
**Process B:** base register = 0x10000  bound register = 0x40000

The table below lists three virtual addresses. Fill the table by translating the addresses for processes A and B. In each cell, write either the physical address that corresponds to the virtual address, or write SEGFAULT if this virtual address is outside the process’s address space (which would cause a segmentation fault, i.e., an out-of-bounds violation).

*Hint:* Recall that the bound check and the translation from virtual to physical address happen in parallel.

<table>
<thead>
<tr>
<th>Virtual Address</th>
<th>Physical address for process A (or SEGFAULT)</th>
<th>Physical address for process B (or SEGFAULT)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x500</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x3500</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x10000</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
(B) Each of these instruction sequences experiences an interrupt or an exception that causes the processor to enter privileged mode (i.e., the operating system).

<table>
<thead>
<tr>
<th>Sequence A</th>
<th>Sequence B</th>
</tr>
</thead>
<tbody>
<tr>
<td>// address 0x0 not resident</td>
<td>li x1, 0x1234</td>
</tr>
<tr>
<td>// in virtual memory</td>
<td>li x2, 0x7</td>
</tr>
<tr>
<td>lw x1, 0x0(x0)</td>
<td>// this instruction is not in RV32I</td>
</tr>
<tr>
<td></td>
<td>div x3, x1, x2</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Sequence C</th>
<th>Sequence D</th>
</tr>
</thead>
<tbody>
<tr>
<td>li x1, 0x10000</td>
<td>endless_loop:</td>
</tr>
<tr>
<td>li x2, 0</td>
<td>la a0, string // loads address</td>
</tr>
<tr>
<td>// this loop gets</td>
<td>li a7, 0x13 // print_string</td>
</tr>
<tr>
<td>// a timer interrupt</td>
<td>syscall number</td>
</tr>
<tr>
<td>loop:</td>
<td>ecall</td>
</tr>
<tr>
<td>addi x2, x2, 1</td>
<td>j endless_loop</td>
</tr>
<tr>
<td>bne x1, x2, loop</td>
<td>string: .ascii &quot;Hello from Quiz 3!\n\n&quot;</td>
</tr>
</tbody>
</table>

Assume that the OS may only switch processes while servicing timer interrupts. Identify the instruction sequence(s) for which the statement applies. If no sequence applies, indicate NONE.

Which sequences...

(i) enter privileged mode: ___A, B, C, D____

(ii) save x1 through x31 and exception pc for the currently executing process:

(iii) handle an exception by emulating the instruction at the saved pc of the current process:

(iv) handle an exception by loading a page from disk: ________________

(v) handle a system call: ________________

(vi) add 4 to the saved pc of the current process: ________________

(vii) subtract 4 from the saved pc of the current process: ________________

(viii) choose a new current process (which may be the same as the current process):

(ix) load registers for the current process, then exit privileged mode and return to the saved pc of the current process: ________________