## MP3 Processor Design

**Group: Latecomers** 

Roger Qiu: rizhaoq2,

Yuqi Xue: yuqixue2,

Nickel Liang: zuodong2

## **Internal Control Signals**

| pcmux_sel       | (JAL/R    (BR && br_en)) ? {alu_out[31:2], 2'b0} : pc_plus_4                                                                                                                                                                                    |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| load_regfile    | default: 0<br>reg   load: 1                                                                                                                                                                                                                     |
| aluop           | default: funct3 auipc, jal, jalr, br, add, load, store: alu_add sr & funct7[5] (reg or imm): alu_sra sr & ~funct7[5] (reg or imm): alu_srl                                                                                                      |
| alumux1_sel     | default: rs1_out<br>auipc   jal: pc_out                                                                                                                                                                                                         |
| alumux2_sel     | default: rs2_out jal: j_imm store: s_imm jalr, load, sr, other_imm: i_imm auipc: u_imm                                                                                                                                                          |
| cmpmux_sel      | default: rs2_out<br>slt, sltu (imm): i_imm                                                                                                                                                                                                      |
| cmpop           | <pre>default: funct3 beq: == bne: != blt, slt (reg or imm): \$signed(rs1_out) &lt; \$signed(cmpmux_out) bge: \$signed(rs1_out) &gt;= \$signed(cmpmux_out) bltu, sltu (reg or imm): rs1_out &lt; cmpmux_out bgeu: rs1_out &gt;= cmpmux_out</pre> |
| regfilemux_sel  | default: alu_out lui: u_imm jal   jalr: pc_plus_4 slt, sltu (reg or imm): br_en load: lb/lh/lw/lbu/lhu (according to funct3)                                                                                                                    |
| mem_read        | default: 0<br>load: 1                                                                                                                                                                                                                           |
| mem_write       | default: 0<br>store: 1                                                                                                                                                                                                                          |
| mem_byte_enable | default: 4'b1111 sb: unique case (mem_addr_mod_4) 2'b00: mem_byte_enable = 4'b0001; 2'b01: mem_byte_enable = 4'b0010;                                                                                                                           |

```
2'b10: mem_byte_enable = 4'b0100;

2'b11: mem_byte_enable = 4'b1000;

endcase

sh: (mem_addr_mod_4 == 2'b00)? mem_byte_enable = 4'b0011:

mem_byte_enable = 4'b1100

sw: mem_byte_enable = 4'b1111;
```

