183 lines
5.6 KiB
Verilog
183 lines
5.6 KiB
Verilog
/*******************************************************************************
|
|
* This file is owned and controlled by Xilinx and must be used *
|
|
* solely for design, simulation, implementation and creation of *
|
|
* design files limited to Xilinx devices or technologies. Use *
|
|
* with non-Xilinx devices or technologies is expressly prohibited *
|
|
* and immediately terminates your license. *
|
|
* *
|
|
* XILINX IS PROVIDING THIS DESIGN, CODE, OR INFORMATION "AS IS" *
|
|
* SOLELY FOR USE IN DEVELOPING PROGRAMS AND SOLUTIONS FOR *
|
|
* XILINX DEVICES. BY PROVIDING THIS DESIGN, CODE, OR INFORMATION *
|
|
* AS ONE POSSIBLE IMPLEMENTATION OF THIS FEATURE, APPLICATION *
|
|
* OR STANDARD, XILINX IS MAKING NO REPRESENTATION THAT THIS *
|
|
* IMPLEMENTATION IS FREE FROM ANY CLAIMS OF INFRINGEMENT, *
|
|
* AND YOU ARE RESPONSIBLE FOR OBTAINING ANY RIGHTS YOU MAY REQUIRE *
|
|
* FOR YOUR IMPLEMENTATION. XILINX EXPRESSLY DISCLAIMS ANY *
|
|
* WARRANTY WHATSOEVER WITH RESPECT TO THE ADEQUACY OF THE *
|
|
* IMPLEMENTATION, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OR *
|
|
* REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM CLAIMS OF *
|
|
* INFRINGEMENT, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS *
|
|
* FOR A PARTICULAR PURPOSE. *
|
|
* *
|
|
* Xilinx products are not intended for use in life support *
|
|
* appliances, devices, or systems. Use in such applications are *
|
|
* expressly prohibited. *
|
|
* *
|
|
* (c) Copyright 1995-2011 Xilinx, Inc. *
|
|
* All rights reserved. *
|
|
*******************************************************************************/
|
|
// You must compile the wrapper file msu_databuf.v when simulating
|
|
// the core, msu_databuf. When compiling the wrapper file, be sure to
|
|
// reference the XilinxCoreLib Verilog simulation library. For detailed
|
|
// instructions, please refer to the "CORE Generator Help".
|
|
|
|
// The synthesis directives "translate_off/translate_on" specified below are
|
|
// supported by Xilinx, Mentor Graphics and Synplicity synthesis
|
|
// tools. Ensure they are correct for your synthesis tool(s).
|
|
|
|
`timescale 1ns/1ps
|
|
|
|
module msu_databuf(
|
|
clka,
|
|
wea,
|
|
addra,
|
|
dina,
|
|
clkb,
|
|
addrb,
|
|
doutb
|
|
);
|
|
|
|
input clka;
|
|
input [0 : 0] wea;
|
|
input [13 : 0] addra;
|
|
input [7 : 0] dina;
|
|
input clkb;
|
|
input [13 : 0] addrb;
|
|
output [7 : 0] doutb;
|
|
|
|
// synthesis translate_off
|
|
|
|
BLK_MEM_GEN_V6_1 #(
|
|
.C_ADDRA_WIDTH(14),
|
|
.C_ADDRB_WIDTH(14),
|
|
.C_ALGORITHM(1),
|
|
.C_AXI_ID_WIDTH(4),
|
|
.C_AXI_SLAVE_TYPE(0),
|
|
.C_AXI_TYPE(1),
|
|
.C_BYTE_SIZE(9),
|
|
.C_COMMON_CLK(1),
|
|
.C_DEFAULT_DATA("0"),
|
|
.C_DISABLE_WARN_BHV_COLL(0),
|
|
.C_DISABLE_WARN_BHV_RANGE(0),
|
|
.C_FAMILY("spartan3"),
|
|
.C_HAS_AXI_ID(0),
|
|
.C_HAS_ENA(0),
|
|
.C_HAS_ENB(0),
|
|
.C_HAS_INJECTERR(0),
|
|
.C_HAS_MEM_OUTPUT_REGS_A(0),
|
|
.C_HAS_MEM_OUTPUT_REGS_B(0),
|
|
.C_HAS_MUX_OUTPUT_REGS_A(0),
|
|
.C_HAS_MUX_OUTPUT_REGS_B(0),
|
|
.C_HAS_REGCEA(0),
|
|
.C_HAS_REGCEB(0),
|
|
.C_HAS_RSTA(0),
|
|
.C_HAS_RSTB(0),
|
|
.C_HAS_SOFTECC_INPUT_REGS_A(0),
|
|
.C_HAS_SOFTECC_OUTPUT_REGS_B(0),
|
|
.C_INIT_FILE_NAME("no_coe_file_loaded"),
|
|
.C_INITA_VAL("0"),
|
|
.C_INITB_VAL("0"),
|
|
.C_INTERFACE_TYPE(0),
|
|
.C_LOAD_INIT_FILE(0),
|
|
.C_MEM_TYPE(1),
|
|
.C_MUX_PIPELINE_STAGES(0),
|
|
.C_PRIM_TYPE(1),
|
|
.C_READ_DEPTH_A(16384),
|
|
.C_READ_DEPTH_B(16384),
|
|
.C_READ_WIDTH_A(8),
|
|
.C_READ_WIDTH_B(8),
|
|
.C_RST_PRIORITY_A("CE"),
|
|
.C_RST_PRIORITY_B("CE"),
|
|
.C_RST_TYPE("SYNC"),
|
|
.C_RSTRAM_A(0),
|
|
.C_RSTRAM_B(0),
|
|
.C_SIM_COLLISION_CHECK("ALL"),
|
|
.C_USE_BYTE_WEA(0),
|
|
.C_USE_BYTE_WEB(0),
|
|
.C_USE_DEFAULT_DATA(0),
|
|
.C_USE_ECC(0),
|
|
.C_USE_SOFTECC(0),
|
|
.C_WEA_WIDTH(1),
|
|
.C_WEB_WIDTH(1),
|
|
.C_WRITE_DEPTH_A(16384),
|
|
.C_WRITE_DEPTH_B(16384),
|
|
.C_WRITE_MODE_A("WRITE_FIRST"),
|
|
.C_WRITE_MODE_B("WRITE_FIRST"),
|
|
.C_WRITE_WIDTH_A(8),
|
|
.C_WRITE_WIDTH_B(8),
|
|
.C_XDEVICEFAMILY("spartan3")
|
|
)
|
|
inst (
|
|
.CLKA(clka),
|
|
.WEA(wea),
|
|
.ADDRA(addra),
|
|
.DINA(dina),
|
|
.CLKB(clkb),
|
|
.ADDRB(addrb),
|
|
.DOUTB(doutb),
|
|
.RSTA(),
|
|
.ENA(),
|
|
.REGCEA(),
|
|
.DOUTA(),
|
|
.RSTB(),
|
|
.ENB(),
|
|
.REGCEB(),
|
|
.WEB(),
|
|
.DINB(),
|
|
.INJECTSBITERR(),
|
|
.INJECTDBITERR(),
|
|
.SBITERR(),
|
|
.DBITERR(),
|
|
.RDADDRECC(),
|
|
.S_ACLK(),
|
|
.S_ARESETN(),
|
|
.S_AXI_AWID(),
|
|
.S_AXI_AWADDR(),
|
|
.S_AXI_AWLEN(),
|
|
.S_AXI_AWSIZE(),
|
|
.S_AXI_AWBURST(),
|
|
.S_AXI_AWVALID(),
|
|
.S_AXI_AWREADY(),
|
|
.S_AXI_WDATA(),
|
|
.S_AXI_WSTRB(),
|
|
.S_AXI_WLAST(),
|
|
.S_AXI_WVALID(),
|
|
.S_AXI_WREADY(),
|
|
.S_AXI_BID(),
|
|
.S_AXI_BRESP(),
|
|
.S_AXI_BVALID(),
|
|
.S_AXI_BREADY(),
|
|
.S_AXI_ARID(),
|
|
.S_AXI_ARADDR(),
|
|
.S_AXI_ARLEN(),
|
|
.S_AXI_ARSIZE(),
|
|
.S_AXI_ARBURST(),
|
|
.S_AXI_ARVALID(),
|
|
.S_AXI_ARREADY(),
|
|
.S_AXI_RID(),
|
|
.S_AXI_RDATA(),
|
|
.S_AXI_RRESP(),
|
|
.S_AXI_RLAST(),
|
|
.S_AXI_RVALID(),
|
|
.S_AXI_RREADY(),
|
|
.S_AXI_INJECTSBITERR(),
|
|
.S_AXI_INJECTDBITERR(),
|
|
.S_AXI_SBITERR(),
|
|
.S_AXI_DBITERR(),
|
|
.S_AXI_RDADDRECC()
|
|
);
|
|
|
|
// synthesis translate_on
|
|
|
|
endmodule
|