mirror of
https://github.com/parallella/parallella-hw.git
synced 2024-11-24 11:35:00 +00:00
177 lines
5.8 KiB
Verilog
177 lines
5.8 KiB
Verilog
|
|
`timescale 1 ns / 1 ps
|
|
|
|
module esaxi_v1_0 #
|
|
(
|
|
// Users to add parameters here
|
|
parameter [11:0] C_READ_TAG_ADDR = 12'h810,
|
|
// User parameters ends
|
|
// Do not modify the parameters beyond this line
|
|
|
|
|
|
// Parameters of Axi Slave Bus Interface S00_AXI
|
|
parameter integer C_S00_AXI_ID_WIDTH = 1,
|
|
parameter integer C_S00_AXI_DATA_WIDTH = 32,
|
|
parameter integer C_S00_AXI_ADDR_WIDTH = 30,
|
|
parameter integer C_S00_AXI_AWUSER_WIDTH = 0,
|
|
parameter integer C_S00_AXI_ARUSER_WIDTH = 0,
|
|
parameter integer C_S00_AXI_WUSER_WIDTH = 0,
|
|
parameter integer C_S00_AXI_RUSER_WIDTH = 0,
|
|
parameter integer C_S00_AXI_BUSER_WIDTH = 0
|
|
)
|
|
(
|
|
// Users to add ports here
|
|
|
|
// FIFO write port, write requests
|
|
output wire [102:0] emwr_wr_data,
|
|
output wire emwr_wr_en,
|
|
input wire emwr_full,
|
|
input wire emwr_prog_full,
|
|
|
|
// FIFO write port, read requests
|
|
output wire [102:0] emrq_wr_data,
|
|
output wire emrq_wr_en,
|
|
input wire emrq_full,
|
|
input wire emrq_prog_full,
|
|
|
|
// FIFO read port, read responses
|
|
input wire [102:0] emrr_rd_data,
|
|
output wire emrr_rd_en,
|
|
input wire emrr_empty,
|
|
|
|
// Control bits from eConfig
|
|
input wire [3:0] ecfg_tx_ctrl_mode,
|
|
input wire [11:0] ecfg_coreid,
|
|
|
|
// User ports ends
|
|
// Do not modify the ports beyond this line
|
|
|
|
|
|
// Ports of Axi Slave Bus Interface S00_AXI
|
|
input wire s00_axi_aclk,
|
|
input wire s00_axi_aresetn,
|
|
input wire [C_S00_AXI_ID_WIDTH-1 : 0] s00_axi_awid,
|
|
input wire [C_S00_AXI_ADDR_WIDTH-1 : 0] s00_axi_awaddr,
|
|
input wire [7 : 0] s00_axi_awlen,
|
|
input wire [2 : 0] s00_axi_awsize,
|
|
input wire [1 : 0] s00_axi_awburst,
|
|
input wire s00_axi_awlock,
|
|
input wire [3 : 0] s00_axi_awcache,
|
|
input wire [2 : 0] s00_axi_awprot,
|
|
input wire [3 : 0] s00_axi_awqos,
|
|
input wire [3 : 0] s00_axi_awregion,
|
|
input wire [C_S00_AXI_AWUSER_WIDTH-1 : 0] s00_axi_awuser,
|
|
input wire s00_axi_awvalid,
|
|
output wire s00_axi_awready,
|
|
input wire [C_S00_AXI_DATA_WIDTH-1 : 0] s00_axi_wdata,
|
|
input wire [(C_S00_AXI_DATA_WIDTH/8)-1 : 0] s00_axi_wstrb,
|
|
input wire s00_axi_wlast,
|
|
input wire [C_S00_AXI_WUSER_WIDTH-1 : 0] s00_axi_wuser,
|
|
input wire s00_axi_wvalid,
|
|
output wire s00_axi_wready,
|
|
output wire [C_S00_AXI_ID_WIDTH-1 : 0] s00_axi_bid,
|
|
output wire [1 : 0] s00_axi_bresp,
|
|
output wire [C_S00_AXI_BUSER_WIDTH-1 : 0] s00_axi_buser,
|
|
output wire s00_axi_bvalid,
|
|
input wire s00_axi_bready,
|
|
input wire [C_S00_AXI_ID_WIDTH-1 : 0] s00_axi_arid,
|
|
input wire [C_S00_AXI_ADDR_WIDTH-1 : 0] s00_axi_araddr,
|
|
input wire [7 : 0] s00_axi_arlen,
|
|
input wire [2 : 0] s00_axi_arsize,
|
|
input wire [1 : 0] s00_axi_arburst,
|
|
input wire s00_axi_arlock,
|
|
input wire [3 : 0] s00_axi_arcache,
|
|
input wire [2 : 0] s00_axi_arprot,
|
|
input wire [3 : 0] s00_axi_arqos,
|
|
input wire [3 : 0] s00_axi_arregion,
|
|
input wire [C_S00_AXI_ARUSER_WIDTH-1 : 0] s00_axi_aruser,
|
|
input wire s00_axi_arvalid,
|
|
output wire s00_axi_arready,
|
|
output wire [C_S00_AXI_ID_WIDTH-1 : 0] s00_axi_rid,
|
|
output wire [C_S00_AXI_DATA_WIDTH-1 : 0] s00_axi_rdata,
|
|
output wire [1 : 0] s00_axi_rresp,
|
|
output wire s00_axi_rlast,
|
|
output wire [C_S00_AXI_RUSER_WIDTH-1 : 0] s00_axi_ruser,
|
|
output wire s00_axi_rvalid,
|
|
input wire s00_axi_rready
|
|
);
|
|
// Instantiation of Axi Bus Interface S00_AXI
|
|
esaxi_v1_0_S00_AXI # (
|
|
.C_READ_TAG_ADDR(C_READ_TAG_ADDR),
|
|
.C_S_AXI_ID_WIDTH(C_S00_AXI_ID_WIDTH),
|
|
.C_S_AXI_DATA_WIDTH(C_S00_AXI_DATA_WIDTH),
|
|
.C_S_AXI_ADDR_WIDTH(C_S00_AXI_ADDR_WIDTH),
|
|
.C_S_AXI_AWUSER_WIDTH(C_S00_AXI_AWUSER_WIDTH),
|
|
.C_S_AXI_ARUSER_WIDTH(C_S00_AXI_ARUSER_WIDTH),
|
|
.C_S_AXI_WUSER_WIDTH(C_S00_AXI_WUSER_WIDTH),
|
|
.C_S_AXI_RUSER_WIDTH(C_S00_AXI_RUSER_WIDTH),
|
|
.C_S_AXI_BUSER_WIDTH(C_S00_AXI_BUSER_WIDTH)
|
|
) esaxi_v1_0_S00_AXI_inst (
|
|
.emwr_wr_data (emwr_wr_data),
|
|
.emwr_wr_en (emwr_wr_en),
|
|
.emwr_full (emwr_full),
|
|
.emwr_prog_full (emwr_prog_full),
|
|
.emrq_wr_data (emrq_wr_data),
|
|
.emrq_wr_en (emrq_wr_en),
|
|
.emrq_full (emrq_full),
|
|
.emrq_prog_full (emrq_prog_full),
|
|
.emrr_rd_data (emrr_rd_data),
|
|
.emrr_rd_en (emrr_rd_en),
|
|
.emrr_empty (emrr_empty),
|
|
.ecfg_tx_ctrl_mode (ecfg_tx_ctrl_mode),
|
|
.ecfg_coreid (ecfg_coreid),
|
|
|
|
.S_AXI_ACLK(s00_axi_aclk),
|
|
.S_AXI_ARESETN(s00_axi_aresetn),
|
|
.S_AXI_AWID(s00_axi_awid),
|
|
.S_AXI_AWADDR(s00_axi_awaddr),
|
|
.S_AXI_AWLEN(s00_axi_awlen),
|
|
.S_AXI_AWSIZE(s00_axi_awsize),
|
|
.S_AXI_AWBURST(s00_axi_awburst),
|
|
.S_AXI_AWLOCK(s00_axi_awlock),
|
|
.S_AXI_AWCACHE(s00_axi_awcache),
|
|
.S_AXI_AWPROT(s00_axi_awprot),
|
|
.S_AXI_AWQOS(s00_axi_awqos),
|
|
.S_AXI_AWREGION(s00_axi_awregion),
|
|
.S_AXI_AWUSER(s00_axi_awuser),
|
|
.S_AXI_AWVALID(s00_axi_awvalid),
|
|
.S_AXI_AWREADY(s00_axi_awready),
|
|
.S_AXI_WDATA(s00_axi_wdata),
|
|
.S_AXI_WSTRB(s00_axi_wstrb),
|
|
.S_AXI_WLAST(s00_axi_wlast),
|
|
.S_AXI_WUSER(s00_axi_wuser),
|
|
.S_AXI_WVALID(s00_axi_wvalid),
|
|
.S_AXI_WREADY(s00_axi_wready),
|
|
.S_AXI_BID(s00_axi_bid),
|
|
.S_AXI_BRESP(s00_axi_bresp),
|
|
.S_AXI_BUSER(s00_axi_buser),
|
|
.S_AXI_BVALID(s00_axi_bvalid),
|
|
.S_AXI_BREADY(s00_axi_bready),
|
|
.S_AXI_ARID(s00_axi_arid),
|
|
.S_AXI_ARADDR(s00_axi_araddr),
|
|
.S_AXI_ARLEN(s00_axi_arlen),
|
|
.S_AXI_ARSIZE(s00_axi_arsize),
|
|
.S_AXI_ARBURST(s00_axi_arburst),
|
|
.S_AXI_ARLOCK(s00_axi_arlock),
|
|
.S_AXI_ARCACHE(s00_axi_arcache),
|
|
.S_AXI_ARPROT(s00_axi_arprot),
|
|
.S_AXI_ARQOS(s00_axi_arqos),
|
|
.S_AXI_ARREGION(s00_axi_arregion),
|
|
.S_AXI_ARUSER(s00_axi_aruser),
|
|
.S_AXI_ARVALID(s00_axi_arvalid),
|
|
.S_AXI_ARREADY(s00_axi_arready),
|
|
.S_AXI_RID(s00_axi_rid),
|
|
.S_AXI_RDATA(s00_axi_rdata),
|
|
.S_AXI_RRESP(s00_axi_rresp),
|
|
.S_AXI_RLAST(s00_axi_rlast),
|
|
.S_AXI_RUSER(s00_axi_ruser),
|
|
.S_AXI_RVALID(s00_axi_rvalid),
|
|
.S_AXI_RREADY(s00_axi_rready)
|
|
);
|
|
|
|
// Add user logic here
|
|
|
|
// User logic ends
|
|
|
|
endmodule
|