Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Pyxsi enablement for alternative rtl simulation #1213

Draft
wants to merge 111 commits into
base: dev
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
111 commits
Select commit Hold shift + click to select a range
42cbf47
[Deps] add pyxsi fork and its deps
maltanar Aug 8, 2024
b6dba8a
[Util] add util to fetch Vivado path
maltanar Aug 8, 2024
1468dbe
[Sim] add a first draft of pyxsi-based simulation, untested
maltanar Aug 8, 2024
6907167
[Sim] try enabling pyxsi logging and tracing
maltanar Aug 8, 2024
5a5461c
[Op] experiment with enabling rtlsim with pyxsi
maltanar Aug 8, 2024
a50cdb6
[Deps] update pyxsi
maltanar Aug 14, 2024
77680dd
[Sim] update pyxsi API to include verilog spec, assume precompiled
maltanar Aug 14, 2024
1804c47
[Deps] ensure pyxsi is compiled + set envvars for its use
maltanar Aug 19, 2024
64e9fc1
[Sim] remove LD_LIBRARY_PATH setting from pyxsi util, doesn't work
maltanar Aug 19, 2024
d480e49
[Deps] update pyxsi
maltanar Aug 20, 2024
3560933
[AddStreams] set rtlsim_cycles for pyxsi prototyping
maltanar Aug 20, 2024
212927c
[Infra] only trigger pyxsi compile if Vivado detected
maltanar Aug 21, 2024
4fd5610
[Sim] move pyxsiutils to own repo, update deps, fix entrypoint chk
maltanar Aug 21, 2024
6e4d085
[pyxsi] trialling RPC server as LD_LIBRARY_PATH workaround
maltanar Sep 9, 2024
4558314
[Infra] remove global LD_LIBRARY_PATH setting from entrypoint
maltanar Oct 1, 2024
aff109f
[pyxsi] add license text to rpcserver&client
maltanar Oct 1, 2024
39ac22e
[Infra] start pyxsi rpc server in entrypoint
maltanar Oct 3, 2024
396cb8a
[Deps] update pyxsi
maltanar Oct 3, 2024
948b5b3
[Infra] redirect pyxsi rpcserver outputs to own logfile
maltanar Oct 3, 2024
159e228
[pyxsi] rework RPC interface to exclude rtlsim_multi_io
maltanar Oct 3, 2024
6250c8f
[Infra] don't launch pyxsi RPC server on startup (will be as needed)
maltanar Oct 4, 2024
42cbe0f
[pyxsi] start (and then terminate when done) one pyxsi RPC server per…
maltanar Oct 4, 2024
db2d9a1
Merge branch 'dev' into feature/pyxsi_integration
auphelia Oct 11, 2024
890ce81
[rtlsim] pyxsi for node-by-node rtlsim enablement via attribute
maltanar Oct 10, 2024
c04a4a8
[Deps] update pyxsi
maltanar Oct 10, 2024
b266a8a
[pyxsi] expose close_rtlsim() to exit cleanly
maltanar Oct 10, 2024
ab3c36f
[rtlsim] call close_rtlsim() to exit cleanly from pyxsi
auphelia Oct 11, 2024
fe7a942
[pyxsi] redirect rpcserver out to file for visible logging
maltanar Oct 10, 2024
655b904
[HLS] use subcore path only if it exists
maltanar Oct 10, 2024
acd88e5
[pyxsi] slightly more reliable start procedure for RPC server
maltanar Oct 10, 2024
c817adb
[prepare rtlsim] move rtlsim prep to rtlbackend for rtl layers
auphelia Oct 11, 2024
8d2daaf
[pyxsi] Make pyxsi import optional to allow GHA to work without insta…
auphelia Oct 14, 2024
1cc5f11
[PrepareRTLSim] Clean-up functions in rtl thresholding and move funct…
auphelia Oct 15, 2024
20e8b59
[rtlsim] enable stitched-IP rtlsim with pyxsi
maltanar Oct 11, 2024
cb6e08d
[Deps] update pyxsi
maltanar Oct 14, 2024
7f09b73
[Deps] update pyxsi
maltanar Oct 16, 2024
7018cfe
Closing the handle if the simulation times out
STFleming Oct 14, 2024
812bde4
[stitchedIP-rtlsim] Default rtlsim backend metadata prop to pyverilator
auphelia Oct 17, 2024
25443da
[prepare rtlsim] Clean-up functions in rtl mvu and vvu
auphelia Oct 22, 2024
afbf1fe
[execute node] switch to rtlsim multi io for all custom ops
auphelia Oct 22, 2024
de5cf61
[rtlsim] Delete obsolete rtlsim fct
auphelia Oct 22, 2024
743644b
Merge branch 'dev' into feature/pyxsi_integration
auphelia Oct 22, 2024
2437687
[prepare rtlsim] Clean up new rtl op fcts
auphelia Oct 25, 2024
cc30757
[AddStreams] Enable both rtlsim backends
auphelia Oct 25, 2024
e1a411b
[xsi] add a firs C++ templatet draft for driving XSI rtlsim directly
maltanar Oct 21, 2024
600b999
[xsi] remodel C++ driver from rtlsim_multi_io in pyxsi
maltanar Oct 21, 2024
2223fed
[xsi] add comments to XSI C++ sim driver and Python fxn
maltanar Oct 22, 2024
02f9c4b
[xsi] fix missing template, parse and return results dict
maltanar Oct 22, 2024
2ae55c1
[xsi] util functions to read signals in C++ template
maltanar Oct 22, 2024
71a0964
[xsi] don't call prep_rtlsim_io_dict for dummy data
maltanar Oct 22, 2024
9dba7c2
[FIFO] introduce XSI-based FIFO sizing
maltanar Oct 22, 2024
69df427
[xsi] make tracing optional
maltanar Oct 22, 2024
eab118d
[FIFO] remove stitched IP and rtlsim metadata after FIFO sizing
maltanar Oct 22, 2024
04c34a0
[xsi] add Vivado lib path to global LD_LIBRARY_PATH again
alexhornburg-xlnx Nov 6, 2024
83dd944
[xsi] replace pyxsi_rpc with pyxsi_utils
alexhornburg-xlnx Nov 14, 2024
d4bf3b3
[pyxsi] Adjust copyright header and linting
auphelia Nov 18, 2024
c0329e2
Merge pull request #1225 from alexhornburg-xlnx/feature/pyxsi_link_poc
auphelia Nov 19, 2024
bf1fafa
[Lint] Run pre-commit
auphelia Nov 19, 2024
42582f9
[pyxsi] Import optional to ensure non synthesis tests run
auphelia Nov 19, 2024
63a7ef6
[pyxsi] Enable both rtlsim backends in all HLS layers
auphelia Nov 19, 2024
8812079
[RTL] make it possible to use pyxsi as rtlsim backend
maltanar Nov 7, 2024
1115ddf
[RTLMVU] prototyping support for pyxsi rtlsim
maltanar Nov 7, 2024
28e482b
[MVU] use rtlsim fxns from base class instead of pyverilator directly
maltanar Nov 18, 2024
6a16fdf
[pyxsi] Remove references to rpc setup in cherry-picked commits
auphelia Nov 19, 2024
43b5437
[pyxsi] Add support for pyxsi execution to rtl fmpadding, dwc, fifo
auphelia Nov 19, 2024
a44237b
[pyxsi] Enable pyxsi for rtl vvau
auphelia Nov 19, 2024
c75678b
[rtl thresh] Rename top module and fix intf names
auphelia Nov 20, 2024
60fdd42
Driving AXI bus padding to zero.
preusser Nov 22, 2024
0a32c66
[pyxsi] Enable pyxsi for rtl swg
auphelia Nov 22, 2024
e8e9ce3
Merge branch 'dev' into feature/pyxsi_integration
auphelia Nov 22, 2024
24357f4
Merge pull request #1234 from Xilinx/preusser.axi_pad_zero
auphelia Nov 22, 2024
563fbb1
[SWG] Driving AXI bus padding to zero
auphelia Nov 22, 2024
7dc169e
[Tests] Default to pyxsi for testing
auphelia Nov 22, 2024
3b8d096
[FIFO] default to xsi instead of pyverilator for FIFO depth setting
maltanar Nov 22, 2024
e45ffb5
[Deps] update pyxsi
maltanar Nov 22, 2024
af603f5
[Test] use pyxsi for checksum test, including pre/post-hooks
maltanar Nov 22, 2024
9bbee05
Merge branch 'feature/pyxsi_integration' of github.com:Xilinx/finn in…
maltanar Nov 22, 2024
42b92c0
[Test] remove xfail from checksum test, works with pyxsi now
maltanar Nov 22, 2024
3385927
[Tests] Switch axilite read and write to pyxsi
auphelia Nov 25, 2024
68ce793
[Test] convert negative ctrl reg vals to 2s complement in dynamic SWG…
maltanar Nov 26, 2024
d0109a5
Adding liveness_threshold to the xsi call
STFleming Dec 9, 2024
1abe1d9
[HWCustomOp] Run linting
auphelia Dec 9, 2024
fb14363
[HLS] disable HLSFPO lib usage - may impact float cppsim!
maltanar Nov 26, 2024
9ac4e12
[HLS] includes have moved to under Vitis path for 2024.2, specify both
maltanar Nov 26, 2024
a7ed867
[Deps] update pyxsi
maltanar Jan 7, 2025
0634323
[Tests] Re-enable stitched ip rtlsim tests for MVAUs
auphelia Jan 7, 2025
afda943
[Tests] Add vitis path to compilation in data packing tests
auphelia Jan 8, 2025
6522c49
[FIFO] call get_simkernel_so for xsicpp FIFO sizing too
maltanar Nov 29, 2024
0e7dfd3
Merge branch 'dev' into feature/pyxsi_integration
auphelia Jan 8, 2025
55a3ff3
[HWCustomOp] Remove unused function for characterization based fifo s…
auphelia Jan 9, 2025
6abbc53
[Deps] update pyxsi
maltanar Jan 10, 2025
7b3e13a
[FIFO] lay groundwork for 2x-clkd xsicpp FIFO sizing
maltanar Nov 22, 2024
f997dd8
[FIFO] check for 2x clocked stitched-IP for xsicpp fifosim
maltanar Nov 22, 2024
faa5d51
[FIFO] handle clk2x key not existing in vivado_stitch_ifnames
maltanar Nov 22, 2024
6c896e4
[FIFO] support multiple I/O streams for xsicpp fifosim
maltanar Nov 22, 2024
ec36907
[RTLMVU] FORCE_BEHAVIORAL=0 for synth again (came from cherry picking)
maltanar Jan 10, 2025
1868a11
[XSICPP] report latency correctly
maltanar Jan 10, 2025
407e00f
[XSICPP] typo fix
maltanar Jan 10, 2025
5003647
[XSICPP] assert timeout
maltanar Jan 10, 2025
8e7311a
[XSICPP] typo fix
maltanar Jan 10, 2025
946ed82
[Util] Set default liveness threshold to 1M
auphelia Jan 10, 2025
967e5a1
[XSICPP] settable liveness threshold & get from latency est for FIFO …
maltanar Jan 13, 2025
f99c5ca
[HWCustomOp] bring back characterization with pyxsi + postclk hook
maltanar Jan 13, 2025
87bf4b5
[XSICPP] add input rate limit support
maltanar Jan 14, 2025
aa420e9
[FIFO] wire up input rate limit support in XSICPP FIFO sizing
maltanar Jan 14, 2025
0bb9f1d
[Build] add cfg options for input throttling and FIFO sim trace
maltanar Jan 14, 2025
47641a1
[FIFO,XSICPP] switch from rate limit to throttle cycles spec
maltanar Jan 14, 2025
cf08bc0
Merge branch 'dev' into feature/pyxsi_integration
auphelia Jan 14, 2025
31dc2dc
[Deps] Update pyxsi
auphelia Jan 15, 2025
0f0fbea
Merge branch 'feature/pyxsi_integration' of https://github.com/Xilinx…
auphelia Jan 15, 2025
99aa799
[Docker/CI] Add pytest-forked to dependencies and update Jenkins comm…
auphelia Jan 20, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 8 additions & 2 deletions docker/Dockerfile.finn
Original file line number Diff line number Diff line change
Expand Up @@ -65,12 +65,18 @@ RUN apt-get update && \
python-is-python3 \
python3-pip \
python3-setuptools-scm \
python3-venv
python3-venv \
pybind11-dev \
libfmt-dev \
libboost-dev \
libjansson-dev \
libgetdata-dev \
libtinfo5
RUN echo "StrictHostKeyChecking no" >> /etc/ssh/ssh_config
RUN locale-gen "en_US.UTF-8"

# install Verilator from source to get the right version
RUN apt-get install -y git perl make autoconf g++ flex bison ccache libgoogle-perftools-dev numactl perl-doc libfl2 libfl-dev zlib1g zlib1g-dev
RUN apt-get install -y git perl make autoconf g++-10 flex bison ccache libgoogle-perftools-dev numactl perl-doc libfl2 libfl-dev zlib1g zlib1g-dev
RUN git clone https://github.com/verilator/verilator
RUN cd verilator && \
git checkout v4.224 && \
Expand Down
17 changes: 17 additions & 0 deletions docker/finn_entrypoint.sh
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,22 @@ else
fi
fi

if [ -z "${XILINX_VIVADO}" ]; then
yecho "pyxsi will be unavailable since Vivado was not found"
else
if [ -f "${FINN_ROOT}/deps/pyxsi/pyxsi.so" ]; then
gecho "Found pyxsi at ${FINN_ROOT}/deps/pyxsi/pyxsi.so"
else
OLDPWD=$(pwd)
cd ${FINN_ROOT}/deps/pyxsi
touch .dockerenv
make
cd $OLDPWD
fi
export PYTHONPATH=$PYTHONPATH:${FINN_ROOT}/deps/pyxsi:${FINN_ROOT}/deps/pyxsi/py
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/lib/x86_64-linux-gnu/:${XILINX_VIVADO}/lib/lnx64.o
fi

if [ -f "$HLS_PATH/settings64.sh" ];then
# source Vitis HLS env.vars
source $HLS_PATH/settings64.sh
Expand All @@ -129,6 +145,7 @@ if [ -d "$FINN_ROOT/.Xilinx" ]; then
mkdir "$HOME/.Xilinx/Vivado/"
cp "$FINN_ROOT/.Xilinx/Vivado/Vivado_init.tcl" "$HOME/.Xilinx/Vivado/"
gecho "Found Vivado_init.tcl and copied to $HOME/.Xilinx/Vivado/Vivado_init.tcl"

else
yecho "Unable to find $FINN_ROOT/.Xilinx/Vivado/Vivado_init.tcl"
fi
Expand Down
4 changes: 2 additions & 2 deletions docker/jenkins/Jenkinsfile
Original file line number Diff line number Diff line change
Expand Up @@ -313,15 +313,15 @@ void createMultiMarkerScript(String markers, String testResultsFilename, String
// Passing multiple markers when running ./run-docker.sh does not work with bash.
// Therefore, create a script to maintain the single quotes that surround the markers
sh """echo "#!/bin/bash
python -m pytest -m \'${markers}\' --junitxml=${testResultsFilename}.xml --html=${testResultsFilename}.html --self-contained-html ${additionalOptions}" >> run-tests.sh
python -m pytest -m \'${markers}\' --forked --junitxml=${testResultsFilename}.xml --html=${testResultsFilename}.html --self-contained-html ${additionalOptions}" >> run-tests.sh
"""

// Give permissions to script
sh 'chmod 777 run-tests.sh'
}

void runDockerPytestWithMarker(String marker, String testResultsFilename, String additionalOptions) {
sh """./run-docker.sh python -m pytest -m ${marker} --junitxml=${testResultsFilename}.xml --html=${testResultsFilename}.html --self-contained-html ${additionalOptions}"""
sh """./run-docker.sh python -m pytest -m ${marker} --forked --junitxml=${testResultsFilename}.xml --html=${testResultsFilename}.html --self-contained-html ${additionalOptions}"""
}

def findBoardBuildFiles(String searchDir, String dirToFind) {
Expand Down
4 changes: 4 additions & 0 deletions fetch-repos.sh
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ XIL_BDF_COMMIT="8cf4bb674a919ac34e3d99d8d71a9e60af93d14e"
RFSOC4x2_BDF_COMMIT="13fb6f6c02c7dfd7e4b336b18b959ad5115db696"
KV260_BDF_COMMIT="98e0d3efc901f0b974006bc4370c2a7ad8856c79"
EXP_BOARD_FILES_MD5="226ca927a16ea4ce579f1332675e9e9a"
PYXSI_COMMIT="4f4ec10a3631c4c44b5bc0ede698d41c924d2b86"

QONNX_URL="https://github.com/fastmachinelearning/qonnx.git"
FINN_EXP_URL="https://github.com/Xilinx/finn-experimental.git"
Expand All @@ -51,6 +52,7 @@ AVNET_BDF_URL="https://github.com/Avnet/bdf.git"
XIL_BDF_URL="https://github.com/Xilinx/XilinxBoardStore.git"
RFSOC4x2_BDF_URL="https://github.com/RealDigitalOrg/RFSoC4x2-BSP.git"
KV260_BDF_URL="https://github.com/Xilinx/XilinxBoardStore.git"
PYXSI_URL="https://github.com/maltanar/pyxsi.git"

QONNX_DIR="qonnx"
FINN_EXP_DIR="finn-experimental"
Expand All @@ -63,6 +65,7 @@ AVNET_BDF_DIR="avnet-bdf"
XIL_BDF_DIR="xil-bdf"
RFSOC4x2_BDF_DIR="rfsoc4x2-bdf"
KV260_SOM_BDF_DIR="kv260-som-bdf"
PYXSI_DIR="pyxsi"

# absolute path to this script, e.g. /home/user/bin/foo.sh
SCRIPT=$(readlink -f "$0")
Expand Down Expand Up @@ -126,6 +129,7 @@ fetch_repo $AVNET_BDF_URL $AVNET_BDF_COMMIT $AVNET_BDF_DIR
fetch_repo $XIL_BDF_URL $XIL_BDF_COMMIT $XIL_BDF_DIR
fetch_repo $RFSOC4x2_BDF_URL $RFSOC4x2_BDF_COMMIT $RFSOC4x2_BDF_DIR
fetch_repo $KV260_BDF_URL $KV260_BDF_COMMIT $KV260_SOM_BDF_DIR
fetch_repo $PYXSI_URL $PYXSI_COMMIT $PYXSI_DIR

# Can skip downloading of board files entirely if desired
if [ "$FINN_SKIP_BOARD_FILES" = "1" ]; then
Expand Down
4 changes: 4 additions & 0 deletions finn-rtllib/swg/swg_template_wrapper.v
Original file line number Diff line number Diff line change
Expand Up @@ -71,4 +71,8 @@ $TOP_MODULE_NAME$_impl #(
.out_V_V_TREADY(out_V_TREADY)
);

if (OUT_WIDTH_PADDED > BUF_OUT_WIDTH) begin
assign out_V_TDATA[OUT_WIDTH_PADDED-1:BUF_OUT_WIDTH] = {(OUT_WIDTH_PADDED-BUF_OUT_WIDTH){1'b0}};
end

endmodule : $TOP_MODULE_NAME$
4 changes: 4 additions & 0 deletions finn-rtllib/swg/swg_template_wrapper_dynamic.v
Original file line number Diff line number Diff line change
Expand Up @@ -180,4 +180,8 @@ $TOP_MODULE_NAME$_impl #(
.cfg_last_write(cfg_last_write)
);

if (OUT_WIDTH_PADDED > BUF_OUT_WIDTH) begin
assign out_V_TDATA[OUT_WIDTH_PADDED-1:BUF_OUT_WIDTH] = {(OUT_WIDTH_PADDED-BUF_OUT_WIDTH){1'b0}};
end

endmodule : $TOP_MODULE_NAME$
5 changes: 4 additions & 1 deletion finn-rtllib/thresholding/hdl/thresholding_axi.sv
Original file line number Diff line number Diff line change
Expand Up @@ -191,7 +191,10 @@ module thresholding_axi #(
.cfg_rack, .cfg_q,

.irdy(s_axis_tready), .ivld(s_axis_tvalid), .idat,
.ordy(m_axis_tready), .ovld(m_axis_tvalid), .odat(m_axis_tdata)
.ordy(m_axis_tready), .ovld(m_axis_tvalid), .odat(m_axis_tdata[PE*O_BITS-1:0])
);
if($bits(m_axis_tdata) > PE*O_BITS) begin : genPadOut
assign m_axis_tdata[$left(m_axis_tdata):PE*O_BITS] = '0;
end : genPadOut

endmodule : thresholding_axi
2 changes: 1 addition & 1 deletion finn-rtllib/thresholding/sim/thresholding_axi_tb.sv
Original file line number Diff line number Diff line change
Expand Up @@ -232,7 +232,7 @@ module thresholding_axi_tb #(
end
join_any
done <= 1;
repeat(N+6) @(posedge clk);
repeat(2*N+8) @(posedge clk);

assert(QW.size() == 0) else begin
$error("Missing %0d outputs.", QW.size());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -404,6 +404,7 @@
"child_model = child_model.transform(CreateStitchedIP(test_fpga_part, target_clk_ns))\n",
"child_model = child_model.transform(PrepareRTLSim())\n",
"child_model.set_metadata_prop(\"exec_mode\",\"rtlsim\")\n",
"child_model.set_metadata_prop(\"rtlsim_backend\",\"pyxsi\")\n",
"child_model.save(build_dir + \"/tfc_w1_a1_dataflow_child.onnx\");"
]
},
Expand Down
1 change: 1 addition & 0 deletions requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ pre-commit==3.3.2
protobuf==3.20.3
psutil==5.9.4
pyscaffold==4.4
pytest-forked==1.6.0
scipy==1.10.1
setupext-janitor>=1.1.2
sigtools==4.0.1
Expand Down
8 changes: 8 additions & 0 deletions src/finn/builder/build_dataflow_config.py
Original file line number Diff line number Diff line change
Expand Up @@ -281,6 +281,14 @@ class DataflowBuildConfig:
#: Only relevant when `auto_fifo_depths = True`
large_fifo_mem_style: Optional[LargeFIFOMemStyle] = LargeFIFOMemStyle.AUTO

#: Enable input throttling for simulation-based FIFO sizing
#: Only relevant if auto_fifo_strategy = LARGEFIFO_RTLSIM
fifosim_input_throttle: Optional[bool] = True

#: Enable saving waveforms from simulation-based FIFO sizing
#: Only relevant if auto_fifo_strategy = LARGEFIFO_RTLSIM
fifosim_save_waveform: Optional[bool] = False

#: Target clock frequency (in nanoseconds) for Vitis HLS synthesis.
#: e.g. `hls_clk_period_ns=5.0` will target a 200 MHz clock.
#: If not specified it will default to synth_clk_period_ns
Expand Down
12 changes: 10 additions & 2 deletions src/finn/builder/build_dataflow_steps.py
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,7 @@
InsertAndSetFIFODepths,
RemoveShallowFIFOs,
SplitLargeFIFOs,
xsi_fifosim,
)
from finn.transformation.fpgadataflow.set_folding import SetFolding
from finn.transformation.fpgadataflow.specialize_layers import SpecializeLayers
Expand All @@ -126,7 +127,6 @@
get_rtlsim_trace_depth,
pyverilate_get_liveness_threshold_cycles,
)
from finn.util.pyverilator import verilator_fifosim
from finn.util.test import execute_parent


Expand Down Expand Up @@ -250,6 +250,8 @@ def prepare_for_stitched_ip_rtlsim(verify_model, cfg):
# set top-level prop for stitched-ip rtlsim and launch
verify_model.set_metadata_prop("exec_mode", "rtlsim")
# TODO make configurable
verify_model.set_metadata_prop("rtlsim_backend", "pyxsi")
# TODO make configurable
# verify_model.set_metadata_prop("rtlsim_trace", "trace.vcd")
return verify_model

Expand Down Expand Up @@ -583,15 +585,21 @@ def step_set_fifo_depths(model: ModelWrapper, cfg: DataflowBuildConfig):
"Multi-in/out streams currently not supported "
+ "in FINN C++ verilator driver, falling back to Python"
)
if cfg.fifosim_save_waveform:
model.set_metadata_prop("rtlsim_trace", "fifosim_trace.wdb")
model = model.transform(
InsertAndSetFIFODepths(
cfg._resolve_fpga_part(),
cfg._resolve_hls_clk_period(),
swg_exception=cfg.default_swg_exception,
vivado_ram_style=cfg.large_fifo_mem_style,
force_python_sim=force_python_sim,
fifosim_input_throttle=cfg.fifosim_input_throttle,
)
)
if cfg.fifosim_save_waveform:
# un-set rtlsim_trace to remove unwanted traces in later steps
model.set_metadata_prop("rtlsim_trace", "")
# InsertAndSetFIFODepths internally removes any shallow FIFOs
# so no need to call RemoveShallowFIFOs here
else:
Expand Down Expand Up @@ -719,7 +727,7 @@ def step_measure_rtlsim_performance(model: ModelWrapper, cfg: DataflowBuildConfi
rtlsim_perf_dict = throughput_test_rtlsim(rtlsim_model, rtlsim_bs)
rtlsim_perf_dict["latency_cycles"] = rtlsim_latency_dict["cycles"]
else:
rtlsim_perf_dict = verilator_fifosim(model, rtlsim_bs)
rtlsim_perf_dict = xsi_fifosim(model, rtlsim_bs)
# keep keys consistent between the Python and C++-styles
cycles = rtlsim_perf_dict["cycles"]
clk_ns = float(model.get_metadata_prop("clk_ns"))
Expand Down
64 changes: 29 additions & 35 deletions src/finn/core/onnx_exec.py
Original file line number Diff line number Diff line change
Expand Up @@ -52,44 +52,38 @@ def execute_onnx(model, input_dict, return_full_exec_context=False, start_node=N
model_exec_mode = model.get_metadata_prop("exec_mode")
if (model_exec_mode is None) or (model_exec_mode == ""):
return execute_onnx_base(model, input_dict, return_full_exec_context, start_node, end_node)
elif model_exec_mode == "rtlsim":
# check sanity of model and then use stitched IP for rtlsim
if not model.check_all_tensor_shapes_specified():
raise Exception("Found unspecified tensor shapes, try infer_shapes")
ret = model.analysis(ta.nodes_topologically_sorted)
assert (
ret["nodes_topologically_sorted"] is True
), """Nodes must be
topologically sorted."""

if not model.check_all_tensor_shapes_specified():
raise Exception("Found unspecified tensor shapes, try infer_shapes")
ret = model.analysis(ta.nodes_topologically_sorted)
assert (
ret["nodes_topologically_sorted"] is True
), """Nodes must be
topologically sorted."""

graph = model.graph
# first, we need to make sure that every variable required by the graph has
# some buffer associated with it. this includes graph inputs (which includes
# the input data as well as the trained parameters) and the graph ValueInfo
# (intermediate tensors between layers)
# this is provided by the execution_context, which is a dict of np.ndarray
execution_context = model.make_empty_exec_context()
# fill in any inputs provided to this function
for inp_name in input_dict.keys():
if inp_name in execution_context:
if execution_context[inp_name].shape == input_dict[inp_name].shape:
execution_context[inp_name] = input_dict[inp_name]
else:
raise Exception(
"Shape mismatch for provided input %s: found %s expected %s "
% (
inp_name,
str(execution_context[inp_name].shape),
str(input_dict[inp_name].shape),
graph = model.graph
# first, we need to make sure that every variable required by the graph has
# some buffer associated with it. this includes graph inputs (which includes
# the input data as well as the trained parameters) and the graph ValueInfo
# (intermediate tensors between layers)
# this is provided by the execution_context, which is a dict of np.ndarray
execution_context = model.make_empty_exec_context()
# fill in any inputs provided to this function
for inp_name in input_dict.keys():
if inp_name in execution_context:
if execution_context[inp_name].shape == input_dict[inp_name].shape:
execution_context[inp_name] = input_dict[inp_name]
else:
raise Exception(
"Shape mismatch for provided input %s: found %s expected %s "
% (
inp_name,
str(execution_context[inp_name].shape),
str(input_dict[inp_name].shape),
)
)
)

# check if model has an execution mode set
# if None, execute model node by node using execute_node()
# if set to "rtlsim" execute model using pyverilator
model_exec_mode = model.get_metadata_prop("exec_mode")
if (model_exec_mode is None) or (model_exec_mode == ""):
return execute_onnx_base()
elif model_exec_mode == "rtlsim":
# use stitched IP for rtlsim
rtlsim_exec(model, execution_context)
else:
Expand Down
Loading
Loading