-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtop.v
113 lines (90 loc) · 1.98 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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
`default_nettype none
module top (
input CLK,
output PIN_1,
output USBPU
);
localparam PX_COUNT = 298;
assign USBPU = 1'b0;
// Inputs and Outputs
reg [9:0] cd_index;
wire [9:0] cd_x, cd_y;
coord cd(
.index(cd_index),
.x(cd_x),
.y(cd_y)
);
reg pixel_valid, pixel_tick;
reg [9:0] pixel_x, pixel_y;
reg pixel_ack;
wire pixel_validOut, pixel_ready;
wire [7:0] pixel_red, pixel_green, pixel_blue, pixel_alpha;
panel_pulse pixel(
.clk(CLK),
.valid(pixel_valid),
.tick(pixel_tick),
.x(pixel_x),
.y(pixel_y),
.ack(pixel_ack),
.validOut(pixel_validOut),
.ready(pixel_ready),
.red(pixel_red),
.green(pixel_green),
.blue(pixel_blue),
.alpha(pixel_alpha)
);
reg [7:0] px_red, px_green, px_blue;
reg px_reset, px_valid;
wire px_ready;
pixel_driver
#(.CLK_HZ(16000000),
.HZ(80),
.LED(PX_COUNT))
px(
.clk(CLK),
.red(px_red),
.green(px_green),
.blue(px_blue),
.reset(px_reset),
.valid(px_valid),
.ready(px_ready),
.clk_out(PIN_1)
);
// Connections
reg [9:0] index = 0;
reg renderValid, renderTick, renderReady;
reg outValid, outReset, outReady;
reg [9:0] x, y;
always @(*) begin
cd_index = index;
x = cd_x;
y = cd_y;
pixel_valid = renderValid;
pixel_tick = renderTick;
pixel_x = index;
pixel_y = 0;
pixel_ack = renderValid;
px_red = pixel_red;
px_green = pixel_green;
px_blue = pixel_blue;
outReset = (index == PX_COUNT);
outReady = px_ready;
outValid = outReady;
px_reset = outReset;
px_valid = outValid;
end
always @(posedge CLK) begin
renderValid <= 0;
renderTick <= 0;
if (outReady) begin
renderValid <= 1;
if (outReset) begin
index <= 0;
end else begin
index <= index + 1;
if (index == PX_COUNT - 1)
renderTick <= 1;
end
end
end
endmodule // top