## E85: Digital Design and Computer Engineering Problem Set 10

Hint: many students in the past have found it helpful to review the textbook for this problem set, including Section 7.4 about the multicycle processor, Section 7.5 about the pipelined processor, Appendix B.3 about the Branch with Link instruction, and Section 5.5.5 about Register files.

- 1) Modify the multicycle-cycle ARM processor to implement the BL instruction. Mark up copies of the controller, main decoder FSM, ALU decoder, and datapath (attached) to handle the new instruction as simply as possible. Name any control signals you need to add.
- 2) Goliath Corp claims to have a patent on a three-ported register file. Rather than fighting Goliath in Court, you offer to design a new register file with only two ports. Port 1 can be read or written, and port 2 is read-only. Redesign the multicycle datapath and controller (attached) to use your new register file.
- 3) How long would your processor from the previous question take to execute the 100-billion instruction program from Example 7.6? Assume your new register file has 30% lower clk-to-Q and setup time because it has fewer ports but ordinary registers and other blocks have delay unchanged.
- 4) Do Exercise 7.28 from the textbook.
- 5) Do Exercise 7.30 from the textbook.
- 6) Impact on Society: Write a thoughtful paragraph describing a concrete example of how the skills you have developed in E85 may be applicable to another field of engineering in which you are interested in practicing.

How long did you spend on this problem set? This will not count toward your grade but will help calibrate the workload.



Problem 1: Multicycle Datapath



Problem 1: Multicycle Controller



Problem 1: Multicycle Main Control FSM

| ALUOp | Funct <sub>4:1</sub><br>(cmd) | Funct <sub>o</sub><br>{S} | Туре   | ALUControl 20 | FlagW <sub>10</sub> |
|-------|-------------------------------|---------------------------|--------|---------------|---------------------|
| 0     | х                             | х                         | Not DP | 00 (Add)      | 00                  |
| 1     | 0100                          | 0                         | ADD    | 00 (Add)      | 00                  |
|       |                               | 1                         |        |               | 11                  |
|       | 0010                          | 0                         | SU B   | 01 (Sub)      | 00                  |
|       |                               | 1                         | ]      |               | 11                  |
|       | 0000                          | 0                         | AN D   | 10 (And)      | 00                  |
|       |                               | 1                         | ]      |               | 10                  |
|       | 1100                          | 0                         | ORR    | 11 (Or)       | 00                  |
|       |                               | 1                         | ]      |               | 10                  |

Table 7.3 ALU Decoder truth table

Problem 1: ALU Decoder



Problem 2: Multicycle Datapath



Problem 2: Multicycle Controller



Problem 2: Multicycle Main Control FSM

| ALUOp | Funct <sub>4:1</sub><br>(cmd) | Funct <sub>o</sub><br>{S} | Туре   | ALUControl 20 | FlagW <sub>10</sub> |
|-------|-------------------------------|---------------------------|--------|---------------|---------------------|
| 0     | х                             | х                         | Not DP | 00 (Add)      | 00                  |
| 1     | 0100                          | 0                         | ADD    | 00 (Add)      | 00                  |
|       |                               | 1                         | ]      |               | 11                  |
|       | 0010                          | 0                         | SU B   | 01 (Sub)      | 00                  |
|       |                               | 1                         | ]      |               | 11                  |
|       | 0000                          | 0                         | AN D   | 10 (And)      | 00                  |
|       |                               | 1                         | ]      |               | 10                  |
|       | 1100                          | 0                         | OR.R.  | 11 (Or)       | 00                  |
|       |                               | 1                         | ]      |               | 10                  |

Table 7.3 ALU Decoder truth table

Problem 2: ALU Decoder