diff options
| author | Marcelina KoĆcielnicka <mwk@0x04.net> | 2020-06-23 15:39:25 +0200 | 
|---|---|---|
| committer | Marcelina KoĆcielnicka <mwk@0x04.net> | 2020-06-23 15:40:02 +0200 | 
| commit | e71d82759029470663037eb299791d03fef83287 (patch) | |
| tree | 2180682e87d7e26cdfb5db404d238a1a754de045 | |
| parent | 832acc86483bf8a61d66bee6f04385ad948902a5 (diff) | |
| download | yosys-e71d82759029470663037eb299791d03fef83287.tar.gz yosys-e71d82759029470663037eb299791d03fef83287.tar.bz2 yosys-e71d82759029470663037eb299791d03fef83287.zip | |
Add add* functions for the new FF types
| -rw-r--r-- | kernel/rtlil.cc | 193 | ||||
| -rw-r--r-- | kernel/rtlil.h | 20 | 
2 files changed, 213 insertions, 0 deletions
| diff --git a/kernel/rtlil.cc b/kernel/rtlil.cc index 7e71adbb0..d7d226942 100644 --- a/kernel/rtlil.cc +++ b/kernel/rtlil.cc @@ -2476,6 +2476,25 @@ RTLIL::Cell* RTLIL::Module::addDffsr(RTLIL::IdString name, const RTLIL::SigSpec  	return cell;  } +RTLIL::Cell* RTLIL::Module::addDffsre(RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr, +		RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity, bool en_polarity, bool set_polarity, bool clr_polarity, const std::string &src) +{ +	RTLIL::Cell *cell = addCell(name, ID($dffsre)); +	cell->parameters[ID::CLK_POLARITY] = clk_polarity; +	cell->parameters[ID::EN_POLARITY] = en_polarity; +	cell->parameters[ID::SET_POLARITY] = set_polarity; +	cell->parameters[ID::CLR_POLARITY] = clr_polarity; +	cell->parameters[ID::WIDTH] = sig_q.size(); +	cell->setPort(ID::CLK, sig_clk); +	cell->setPort(ID::EN, sig_en); +	cell->setPort(ID::SET, sig_set); +	cell->setPort(ID::CLR, sig_clr); +	cell->setPort(ID::D, sig_d); +	cell->setPort(ID::Q, sig_q); +	cell->set_src_attribute(src); +	return cell; +} +  RTLIL::Cell* RTLIL::Module::addAdff(RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_arst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q,  		RTLIL::Const arst_value, bool clk_polarity, bool arst_polarity, const std::string &src)  { @@ -2492,6 +2511,76 @@ RTLIL::Cell* RTLIL::Module::addAdff(RTLIL::IdString name, const RTLIL::SigSpec &  	return cell;  } +RTLIL::Cell* RTLIL::Module::addAdffe(RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_arst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +		RTLIL::Const arst_value, bool clk_polarity, bool en_polarity, bool arst_polarity, const std::string &src) +{ +	RTLIL::Cell *cell = addCell(name, ID($adffe)); +	cell->parameters[ID::CLK_POLARITY] = clk_polarity; +	cell->parameters[ID::EN_POLARITY] = en_polarity; +	cell->parameters[ID::ARST_POLARITY] = arst_polarity; +	cell->parameters[ID::ARST_VALUE] = arst_value; +	cell->parameters[ID::WIDTH] = sig_q.size(); +	cell->setPort(ID::CLK, sig_clk); +	cell->setPort(ID::EN, sig_en); +	cell->setPort(ID::ARST, sig_arst); +	cell->setPort(ID::D, sig_d); +	cell->setPort(ID::Q, sig_q); +	cell->set_src_attribute(src); +	return cell; +} + +RTLIL::Cell* RTLIL::Module::addSdff(RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_srst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +		RTLIL::Const srst_value, bool clk_polarity, bool srst_polarity, const std::string &src) +{ +	RTLIL::Cell *cell = addCell(name, ID($sdff)); +	cell->parameters[ID::CLK_POLARITY] = clk_polarity; +	cell->parameters[ID::SRST_POLARITY] = srst_polarity; +	cell->parameters[ID::SRST_VALUE] = srst_value; +	cell->parameters[ID::WIDTH] = sig_q.size(); +	cell->setPort(ID::CLK, sig_clk); +	cell->setPort(ID::SRST, sig_srst); +	cell->setPort(ID::D, sig_d); +	cell->setPort(ID::Q, sig_q); +	cell->set_src_attribute(src); +	return cell; +} + +RTLIL::Cell* RTLIL::Module::addSdffe(RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_srst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +		RTLIL::Const srst_value, bool clk_polarity, bool en_polarity, bool srst_polarity, const std::string &src) +{ +	RTLIL::Cell *cell = addCell(name, ID($sdffe)); +	cell->parameters[ID::CLK_POLARITY] = clk_polarity; +	cell->parameters[ID::EN_POLARITY] = en_polarity; +	cell->parameters[ID::SRST_POLARITY] = srst_polarity; +	cell->parameters[ID::SRST_VALUE] = srst_value; +	cell->parameters[ID::WIDTH] = sig_q.size(); +	cell->setPort(ID::CLK, sig_clk); +	cell->setPort(ID::EN, sig_en); +	cell->setPort(ID::SRST, sig_srst); +	cell->setPort(ID::D, sig_d); +	cell->setPort(ID::Q, sig_q); +	cell->set_src_attribute(src); +	return cell; +} + +RTLIL::Cell* RTLIL::Module::addSdffce(RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_srst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +		RTLIL::Const srst_value, bool clk_polarity, bool en_polarity, bool srst_polarity, const std::string &src) +{ +	RTLIL::Cell *cell = addCell(name, ID($sdffce)); +	cell->parameters[ID::CLK_POLARITY] = clk_polarity; +	cell->parameters[ID::EN_POLARITY] = en_polarity; +	cell->parameters[ID::SRST_POLARITY] = srst_polarity; +	cell->parameters[ID::SRST_VALUE] = srst_value; +	cell->parameters[ID::WIDTH] = sig_q.size(); +	cell->setPort(ID::CLK, sig_clk); +	cell->setPort(ID::EN, sig_en); +	cell->setPort(ID::SRST, sig_srst); +	cell->setPort(ID::D, sig_d); +	cell->setPort(ID::Q, sig_q); +	cell->set_src_attribute(src); +	return cell; +} +  RTLIL::Cell* RTLIL::Module::addDlatch(RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, bool en_polarity, const std::string &src)  {  	RTLIL::Cell *cell = addCell(name, ID($dlatch)); @@ -2504,6 +2593,22 @@ RTLIL::Cell* RTLIL::Module::addDlatch(RTLIL::IdString name, const RTLIL::SigSpec  	return cell;  } +RTLIL::Cell* RTLIL::Module::addAdlatch(RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_arst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +		RTLIL::Const arst_value, bool en_polarity, bool arst_polarity, const std::string &src) +{ +	RTLIL::Cell *cell = addCell(name, ID($adlatch)); +	cell->parameters[ID::EN_POLARITY] = en_polarity; +	cell->parameters[ID::ARST_POLARITY] = arst_polarity; +	cell->parameters[ID::ARST_VALUE] = arst_value; +	cell->parameters[ID::WIDTH] = sig_q.size(); +	cell->setPort(ID::EN, sig_en); +	cell->setPort(ID::ARST, sig_arst); +	cell->setPort(ID::D, sig_d); +	cell->setPort(ID::Q, sig_q); +	cell->set_src_attribute(src); +	return cell; +} +  RTLIL::Cell* RTLIL::Module::addDlatchsr(RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr,  		RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool en_polarity, bool set_polarity, bool clr_polarity, const std::string &src)  { @@ -2521,6 +2626,17 @@ RTLIL::Cell* RTLIL::Module::addDlatchsr(RTLIL::IdString name, const RTLIL::SigSp  	return cell;  } +RTLIL::Cell* RTLIL::Module::addSrGate(RTLIL::IdString name, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr, +		const RTLIL::SigSpec &sig_q, bool set_polarity, bool clr_polarity, const std::string &src) +{ +	RTLIL::Cell *cell = addCell(name, stringf("$_SR_%c%c_", set_polarity ? 'P' : 'N', clr_polarity ? 'P' : 'N')); +	cell->setPort(ID::S, sig_set); +	cell->setPort(ID::R, sig_clr); +	cell->setPort(ID::Q, sig_q); +	cell->set_src_attribute(src); +	return cell; +} +  RTLIL::Cell* RTLIL::Module::addFfGate(RTLIL::IdString name, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, const std::string &src)  {  	RTLIL::Cell *cell = addCell(name, ID($_FF_)); @@ -2564,6 +2680,20 @@ RTLIL::Cell* RTLIL::Module::addDffsrGate(RTLIL::IdString name, const RTLIL::SigS  	return cell;  } +RTLIL::Cell* RTLIL::Module::addDffsreGate(RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr, +		RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity, bool en_polarity, bool set_polarity, bool clr_polarity, const std::string &src) +{ +	RTLIL::Cell *cell = addCell(name, stringf("$_DFFSRE_%c%c%c%c_", clk_polarity ? 'P' : 'N', set_polarity ? 'P' : 'N', clr_polarity ? 'P' : 'N', en_polarity ? 'P' : 'N')); +	cell->setPort(ID::C, sig_clk); +	cell->setPort(ID::S, sig_set); +	cell->setPort(ID::R, sig_clr); +	cell->setPort(ID::E, sig_en); +	cell->setPort(ID::D, sig_d); +	cell->setPort(ID::Q, sig_q); +	cell->set_src_attribute(src); +	return cell; +} +  RTLIL::Cell* RTLIL::Module::addAdffGate(RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_arst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q,  		bool arst_value, bool clk_polarity, bool arst_polarity, const std::string &src)  { @@ -2576,6 +2706,57 @@ RTLIL::Cell* RTLIL::Module::addAdffGate(RTLIL::IdString name, const RTLIL::SigSp  	return cell;  } +RTLIL::Cell* RTLIL::Module::addAdffeGate(RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_arst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +		bool arst_value, bool clk_polarity, bool en_polarity, bool arst_polarity, const std::string &src) +{ +	RTLIL::Cell *cell = addCell(name, stringf("$_DFFE_%c%c%c%c_", clk_polarity ? 'P' : 'N', arst_polarity ? 'P' : 'N', arst_value ? '1' : '0', en_polarity ? 'P' : 'N')); +	cell->setPort(ID::C, sig_clk); +	cell->setPort(ID::R, sig_arst); +	cell->setPort(ID::E, sig_en); +	cell->setPort(ID::D, sig_d); +	cell->setPort(ID::Q, sig_q); +	cell->set_src_attribute(src); +	return cell; +} + +RTLIL::Cell* RTLIL::Module::addSdffGate(RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_srst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +		bool srst_value, bool clk_polarity, bool srst_polarity, const std::string &src) +{ +	RTLIL::Cell *cell = addCell(name, stringf("$_SDFF_%c%c%c_", clk_polarity ? 'P' : 'N', srst_polarity ? 'P' : 'N', srst_value ? '1' : '0')); +	cell->setPort(ID::C, sig_clk); +	cell->setPort(ID::R, sig_srst); +	cell->setPort(ID::D, sig_d); +	cell->setPort(ID::Q, sig_q); +	cell->set_src_attribute(src); +	return cell; +} + +RTLIL::Cell* RTLIL::Module::addSdffeGate(RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_srst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +		bool srst_value, bool clk_polarity, bool en_polarity, bool srst_polarity, const std::string &src) +{ +	RTLIL::Cell *cell = addCell(name, stringf("$_SDFFE_%c%c%c%c_", clk_polarity ? 'P' : 'N', srst_polarity ? 'P' : 'N', srst_value ? '1' : '0', en_polarity ? 'P' : 'N')); +	cell->setPort(ID::C, sig_clk); +	cell->setPort(ID::R, sig_srst); +	cell->setPort(ID::E, sig_en); +	cell->setPort(ID::D, sig_d); +	cell->setPort(ID::Q, sig_q); +	cell->set_src_attribute(src); +	return cell; +} + +RTLIL::Cell* RTLIL::Module::addSdffceGate(RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_srst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +		bool srst_value, bool clk_polarity, bool en_polarity, bool srst_polarity, const std::string &src) +{ +	RTLIL::Cell *cell = addCell(name, stringf("$_SDFFCE_%c%c%c%c_", clk_polarity ? 'P' : 'N', srst_polarity ? 'P' : 'N', srst_value ? '1' : '0', en_polarity ? 'P' : 'N')); +	cell->setPort(ID::C, sig_clk); +	cell->setPort(ID::R, sig_srst); +	cell->setPort(ID::E, sig_en); +	cell->setPort(ID::D, sig_d); +	cell->setPort(ID::Q, sig_q); +	cell->set_src_attribute(src); +	return cell; +} +  RTLIL::Cell* RTLIL::Module::addDlatchGate(RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, bool en_polarity, const std::string &src)  {  	RTLIL::Cell *cell = addCell(name, stringf("$_DLATCH_%c_", en_polarity ? 'P' : 'N')); @@ -2586,6 +2767,18 @@ RTLIL::Cell* RTLIL::Module::addDlatchGate(RTLIL::IdString name, const RTLIL::Sig  	return cell;  } +RTLIL::Cell* RTLIL::Module::addAdlatchGate(RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_arst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +		bool arst_value, bool en_polarity, bool arst_polarity, const std::string &src) +{ +	RTLIL::Cell *cell = addCell(name, stringf("$_DLATCH_%c%c%c_", en_polarity ? 'P' : 'N', arst_polarity ? 'P' : 'N', arst_value ? '1' : '0')); +	cell->setPort(ID::E, sig_en); +	cell->setPort(ID::R, sig_arst); +	cell->setPort(ID::D, sig_d); +	cell->setPort(ID::Q, sig_q); +	cell->set_src_attribute(src); +	return cell; +} +  RTLIL::Cell* RTLIL::Module::addDlatchsrGate(RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr,  		RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool en_polarity, bool set_polarity, bool clr_polarity, const std::string &src)  { diff --git a/kernel/rtlil.h b/kernel/rtlil.h index 511df29fe..6c561cb85 100644 --- a/kernel/rtlil.h +++ b/kernel/rtlil.h @@ -1274,8 +1274,14 @@ public:  	RTLIL::Cell* addDff   (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_d,   const RTLIL::SigSpec &sig_q, bool clk_polarity = true, const std::string &src = "");  	RTLIL::Cell* addDffe  (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en,  const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity = true, bool en_polarity = true, const std::string &src = "");  	RTLIL::Cell* addDffsr (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr, RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity = true, bool set_polarity = true, bool clr_polarity = true, const std::string &src = ""); +	RTLIL::Cell* addDffsre (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr, RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity = true, bool en_polarity = true, bool set_polarity = true, bool clr_polarity = true, const std::string &src = "");  	RTLIL::Cell* addAdff (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_arst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, RTLIL::Const arst_value, bool clk_polarity = true, bool arst_polarity = true, const std::string &src = ""); +	RTLIL::Cell* addAdffe (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_arst,  const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, RTLIL::Const arst_value, bool clk_polarity = true, bool en_polarity = true, bool arst_polarity = true, const std::string &src = ""); +	RTLIL::Cell* addSdff (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_srst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, RTLIL::Const srst_value, bool clk_polarity = true, bool srst_polarity = true, const std::string &src = ""); +	RTLIL::Cell* addSdffe (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_srst,  const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, RTLIL::Const srst_value, bool clk_polarity = true, bool en_polarity = true, bool srst_polarity = true, const std::string &src = ""); +	RTLIL::Cell* addSdffce (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_srst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, RTLIL::Const srst_value, bool clk_polarity = true, bool en_polarity = true, bool srst_polarity = true, const std::string &src = "");  	RTLIL::Cell* addDlatch (RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, bool en_polarity = true, const std::string &src = ""); +	RTLIL::Cell* addAdlatch (RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_arst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, RTLIL::Const arst_value, bool en_polarity = true, bool arst_polarity = true, const std::string &src = "");  	RTLIL::Cell* addDlatchsr (RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr, RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool en_polarity = true, bool set_polarity = true, bool clr_polarity = true, const std::string &src = "");  	RTLIL::Cell* addBufGate    (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_y, const std::string &src = ""); @@ -1295,14 +1301,28 @@ public:  	RTLIL::Cell* addAoi4Gate   (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_c, const RTLIL::SigBit &sig_d, const RTLIL::SigBit &sig_y, const std::string &src = "");  	RTLIL::Cell* addOai4Gate   (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_c, const RTLIL::SigBit &sig_d, const RTLIL::SigBit &sig_y, const std::string &src = ""); +	RTLIL::Cell* addSrGate     (RTLIL::IdString name, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr, +			const RTLIL::SigSpec &sig_q, bool set_polarity = true, bool clr_polarity = true, const std::string &src = "");  	RTLIL::Cell* addFfGate     (RTLIL::IdString name, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, const std::string &src = "");  	RTLIL::Cell* addDffGate    (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity = true, const std::string &src = "");  	RTLIL::Cell* addDffeGate   (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity = true, bool en_polarity = true, const std::string &src = "");  	RTLIL::Cell* addDffsrGate  (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr,  			RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity = true, bool set_polarity = true, bool clr_polarity = true, const std::string &src = ""); +	RTLIL::Cell* addDffsreGate (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr, +			RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity = true, bool en_polarity = true, bool set_polarity = true, bool clr_polarity = true, const std::string &src = "");  	RTLIL::Cell* addAdffGate   (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_arst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q,  			bool arst_value = false, bool clk_polarity = true, bool arst_polarity = true, const std::string &src = ""); +	RTLIL::Cell* addAdffeGate  (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_arst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +			bool arst_value = false, bool clk_polarity = true, bool en_polarity = true, bool arst_polarity = true, const std::string &src = ""); +	RTLIL::Cell* addSdffGate   (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_srst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +			bool srst_value = false, bool clk_polarity = true, bool srst_polarity = true, const std::string &src = ""); +	RTLIL::Cell* addSdffeGate  (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_srst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +			bool srst_value = false, bool clk_polarity = true, bool en_polarity = true, bool srst_polarity = true, const std::string &src = ""); +	RTLIL::Cell* addSdffceGate (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_srst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +			bool srst_value = false, bool clk_polarity = true, bool en_polarity = true, bool srst_polarity = true, const std::string &src = "");  	RTLIL::Cell* addDlatchGate (RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, bool en_polarity = true, const std::string &src = ""); +	RTLIL::Cell* addAdlatchGate(RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_arst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, +			bool arst_value = false, bool en_polarity = true, bool arst_polarity = true, const std::string &src = "");  	RTLIL::Cell* addDlatchsrGate  (RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr,  			RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool en_polarity = true, bool set_polarity = true, bool clr_polarity = true, const std::string &src = ""); | 
