Computer Science, asked by dulapallip3234, 3 days ago

A computer system contains a main memory of 32k 16-bit words. It also has a 4kword cache divided into four-line sets with 64 words per line. Assume that the cache is initially empty. The processor fetches words from locations 0, 1, 2, . . ., 4351 in that order. It then repeats this fetch sequence nine more times.The cache is 10 times faster than main memory. Estimate the improvement resulting from the use of the cache. Assume an lru policy for block replacement.

Answers

Answered by kumarisushma
0

Answer:

In cache we have 64 words per line and 4 lines per set (4 way associativity) and total size is 4096 words. So,

number of sets=409664×4=16

So after accessing 16×64=1024 words (0-1023) all the sets will be filled with one entry each. But with 4-way associativity each set has space for 3 more. So filling can go like this for 4096 words (0-4095). After this next entry (cache line from 4096-4159) will go to first set and will replace the cache line 0-63 due to LRU policy. Like wise total no. of cache replacements = (4351-4096)/64 = 256/64 = 4.

Now for the second iteration the first four cache line accesses will be cache misses as they got replaced. But these cache lines will be replacing the oldest used one in the set. For example cache line 0-63 will be replacing 1024-1095. Now the cache line 1024-1095 will in turn be replacing 2048-2111 and likewise all new cache line accesses will be cache misses (LRU works badly). This will trigger 16 cache line misses - 4 each from the first four sets. For 5th set to 16th set, there won't be any cache miss. Now, for the cache lines 4096-4351, there will be 4 more cache misses which are again coming from the first 4 sets. So, totally 16+4 = 20 cache misses. (Shown in figure at end)

Thus,

Access time with cache=no. of memory access×hit time+no. of cache misses×memory access time for a block=(4352×10)×0.1x+(68+9×20)64x=20224x

Similar questions