1.

|                         | Add | $\operatorname{Sub}$ | LW  | SW                   | BEQ                  | Addi                 |
|-------------------------|-----|----------------------|-----|----------------------|----------------------|----------------------|
| RegDst                  | 1   | 1                    | 0   | D                    | D                    | 0                    |
| $\operatorname{ALUSrc}$ | 0   | 0                    | 1   | 1                    | 0                    | 1                    |
| MemToReg                | 0   | 0                    | 1   | D                    | 0                    | 0                    |
| RegWrite                | 1   | 1                    | 1   | 0                    | 0                    | 1                    |
| PCSrc                   | 0   | 0                    | 0   | 0                    | 1                    | 0                    |
| MemWrite                | 0   | 0                    | 0   | 1                    | 0                    | 0                    |
| MemRead                 | 0   | 0                    | 1   | 0                    | 0                    | 0                    |
| ALUOp                   | Add | Sub                  | Add | $\operatorname{Add}$ | $\operatorname{Sub}$ | $\operatorname{Add}$ |

2.

No changes would need to be made to the diagram.

RegDst 1
AluSrc 0
PCSrc 0
MemToReg 1
MemRead 1
MemWrite 0



a)

I would add a mux in front of the read 1 input that on a 1 would select the low order 5 bits called ReadA and I would add a Mux to the read 2 input that on a 1 would select 15-11 called ReadB

