## Assignment 2 (100 points) Due Thursday, September 10th

1 (60 pts) Schedule the following code segment by applying Tomasulo' algorithm. Assume the floating point addition takes 2 cycles, the floating point multiplication takes 3 cycles and other operations take only 1 cycle. Figure 1 shows the initial states of the reservation station for the adder and multiplier, and the initial values of the floating point registers (FLR). Please schedule the instructions and update the states of the reservation stations and FLR for each clock cycle, until this code segment is finished.





2. (40 pts) In your own words, summarize how are RAW, WAR, and WAR dependences handled by the Tomasulo's algorithm.

WAR is handled by copying the read data into the reservation station during dispatch, so any subsequent writes don't affect the operand data.

RAW is handled by marking the incomplete register data as busy, and at dispatch time the reading (latter) instruction takes the tag instead of the data. Now the former instruction can fill in the tag with the actual data when it completes.

WAW is handled in a way similar to register forwarding. The first write writes its tag to the FLR and any subsequent instruction before the later write will use that tag and eventually get the correct data from the CDB. So, the later instruction can overwrite anything in the FLR and not cause any data to be incorrect.