Due at the beginning of recitation R22 on Friday November 30.

Consider a direct-mapped branch target buffer (BTB) like the one we’ve seen in lecture.

(A) Assume you have a processor that supports 32-bit addresses. Given a BTB with 8 entries in it. What would be the size of each entry of your BTB if you had a long enough tag to differentiate between each address in your addresses space? Make sure to account for the tag bits, the target address bits, and the valid bit.

   Size of a BTB entry: _______________

(B) Now suppose that you are told that each of your code segments was at most 4k bytes long. What effect, if any, would that have on the size of your BTB entry if you want to use the minimum number of tag bits necessary to differentiate between any two addresses in a given program? Assume that the target address bits do not change.

   Size of a BTB entry (with 4k max code segments): _______________

(C) What are the implications of having only 8 entries in your BTB?