aboutsummaryrefslogtreecommitdiffstats
path: root/passes/pmgen/xilinx_dsp.pmg
diff options
context:
space:
mode:
authorEddie Hung <eddie@fpgeh.com>2019-09-25 14:04:36 -0700
committerEddie Hung <eddie@fpgeh.com>2019-09-25 14:04:36 -0700
commit53ea5daa42db335a69d3fccbf237fe5555f4bccb (patch)
tree6dc9bc21331cbaeb8625e05676b0d23f4f7f9e8d /passes/pmgen/xilinx_dsp.pmg
parent93363c94a2e88e2cdbdb962ff9e10ba5dfe3f586 (diff)
downloadyosys-53ea5daa42db335a69d3fccbf237fe5555f4bccb.tar.gz
yosys-53ea5daa42db335a69d3fccbf237fe5555f4bccb.tar.bz2
yosys-53ea5daa42db335a69d3fccbf237fe5555f4bccb.zip
Call 'wreduce' after mul2dsp to avoid unextend()
Diffstat (limited to 'passes/pmgen/xilinx_dsp.pmg')
-rw-r--r--passes/pmgen/xilinx_dsp.pmg9
1 files changed, 4 insertions, 5 deletions
diff --git a/passes/pmgen/xilinx_dsp.pmg b/passes/pmgen/xilinx_dsp.pmg
index 553195649..bca44c08d 100644
--- a/passes/pmgen/xilinx_dsp.pmg
+++ b/passes/pmgen/xilinx_dsp.pmg
@@ -1,6 +1,5 @@
pattern xilinx_dsp_pack
-udata <std::function<SigSpec(const SigSpec&)>> unextend
state <SigBit> clock
state <SigSpec> sigA sigB sigC sigD sigM sigP
state <IdString> postAddAB postAddMuxAB
@@ -25,7 +24,7 @@ match dsp
endmatch
code sigA sigB sigC sigD sigM clock
- unextend = [](const SigSpec &sig) {
+ auto unextend = [](const SigSpec &sig) {
int i;
for (i = GetSize(sig)-1; i > 0; i--)
if (sig[i] != sig[i-1])
@@ -272,9 +271,9 @@ match postAdd
filter !ffMcemux || nusers(port(postAdd, AB)) == 3
index <SigBit> port(postAdd, AB)[0] === sigP[0]
- filter GetSize(unextend(port(postAdd, AB))) <= GetSize(sigP)
- filter unextend(port(postAdd, AB)) == sigP.extract(0, GetSize(unextend(port(postAdd, AB))))
- filter nusers(sigP.extract_end(GetSize(unextend(port(postAdd, AB))))) <= 1
+ filter GetSize(port(postAdd, AB)) <= GetSize(sigP)
+ filter port(postAdd, AB) == sigP.extract(0, GetSize(port(postAdd, AB)))
+ filter nusers(sigP.extract_end(GetSize(port(postAdd, AB)))) <= 1
set postAddAB AB
optional
endmatch