(b) The results are shown in the following two tables; the first table corresponds direct mapping and the second two-way set-associative mapping. In each table, arrow connecting the same block numbers indicates that the corresponding acc takes more than one cycle due to read/write misses or bus contention. In any ca at most 3 cycles are required to complete an access in the case of a read/write m coupled with bus contention. The subscript associated with a block indicates t state of that block (R for read-only, and W for read-write.)

| Г  | cycle       | 1   | 2             | 3     | 4     | 5     | 6             | 7     | 8     | 9     | 10                         | 11                         | 12          | 13      | 14            | 15         | 16                         | 17                         |
|----|-------------|-----|---------------|-------|-------|-------|---------------|-------|-------|-------|----------------------------|----------------------------|-------------|---------|---------------|------------|----------------------------|----------------------------|
| P1 | block trace | 0 - | → O           | 0     | 0     | 1 -   | → <b>1</b>    | 1     | 4 -   | → 4   | 3 -                        | → 3                        | 3           | 5       | $\rightarrow$ | 5          | 5                          | 5                          |
|    | frame 0     | _   | $0_R$         | $0_w$ | $0_w$ | $0_w$ | $0_R$         | $0_R$ | _     | $4_R$ | $4_{\scriptscriptstyle R}$ | $4_{\scriptscriptstyle R}$ | $4_R$       | $4_R$   | $4_R$         | $4_R$      | $4_{\scriptscriptstyle R}$ | $4_{\scriptscriptstyle R}$ |
|    | frame 1     | _   | _             | _     | _     | _     | $1_w$         | $1_w$ | $1_w$ | $1_w$ |                            | $1_w$                      | $1_w$       | _       |               | $5_R$      | $5_w$                      | $5_w$                      |
|    | frame 2     |     | _             | _     | _     | _     | _             | _     | _     | _     |                            |                            | _           | _       | _             |            |                            |                            |
|    | frame 3     | _   | _             | _     | _     | _     |               | _     | _     | _     | _                          | $3_R$                      | $3_R$       | $3_R$   | $3_R$         | $3_R$      | $3_R$                      | $3_R$                      |
|    | cache miss  | *   |               | ×     |       | *     |               |       | *     |       | *                          | - 10                       | -10         | *       | 10            | - 10       | 10                         | 7.                         |
|    | bus in use  | *   |               | *     |       | *     |               |       | *     |       | *                          |                            |             | *       | *             |            | *                          |                            |
| P2 | block trace | 2   | $\rightarrow$ | 2     | 2     | 0     | $\rightarrow$ | 0     | 0     |       | → <b>7</b>                 | -                          |             | 5       | 5             | 7          | 7                          | 0                          |
|    | frame 0     | _   | _             | _     | _     | _     | _             | $0_R$ | $0_R$ | $0_R$ | $0_R$                      | $0_R$                      | $0_R$       | $0_R$   | $0_R$         | $0_R$      | $0_R$                      | $0_R$                      |
|    | frame 1     |     | _             | _     | -     | _     | _             | _     | _     | _     | -                          |                            | $5_R$       | $5_R$   | $5_R$         | $5_R$      | _                          |                            |
|    | frame 2     | -   |               | $2_R$ | $2_w$ | $2_w$ | $2_w$         | $2_w$ | $2_w$ | $2_w$ | $2_w$                      | $2_w$                      | $2_w$       | $2_w$   | $2_w$         | $2_w$      | $2_w$                      | $2_w$                      |
|    | frame 3     | 9-  | _             | _     |       | _     | _             | _     | _     | _     |                            | $7_w$                      | $7_w$       | $7_w$   | $7_w$         | $7_w$      | $7_w$                      | $7_w$                      |
|    | cache miss  | *   |               |       |       | *     |               |       |       | *     |                            | *                          |             | - 5     |               | 6          |                            |                            |
|    | bus in use  |     | *             |       | *     |       | *             |       |       | *     |                            | *                          |             |         |               | (*)        |                            |                            |
|    | _           | 200 |               |       |       |       |               |       |       |       |                            |                            |             |         |               | $\bigcirc$ | ۲,                         |                            |
| P1 | cycle       | 1   | 2             | 3     | 4     | 5     | 6             | 7     | 8     | 9     | 10                         | 11                         | 12          | 13      | 14            | 15         | 16                         | 17                         |
|    | block trace |     |               | 0     | 0     | 1 -   |               | 1     | 4 -   |       | 3 -                        |                            | 3           | 5       | $\rightarrow$ | 5          | 5                          | 5                          |
|    | frame 0     |     | $0_R$         | $0_w$ | $0_w$ | $0_w$ | $0_R$         | $0_R$ | $0_R$ | $0_R$ | $0_R$                      | $0_R$                      | $0_R$       | $0_R$   | $0_R$         | $0_R$      | $0_R$                      | $0_R$                      |
|    | frame 1     | _   |               | _     |       | _     | _             |       | _     | $4_R$ | $4_R$                      | $4_R$                      | $4_R$       | $4_R$   | $4_R$         | $ 4_R $    | $4_{\scriptscriptstyle R}$ | $4_R$                      |
|    | frame 2     | _   | _             |       | _     | _     | $1_w$         | $1_w$ | $1_w$ | $1_w$ | $1_w$                      | $\perp_{w}$                | $\perp_{W}$ | _       |               | $ 5_R $    | $5_w$                      | $ 5_w $                    |
|    | frame 3     |     | _             | _     | _     | _     | _             | _     | =     | _     | _                          | $3_R$                      | $3_R$       | $3_R$   | $3_R$         | $3_R$      | $3_R$                      | $3_R$                      |
|    | cache miss  | *   |               |       |       | *     |               |       | *     |       | *                          |                            |             | *       |               |            |                            | 22.                        |
|    | bus in use  | *   |               | *     |       | *     |               |       | *     |       | *                          |                            |             | *       | *             |            | *                          |                            |
| P2 | block trace | 2   | $\rightarrow$ | 2     | 2     | 0     | $\rightarrow$ | 0     | 0     | 100   | → <b>7</b>                 | 5 -                        |             | 5       | 5             | 7          | 7                          | 0                          |
|    | frame 0     | _   | _             | $2_R$ | $2_w$ | $2_w$ | $2_w$         | $2_w$ | $2_w$ | $2_w$ | $2_w$                      | $2_w$                      | $2_w$       | $2_w$   | $2_w$         | $2_w$      | $2_w$                      | $2_w$                      |
|    | frame 1     | _   | _             | _     | _     | _     | _             | $0_R$ | $0_R$ | $0_R$ | $0_R$                      | $0_R$                      | $0_R$       | $0_R$   | $0_R$         | $0_R$      | $0_R$                      | $0_R$                      |
|    | frame 2     | _   |               | _     | _     | _     | _             | _     |       | _     | $7_w$                      | $7_w$                      | $ 7_w $     | $ 7_w $ | $ 7_w $       | $7_w$      | $7_w$                      | $7_w$                      |
|    | frame 3     |     | _             | _     | _     | _     | _             | _     | _     | -     | -                          |                            | $5_R$       | $5_R$   | $5_R$         | $5_R$      | _                          |                            |
|    | cache miss  | *   |               |       |       | *     |               |       |       | *     |                            | *                          |             |         |               |            |                            |                            |
|    | bus in use  |     | *             |       | *     |       | *             |       |       | *     |                            | *                          |             |         |               | *          |                            |                            |

For the given page reference patterns, the hit ratio is 6/11 for P1 and 7/11 for P2 with either cache organization. The major difference is the contents of block frames in the caches due to different ways of mapping between memory and cache As can be seen, a memory block can possibly reside in more cache block frames with the set-associative organization, which generally improves hit ratio.