首次提交

This commit is contained in:
eesimple
2026-03-06 16:22:17 +08:00
commit b8fe9f77ec
465 changed files with 115939 additions and 0 deletions

View File

@@ -0,0 +1,826 @@
<?xml version="1.0" encoding="UTF-8"?>
<spirit:component xmlns:xilinx="http://www.xilinx.com" xmlns:spirit="http://www.spiritconsortium.org/XMLSchema/SPIRIT/1685-2009" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<spirit:vendor>xilinx.com</spirit:vendor>
<spirit:library>user</spirit:library>
<spirit:name>stream_tx_if</spirit:name>
<spirit:version>1.0</spirit:version>
<spirit:busInterfaces>
<spirit:busInterface>
<spirit:name>interface_axis</spirit:name>
<spirit:busType spirit:vendor="xilinx.com" spirit:library="interface" spirit:name="axis" spirit:version="1.0"/>
<spirit:abstractionType spirit:vendor="xilinx.com" spirit:library="interface" spirit:name="axis_rtl" spirit:version="1.0"/>
<spirit:master/>
<spirit:portMaps>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>TDATA</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>tdata</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>TSTRB</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>tstrb</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>TKEEP</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>tkeep</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>TLAST</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>tlast</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>TVALID</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>tvalid</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>TREADY</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>tready</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
</spirit:portMaps>
</spirit:busInterface>
<spirit:busInterface>
<spirit:name>rst_n</spirit:name>
<spirit:busType spirit:vendor="xilinx.com" spirit:library="signal" spirit:name="reset" spirit:version="1.0"/>
<spirit:abstractionType spirit:vendor="xilinx.com" spirit:library="signal" spirit:name="reset_rtl" spirit:version="1.0"/>
<spirit:slave/>
<spirit:portMaps>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>RST</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>rst_n</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
</spirit:portMaps>
<spirit:parameters>
<spirit:parameter>
<spirit:name>POLARITY</spirit:name>
<spirit:value spirit:id="BUSIFPARAM_VALUE.RST_N.POLARITY" spirit:choiceRef="choice_list_9d8b0d81">ACTIVE_LOW</spirit:value>
</spirit:parameter>
</spirit:parameters>
</spirit:busInterface>
<spirit:busInterface>
<spirit:name>buf_clk</spirit:name>
<spirit:busType spirit:vendor="xilinx.com" spirit:library="signal" spirit:name="clock" spirit:version="1.0"/>
<spirit:abstractionType spirit:vendor="xilinx.com" spirit:library="signal" spirit:name="clock_rtl" spirit:version="1.0"/>
<spirit:master/>
<spirit:portMaps>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>CLK</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>buf_clk</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
</spirit:portMaps>
</spirit:busInterface>
<spirit:busInterface>
<spirit:name>clk</spirit:name>
<spirit:busType spirit:vendor="xilinx.com" spirit:library="signal" spirit:name="clock" spirit:version="1.0"/>
<spirit:abstractionType spirit:vendor="xilinx.com" spirit:library="signal" spirit:name="clock_rtl" spirit:version="1.0"/>
<spirit:slave/>
<spirit:portMaps>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>CLK</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>clk</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
</spirit:portMaps>
<spirit:parameters>
<spirit:parameter>
<spirit:name>ASSOCIATED_BUSIF</spirit:name>
<spirit:value spirit:id="BUSIFPARAM_VALUE.CLK.ASSOCIATED_BUSIF">interface_axis</spirit:value>
</spirit:parameter>
</spirit:parameters>
</spirit:busInterface>
<spirit:busInterface>
<spirit:name>desc_clk</spirit:name>
<spirit:busType spirit:vendor="xilinx.com" spirit:library="signal" spirit:name="clock" spirit:version="1.0"/>
<spirit:abstractionType spirit:vendor="xilinx.com" spirit:library="signal" spirit:name="clock_rtl" spirit:version="1.0"/>
<spirit:master/>
<spirit:portMaps>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>CLK</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>desc_clk</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
</spirit:portMaps>
</spirit:busInterface>
<spirit:busInterface>
<spirit:name>buf_if</spirit:name>
<spirit:displayName>buf_if</spirit:displayName>
<spirit:description>buf_if</spirit:description>
<spirit:busType spirit:vendor="xilinx.com" spirit:library="interface" spirit:name="bram" spirit:version="1.0"/>
<spirit:abstractionType spirit:vendor="xilinx.com" spirit:library="interface" spirit:name="bram_rtl" spirit:version="1.0"/>
<spirit:master/>
<spirit:portMaps>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>DIN</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>buf_wdata</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>DOUT</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>buf_rdata</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>CLK</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>buf_clk</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>WE</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>buf_wea</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>ADDR</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>buf_addr</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
</spirit:portMaps>
</spirit:busInterface>
<spirit:busInterface>
<spirit:name>desc_if</spirit:name>
<spirit:displayName>desc_if</spirit:displayName>
<spirit:description>desc_if</spirit:description>
<spirit:busType spirit:vendor="xilinx.com" spirit:library="interface" spirit:name="bram" spirit:version="1.0"/>
<spirit:abstractionType spirit:vendor="xilinx.com" spirit:library="interface" spirit:name="bram_rtl" spirit:version="1.0"/>
<spirit:master/>
<spirit:portMaps>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>DIN</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>desc_wdata</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>DOUT</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>desc_rdata</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>CLK</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>desc_clk</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>WE</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>desc_wea</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
<spirit:portMap>
<spirit:logicalPort>
<spirit:name>ADDR</spirit:name>
</spirit:logicalPort>
<spirit:physicalPort>
<spirit:name>desc_addr</spirit:name>
</spirit:physicalPort>
</spirit:portMap>
</spirit:portMaps>
</spirit:busInterface>
</spirit:busInterfaces>
<spirit:model>
<spirit:views>
<spirit:view>
<spirit:name>xilinx_anylanguagesynthesis</spirit:name>
<spirit:displayName>Synthesis</spirit:displayName>
<spirit:envIdentifier>:vivado.xilinx.com:synthesis</spirit:envIdentifier>
<spirit:language>SystemVerilog</spirit:language>
<spirit:modelName>stream_tx_if</spirit:modelName>
<spirit:fileSetRef>
<spirit:localName>xilinx_anylanguagesynthesis_view_fileset</spirit:localName>
</spirit:fileSetRef>
<spirit:parameters>
<spirit:parameter>
<spirit:name>viewChecksum</spirit:name>
<spirit:value>a46450fe</spirit:value>
</spirit:parameter>
</spirit:parameters>
</spirit:view>
<spirit:view>
<spirit:name>xilinx_anylanguagebehavioralsimulation</spirit:name>
<spirit:displayName>Simulation</spirit:displayName>
<spirit:envIdentifier>:vivado.xilinx.com:simulation</spirit:envIdentifier>
<spirit:language>SystemVerilog</spirit:language>
<spirit:modelName>stream_tx_if</spirit:modelName>
<spirit:fileSetRef>
<spirit:localName>xilinx_anylanguagebehavioralsimulation_view_fileset</spirit:localName>
</spirit:fileSetRef>
<spirit:parameters>
<spirit:parameter>
<spirit:name>viewChecksum</spirit:name>
<spirit:value>a46450fe</spirit:value>
</spirit:parameter>
</spirit:parameters>
</spirit:view>
<spirit:view>
<spirit:name>xilinx_xpgui</spirit:name>
<spirit:displayName>UI Layout</spirit:displayName>
<spirit:envIdentifier>:vivado.xilinx.com:xgui.ui</spirit:envIdentifier>
<spirit:fileSetRef>
<spirit:localName>xilinx_xpgui_view_fileset</spirit:localName>
</spirit:fileSetRef>
<spirit:parameters>
<spirit:parameter>
<spirit:name>viewChecksum</spirit:name>
<spirit:value>900f4290</spirit:value>
</spirit:parameter>
</spirit:parameters>
</spirit:view>
</spirit:views>
<spirit:ports>
<spirit:port>
<spirit:name>clk</spirit:name>
<spirit:wire>
<spirit:direction>in</spirit:direction>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>rst_n</spirit:name>
<spirit:wire>
<spirit:direction>in</spirit:direction>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>enable</spirit:name>
<spirit:wire>
<spirit:direction>in</spirit:direction>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>burst_time_interval</spirit:name>
<spirit:wire>
<spirit:direction>in</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long">15</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>doorbell</spirit:name>
<spirit:wire>
<spirit:direction>in</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long">31</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>buf_status</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long">31</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>counter_tx_beats</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long">31</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>counter_tx_bursts</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long">31</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>tdata</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long" spirit:resolve="dependent" spirit:dependency="(spirit:decode(id(&apos;MODELPARAM_VALUE.STREAM_WIDTH&apos;)) - 1)">7</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>tvalid</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>tlast</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>tkeep</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long" spirit:resolve="dependent" spirit:dependency="((spirit:decode(id(&apos;MODELPARAM_VALUE.STREAM_WIDTH&apos;)) / 8) - 1)">0</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>tstrb</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long" spirit:resolve="dependent" spirit:dependency="((spirit:decode(id(&apos;MODELPARAM_VALUE.STREAM_WIDTH&apos;)) / 8) - 1)">0</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>tready</spirit:name>
<spirit:wire>
<spirit:direction>in</spirit:direction>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
<spirit:driver>
<spirit:defaultValue spirit:format="long">1</spirit:defaultValue>
</spirit:driver>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>buf_clk</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>buf_addr</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long" spirit:resolve="dependent" spirit:dependency="(spirit:ceil(spirit:log(2,spirit:decode(id(&apos;MODELPARAM_VALUE.BUF_SIZE&apos;)))) - 1)">11</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>buf_wea</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long" spirit:resolve="dependent" spirit:dependency="((spirit:decode(id(&apos;MODELPARAM_VALUE.STREAM_WIDTH&apos;)) / 8) - 1)">0</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>buf_wdata</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long" spirit:resolve="dependent" spirit:dependency="(spirit:decode(id(&apos;MODELPARAM_VALUE.STREAM_WIDTH&apos;)) - 1)">7</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>buf_rdata</spirit:name>
<spirit:wire>
<spirit:direction>in</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long" spirit:resolve="dependent" spirit:dependency="(spirit:decode(id(&apos;MODELPARAM_VALUE.STREAM_WIDTH&apos;)) - 1)">7</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>desc_clk</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>desc_addr</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long">11</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>desc_wea</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long">3</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>desc_wdata</spirit:name>
<spirit:wire>
<spirit:direction>out</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long">31</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
<spirit:port>
<spirit:name>desc_rdata</spirit:name>
<spirit:wire>
<spirit:direction>in</spirit:direction>
<spirit:vector>
<spirit:left spirit:format="long">31</spirit:left>
<spirit:right spirit:format="long">0</spirit:right>
</spirit:vector>
<spirit:wireTypeDefs>
<spirit:wireTypeDef>
<spirit:typeName>logic</spirit:typeName>
<spirit:viewNameRef>xilinx_anylanguagesynthesis</spirit:viewNameRef>
<spirit:viewNameRef>xilinx_anylanguagebehavioralsimulation</spirit:viewNameRef>
</spirit:wireTypeDef>
</spirit:wireTypeDefs>
</spirit:wire>
</spirit:port>
</spirit:ports>
<spirit:modelParameters>
<spirit:modelParameter xsi:type="spirit:nameValueTypeType" spirit:dataType="integer">
<spirit:name>FREQ_HZ</spirit:name>
<spirit:displayName>Freq Hz</spirit:displayName>
<spirit:value spirit:format="long" spirit:resolve="generated" spirit:id="MODELPARAM_VALUE.FREQ_HZ">125000000</spirit:value>
</spirit:modelParameter>
<spirit:modelParameter spirit:dataType="integer">
<spirit:name>BRAM_LATENCY</spirit:name>
<spirit:displayName>Bram Latency</spirit:displayName>
<spirit:value spirit:format="long" spirit:resolve="generated" spirit:id="MODELPARAM_VALUE.BRAM_LATENCY">1</spirit:value>
</spirit:modelParameter>
<spirit:modelParameter spirit:dataType="integer">
<spirit:name>STREAM_WIDTH</spirit:name>
<spirit:displayName>Stream Width</spirit:displayName>
<spirit:value spirit:format="long" spirit:resolve="generated" spirit:id="MODELPARAM_VALUE.STREAM_WIDTH">8</spirit:value>
</spirit:modelParameter>
<spirit:modelParameter spirit:dataType="integer">
<spirit:name>BUF_SIZE</spirit:name>
<spirit:displayName>Buf Size</spirit:displayName>
<spirit:value spirit:format="long" spirit:resolve="generated" spirit:id="MODELPARAM_VALUE.BUF_SIZE">4096</spirit:value>
</spirit:modelParameter>
<spirit:modelParameter spirit:dataType="integer">
<spirit:name>DESC_TOTAL</spirit:name>
<spirit:displayName>Desc Total</spirit:displayName>
<spirit:value spirit:format="long" spirit:resolve="generated" spirit:id="MODELPARAM_VALUE.DESC_TOTAL">256</spirit:value>
</spirit:modelParameter>
</spirit:modelParameters>
</spirit:model>
<spirit:choices>
<spirit:choice>
<spirit:name>choice_list_9d8b0d81</spirit:name>
<spirit:enumeration>ACTIVE_HIGH</spirit:enumeration>
<spirit:enumeration>ACTIVE_LOW</spirit:enumeration>
</spirit:choice>
</spirit:choices>
<spirit:fileSets>
<spirit:fileSet>
<spirit:name>xilinx_anylanguagesynthesis_view_fileset</spirit:name>
<spirit:file>
<spirit:name>wall_timer.sv</spirit:name>
<spirit:fileType>systemVerilogSource</spirit:fileType>
</spirit:file>
<spirit:file>
<spirit:name>stream_tx_if.sv</spirit:name>
<spirit:fileType>systemVerilogSource</spirit:fileType>
<spirit:userFileType>CHECKSUM_432aa8a5</spirit:userFileType>
</spirit:file>
</spirit:fileSet>
<spirit:fileSet>
<spirit:name>xilinx_anylanguagebehavioralsimulation_view_fileset</spirit:name>
<spirit:file>
<spirit:name>wall_timer.sv</spirit:name>
<spirit:fileType>systemVerilogSource</spirit:fileType>
</spirit:file>
<spirit:file>
<spirit:name>stream_tx_if.sv</spirit:name>
<spirit:fileType>systemVerilogSource</spirit:fileType>
</spirit:file>
</spirit:fileSet>
<spirit:fileSet>
<spirit:name>xilinx_xpgui_view_fileset</spirit:name>
<spirit:file>
<spirit:name>xgui/stream_tx_if_v1_0.tcl</spirit:name>
<spirit:fileType>tclSource</spirit:fileType>
<spirit:userFileType>CHECKSUM_900f4290</spirit:userFileType>
<spirit:userFileType>XGUI_VERSION_2</spirit:userFileType>
</spirit:file>
</spirit:fileSet>
</spirit:fileSets>
<spirit:description>stream_tx_if_v1_0</spirit:description>
<spirit:parameters>
<spirit:parameter>
<spirit:name>FREQ_HZ</spirit:name>
<spirit:displayName>Freq Hz</spirit:displayName>
<spirit:value spirit:format="long" spirit:resolve="user" spirit:id="PARAM_VALUE.FREQ_HZ">125000000</spirit:value>
</spirit:parameter>
<spirit:parameter>
<spirit:name>BRAM_LATENCY</spirit:name>
<spirit:displayName>Bram Latency</spirit:displayName>
<spirit:value spirit:format="long" spirit:resolve="user" spirit:id="PARAM_VALUE.BRAM_LATENCY">1</spirit:value>
</spirit:parameter>
<spirit:parameter>
<spirit:name>STREAM_WIDTH</spirit:name>
<spirit:displayName>Stream Width</spirit:displayName>
<spirit:value spirit:format="long" spirit:resolve="user" spirit:id="PARAM_VALUE.STREAM_WIDTH">8</spirit:value>
</spirit:parameter>
<spirit:parameter>
<spirit:name>BUF_SIZE</spirit:name>
<spirit:displayName>Buf Size</spirit:displayName>
<spirit:value spirit:format="long" spirit:resolve="user" spirit:id="PARAM_VALUE.BUF_SIZE">4096</spirit:value>
</spirit:parameter>
<spirit:parameter>
<spirit:name>DESC_TOTAL</spirit:name>
<spirit:displayName>Desc Total</spirit:displayName>
<spirit:value spirit:format="long" spirit:resolve="user" spirit:id="PARAM_VALUE.DESC_TOTAL">256</spirit:value>
</spirit:parameter>
<spirit:parameter>
<spirit:name>Component_Name</spirit:name>
<spirit:value spirit:resolve="user" spirit:id="PARAM_VALUE.Component_Name" spirit:order="1">stream_tx_if_v1_0</spirit:value>
</spirit:parameter>
</spirit:parameters>
<spirit:vendorExtensions>
<xilinx:coreExtensions>
<xilinx:supportedFamilies>
<xilinx:family xilinx:lifeCycle="Production">virtex7</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">qvirtex7</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">versal</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">kintex7</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">kintex7l</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">qkintex7</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">qkintex7l</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">akintex7</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">artix7</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">artix7l</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">aartix7</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">qartix7</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">zynq</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">qzynq</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">azynq</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">spartan7</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">aspartan7</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">virtexu</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">zynquplus</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">virtexuplus</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">virtexuplusHBM</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">virtexuplus58g</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">kintexuplus</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">artixuplus</xilinx:family>
<xilinx:family xilinx:lifeCycle="Production">kintexu</xilinx:family>
</xilinx:supportedFamilies>
<xilinx:taxonomies>
<xilinx:taxonomy>/UserIP</xilinx:taxonomy>
</xilinx:taxonomies>
<xilinx:displayName>stream_tx_if_v1_0</xilinx:displayName>
<xilinx:definitionSource>package_project</xilinx:definitionSource>
<xilinx:xpmLibraries>
<xilinx:xpmLibrary>XPM_CDC</xilinx:xpmLibrary>
<xilinx:xpmLibrary>XPM_FIFO</xilinx:xpmLibrary>
<xilinx:xpmLibrary>XPM_MEMORY</xilinx:xpmLibrary>
</xilinx:xpmLibraries>
<xilinx:coreRevision>2</xilinx:coreRevision>
<xilinx:coreCreationDateTime>2025-11-27T12:10:33Z</xilinx:coreCreationDateTime>
<xilinx:tags>
<xilinx:tag xilinx:name="nopcore"/>
</xilinx:tags>
</xilinx:coreExtensions>
<xilinx:packagingInfo>
<xilinx:xilinxVersion>2023.2</xilinx:xilinxVersion>
<xilinx:checksum xilinx:scope="busInterfaces" xilinx:value="536828d3"/>
<xilinx:checksum xilinx:scope="fileGroups" xilinx:value="2ff6f6e4"/>
<xilinx:checksum xilinx:scope="ports" xilinx:value="5c65c791"/>
<xilinx:checksum xilinx:scope="hdlParameters" xilinx:value="b19f3140"/>
<xilinx:checksum xilinx:scope="parameters" xilinx:value="fb4c72d7"/>
</xilinx:packagingInfo>
</spirit:vendorExtensions>
</spirit:component>

View File

@@ -0,0 +1,314 @@
module stream_tx_if #(
parameter FREQ_HZ = 125_000_000,
parameter BRAM_LATENCY = 1, // 1: LATCH only, 2: +primitive or core out reg, 3: +primitive and core out reg, 4+: +pipeline
parameter STREAM_WIDTH = 8,
parameter BUF_SIZE = 4096, // in bytes
parameter DESC_TOTAL = 256
) (
input logic clk,
input logic rst_n,
input logic enable,
input logic [15:0] burst_time_interval, // us
input logic [31:0] doorbell,
output logic [31:0] buf_status,
output logic [31:0] counter_tx_beats,
output logic [31:0] counter_tx_bursts,
// input stream interface
output logic [STREAM_WIDTH-1:0] tdata,
output logic tvalid,
output logic tlast,
output logic [STREAM_WIDTH/8-1:0] tkeep,
output logic [STREAM_WIDTH/8-1:0] tstrb,
input logic tready,
// buffer interface
output logic buf_clk,
output logic [$clog2(BUF_SIZE)-1:0] buf_addr,
output logic [STREAM_WIDTH/8-1:0] buf_wea,
output logic [STREAM_WIDTH-1:0] buf_wdata,
input logic [STREAM_WIDTH-1:0] buf_rdata,
// reg interface
output logic desc_clk,
output logic [11:0] desc_addr,
output logic [ 3:0] desc_wea,
output logic [31:0] desc_wdata,
input logic [31:0] desc_rdata
);
localparam BUF_ADDR_WIDTH = $clog2(BUF_SIZE);
localparam DESC_IDX_WIDTH = $clog2(DESC_TOTAL);
if (STREAM_WIDTH != 8 && STREAM_WIDTH != 16 && STREAM_WIDTH != 32 && STREAM_WIDTH != 64) begin
$error("STREAM_WIDTH must be one of the following values: 8, 16, 32, 64!");
end
localparam ADDR_STEP = STREAM_WIDTH / 8;
logic [15:0] burst_time_interval_latched;
logic [15:0] timer_us;
logic timer_enable;
logic timeout;
typedef enum logic [2:0] {
TX_INIT,
TX_OFF,
TX_IDLE,
TX_SKIP,
TX_DATA,
TX_WAIT,
TX_INTERVAL
} tx_state_t;
tx_state_t tx_state, tx_state_next;
logic [$clog2(BRAM_LATENCY+1)-1:0] bram_latency_cnt;
logic ip_ready;
logic burst_done;
logic [15:0] burst_len;
logic [15:0] burst_beats;
logic [31:0] current_entry;
logic [DESC_IDX_WIDTH-1:0] next_entry_index;
logic desc_wen;
assign buf_clk = clk;
assign desc_clk = clk;
assign buf_wdata = 0; // not used
assign buf_wea = {STREAM_WIDTH/8{1'b0}};
assign desc_wea = {4{desc_wen}};
assign desc_wdata = 0;
// FSM: register update
always_ff @(posedge clk) begin
if (!rst_n) begin
tx_state <= TX_INIT;
end else begin
tx_state <= tx_state_next;
end
end
// FSM: next state logic
always_comb begin
tx_state_next = tx_state;
case (tx_state)
TX_INIT: begin
if (next_entry_index == DESC_TOTAL - 1)
tx_state_next = TX_OFF;
end
TX_OFF: begin
if (enable)
tx_state_next = TX_IDLE;
end
TX_IDLE: begin
if (desc_addr != doorbell[11:0])
tx_state_next = TX_SKIP;
if (!enable)
tx_state_next = TX_INIT;
end
TX_SKIP: begin
if (bram_latency_cnt >= BRAM_LATENCY - 1)
tx_state_next = TX_DATA;
if (!enable)
tx_state_next = TX_INIT;
end
TX_DATA: begin
tx_state_next = TX_WAIT;
if (!enable)
tx_state_next = TX_INIT;
end
TX_WAIT: begin
if (tvalid && tready) begin
if (burst_beats < burst_len)
tx_state_next = TX_SKIP;
else
tx_state_next = TX_INTERVAL;
end
if (!enable)
tx_state_next = TX_INIT;
end
TX_INTERVAL: begin
if (timeout) begin
tx_state_next = TX_IDLE;
end
if (!enable)
tx_state_next = TX_INIT;
end
default: begin
tx_state_next = TX_IDLE;
end
endcase
end
// FSM: output logic
always_ff @(posedge clk) begin
if (!rst_n) begin
buf_addr <= 0;
desc_addr <= 0;
desc_wen <= 0;
tvalid <= 0;
tdata <= 0;
tkeep <= 0;
tstrb <= 0;
tlast <= 0;
ip_ready <= 0;
burst_time_interval_latched <= 0;
bram_latency_cnt <= 0;
timer_enable <= 0;
burst_len <= 0;
burst_beats <= 0;
burst_done <= 0;
next_entry_index <= 0;
counter_tx_beats <= 0;
counter_tx_bursts <= 0;
end else begin
tvalid <= 0;
tkeep <= 0;
tstrb <= 0;
tlast <= 0;
desc_wen <= 0;
desc_addr <= next_entry_index;
bram_latency_cnt <= 0;
burst_done <= 0;
if (burst_done) begin
desc_wen <= 1'b1;
next_entry_index <= next_entry_index + 1'b1;
counter_tx_bursts <= counter_tx_bursts + 1'b1;
end
case (tx_state)
TX_INIT: begin
desc_wen <= 1'b1;
next_entry_index <= next_entry_index + 1'b1;
if (next_entry_index == DESC_TOTAL - 1) begin
ip_ready <= 1'b1;
next_entry_index <= 0;
end
end
TX_OFF: begin
buf_addr <= 0;
timer_enable <= 0;
burst_beats <= 0;
counter_tx_beats <= 0;
counter_tx_bursts <= 0;
end
TX_IDLE: begin
burst_beats <= 0;
if (|burst_time_interval)
burst_time_interval_latched <= burst_time_interval;
else
burst_time_interval_latched <= 16'h1; // min 1us
if (desc_addr != doorbell[11:0]) begin
buf_addr <= {current_entry[15:0], 4'h0};
burst_len <= current_entry[27:16];
end
if (!enable) begin
next_entry_index <= 0;
end
end
TX_SKIP: begin
bram_latency_cnt <= bram_latency_cnt + 1'b1;
if (bram_latency_cnt >= BRAM_LATENCY - 1) begin
bram_latency_cnt <= 0;
end
if (!enable) begin
next_entry_index <= 0;
end
end
TX_DATA: begin
tvalid <= 1'b1;
tkeep <= {ADDR_STEP{1'b1}};
tstrb <= {ADDR_STEP{1'b1}};
tlast <= (burst_beats == burst_len - 1);
tdata <= buf_rdata;
buf_addr <= buf_addr + ADDR_STEP;
burst_beats <= burst_beats + 1'b1;
counter_tx_beats <= counter_tx_beats + 1'b1;
if (!enable) begin
next_entry_index <= 0;
end
end
TX_WAIT: begin
if (tvalid && tready) begin
tvalid <= 0;
tkeep <= 0;
tstrb <= 0;
tlast <= 0;
if (burst_beats >= burst_len) begin
burst_beats <= 0;
burst_done <= 1'b1;
timer_enable <= 1'b1;
end
end else begin
tvalid <= 1'b1;
tkeep <= {ADDR_STEP{1'b1}};
tstrb <= {ADDR_STEP{1'b1}};
tlast <= tlast;
end
if (!enable) begin
next_entry_index <= 0;
end
end
TX_INTERVAL: begin
if (timeout) begin
timer_enable <= 0;
end
if (!enable) begin
next_entry_index <= 0;
end
end
default: begin
// Do nothing
end
endcase
end
end
assign timeout = (timer_us >= burst_time_interval_latched) && timer_enable;
wall_timer #(
.MODULE_FREQ_HZ(FREQ_HZ),
.US_WIDTH(16)
) wall_timer_us_inst (
.clk(clk),
.rst(!rst_n),
.enable(timer_enable),
.resume(1'b0),
.us(timer_us),
.ms(),
.sec(),
.hour()
);
assign current_entry = desc_rdata;
assign buf_status[15: 0] = {next_entry_index};
assign buf_status[31:16] = {ip_ready, 8'h0};
endmodule

View File

@@ -0,0 +1,243 @@
//---------------------------------------------------------------------------------------
// filename: wall_timer.sv
// description: wall timer
// author: leguoqing@paisat.cn
//---------------------------------------------------------------------------------------
module wall_timer
#(
parameter MODULE_FREQ_HZ = 50e6,
parameter US_WIDTH = 10,
parameter MS_WIDTH = 0,
parameter SEC_WIDTH = 0,
parameter HOUR_WIDTH = 0
)(
input logic clk,
input logic rst,
input logic enable,
input logic resume,
output logic [(US_WIDTH>0 ? US_WIDTH-1 : 0):0] us,
output logic [(MS_WIDTH>0 ? MS_WIDTH-1 : 0):0] ms,
output logic [(SEC_WIDTH>0 ? SEC_WIDTH-1 : 0):0] sec,
output logic [(HOUR_WIDTH>0 ? HOUR_WIDTH-1 : 0):0] hour
);
if (MODULE_FREQ_HZ < 1e6) $error("ERROR: MODULE_FREQ_HZ < 1e6!");
if (MS_WIDTH > 0 && US_WIDTH < 10) $error("ERROR: MS_WIDTH > 0 && US_WIDTH < 10!");
if (SEC_WIDTH > 0 && MS_WIDTH < 10) $error("ERROR: SEC_WIDTH > 0 && MS_WIDTH < 10!");
if (HOUR_WIDTH > 0 && SEC_WIDTH < 12) $error("ERROR: HOUR_WIDTH > 0 && SEC_WIDTH < 12!");
localparam integer FREQ_CLK_MHZ = MODULE_FREQ_HZ / 1e6;
localparam integer CYCLE_WIDTH = $clog2(FREQ_CLK_MHZ);
logic [CYCLE_WIDTH-1:0] cycle_cnt;
/* tick signals, better as output port ? */
logic us_tick;
logic ms_tick;
logic sec_tick;
logic hour_tick;
always_ff @(posedge clk) begin
if (rst) begin
cycle_cnt <= 0;
end else begin
if (enable == 1 && resume == 0) begin
cycle_cnt <= cycle_cnt + 1;
if (cycle_cnt == CYCLE_WIDTH'(FREQ_CLK_MHZ - 1)) begin
cycle_cnt <= 0;
end
end else begin
cycle_cnt <= 0;
end
end
end
`ifndef __MICROSATE_SIM__
// us
always_ff @(posedge clk) begin
if (rst) begin
us_tick <= 0;
us <= 0;
end else begin
us_tick <= 0;
if (enable == 1 && resume == 0) begin
if (cycle_cnt == CYCLE_WIDTH'(FREQ_CLK_MHZ - 1)) begin
us_tick <= 1;
end
if (us_tick) begin
us <= us + 1;
if (MS_WIDTH == 0) begin
if (us_tick && us != {US_WIDTH{1'b1}}) begin
us <= us + 1;
end
end else begin
if (us_tick) begin
us <= us + 1;
if (us == US_WIDTH'(999)) begin
us <= 0;
end
end
end
end
end else begin
us <= 0;
end
end
end
// ms
generate
if (MS_WIDTH > 0) begin
always_ff @(posedge clk) begin
if (rst) begin
ms_tick <= 0;
ms <= 0;
end else begin
ms_tick <= 0;
if (enable == 1 && resume == 0) begin
if (us_tick && us == US_WIDTH'(999)) begin
ms_tick <= 1;
end
if (SEC_WIDTH == 0) begin
if (ms_tick && ms != {MS_WIDTH{1'b1}}) begin
ms <= ms + 1;
end
end else begin
if (ms_tick) begin
ms <= ms + 1;
if (ms == MS_WIDTH'(999)) begin
ms <= 0;
end
end
end
end else begin
ms <= 0;
end
end
end
end else begin
assign ms_tick = 0;
assign ms = 0;
end
endgenerate
`else
// us
always_ff @(posedge clk) begin
if (rst) begin
us_tick <= 0;
us <= 0;
end else begin
us_tick <= 0;
if (enable == 1 && resume == 0) begin
if (cycle_cnt == CYCLE_WIDTH'(FREQ_CLK_MHZ - 1)) begin
us_tick <= 1;
end
end else begin
us <= 0;
end
end
end
// ms
generate
if (MS_WIDTH > 0) begin
always_ff @(posedge clk) begin
if (rst) begin
ms_tick <= 0;
ms <= 0;
end else begin
ms_tick <= 0;
if (enable == 1 && resume == 0) begin
if (us_tick) begin
ms_tick <= 1;
end
if (SEC_WIDTH == 0) begin
if (ms_tick && ms != {MS_WIDTH{1'b1}}) begin
ms <= ms + 1;
end
end else begin
if (ms_tick) begin
ms <= ms + 1;
if (ms == MS_WIDTH'(999)) begin
ms <= 0;
end
end
end
end else begin
ms <= 0;
end
end
end
end else begin
assign ms_tick = 0;
assign ms = 0;
end
endgenerate
`endif
// sec
generate
if (SEC_WIDTH > 0) begin
always_ff @(posedge clk) begin
if (rst) begin
sec_tick <= 0;
sec <= 0;
end else begin
sec_tick <= 0;
if (enable == 1 && resume == 0) begin
if (ms_tick && ms == MS_WIDTH'(999)) begin
sec_tick <= 1;
end
if (HOUR_WIDTH == 0) begin
if (sec_tick && sec != {SEC_WIDTH{1'b1}}) begin
sec <= sec + 1;
end
end else begin
if (sec_tick) begin
sec <= sec + 1;
if (sec == SEC_WIDTH'(3599)) begin
sec <= 0;
end
end
end
end else begin
sec <= 0;
end
end
end
end else begin
assign sec_tick = 0;
assign sec = 0;
end
endgenerate
// hour
generate
if (HOUR_WIDTH > 0) begin
always_ff @(posedge clk) begin
if (rst) begin
hour_tick <= 0;
hour <= 0;
end else begin
hour_tick <= 0;
if (enable == 1 && resume == 0) begin
if (sec_tick && sec == SEC_WIDTH'(3599)) begin
hour_tick <= 1;
end
if (hour_tick && hour != {HOUR_WIDTH{1'b1}}) begin
hour <= hour + 1;
end
end else begin
hour <= 0;
end
end
end
end else begin
assign hour_tick = 0;
assign hour = 0;
end
endgenerate
endmodule

View File

@@ -0,0 +1,85 @@
# Definitional proc to organize widgets for parameters.
proc init_gui { IPINST } {
ipgui::add_param $IPINST -name "Component_Name"
#Adding Page
set Page_0 [ipgui::add_page $IPINST -name "Page 0"]
ipgui::add_param $IPINST -name "BRAM_LATENCY" -parent ${Page_0}
ipgui::add_param $IPINST -name "BUF_SIZE" -parent ${Page_0}
ipgui::add_param $IPINST -name "DESC_TOTAL" -parent ${Page_0}
ipgui::add_param $IPINST -name "FREQ_HZ" -parent ${Page_0}
ipgui::add_param $IPINST -name "STREAM_WIDTH" -parent ${Page_0}
}
proc update_PARAM_VALUE.BRAM_LATENCY { PARAM_VALUE.BRAM_LATENCY } {
# Procedure called to update BRAM_LATENCY when any of the dependent parameters in the arguments change
}
proc validate_PARAM_VALUE.BRAM_LATENCY { PARAM_VALUE.BRAM_LATENCY } {
# Procedure called to validate BRAM_LATENCY
return true
}
proc update_PARAM_VALUE.BUF_SIZE { PARAM_VALUE.BUF_SIZE } {
# Procedure called to update BUF_SIZE when any of the dependent parameters in the arguments change
}
proc validate_PARAM_VALUE.BUF_SIZE { PARAM_VALUE.BUF_SIZE } {
# Procedure called to validate BUF_SIZE
return true
}
proc update_PARAM_VALUE.DESC_TOTAL { PARAM_VALUE.DESC_TOTAL } {
# Procedure called to update DESC_TOTAL when any of the dependent parameters in the arguments change
}
proc validate_PARAM_VALUE.DESC_TOTAL { PARAM_VALUE.DESC_TOTAL } {
# Procedure called to validate DESC_TOTAL
return true
}
proc update_PARAM_VALUE.FREQ_HZ { PARAM_VALUE.FREQ_HZ } {
# Procedure called to update FREQ_HZ when any of the dependent parameters in the arguments change
}
proc validate_PARAM_VALUE.FREQ_HZ { PARAM_VALUE.FREQ_HZ } {
# Procedure called to validate FREQ_HZ
return true
}
proc update_PARAM_VALUE.STREAM_WIDTH { PARAM_VALUE.STREAM_WIDTH } {
# Procedure called to update STREAM_WIDTH when any of the dependent parameters in the arguments change
}
proc validate_PARAM_VALUE.STREAM_WIDTH { PARAM_VALUE.STREAM_WIDTH } {
# Procedure called to validate STREAM_WIDTH
return true
}
proc update_MODELPARAM_VALUE.FREQ_HZ { MODELPARAM_VALUE.FREQ_HZ PARAM_VALUE.FREQ_HZ } {
# Procedure called to set VHDL generic/Verilog parameter value(s) based on TCL parameter value
set_property value [get_property value ${PARAM_VALUE.FREQ_HZ}] ${MODELPARAM_VALUE.FREQ_HZ}
}
proc update_MODELPARAM_VALUE.BRAM_LATENCY { MODELPARAM_VALUE.BRAM_LATENCY PARAM_VALUE.BRAM_LATENCY } {
# Procedure called to set VHDL generic/Verilog parameter value(s) based on TCL parameter value
set_property value [get_property value ${PARAM_VALUE.BRAM_LATENCY}] ${MODELPARAM_VALUE.BRAM_LATENCY}
}
proc update_MODELPARAM_VALUE.STREAM_WIDTH { MODELPARAM_VALUE.STREAM_WIDTH PARAM_VALUE.STREAM_WIDTH } {
# Procedure called to set VHDL generic/Verilog parameter value(s) based on TCL parameter value
set_property value [get_property value ${PARAM_VALUE.STREAM_WIDTH}] ${MODELPARAM_VALUE.STREAM_WIDTH}
}
proc update_MODELPARAM_VALUE.BUF_SIZE { MODELPARAM_VALUE.BUF_SIZE PARAM_VALUE.BUF_SIZE } {
# Procedure called to set VHDL generic/Verilog parameter value(s) based on TCL parameter value
set_property value [get_property value ${PARAM_VALUE.BUF_SIZE}] ${MODELPARAM_VALUE.BUF_SIZE}
}
proc update_MODELPARAM_VALUE.DESC_TOTAL { MODELPARAM_VALUE.DESC_TOTAL PARAM_VALUE.DESC_TOTAL } {
# Procedure called to set VHDL generic/Verilog parameter value(s) based on TCL parameter value
set_property value [get_property value ${PARAM_VALUE.DESC_TOTAL}] ${MODELPARAM_VALUE.DESC_TOTAL}
}