-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmojo_top.v
176 lines (152 loc) · 3.72 KB
/
mojo_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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
module mojo_top(
// 50MHz clock input
input clk,
// Input from reset button (active low)
input rst_n,
// cclk input from AVR, high when AVR is ready
input cclk,
// Outputs to the 8 onboard LEDs
output[7:0]led,
// AVR SPI connections
output spi_miso,
input spi_ss,
input spi_mosi,
input spi_sck,
// AVR ADC channel select
output [3:0] spi_channel,
// Serial connections
input avr_tx, // AVR Tx => FPGA Rx
output avr_rx, // AVR Rx => FPGA Tx
input avr_rx_busy, // AVR Rx buffer full
// WS2812
output reg d_out
);
wire rst = ~rst_n; // make reset active high
// these signals should be high-z when not used
assign spi_miso = 1'bz;
assign avr_rx = 1'bz;
assign spi_channel = 4'bzzzz;
wire nclock;
wire [31:0] colour;
reg [31:0] mdin = 0;
reg [31:0] addra = 0;
reg [3:0] wea = 0;
blkmem colours (
.clka(clk), // input clka
.wea(wea), // input [3 : 0] wea
.addra(addra), // input [31 : 0] addra
.dina(mdin), // input [31 : 0] dina
.douta(colour) // output [31 : 0] douta
);
// Start LED Control
parameter FSM_RST = 3'b000;
parameter FSM_1_H = 3'b001;
parameter FSM_1_L = 3'b010;
parameter FSM_0_H = 3'b011;
parameter FSM_0_L = 3'b100;
parameter FSM_READ = 3'b101;
parameter TEST_COLOR = 48'h020020000000;
parameter TEST_BLACK = 48'h000000020020;
parameter TEST_LEN = 8'd48;
parameter T1H = 32'd35; //0.70us
parameter T1L = 32'd30; //0.60us
parameter T0H = 32'd17; //0.34us
parameter T0L = 32'd35; //0.80us
parameter T_RES = 32'd50000; //1ms
parameter NUM_LEDS = 8'd2;
wire send_data = led[0];
reg [2:0] FSM = 3'b000;
reg [7:0] r_position = 8'b0;
reg [7:0] current_led = 8'b0;
wire [31:0] counter1;
reg counter1_rst = 1'b0;
reg flip_colour = 1'b0;
reg [31:0] filp_counter = 0;
assign led[7:3] = 0;
assign led[2:0] = FSM[2:0];
initial begin
d_out = 1'b0;
end
counter counter1_cntr(.rst(counter1_rst), .clk(clk), .mycounter(counter1));
always @(posedge clk)
case(FSM)
FSM_RST: begin
if (filp_counter == 1000) begin
filp_counter = 0;
flip_colour = ~flip_colour;
end
filp_counter = filp_counter + 1;
// Reset Read
counter1_rst = 0;
current_led = 0;
r_position = 8'b0;
d_out = 1'b0;
if (addra > 100)
addra = 0;
if (counter1 > T_RES) begin
counter1_rst = 1;
FSM = FSM_READ;
end
end
FSM_READ: begin
if (r_position == TEST_LEN) begin
addra = addra + 1;
if ((current_led + 1) == NUM_LEDS) begin
FSM = FSM_RST;
counter1_rst = 1;
end else begin
r_position = 0;
current_led = current_led + 1;
end
end else begin
if (flip_colour) begin
if (colour[r_position] == 1) begin
FSM = FSM_1_H;
end else begin
FSM = FSM_0_H;
end
end else begin
if (TEST_BLACK[r_position] == 1) begin
FSM = FSM_1_H;
end else begin
FSM = FSM_0_H;
end
end
r_position = r_position + 1;
end
end
FSM_1_H: begin
counter1_rst = 0;
d_out= 1'b1;
if(counter1 > T1H) begin
counter1_rst = 1'b1;
FSM = FSM_1_L;
end
end
FSM_1_L: begin
counter1_rst = 0;
d_out = 1'b0;
if(counter1 > T1L) begin
counter1_rst = 1'b1;
FSM = FSM_READ;
end
end
FSM_0_H: begin
counter1_rst = 0;
d_out = 1'b1;
if(counter1 > T0H) begin
counter1_rst = 1'b1;
FSM = FSM_0_L;
end
end
FSM_0_L: begin
counter1_rst = 0;
d_out = 1'b0;
d_out = 1'b0;
if(counter1 > T0L) begin
counter1_rst = 1'b1;
FSM = FSM_READ;
end
end
endcase
endmodule