-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtop.v
74 lines (68 loc) · 1.62 KB
/
top.v
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
module top(
input CLOCK_50,
input [3:0] KEY,
input [17:0] SW,
output [8:0] LEDG,
output [17:0] LEDR,
output [6:0] HEX0,
output [6:0] HEX1,
output [6:0] HEX2,
output [6:0] HEX3,
output [6:0] HEX4,
output [6:0] HEX5,
output [6:0] HEX6,
output [6:0] HEX7,
inout [35:0] GPIO
);
wire wClock;
clock clock0(
.iStateClock(KEY[1]),
.iState(SW[9:8]),
.iMaxClock(CLOCK_50),
.iManualClock(KEY[0]),
.iLimit(SW[7:0]),
.oClock(wClock)
);
wire [2:0] wcounter;
wire [31:0] wIP;
wire [31:0] wA;
wire [31:0] wB;
wire [31:0] wJ;
wire [31:0] wq;
wire [31:0] wsub;
wire wleq;
subleq cpu(
.iClock(wClock),
.iReset(~KEY[3]),
.ocounter(wcounter),
.oIP(wIP),
.oA(wA),
.oB(wB),
.oJ(wJ),
.oq(wq),
.osub(wsub),
.oleq(wleq)
);
wire [31:0] decoder7_num;
always @(SW[15:13], wcounter, wIP, wA, wB, wJ, wq, wsub, wleq) begin
case (SW[15:13])
3'd0: decoder7_num <= {29'b0, wcounter};
3'd1: decoder7_num <= wIP;
3'd2: decoder7_num <= wA;
3'd3: decoder7_num <= wB;
3'd4: decoder7_num <= wJ;
3'd5: decoder7_num <= wq;
3'd6: decoder7_num <= wsub;
3'd7: decoder7_num <= {31'b0, wleq};
endcase
end
decoder7 dec0(.in(decoder7_num[3:0]), .out(HEX0));
decoder7 dec1(.in(decoder7_num[7:4]), .out(HEX1));
decoder7 dec2(.in(decoder7_num[11:8]), .out(HEX2));
decoder7 dec3(.in(decoder7_num[15:12]), .out(HEX3));
decoder7 dec4(.in(decoder7_num[19:16]), .out(HEX4));
decoder7 dec5(.in(decoder7_num[23:20]), .out(HEX5));
decoder7 dec6(.in(decoder7_num[27:24]), .out(HEX6));
decoder7 dec7(.in(decoder7_num[31:28]), .out(HEX7));
assign GPIO[0] = (wcounter == 3'd0);
endmodule