Account for D port being a constant
authorEddie Hung <eddie@fpgeh.com>
Wed, 28 Aug 2019 22:31:55 +0000 (15:31 -0700)
committerEddie Hung <eddie@fpgeh.com>
Wed, 28 Aug 2019 22:31:55 +0000 (15:31 -0700)
passes/pmgen/xilinx_srl.pmg

index 45d44247a1abbf192e6ee2f10634651e6e0afddc..b18119b872b191346af82b2c6d2161bd0e216f38 100644 (file)
@@ -105,7 +105,7 @@ endcode
 match next
        select next->type.in($_DFF_N_, $_DFF_P_, $_DFFE_NN_, $_DFFE_NP_, $_DFFE_PN_, $_DFFE_PP_, \FDRE, \FDRE_1)
        select !next->has_keep_attr()
-       select !port(next, \D)[0].wire->get_bool_attribute(\keep)
+       select port(next, \D)[0].wire && !port(next, \D)[0].wire->get_bool_attribute(\keep)
        select nusers(port(next, \Q)) == 2
        index <IdString> next->type === first->type
        index <SigBit> port(next, \Q) === port(first, \D)
@@ -132,7 +132,7 @@ match next
        semioptional
        select next->type.in($_DFF_N_, $_DFF_P_, $_DFFE_NN_, $_DFFE_NP_, $_DFFE_PN_, $_DFFE_PP_, \FDRE, \FDRE_1)
        select !next->has_keep_attr()
-       select !port(next, \D)[0].wire->get_bool_attribute(\keep)
+       select port(next, \D)[0].wire && !port(next, \D)[0].wire->get_bool_attribute(\keep)
        select nusers(port(next, \Q)) == 2
        index <IdString> next->type === chain.back()->type
        index <SigBit> port(next, \Q) === port(chain.back(), \D)
@@ -201,7 +201,7 @@ endcode
 match first
        select first->type.in($_DFF_N_, $_DFF_P_, $_DFFE_NN_, $_DFFE_NP_, $_DFFE_PN_, $_DFFE_PP_, $dff, $dffe)
        select !first->has_keep_attr()
-       select !port(first, \Q)[0].wire->get_bool_attribute(\keep)
+       select port(first, \Q)[0].wire && !port(first, \Q)[0].wire->get_bool_attribute(\keep)
        slice idx GetSize(port(first, \Q))
        select nusers(port(first, \Q)[idx]) <= 2
        index <SigBit> port(first, \Q)[idx] === port(shiftx, \A)[shiftx_width-1]
@@ -272,7 +272,7 @@ match next
        semioptional
        select next->type.in($_DFF_N_, $_DFF_P_, $_DFFE_NN_, $_DFFE_NP_, $_DFFE_PN_, $_DFFE_PP_, $dff, $dffe)
        select !next->has_keep_attr()
-       select !port(next, \D)[0].wire->get_bool_attribute(\keep)
+       select port(next, \D)[0].wire && !port(next, \D)[0].wire->get_bool_attribute(\keep)
        slice idx GetSize(port(next, \Q))
        select nusers(port(next, \Q)[idx]) <= 3
        index <IdString> next->type === chain.back().first->type