| Name: | Uname: | | |-------|-----------|--| | Name. | Olidilic, | | You have 25 minutes for this quiz. The quiz is closed notes/closed book. If you should finish early, you are welcome to turn in your quiz and step out of the room until the lecture starts. There are 2 pages to this quiz. I have neither given nor received aid on this quiz, nor observed anyone else doing so. In the graph to the right, we see the expected hit rate of a memory access with a given stack distance for two caches with the same number of lines (128) but different degrees of associativity. Both lines have the same area under the curve (again, 128). Using this graph, <u>briefly</u> explain why more associative caches tend to get higher hit rates than less associative caches. [8 points] Consider the following access pattern: A, B, C, A. Assume that A, B, and C are memory addresses each of which are in a different block of memory. Further, assume A, B and C are generated in a uniformly random way and that a "true" LRU replacement algorithm is used. Further, assume that any given block has an equal chance of being placed in either "way" if both blocks are invalid. To receive credit you must show your work. [7 points] What is the probability he the second instance of "A" will be a hit if: - a. The cache has 8 lines (total) and is a two-way associative cache [2] - b. The cache has 8 lines (total) and is a two-way associative skew cache [5] - Consider a case of having 3 processors using a snoopy MESI protocol where the memories can snarf data. All three have a 2 line direct-mapped cache with each line consisting of 16 bytes. The caches begin with all lines marked as invalid. Fill in the following tables indicating - · If the processor gets a hit or a miss in its cache - . If a HIT or HITM (or nothing) occurs on the bus during snoop. - What bus transaction(s) (if any) the processor performs (BRL, BWL, BRIL, BIL) - For misses only, indicate if the miss is compulsory, capacity, conflict, or coherence. A coherence miss is one where there would not have had to create a bus transaction had some other processor not caused an invalidation of that line. In the event more than one bus transaction occurs due to a given memory read/write indicate the response for each bus transaction. Finally, indicate the state of the processor after all of these memory operations have completed. The operations occur in the order shown. [15 points, -0.5 per wrong or blank, minimum of 0] | Processor | Address | Read/<br>Write | Cache<br>Hit/Miss | Bus<br>transaction(s) | HIT/<br>HITM | "4C" miss type<br>(if any) | |-----------|---------|----------------|-------------------|-----------------------|--------------|----------------------------| | ı | 0x100 | Read | | | | | | 1 | 0x210 | Write | | | | | | 1 | 0x200 | Read | | | | | | 1 | 0x100 | Read | | | | | | 1 | 0x140 | Write | | | | | | 2 | 0x200 | Read | | | | | | 1 | 0x100 | Write | | | | | | 1 | 0x210 | Write | | | | | | 3 | 0x120 | Write | | | | | | 1 | 0x310 | Read | | | | | Final state: | | Proc 1 | | | Proc 2 | | | Proc 3 | | |-------|---------|-------|-------|---------|-------|-------|---------|-------| | | Address | State | | Address | State | | Address | State | | Set 0 | | | Set 0 | | | Set 0 | | | | Set 1 | | | Set 1 | | | Set 1 | | | You have 25 minutes for this quiz. The quiz is closed notes/closed book. If you should finish early, you are welcome to turn in your quiz and step out of the room until the lecture starts. There are 2 pages to this quiz. I have neither given nor received aid on this quiz, nor observed anyone else doing so. 1. In the graph to the right, we see the expected hit rate of a memory access with a given stack distance for two caches with the same number of lines (128) but different degrees of associativity. Both lines have the same area under the curve (again, 128). Using this graph, briefly explain why more associative caches tend to get higher hit rates than less associative caches. [8 points] Ascon bee seen, associative Caches get a higher hit rate on low stack distances Because most programs have significant temperal locality we expect mist programs to have me a high percentuse of fairly low stak distance accesses This the associative cache will set a better hit rate. 2. Consider the following access pattern: A, B, C, A. Assume that A, B, and C are memory addresses each of which are in a different block of memory. Further, assume A, B and C are generated in a uniformly random way and that a "true" LRU replacement algorithm is used. Further, assume that any given block has an equal chance of being placed in either "way" if both blocks are invalid. To receive credit you must show your work. [7 points] What is the probability he the second instance of "A" will be a hit if: a. The cache has 8 lines (total) and is a two-way associative cache [2] 1-14-(14) = 15/16 B+C so to some set as A. b. The cache has 8 lines (total) and is a two-way associative skew cache [5] And B goes to different way = (4)-1+3.1/2 = 1/4+ 03/8 = 5/8 B.C conflicts with A+B = 1/16 - Consider a case of having 3 processors using a snoopy MESI protocol where the memories can snarf data. All three have a 2 line direct-mapped cache with each line consisting of 16 bytes. The caches begin with all lines marked as invalid. Fill in the following tables indicating - · If the processor gets a hit or a miss in its cache - If a HIT or HITM (or nothing) occurs on the bus during snoop. - What bus transaction(s) (if any) the processor performs (BRL, BWL, BRIL, BIL) - For misses only, indicate if the miss is compulsory, capacity, conflict, or coherence. A coherence miss is one where there would not have had to create a bus transaction had some other processor not caused an invalidation of that line. In the event more than one bus transaction occurs due to a given memory read/write indicate the response for each bus transaction. Finally, indicate the state of the processor after all of these memory operations have completed. The operations occur in the order shown. [15 points, -0.5 per wrong or blank, minimum of 0] | Processor | Address | Read/<br>Write | Cache<br>Hit/Miss | Bus<br>transaction(s) | HIT/<br>HITM | "4C" miss type<br>(if any) | |-----------|---------|----------------|-------------------|-----------------------|--------------|----------------------------| | 1 | 0x100 | Read | MISS | BRL | - | CUMP | | 1 | 0x210 | Write | MIS 5 | BRIL | 3 | cump | | 1 | 0x200 | Read | M195 | BRL | <del></del> | cump | | 1 | 0x100 | Read | MISS | BRL | - | cas | | 1 | 0x140 | Write | MISS | BPIL | -2 | cump | | 2 | 0x200 | Read | M155 | BRL | ~ | CUMP | | 1 | 0x100 | Write | Miss | BRIL BUL | _ | conflict | | 1 | 0x210 | Write | Hit | - | - | / | | 3 | 0x120 | Write | M195) | BRIL | - | cump | | 1 | 0x310 | Read | MHS | BRL 110WL | 11- | cump | Final state: | | Proc 1 | | | Proc 2 | | | Proc 3 | | |-------|---------|-------|-------|---------|-------|-------|---------|-------| | onl | Address | State | | Address | State | | Address | State | | Set 0 | 02200 | EA | Set 0 | #1200 | ŧ | Set 0 | 01/20 | M | | Set 1 | 0±210 | 104 | Set 1 | | | Set 1 | | | | | on310 | E | - | | | | | |