-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCU.v
More file actions
85 lines (74 loc) · 1.91 KB
/
CU.v
File metadata and controls
85 lines (74 loc) · 1.91 KB
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
module CU(input [3:0] opcode,
input clk,
output logic reg_write_en,
output logic mem_write_en,
output logic mem_to_reg,
output logic mem_op,
output reg [1:0] ALU_select
);
// initial begin
// ALU_select <= 2'b00;
// end
always @(posedge clk) begin
case(opcode)
// Load
// Write to reg, read from mem
4'b0000:
begin
mem_op <= 1;
mem_to_reg <= 1;
reg_write_en <= 1;
mem_write_en <= 0;
end
// Store
// Write to mem, read from reg
4'b0001:
begin
mem_op <= 1;
mem_to_reg <= 0;
reg_write_en <= 0;
mem_write_en <= 1;
end
// Add
// Write to reg, ALU_select = 0
4'b0010:
begin
mem_op <= 0;
mem_to_reg <= 0;
reg_write_en <= 1;
mem_write_en <= 0;
ALU_select <= 2'b00;
end
// Subtract
// No memory operation, ALU_select = 1
4'b0011:
begin
mem_op <= 0;
mem_to_reg <= 0;
reg_write_en <= 1;
mem_write_en <= 0;
ALU_select <= 2'b01;
end
// LS
// No memory operation, ALU_select = 2
4'b0100:
begin
mem_op <= 0;
mem_to_reg <= 0;
reg_write_en <= 1;
mem_write_en <= 0;
ALU_select <= 2'b10;
end
// Compare
// No memory operation, ALU_select = 3
4'b0101:
begin
mem_op <= 0;
mem_to_reg <= 0;
reg_write_en <= 1;
mem_write_en <= 0;
ALU_select <= 2'b11;
end
endcase
end
endmodule