Line 70... |
Line 70... |
logic [31:0] data_int;
|
logic [31:0] data_int;
|
logic [31:0] data_int_next;
|
logic [31:0] data_int_next;
|
logic [15:0] counter;
|
logic [15:0] counter;
|
logic [15:0] counter_trgt;
|
logic [15:0] counter_trgt;
|
logic [15:0] counter_next;
|
logic [15:0] counter_next;
|
logic [15:0] counter_trgt_next;
|
|
logic reg_done;
|
logic reg_done;
|
enum logic [1:0] { IDLE, RECEIVE, WAIT_FIFO, WAIT_FIFO_DONE } rx_CS, rx_NS;
|
enum logic [1:0] { IDLE, RECEIVE, WAIT_FIFO, WAIT_FIFO_DONE } rx_CS, rx_NS;
|
|
|
|
|
assign reg_done = (!en_quad_in && (counter[4:0] == 5'b11111)) || (en_quad_in && (counter[2:0] == 3'b111));
|
assign reg_done = (!en_quad_in && (counter[4:0] == 5'b11111)) || (en_quad_in && (counter[2:0] == 3'b111));
|
|
|
// RISV is little endian, so data is converted to little endian format
|
// RISV is little endian, so data is converted to little endian format
|
assign data = (ENDIEAN) ? data_int_next : {data_int_next[7:0],data_int_next[15:8],data_int_next[23:16],data_int_next[31:24]};
|
assign data = (ENDIEAN) ? data_int_next : {data_int_next[7:0],data_int_next[15:8],data_int_next[23:16],data_int_next[31:24]};
|
assign rx_done = (counter == (counter_trgt-1)) & rx_edge;
|
|
|
|
always_comb
|
|
begin
|
|
if (counter_in_upd)
|
|
counter_trgt_next = (en_quad_in) ? {2'b00,counter_in[15:2]} : counter_in;
|
|
else
|
|
counter_trgt_next = counter_trgt;
|
|
end
|
|
|
|
always_comb
|
always_comb
|
begin
|
begin
|
rx_NS = rx_CS;
|
rx_NS = rx_CS;
|
clk_en_o = 1'b0;
|
|
data_int_next = data_int;
|
data_int_next = data_int;
|
data_valid = 1'b0;
|
data_valid = 1'b0;
|
counter_next = counter;
|
counter_next = counter;
|
|
|
case (rx_CS)
|
case (rx_CS)
|
IDLE: begin
|
IDLE: begin
|
clk_en_o = 1'b0;
|
|
|
|
// check first if there is available space instead of later
|
// check first if there is available space instead of later
|
if (en) begin
|
if (en) begin
|
rx_NS = RECEIVE;
|
rx_NS = RECEIVE;
|
end
|
end
|
end
|
end
|
|
|
RECEIVE: begin
|
RECEIVE: begin
|
clk_en_o = 1'b1;
|
|
|
|
if (rx_edge) begin
|
if (rx_edge) begin
|
counter_next = counter + 1;
|
counter_next = counter + 1;
|
if (en_quad_in)
|
if (en_quad_in)
|
data_int_next = {data_int[27:0],sdi3,sdi2,sdi1,sdi0};
|
data_int_next = {data_int[27:0],sdi3,sdi2,sdi1,sdi0};
|
Line 130... |
Line 118... |
end else if (reg_done) begin
|
end else if (reg_done) begin
|
data_valid = 1'b1;
|
data_valid = 1'b1;
|
|
|
if (~data_ready) begin
|
if (~data_ready) begin
|
// no space in the FIFO, wait for free space
|
// no space in the FIFO, wait for free space
|
clk_en_o = 1'b0;
|
|
rx_NS = WAIT_FIFO;
|
rx_NS = WAIT_FIFO;
|
end
|
end
|
end
|
end
|
end
|
end
|
end
|
end
|
Line 159... |
Line 146... |
if (rstn == 0)
|
if (rstn == 0)
|
begin
|
begin
|
counter <= 0;
|
counter <= 0;
|
counter_trgt <= 'h8;
|
counter_trgt <= 'h8;
|
data_int <= '0;
|
data_int <= '0;
|
|
rx_done <= '0;
|
|
clk_en_o <= '0;
|
rx_CS <= IDLE;
|
rx_CS <= IDLE;
|
end
|
end
|
else
|
else
|
begin
|
begin
|
|
if (rx_edge) begin
|
counter <= counter_next;
|
counter <= counter_next;
|
counter_trgt <= counter_trgt_next;
|
|
data_int <= data_int_next;
|
data_int <= data_int_next;
|
rx_CS <= rx_NS;
|
rx_CS <= rx_NS;
|
|
rx_done <= (counter_next == (counter_trgt-1)) && (rx_NS == RECEIVE);
|
|
clk_en_o <= (rx_NS == RECEIVE);
|
|
end
|
|
if (en && counter_in_upd) begin
|
|
counter_trgt <= (en_quad_in) ? {2'b00,counter_in[15:2]} : counter_in;
|
|
end
|
end
|
end
|
end
|
end
|
|
|
endmodule
|
endmodule
|