aboutsummaryrefslogtreecommitdiffstats
path: root/techlibs/xilinx
diff options
context:
space:
mode:
authorN. Engelhardt <nak@symbioticeda.com>2019-10-17 21:33:54 +0200
committerN. Engelhardt <nak@symbioticeda.com>2019-10-17 21:33:54 +0200
commit3b405d985e789ecf0082f724d2d62d3752e4b60c (patch)
tree22bc7aea6e7df31a45e2754e14e26a76f8d83423 /techlibs/xilinx
parent0d037bf9d8d866239de15d72dc8c5acd7ab5e5cf (diff)
downloadyosys-3b405d985e789ecf0082f724d2d62d3752e4b60c.tar.gz
yosys-3b405d985e789ecf0082f724d2d62d3752e4b60c.tar.bz2
yosys-3b405d985e789ecf0082f724d2d62d3752e4b60c.zip
Call memory_dff before DSP mapping to reserve registers (fixes #1447)
Diffstat (limited to 'techlibs/xilinx')
-rw-r--r--techlibs/xilinx/synth_xilinx.cc1
1 files changed, 1 insertions, 0 deletions
diff --git a/techlibs/xilinx/synth_xilinx.cc b/techlibs/xilinx/synth_xilinx.cc
index f13740865..6f8254b59 100644
--- a/techlibs/xilinx/synth_xilinx.cc
+++ b/techlibs/xilinx/synth_xilinx.cc
@@ -341,6 +341,7 @@ struct SynthXilinxPass : public ScriptPass
if (check_label("map_dsp", "(skip if '-nodsp')")) {
if (!nodsp || help_mode) {
+ run("memory_dff"); // xilinx_dsp will merge registers, reserve memory port registers first
// NB: Xilinx multipliers are signed only
run("techmap -map +/mul2dsp.v -map +/xilinx/dsp_map.v -D DSP_A_MAXWIDTH=25 "
"-D DSP_A_MAXWIDTH_PARTIAL=18 -D DSP_B_MAXWIDTH=18 " // Partial multipliers are intentionally