From 14a5c42a8bd425a4882ba566b26e11bd6d1e1721 Mon Sep 17 00:00:00 2001 From: Norbert Braun Date: Mon, 2 Nov 2020 22:00:17 +0100 Subject: [PATCH] vendor.xilinx_7series: byte swap generated bitstream The Zynq driver in the FPGA Manager framework on Linux expects bitstreams that are byte swapped with respect to what the Vivado command `write_bitstream -bin_file` produces. Thus, use the `write_cfgmem` command with appropriate options to generate the bitstream (.bin file). Fixes #519. --- nmigen/vendor/xilinx_7series.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/nmigen/vendor/xilinx_7series.py b/nmigen/vendor/xilinx_7series.py index 136ab18..9dd738c 100644 --- a/nmigen/vendor/xilinx_7series.py +++ b/nmigen/vendor/xilinx_7series.py @@ -143,7 +143,8 @@ class Xilinx7SeriesPlatform(TemplatedPlatform): report_timing_summary -datasheet -max_paths 10 -file {{name}}_timing.rpt report_power -file {{name}}_power.rpt {{get_override("script_before_bitstream")|default("# (script_before_bitstream placeholder)")}} - write_bitstream -force -bin_file {{name}}.bit + write_bitstream -force {{name}}.bit + write_cfgmem -force -format bin -interface smapx32 -disablebitswap -loadbit "up 0 {{name}}.bit" {{name}}.bin {{get_override("script_after_bitstream")|default("# (script_after_bitstream placeholder)")}} quit """, -- 2.30.2