## Control words for each stage

| Opcode                                                                                              | Fetc<br>h | Decode                     | Execute                                                                     | Mem Access                                          | WB                                      |
|-----------------------------------------------------------------------------------------------------|-----------|----------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------|-----------------------------------------|
| Add<br>SUB<br>SLL<br>SLTU<br>XOR<br>SRL<br>SRA<br>OR<br>AND                                         |           | Rs1<br>Rs2<br>Rd           | Rd_rt = rd<br>Alu_op = alu<br>Alu_mux_sel1 = Rs1<br>Alu_mux_sel2 = Rs2      |                                                     | Data_or_alu = alu<br>Load_reg_file = 1  |
| ADDI<br>SLTI<br>SLTIU<br>XORI<br>ORI<br>ANDI<br>SLTI<br>XORI<br>ORI<br>ANDI<br>SLLI<br>SRLI<br>SRAI |           | Rs1<br>Rd                  | Rd_rt = rd<br>Alu_op = alu<br>Alu_mux_sel1 = Rs1<br>Alu_mux_sel2 =<br>i_imm |                                                     | Data_or_alu = alu<br>Load_reg_file = 1  |
| SB<br>SH<br>SW                                                                                      |           | Rs1<br>Rs2                 | Rd_rt = rt Alu_op = add Alu_mux_sel1 = Rs1 Alu_mux_sel2 = s_imm             | Mem_write = 1 Mem_address = alu_out Mem_wdata = rs2 |                                         |
| LB<br>LH<br>LW<br>LBU<br>LHU                                                                        |           | Rs1<br>Rd                  | Rd_rt = rd<br>Alu_op = add<br>Alu_mux_sel1 = Rs1<br>Alu_mux_sel2 =<br>s_imm | Mem_read = 1 Mem_address = alu_out                  | Data_or_alu = data<br>Load_reg_file = 1 |
| BEQ<br>BNE<br>BLT<br>BGE                                                                            |           | Pass Pc to adder Branch or |                                                                             |                                                     |                                         |

| BLTU<br>BGEU | jal=branch<br>Rs1<br>Rs2                |                                                              |                                            |
|--------------|-----------------------------------------|--------------------------------------------------------------|--------------------------------------------|
| JALR         | Rs1<br>Rd<br>Jalr = 1                   | Rd_rt = rd                                                   | Data_or_alu = pcPlus4<br>Load_reg_file = 1 |
| JAL          | Rd Pass Pc to adder branch or jal = jal | Rd_rt = rd                                                   | Data_or_alu = pcPlus4<br>Load_reg_file = 1 |
| AUIPC        | Rd                                      | Alu_op = add<br>Alu_mux_sel1 = pc<br>Alu_mux_sel2<br>= u_imm | Data_or_alu = alu<br>Load_reg_file = 1     |
| LUI          | Rd                                      |                                                              | Data_or_alu = u_imm<br>Load_reg_file = 1   |