mirror of
https://github.com/aolofsson/oh.git
synced 2025-01-17 20:02:53 +08:00
156 lines
4.5 KiB
Verilog
156 lines
4.5 KiB
Verilog
module ctx (/*AUTOARG*/
|
|
// Outputs
|
|
wait_out, tx_clk, tx_access, tx_packet,
|
|
// Inputs
|
|
clk, io_clk, nreset, divcfg, access_in, packet_in, datasize,
|
|
tx_wait
|
|
);
|
|
|
|
//#####################################################################
|
|
//# INTERFACE
|
|
//#####################################################################
|
|
|
|
//parameters
|
|
parameter PW = 104; // data width (core)
|
|
parameter IOW = 16; // IO data width
|
|
parameter FIFO_DEPTH = 32; // fifo depth
|
|
localparam CW = $clog2(2*PW/IOW); // transfer count width
|
|
|
|
//reset, clk
|
|
input clk; // main core clock
|
|
input io_clk; // clock for tx
|
|
input nreset; // async active low reset
|
|
input [3:0] divcfg; // tx_clk divider config
|
|
|
|
// data to transmit
|
|
input access_in; // fifo data valid
|
|
input [PW-1:0] packet_in; // fifo packet
|
|
input [CW-1:0] datasize; // size of data transmitted
|
|
output wait_out; // wait pushback for fifo
|
|
|
|
//IO interface
|
|
output tx_clk; // phase shifted clock for IO
|
|
output tx_access; // access signal for IO
|
|
output [IOW-1:0] tx_packet; // packet for IO
|
|
input tx_wait; // pushback from IO
|
|
|
|
//#####################################################################
|
|
//# BODY
|
|
//#####################################################################
|
|
/*AUTOOUTPUT*/
|
|
/*AUTOINPUT*/
|
|
/*AUTOWIRE*/
|
|
// Beginning of automatic wires (for undeclared instantiated-module outputs)
|
|
wire fifo_access; // From fifo of oh_fifo_cdc.v
|
|
wire [PW-1:0] fifo_packet; // From fifo of oh_fifo_cdc.v
|
|
wire fifo_wait; // From ctx_protocol of ctx_protocol.v
|
|
wire io_access; // From ctx_protocol of ctx_protocol.v
|
|
wire [2*IOW-1:0] io_packet; // From ctx_protocol of ctx_protocol.v
|
|
wire tx_io_clk; // From oh_clkdiv of oh_clockdiv.v
|
|
// End of automatics
|
|
|
|
|
|
//########################################
|
|
//# SYNCHRONIZATION FIFO
|
|
//########################################
|
|
|
|
/*oh_fifo_cdc AUTO_TEMPLATE (
|
|
.wait_out (wait_out),
|
|
.access_out (fifo_access),
|
|
.packet_out (fifo_packet[PW-1:0]),
|
|
// Inputs
|
|
.nreset (nreset),
|
|
.clk_in (clk),
|
|
.access_in (access_in),
|
|
.packet_in (packet_in[PW-1:0]),
|
|
.clk_out (tx_io_clk),
|
|
.wait_in (fifo_wait),
|
|
);
|
|
*/
|
|
|
|
oh_fifo_cdc #(.DW(PW),
|
|
.DEPTH(FIFO_DEPTH))
|
|
fifo (/*AUTOINST*/
|
|
// Outputs
|
|
.wait_out (wait_out), // Templated
|
|
.access_out (fifo_access), // Templated
|
|
.packet_out (fifo_packet[PW-1:0]), // Templated
|
|
// Inputs
|
|
.nreset (nreset), // Templated
|
|
.clk_in (clk), // Templated
|
|
.access_in (access_in), // Templated
|
|
.packet_in (packet_in[PW-1:0]), // Templated
|
|
.clk_out (tx_io_clk), // Templated
|
|
.wait_in (fifo_wait)); // Templated
|
|
|
|
//########################################
|
|
//# PROTOCOL
|
|
//########################################
|
|
/*ctx_protocol AUTO_TEMPLATE (
|
|
.clk (tx_io_clk),
|
|
);
|
|
*/
|
|
ctx_protocol #(.IOW(IOW),
|
|
.PW(PW))
|
|
|
|
ctx_protocol (/*AUTOINST*/
|
|
// Outputs
|
|
.fifo_wait (fifo_wait),
|
|
.io_access (io_access),
|
|
.io_packet (io_packet[2*IOW-1:0]),
|
|
// Inputs
|
|
.clk (tx_io_clk), // Templated
|
|
.nreset (nreset),
|
|
.datasize (datasize[CW-1:0]),
|
|
.fifo_access (fifo_access),
|
|
.fifo_packet (fifo_packet[PW-1:0]),
|
|
.tx_wait (tx_wait));
|
|
|
|
//########################################
|
|
//# FAST IO (DDR)
|
|
//########################################
|
|
/*ctx_io AUTO_TEMPLATE (
|
|
.clk (tx_io_clk),
|
|
);
|
|
*/
|
|
ctx_io #(.IOW(IOW))
|
|
ctx_io (/*AUTOINST*/
|
|
// Outputs
|
|
.tx_packet (tx_packet[IOW-1:0]),
|
|
.tx_access (tx_access),
|
|
// Inputs
|
|
.nreset (nreset),
|
|
.clk (tx_io_clk), // Templated
|
|
.io_access (io_access),
|
|
.io_packet (io_packet[2*IOW-1:0]),
|
|
.tx_wait (tx_wait));
|
|
|
|
//########################################
|
|
//# CLOCK DIVIDER
|
|
//########################################
|
|
|
|
/*oh_clockdiv AUTO_TEMPLATE (
|
|
.en (1'b1),
|
|
.clk (io_clk),
|
|
.clkout (tx_io_clk),
|
|
.clkout90 (tx_clk),
|
|
);
|
|
*/
|
|
|
|
oh_clockdiv oh_clkdiv(
|
|
/*AUTOINST*/
|
|
// Outputs
|
|
.clkout (tx_io_clk), // Templated
|
|
.clkout90 (tx_clk), // Templated
|
|
// Inputs
|
|
.clk (io_clk), // Templated
|
|
.en (1'b1), // Templated
|
|
.nreset (nreset),
|
|
.divcfg (divcfg[3:0]));
|
|
|
|
endmodule // ctx
|
|
// Local Variables:
|
|
// verilog-library-directories:("." "../../common/hdl")
|
|
// End:
|
|
|