-
Notifications
You must be signed in to change notification settings - Fork 0
/
ID.sv
48 lines (48 loc) · 2.7 KB
/
ID.sv
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
/*
┌──────────────────────────────────────┐
│ ┌─────────────────────┼─────
│ │ [31:0] │
│ ┌─────┐ │DIn ┌─────────┐ │
│ │ │rd └────► │r1 │
│ │ ├─────────► Reg ├──────┼────►
│ │ D │rs1[4:0] │ File │ │
│ │ ├─────────► │r2 │
│ │ E │rs2[4:0] │ ├──────┼────►
Data │ │ ├─────────► │ │
─────┼────► C │ │ Wr│ │
[31:0]│ │ │ └──────▲──┘ │
│ │ O │ │ │
│ │ │Instruction │ │
│ │ D ├──────────┐ │ │
│ │ │ [31:0] │ │ │
│ │ E │ │ │ │
│ │ │ ┌──▼───┐ │ │
│ │ R │Opcode│ │ │ │ [31:0]
│ │ ├┬─────► Ext ├──┼─────────┼────►Immediate
│ │ ││[6:0]│ │ │ │ Value
│ └┬──┬─┘│ └──────┘ │ │
│ │ │ │ │ │
└──────┼──┼──┼───────────────┼─────────┘
▼ ▼ ▼ ▼ WriteEn
F3 F7 Opcode
*/
module ID(data, f3, f7, opcode, WrEn, Imm, r1, r2, DIn, clk);
input logic [31:0] data;
output logic [2:0] f3;
output logic [6:0] f7;
output logic [6:0] opcode;
input bit WrEn;
input bit clk;
output logic [31:0] Imm;
output logic [31:0] r1;
output logic [31:0] r2;
input logic [31:0] DIn;
logic [31:0] inst;
logic [4:0] rs1;
logic [4:0] rs2;
logic [4:0] rd;
decoder dec(.instIn(data), .opcode(opcode), .instOut(inst), .rs1(rs1), .rs2(rs2), .rd(rd), .fn3(f3), .fn7(f7));
//decoder dec(.(data), .(opcode), .(inst), .(rs1), .(rs2), .(rd), .(f3), .(f7));
SignExtender sext(.opcode(opc), .instIn(inst), .immOut(Imm));
RegisterFile regfile(.din(DIn), .rd(rd), .rs1(rs1), .rs2(rs2), .wen(WrEn), .r1(r1), .r2(r2), .clk(clk));
endmodule