ALU (immediate part) to ALUout(register): second cycle (load & store instructions)
sign extend & shift to ALU to
| Signal name | 0 | 1 | Comment | 1 | 2 | 3R | 3M | 3B | 4R | 4M | 5 |
| RegDst | write to rt | write to rd | MUX2 | X | X | X | X | X | 1 | X | 0 |
| RegWrite | write to register | X | X | X | X | X | 1 | X | 1 | ||
| ALUSrcA | PC | register A | MUX4 | 0 | 0 | 1 | 1 | 1 | |||
| MemRead | read from memory | 1 | 1 | ||||||||
| MemWrite | write to memory | X | |||||||||
| MemToReg | data from ALU | data from memory | MUX3 | 0 | 1 | ||||||
| IorD | address from PC | address from ALU | MUX1 | 0 | 1 | ||||||
| IRWrite | latch instruction register | 1 | |||||||||
| PCWrite | write PC | 1 | |||||||||
| CondPCWrite | write PC if ALUout = 0 | 1 |
| Signal | Value | Effect | 1 | 2 | 3E | 3M | 3B | 4 | 5 |
| ALUOp | 00 | add | S | S | S | S | |||
| 01 | subtract | S | |||||||
| 10 | determine by funct | ||||||||
| ALUSrcB | 00 | input from register B | S | ||||||
| 01 | input is 4 | S | |||||||
| 10 | input is immediate field | S | S | ||||||
| 11 | input is shifted immediate field | S | |||||||
| PCSource | 00 | PC from ALUout | S | ||||||
| 01 | PC from ALUOut | S | |||||||
| 10 | PC gets jump target from immediate |
Return to: