aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEddie Hung <eddie@fpgeh.com>2019-08-23 16:13:16 -0700
committerEddie Hung <eddie@fpgeh.com>2019-08-23 16:13:16 -0700
commit2217d926a9d353d732ba7dd81a3782f964463f5d (patch)
tree21bb6db7df003ed73c1e5c4cc2a68cebe2fdba1b
parentb1caf7be5eef134f7bd84c5336560dd3dff1e29b (diff)
downloadyosys-2217d926a9d353d732ba7dd81a3782f964463f5d.tar.gz
yosys-2217d926a9d353d732ba7dd81a3782f964463f5d.tar.bz2
yosys-2217d926a9d353d732ba7dd81a3782f964463f5d.zip
Same for variable length
-rw-r--r--passes/pmgen/xilinx_srl.pmg12
1 files changed, 10 insertions, 2 deletions
diff --git a/passes/pmgen/xilinx_srl.pmg b/passes/pmgen/xilinx_srl.pmg
index cefd1ea71..531ea1828 100644
--- a/passes/pmgen/xilinx_srl.pmg
+++ b/passes/pmgen/xilinx_srl.pmg
@@ -181,7 +181,7 @@ endcode
pattern variable
-state <IdString> clk_port
+state <IdString> clk_port en_port
state <int> shiftx_width
state <int> slice
udata <int> minlen
@@ -207,12 +207,18 @@ match first
set slice idx
endmatch
-code clk_port
+code clk_port en_port
if (first->type.in($_DFF_N_, $_DFF_P_, $_DFFE_NN_, $_DFFE_NP_, $_DFFE_PN_, $_DFFE_PP_))
clk_port = \C;
else if (first->type.in($dff, $dffe))
clk_port = \CLK;
else log_abort();
+ if (first->type.in($_DFF_N_, $_DFF_P_, $_DFFE_NN_, $_DFFE_NP_, $_DFFE_PN_, $_DFFE_PP_))
+ en_port = \E;
+ else if (first->type.in($dff, $dffe))
+ en_port = \EN;
+ else log_abort();
+
chain.emplace_back(first, slice);
subpattern(tail);
finally
@@ -229,6 +235,7 @@ arg shiftx
arg shiftx_width
arg slice
arg clk_port
+arg en_port
match next
semioptional
@@ -241,6 +248,7 @@ match next
index <SigBit> port(next, \Q)[idx] === port(chain.back().first, \D)[chain.back().second]
index <SigBit> port(next, \Q)[idx] === port(shiftx, \A)[shiftx_width-1-GetSize(chain)]
filter port(next, clk_port) == port(first, clk_port)
+ filter en_port == IdString() || port(next, en_port) == port(first, en_port)
set slice idx
endmatch