1 point for saying there was no change to the datapath, or less preferably you drew an unmodified diagram.
1/2 point per correct signal value (RegDst, ALUSrc etc) plus a free 1/2 point (it makes the point total a whole number).
The signal values should be:
RegDst | ALUSrc | Memto- Reg | Reg Write | Mem Read | Mem Write | Branch | ALUOp1 | ALUOp2 |
---|---|---|---|---|---|---|---|---|
0a | 1b | 0c | 1d | 0c | 0c | 0e | 0f | 0f |
1 point for saying it would not affect a single cycle datapath.
1 point for a reason why this is the case, no matter whether you said it would
or would not affect the datapath.
1 point for explicitly stating it would not affect a multicycle datapath.
1 point for a reason why, again no matter whether you said it would or would
not affect the datapath.
In the single cycle datapath, both signals are asserted or deasserted at the same time for any operation, or one signal has a value and the other is a don't care. Hence we can use one combined control signal.
In the multicycle datapath, it is not the case that the signals are asserted or deasserted at the same time. However they can be and the finite state machine can be modified accordingly. The deasserted RegWrite signal will prevent old values in the memory data register from being written to the register file. That is only when a load from memory has completed will we write into the register file. Note that this same deasserted signal prevents the instruction fetch stage from accidently overwriting a general purpose register.
If you only drew the part of the finite state you had to make it clear what changes you had made, for example distinguishing new states from existing ones.
1 point for saying there was no change to the datapath, or less preferably you drew an unmodified diagram.
7 points for the finite state diagram:
1 point for stating how many cycles it takes to to execute an addi instruction.
The number of cycles for addi is the same as any R-type instruction i.e. 4 cycles. To work this out, you just have to count the number of transitions you make when following the path through the finite state diagam for an addi instruction, starting and ending in state 0.