HITDAQ/FPGA_firmware/q_sys/synthesis/submodules/st2mm.v
2024-10-11 14:49:54 +02:00

82 lines
2.1 KiB
Verilog

//a module bridge the avalon streaming interface and avalon memory map interface
//collect data from interface and write to RAM
//32 2; OR 16 1
module st2mm #(parameter BITSIZE = 32, EMPTY_SIZE = 2)(
//clock and reset
input wire clk,
input wire rst,
//avalon ST(Streaming) sink: 0 readlatency and 0 readallowence
input wire [BITSIZE-1:0] st_data, // st.data
output wire st_ready, // .ready
input wire st_valid, // .valid
input wire [EMPTY_SIZE-1:0] st_empty, // .empty
input wire st_endofpacket, // .endofpacket
input wire st_startofpacket, // .startofpacket
//avalon MM(Memory Mapped) source writelatency 0; readlatency 1 but no read logic here
output wire [8:0] mm_address,
output wire mm_chipselect, // only for write
//output wire mm_clken, //only for write; write enable
input wire [BITSIZE-1:0]mm_readdate, //do not read
output wire mm_write,
output wire [BITSIZE-1:0] mm_writedata,
input wire mm_waitrequest_n
);
reg[1:0] state;
localparam STATE_IDLE = 2'd0; //waiting for startofpacket
localparam STATE_WRITE = 2'd1; //write to mm
localparam STATE_LOCK = 2'd3; //Finish writing
reg[8:0] ctr; // count data and the address for MM
localparam CTR_ZERO = 9'd0;
assign mm_address = ctr;
assign mm_writedata = st_data;
assign mm_chipselect = (state == STATE_WRITE && st_valid)? 1'b1: 1'b0;
//assign mm_clken = (state == STATE_WRITE && st_valid)? 1'b1: 1'b0;
assign st_ready = (state == STATE_WRITE)? 1'b1: 1'b0;
always @ (posedge clk or posedge rst)
begin
if (rst)
begin
state <= STATE_IDLE;
ctr <= CTR_ZERO;
end
else case(state)
STATE_IDLE:
begin
ctr <= CTR_ZERO;
if (st_startofpacket)
state <= STATE_WRITE;
end
STATE_WRITE:
begin
if (st_valid && mm_waitrequest_n)
begin
ctr <= ctr + 1'b1;
if (st_endofpacket)
state <= STATE_LOCK;
end
end
STATE_LOCK:
begin
state <= STATE_IDLE;
ctr <= CTR_ZERO;
end
default:
state <= STATE_IDLE;
endcase
end
endmodule