forked from tanchou/Verilog
MAJ FIFO -> turn wire rd_data into register
This commit is contained in:
@@ -1,25 +1,24 @@
|
|||||||
module fifo #(
|
module fifo #(
|
||||||
parameter DETPH = 16,
|
parameter SIZE = 16,
|
||||||
parameter WIDTH = 8
|
parameter WIDTH = 8
|
||||||
)(
|
)(
|
||||||
input wire clk,
|
input wire clk,
|
||||||
input wire wr_en,
|
input wire wr_en,
|
||||||
input wire[WIDTH-1:0] wr_data,
|
input wire[WIDTH-1:0] wr_data,
|
||||||
input wire rd_en,
|
input wire rd_en,
|
||||||
output wire[WIDTH-1:0] rd_data,
|
output reg[WIDTH-1:0] rd_data,
|
||||||
|
|
||||||
output wire full,
|
output wire full,
|
||||||
output wire empty
|
output wire empty
|
||||||
);
|
);
|
||||||
|
|
||||||
reg [WIDTH-1:0] fifo[0:DETPH-1];
|
reg [WIDTH-1:0] fifo[0:SIZE-1];
|
||||||
reg [3:0] wr_ptr;
|
reg [3:0] wr_ptr;
|
||||||
reg [3:0] rd_ptr;
|
reg [3:0] rd_ptr;
|
||||||
reg [3:0] count;
|
reg [3:0] count;
|
||||||
|
|
||||||
assign full = (count == DETPH);
|
assign full = (count == SIZE);
|
||||||
assign empty = (count == 0);
|
assign empty = (count == 0);
|
||||||
assign rd_data = fifo[rd_ptr];
|
|
||||||
|
|
||||||
initial begin
|
initial begin
|
||||||
wr_ptr = 0;
|
wr_ptr = 0;
|
||||||
@@ -27,15 +26,16 @@
|
|||||||
count = 0;
|
count = 0;
|
||||||
end
|
end
|
||||||
|
|
||||||
always @(posedge clk) begin
|
always @(posedge clk) begin // IN
|
||||||
if (wr_en && !full) begin
|
if (wr_en && !full) begin
|
||||||
fifo[wr_ptr] <= wr_data;
|
fifo[wr_ptr] <= wr_data;
|
||||||
wr_ptr <= (wr_ptr + 1) % DETPH;
|
wr_ptr <= (wr_ptr + 1) % SIZE;
|
||||||
count <= count + 1;
|
count <= count + 1;
|
||||||
end
|
end
|
||||||
|
|
||||||
if (rd_en && !empty) begin
|
if (rd_en && !empty) begin // OUT
|
||||||
rd_ptr <= (rd_ptr + 1) % DETPH;
|
rd_ptr <= (rd_ptr + 1) % SIZE;
|
||||||
|
rd_data <= fifo[rd_ptr];
|
||||||
count <= count - 1;
|
count <= count - 1;
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@@ -120,14 +120,12 @@ localparam DATA_BYTE = 8'h31; // ASCII '1'
|
|||||||
tx_enable <= 1'b0;
|
tx_enable <= 1'b0;
|
||||||
leds[5:0] <= rx_data[5:0];
|
leds[5:0] <= rx_data[5:0];
|
||||||
|
|
||||||
if (tx_ready && delay_counter == 0) begin
|
if (tx_ready && rx_received) begin
|
||||||
// Start new transmission
|
// Start new transmission
|
||||||
tx_enable <= 1'b1;
|
tx_enable <= 1'b1;
|
||||||
data_const <= DATA_BYTE;
|
data_const <= DATA_BYTE;
|
||||||
tx_data <= rx_data;
|
tx_data <= rx_data;
|
||||||
|
|
||||||
// Display received data on LEDs
|
|
||||||
|
|
||||||
delay_counter <= DELAY_CYCLES;
|
delay_counter <= DELAY_CYCLES;
|
||||||
end
|
end
|
||||||
else if (delay_counter > 0) begin
|
else if (delay_counter > 0) begin
|
||||||
|
Reference in New Issue
Block a user