Internal Cell Library — Yosys documentation (2024)

Most of the passes in Yosys operate on netlists, i.e.they only careabout the RTLIL::Wire and RTLIL::Cell objects in an RTLIL::Module. Thischapter discusses the cell types used by Yosys to represent abehavioural design internally.

This chapter is split in two parts. In the first part the internal RTLcells are covered. These cells are used to represent the design on acoarse grain level. Like in the original HDL code on this level thecells operate on vectors of signals and complex cells like adders exist.In the second part the internal gate cells are covered. These cells areused to represent the design on a fine-grain gate-level. All cells fromthis category operate on single bit signals.

RTL Cells

Most of the RTL cells closely resemble the operators available in HDLssuch as Verilog or VHDL. Therefore Verilog operators are used in thefollowing sections to define the behaviour of the RTL cells.

Note that all RTL cells have parameters indicating the size of inputsand outputs. When passes modify RTL cells they must always keep thevalues of these parameters in sync with the size of the signalsconnected to the inputs and outputs.

Simulation models for the RTL cells can be found in the filetechlibs/common/simlib.v in the Yosys source tree.

Unary Operators

All unary RTL cells have one input port and one output port . They alsohave the following parameters:

  • Set to a non-zero value if the input is signed and therefore shouldbe sign-extended when needed.

  • The width of the input port .

  • The width of the output port .

Table[tab:CellLib_unary] lists all cells forunary RTL operators.

ll Verilog & Cell Type

Y = ~A & $not

Y = +A & $pos

Y = -A & $neg

Y = &A & $reduce_and

Y = |A & $reduce_or

Y = ^A & $reduce_xor

Y = ~^A & $reduce_xnor

Y = |A & $reduce_bool

Y = !A & $logic_not

For the unary cells that output a logical value ($reduce_and,$reduce_or, $reduce_xor, $reduce_xnor, $reduce_bool,$logic_not), when the parameter is greater than 1, the output iszero-extended, and only the least significant bit varies.

Note that $reduce_or and $reduce_bool actually represent thesame logic function. But the HDL frontends generate them in differentsituations. A $reduce_or cell is generated when the prefix |operator is being used. A $reduce_bool cell is generated when a bitvector is used as a condition in an if-statement or?:-expression.

Binary Operators

All binary RTL cells have two input ports and and one output port . Theyalso have the following parameters:

  • Set to a non-zero value if the input is signed and therefore shouldbe sign-extended when needed.

  • The width of the input port .

  • Set to a non-zero value if the input is signed and therefore shouldbe sign-extended when needed.

  • The width of the input port .

  • The width of the output port .

Table1.1 lists all cells for binary RTLoperators.

ll Verilog & Cell Type

Y = A & B & $and

Y = A | B & $or

Y = A ^ B & $xor

Y = A ~^ B & $xnor

Y = A << B & $shl

Y = A >> B & $shr

Y = A <<< B & $sshl

Y = A >>> B & $sshr

Y = A && B & $logic_and

Y = A || B & $logic_or

Y = A === B & $eqx

Y = A !== B & $nex

Verilog expressions.

Verilog

Cell Type

Y = A < B

$lt

Y = A <= B

$le

Y = A == B

$eq

Y = A != B

$ne

Y = A >= B

$ge

Y = A > B

$gt

Y = A + B

$add

Y = A - B

$sub

Y = A * B

$mul

Y = A / B

$div

Y = A % B & $mod

$divfloor

[N/A]

$modfoor

Y = A ** B

$pow

The $shl and $shr cells implement logical shifts, whereas the$sshl and $sshr cells implement arithmetic shifts. The $shland $sshl cells implement the same operation. All four of thesecells interpret the second operand as unsigned, and require to be zero.

Two additional shift operator cells are available that do not directlycorrespond to any operator in Verilog, $shift and $shiftx. The$shift cell performs a right logical shift if the second operand ispositive (or unsigned), and a left logical shift if it is negative. The$shiftx cell performs the same operation as the $shift cell, butthe vacated bit positions are filled with undef (x) bits, andcorresponds to the Verilog indexed part-select expression.

For the binary cells that output a logical value ($logic_and,$logic_or, $eqx, $nex, $lt, $le, $eq, $ne,$ge, $gt), when the parameter is greater than 1, the output iszero-extended, and only the least significant bit varies.

Division and modulo cells are available in two rounding modes. Theoriginal $div and $mod cells are based on truncating division,and correspond to the semantics of the verilog / and %operators. The $divfloor and $modfloor cells represent flooringdivision and flooring modulo, the latter of which is also known as“remainder” in several languages. Seetable1.2 for a side-by-side comparisonbetween the different semantics.

and modulo cells.

Division

Result

Truncating

Flooring

$div

$mod

$divfloor

$modfloor

-10 / 3

-3.3

-3

-1

-4

2

10 / -3

-3.3

-3

1

-4

-2

-10 / -3

3.3

3

-1

3

-1

10 / 3

3.3

3

1

3

1

Multiplexers

Multiplexers are generated by the Verilog HDL frontend for?:-expressions. Multiplexers are also generated by the proc passto map the decision trees from RTLIL::Process objects to logic.

The simplest multiplexer cell type is $mux. Cells of this type havea parameter and data inputs and and a data output , all of the specifiedwidth. This cell also has a single bit control input . If is 0 the valuefrom the input is sent to the output, if it is 1 the value from theinput is sent to the output. So the $mux cell implements thefunction Y = S ? B : A.

The $pmux cell is used to multiplex between many inputs using aone-hot select signal. Cells of this type have a and a parameter andinputs , , and and an output . The input is bits wide. The input and theoutput are both bits wide and the input is * bits wide. When all bitsof are zero, the value from input is sent to the output. If then’th bit from is set, the value n’th bits wide sliceof the input is sent to the output. When more than one bit from is setthe output is undefined. Cells of this type are used to model “parallelcases” (defined by using the parallel_case attribute or detected byan optimization).

The $tribuf cell is used to implement tristate logic. Cells of thistype have a parameter and inputs and and an output . The input andoutput are bits wide, and the input is one bit wide. When is 0, theoutput is not driven. When is 1, the value from input is sent to theoutput. Therefore, the $tribuf cell implements the functionY = EN ? A : 'bz.

Behavioural code with cascaded if-then-else- and case-statementsusually results in trees of multiplexer cells. Many passes (from variousoptimizations to FSM extraction) heavily depend on these multiplexertrees to understand dependencies between signals. Thereforeoptimizations should not break these multiplexer trees (e.g.byreplacing a multiplexer between a calculated signal and a constant zerowith an $and gate).

Registers

SR-type latches are represented by $sr cells. These cells have inputports and and an output port . They have the following parameters:

  • The width of inputs and and output .

  • The set input bits are active-high if this parameter has the value1’b1 and active-low if this parameter is 1’b0.

  • The reset input bits are active-high if this parameter has thevalue 1’b1 and active-low if this parameter is 1’b0.

Both set and reset inputs have separate bits for every output bit. Whenboth the set and reset inputs of an $sr cell are active for a givenbit index, the reset input takes precedence.

D-type flip-flops are represented by $dff cells. These cells have aclock port , an input port and an output port . The following parametersare available for $dff cells:

  • The width of input and output .

  • Clock is active on the positive edge if this parameter has thevalue 1’b1 and on the negative edge if this parameter is1’b0.

D-type flip-flops with asynchronous reset are represented by $adffcells. As the $dff cells they have , and ports. In addition theyalso have a single-bit input port for the reset pin and the followingadditional two parameters:

  • The asynchronous reset is active-high if this parameter has thevalue 1’b1 and active-low if this parameter is 1’b0.

  • The state of will be set to this value when the reset is active.

Usually these cells are generated by the proc pass using theinformation in the designs RTLIL::Process objects.

D-type flip-flops with synchronous reset are represented by $sdffcells. As the $dff cells they have , and ports. In addition theyalso have a single-bit input port for the reset pin and the followingadditional two parameters:

  • The synchronous reset is active-high if this parameter has thevalue 1’b1 and active-low if this parameter is 1’b0.

  • The state of will be set to this value when the reset is active.

Note that the $adff and $sdff cells can only be used when thereset value is constant.

D-type flip-flops with asynchronous set and reset are represented by$dffsr cells. As the $dff cells they have , and ports. Inaddition they also have multi-bit and input ports and the correspondingpolarity parameters, like $sr cells.

D-type flip-flops with enable are represented by $dffe, $adffe,$dffsre, $sdffe, and $sdffce cells, which are enhancedvariants of $dff, $adff, $dffsr, $sdff (with reset overenable) and $sdff (with enable over reset) cells, respectively. Theyhave the same ports and parameters as their base cell. In addition theyalso have a single-bit input port for the enable pin and the followingparameter:

  • The enable input is active-high if this parameter has the value1’b1 and active-low if this parameter is 1’b0.

D-type latches are represented by $dlatch cells. These cells have anenable port , an input port , and an output port . The followingparameters are available for $dlatch cells:

  • The width of input and output .

  • The enable input is active-high if this parameter has the value1’b1 and active-low if this parameter is 1’b0.

The latch is transparent when the input is active.

D-type latches with reset are represented by $adlatch cells. Inaddition to $dlatch ports and parameters, they also have asingle-bit input port for the reset pin and the following additionalparameters:

  • The asynchronous reset is active-high if this parameter has thevalue 1’b1 and active-low if this parameter is 1’b0.

  • The state of will be set to this value when the reset is active.

D-type latches with set and reset are represented by $dlatchsrcells. In addition to $dlatch ports and parameters, they also havemulti-bit and input ports and the corresponding polarity parameters,like $sr cells.

Memories

Memories are either represented using RTLIL::Memory objects, $memrd,$memwr, and $meminit cells, or by $mem cells alone.

In the first alternative the RTLIL::Memory objects hold the generalmetadata for the memory (bit width, size in number of words, etc.) andfor each port a $memrd (read port) or $memwr (write port) cellis created. Having individual cells for read and write ports has theadvantage that they can be consolidated using resource sharing passes.In some cases this drastically reduces the number of required ports onthe memory cell. In this alternative, memory initialization data isrepresented by $meminit cells, which allow delaying constant foldingfor initialization addresses and data until after the frontend finishes.

The $memrd cells have a clock input , an enable input , an addressinput , and a data output . They also have the following parameters:

  • The name of the RTLIL::Memory object that is associated with thisread port.

  • The number of address bits (width of the input port).

  • The number of data bits (width of the output port).

  • When this parameter is non-zero, the clock is used. Otherwise thisread port is asynchronous and the input is not used.

  • Clock is active on the positive edge if this parameter has thevalue 1’b1 and on the negative edge if this parameter is1’b0.

  • If this parameter is set to 1’b1, a read and write to the sameaddress in the same cycle will return the new value. Otherwise theold value is returned.

The $memwr cells have a clock input , an enable input (one enablebit for each data bit), an address input and a data input . They alsohave the following parameters:

  • The name of the RTLIL::Memory object that is associated with thiswrite port.

  • The number of address bits (width of the input port).

  • The number of data bits (width of the output port).

  • When this parameter is non-zero, the clock is used. Otherwise thiswrite port is asynchronous and the input is not used.

  • Clock is active on positive edge if this parameter has the value1’b1 and on the negative edge if this parameter is 1’b0.

  • The cell with the higher integer value in this parameter wins awrite conflict.

The $meminit cells have an address input and a data input , with thewidth of the port equal to parameter times parameter. Both of the inputsmust resolve to a constant for synthesis to succeed.

  • The name of the RTLIL::Memory object that is associated with thisinitialization cell.

  • The number of address bits (width of the input port).

  • The number of data bits per memory location.

  • The number of consecutive memory locations initialized by thiscell.

  • The cell with the higher integer value in this parameter wins aninitialization conflict.

The HDL frontend models a memory using RTLIL::Memory objects andasynchronous $memrd and $memwr cells. The memory pass(i.e.its various sub-passes) migrates $dff cells into the$memrd and $memwr cells making them synchronous, then convertsthem to a single $mem cell and (optionally) maps this cell type to$dff cells for the individual words and multiplexer-based addressdecoders for the read and write interfaces. When the last step isdisabled or not possible, a $mem cell is left in the design.

The $mem cell provides the following parameters:

  • The name of the original RTLIL::Memory object that became this$mem cell.

  • The number of words in the memory.

  • The number of address bits.

  • The number of data bits per word.

  • The initial memory contents.

  • The number of read ports on this memory cell.

  • This parameter is bits wide, containing a clock enable bit for eachread port.

  • This parameter is bits wide, containing a clock polarity bit foreach read port.

  • This parameter is bits wide, containing a transparent bit for eachread port.

  • The number of write ports on this memory cell.

  • This parameter is bits wide, containing a clock enable bit for eachwrite port.

  • This parameter is bits wide, containing a clock polarity bit foreach write port.

The $mem cell has the following ports:

  • This input is bits wide, containing all clock signals for the readports.

  • This input is bits wide, containing all enable signals for the readports.

  • This input is * bits wide, containing all address signals for theread ports.

  • This input is * bits wide, containing all data signals for theread ports.

  • This input is bits wide, containing all clock signals for the writeports.

  • This input is * bits wide, containing all enable signals for thewrite ports.

  • This input is * bits wide, containing all address signals for thewrite ports.

  • This input is * bits wide, containing all data signals for thewrite ports.

The memory_collect pass can be used to convert discrete $memrd,$memwr, and $meminit cells belonging to the same memory to asingle $mem cell, whereas the memory_unpack pass performs theinverse operation. The memory_dff pass can combine asynchronousmemory ports that are fed by or feeding registers into synchronousmemory ports. The memory_bram pass can be used to recognize $memcells that can be implemented with a block RAM resource on an FPGA. Thememory_map pass can be used to implement $mem cells as basiclogic: word-wide DFFs and address decoders.

Finite State Machines

Add a brief description of the $fsm cell type.

Specify rules

Add information about $specify2, $specify3, and $specrulecells.

Formal verification cells

Add information about $assert, $assume, $live, $fair,$cover, $equiv, $initstate, $anyconst, $anyseq,$allconst, $allseq cells.

Add information about $ff and $_FF_ cells.

Gates

For gate level logic networks, fixed function single bit cells are usedthat do not provide any parameters.

Simulation models for these cells can be found in the filetechlibs/common/simcells.v in the Yosys source tree.

ll Verilog & Cell Type

Y = A & $_BUF_

Y = ~A & $_NOT_

Y = A & B & $_AND_

Y = ~(A & B) & $_NAND_

Y = A & ~B & $_ANDNOT_

Y = A | B & $_OR_

Y = ~(A | B) & $_NOR_

Y = A | ~B & $_ORNOT_

Y = A ^ B & $_XOR_

Y = ~(A ^ B) & $_XNOR_

Y = ~((A & B) | C) & $_AOI3_

Y = ~((A | B) & C) & $_OAI3_

Y = ~((A & B) | (C & D)) & $_AOI4_

Y = ~((A | B) & (C | D)) & $_OAI4_

Y = S ? B : A & $_MUX_

Y = ~(S ? B : A) & $_NMUX_

(see below) & $_MUX4_

(see below) & $_MUX8_

(see below) & $_MUX16_

Y = EN ? A : 1'bz & $_TBUF_

always @(negedge C) Q <= D & $_DFF_N_

always @(posedge C) Q <= D & $_DFF_P_

always @* if (!E) Q <= D & $_DLATCH_N_

always @* if (E) Q <= D & $_DLATCH_P_

Cell types for gate level logic networks (FFs with reset)

:math:ClkEdge

RstLvl

RstVal

Cell Type

negedge

`$_DFF_NN0_`,`$_SDFF_NN0_`

negedge

1

`$_DFF_NN1_`,`$_SDFF_NN1_`

negedge

1

`$_DFF_NP0_`,`$_SDFF_NP0_`

negedge

1

1

`$_DFF_NP1_`,`$_SDFF_NP1_`

posedge

`$_DFF_PN0_`,`$_SDFF_PN0_`

posedge

1

`$_DFF_PN1_`,`$_SDFF_PN1_`

posedge

1

`$_DFF_PP0_`,`$_SDFF_PP0_`

posedge

1

1

`$_DFF_PP1_`,`$_SDFF_PP1_`

Cell types for gate level logic networks (FFs with enable)

ClkEdge

EnLvl

Cell Type

negedge

$_DFFE_NN_

negedge

1

$_DFFE_NP_

posedge

$_DFFE_PN_

posedge

1

$_DFFE_PP_

and enable)

:math:ClkEdge

:math:RstLvl

:math:RstVal

:math:EnLvl

Cell Type

negedge

$_DFFE_NN0N_,$_SDFFE_NN0N_,$_SDFFCE_NN0N_

negedge

1

$_DFFE_NN0P_,$_SDFFE_NN0P_,$_SDFFCE_NN0P_

negedge

1

$_DFFE_NN1N_,$_SDFFE_NN1N_,$_SDFFCE_NN1N_

negedge

1

1

$_DFFE_NN1P_,$_SDFFE_NN1P_,$_SDFFCE_NN1P_

negedge

1

$_DFFE_NP0N_,$_SDFFE_NP0N_,$_SDFFCE_NP0N_

negedge

1

1

$_DFFE_NP0P_,$_SDFFE_NP0P_,$_SDFFCE_NP0P_

negedge

1

1

$_DFFE_NP1N_,$_SDFFE_NP1N_,$_SDFFCE_NP1N_

negedge

1

1

1

$_DFFE_NP1P_,$_SDFFE_NP1P_,$_SDFFCE_NP1P_

posedge

$_DFFE_PN0N_,$_SDFFE_PN0N_,$_SDFFCE_PN0N_

posedge

1

$_DFFE_PN0P_,$_SDFFE_PN0P_,$_SDFFCE_PN0P_

posedge

1

$_DFFE_PN1N_,$_SDFFE_PN1N_,$_SDFFCE_PN1N_

posedge

1

1

$_DFFE_PN1P_,$_SDFFE_PN1P_,$_SDFFCE_PN1P_

posedge

1

$_DFFE_PP0N_,$_SDFFE_PP0N_,$_SDFFCE_PP0N_

posedge

1

1

$_DFFE_PP0P_,$_SDFFE_PP0P_,$_SDFFCE_PP0P_

posedge

1

1

$_DFFE_PP1N_,$_SDFFE_PP1N_,$_SDFFCE_PP1N_

posedge

1

1

1

$_DFFE_PP1P_,$_SDFFE_PP1P_,$_SDFFCE_PP1P_

reset)

ClkEdge

SetLvl

RstLvl

Cell Type

negedge

$_DFFSR_NNN_

negedge

1

$_DFFSR_NNP_

negedge

1

$_DFFSR_NPN_

negedge

1

1

$_DFFSR_NPP_

posedge

$_DFFSR_PNN_

posedge

1

$_DFFSR_PNP_

posedge

1

$_DFFSR_PPN_

posedge

1

1

$_DFFSR_PPP_

reset and enable)

:math:ClkEdge

:math:SetLvl

:math:RstLvl

:math:EnLvl

Cell Type

negedge

$_DFFSRE_NNNN_

negedge

1

$_DFFSRE_NNNP_

negedge

1

$_DFFSRE_NNPN_

negedge

1

1

$_DFFSRE_NNPP_

negedge

1

$_DFFSRE_NPNN_

negedge

1

1

$_DFFSRE_NPNP_

negedge

1

1

$_DFFSRE_NPPN_

negedge

1

1

1

$_DFFSRE_NPPP_

posedge

$_DFFSRE_PNNN_

posedge

1

$_DFFSRE_PNNP_

posedge

1

$_DFFSRE_PNPN_

posedge

1

1

$_DFFSRE_PNPP_

posedge

1

$_DFFSRE_PPNN_

posedge

1

1

$_DFFSRE_PPNP_

posedge

1

1

$_DFFSRE_PPPN_

posedge

1

1

1

$_DFFSRE_PPPP_

reset)

EnLvl

RstLvl

RstVal

Cell Type

$_DLATCH_NN0_

1

$_DLATCH_NN1_

1

$_DLATCH_NP0_

1

1

$_DLATCH_NP1_

1

$_DLATCH_PN0_

1

1

$_DLATCH_PN1_

1

1

$_DLATCH_PP0_

1

1

1

$_DLATCH_PP1_

and reset)

EnLvl

SetLvl

RstLvl

Cell Type

$_DLATCHSR_NNN_

1

$_DLATCHSR_NNP_

1

$_DLATCHSR_NPN_

1

1

$_DLATCHSR_NPP_

1

$_DLATCHSR_PNN_

1

1

$_DLATCHSR_PNP_

1

1

$_DLATCHSR_PPN_

1

1

1

$_DLATCHSR_PPP_

Cell types for gate level logic networks (SR latches)

SetLvl

RstLvl

Cell Type

$_SR_NN_

1

$_SR_NP_

1

$_SR_PN_

1

1

$_SR_PP_

Tables[tab:CellLib_gates],1.4, 1.3,1.5, 1.6,1.7,1.8,1.9 and1.10 list all cell types used for gate levellogic. The cell types $_BUF_, $_NOT_, $_AND_, $_NAND_,$_ANDNOT_, $_OR_, $_NOR_, $_ORNOT_, $_XOR_,$_XNOR_, $_AOI3_, $_OAI3_, $_AOI4_, $_OAI4_,$_MUX_, $_MUX4_, $_MUX8_, $_MUX16_ and $_NMUX_ areused to model combinatorial logic. The cell type $_TBUF_ is used tomodel tristate logic.

The $_MUX4_, $_MUX8_ and $_MUX16_ cells are used to modelwide muxes, and correspond to the following Verilog code:

// $_MUX4_assign Y = T ? (S ? D : C) : (S ? B : A);// $_MUX8_assign Y = U ? T ? (S ? H : G) : (S ? F : E) : T ? (S ? D : C) : (S ? B : A);// $_MUX16_assign Y = V ? U ? T ? (S ? P : O) : (S ? N : M) : T ? (S ? L : K) : (S ? J : I) : U ? T ? (S ? H : G) : (S ? F : E) : T ? (S ? D : C) : (S ? B : A);

The cell types $_DFF_N_ and $_DFF_P_ represent d-typeflip-flops.

The cell types $_DFFE_[NP][NP]_ implement d-type flip-flops withenable. The values in the table for these cell types relate to thefollowing Verilog code template.

always @($ClkEdge$ C) if (EN == $EnLvl$) Q <= D;

The cell types $_DFF_[NP][NP][01]_ implement d-type flip-flops withasynchronous reset. The values in the table for these cell types relateto the following Verilog code template, where $RstEdge$ isposedge if $RstLvl$ if 1, and negedge otherwise.

always @($ClkEdge$ C, $RstEdge$ R) if (R == $RstLvl$) Q <= $RstVal$; else Q <= D;

The cell types $_SDFF_[NP][NP][01]_ implement d-type flip-flops withsynchronous reset. The values in the table for these cell types relateto the following Verilog code template:

always @($ClkEdge$ C) if (R == $RstLvl$) Q <= $RstVal$; else Q <= D;

The cell types $_DFFE_[NP][NP][01][NP]_ implement d-type flip-flopswith asynchronous reset and enable. The values in the table for thesecell types relate to the following Verilog code template, where$RstEdge$ is posedge if $RstLvl$ if 1, and negedgeotherwise.

always @($ClkEdge$ C, $RstEdge$ R) if (R == $RstLvl$) Q <= $RstVal$; else if (EN == $EnLvl$) Q <= D;

The cell types $_SDFFE_[NP][NP][01][NP]_ implement d-type flip-flopswith synchronous reset and enable, with reset having priority overenable. The values in the table for these cell types relate to thefollowing Verilog code template:

always @($ClkEdge$ C) if (R == $RstLvl$) Q <= $RstVal$; else if (EN == $EnLvl$) Q <= D;

The cell types $_SDFFCE_[NP][NP][01][NP]_ implement d-typeflip-flops with synchronous reset and enable, with enable havingpriority over reset. The values in the table for these cell types relateto the following Verilog code template:

always @($ClkEdge$ C) if (EN == $EnLvl$) if (R == $RstLvl$) Q <= $RstVal$; else Q <= D;

The cell types $_DFFSR_[NP][NP][NP]_ implement d-type flip-flopswith asynchronous set and reset. The values in the table for these celltypes relate to the following Verilog code template, where $RstEdge$is posedge if $RstLvl$ if 1, negedge otherwise, and$SetEdge$ is posedge if $SetLvl$ if 1, negedgeotherwise.

always @($ClkEdge$ C, $RstEdge$ R, $SetEdge$ S) if (R == $RstLvl$) Q <= 0; else if (S == $SetLvl$) Q <= 1; else Q <= D;

The cell types $_DFFSRE_[NP][NP][NP][NP]_ implement d-typeflip-flops with asynchronous set and reset and enable. The values in thetable for these cell types relate to the following Verilog codetemplate, where $RstEdge$ is posedge if $RstLvl$ if 1,negedge otherwise, and $SetEdge$ is posedge if $SetLvl$if 1, negedge otherwise.

always @($ClkEdge$ C, $RstEdge$ R, $SetEdge$ S) if (R == $RstLvl$) Q <= 0; else if (S == $SetLvl$) Q <= 1; else if (E == $EnLvl$) Q <= D;

The cell types $_DLATCH_N_ and $_DLATCH_P_ represent d-typelatches.

The cell types $_DLATCH_[NP][NP][01]_ implement d-type latches withreset. The values in the table for these cell types relate to thefollowing Verilog code template:

always @* if (R == $RstLvl$) Q <= $RstVal$; else if (E == $EnLvl$) Q <= D;

The cell types $_DLATCHSR_[NP][NP][NP]_ implement d-type latcheswith set and reset. The values in the table for these cell types relateto the following Verilog code template:

always @* if (R == $RstLvl$) Q <= 0; else if (S == $SetLvl$) Q <= 1; else if (E == $EnLvl$) Q <= D;

The cell types $_SR_[NP][NP]_ implement sr-type latches. The valuesin the table for these cell types relate to the following Verilog codetemplate:

always @* if (R == $RstLvl$) Q <= 0; else if (S == $SetLvl$) Q <= 1;

In most cases gate level logic networks are created from RTL networksusing the techmap pass. The flip-flop cells from the gate levellogic network can be mapped to physical flip-flop cells from a Libertyfile using the dfflibmap pass. The combinatorial logic cells can bemapped to physical cells from a Liberty file via ABC using the abcpass.

Add information about $slice and $concat cells.

Add information about $lut and $sop cells.

Add information about $alu, $macc, $fa, and $lcucells.

Internal Cell Library — Yosys  documentation (2024)

FAQs

What does an ASIC cell library typically contains? ›

In general, a standard cell library contains the following types of cell: All basic and universal gates (like AND, OR, NOT, NAND, NOR, XOR etc) Complex gates (like MUX, HA, FA, Comparators, AOI, OAI etc) Clock tree cells (like Clock buffers, clock inverters, ICG cells etc)

What is Yosys used for? ›

Yosys is a framework for RTL synthesis and more. It currently has extensive Verilog-2005 support and provides a basic set of synthesis algorithms for various application domains. Yosys is the core component of most our implementation and verification flows.

Is Yosys open source? ›

Yosys is an open source framework for RTL synthesis. To learn more about Yosys, see What is Yosys. For a quick guide on how to get started using Yosys, check out Getting started with Yosys.

What is the content of standard cell library? ›

A standard-cell library is a collection of low-level electronic logic functions such as AND, OR, INVERT, flip-flops, latches, and buffers. These cells are realized as fixed-height, variable-width full-custom cells.

What does ASIC contain? ›

Modern ASICs often include entire microprocessors, memory blocks including ROM, RAM, EEPROM, flash memory and other large building blocks. Such an ASIC is often termed a SoC (system-on-chip).

Does Yosys support SystemVerilog? ›

Now Yosys is extended with 2 additional commands: read_systemverilog [options] [filenames] - reads SystemVerilog files directly in Yosys. It executes Surelog with provided filenames and converts them (in memory) into an UHDM file. This UHDM file is converted into a Yosys AST.

Is Yosys free? ›

Yosys is free software licensed under the ISC license (a GPL compatible license that is similar in terms to the MIT license or the 2-clause BSD license).

What is the RTL synthesis? ›

RTL Synthesis (or logic synthesis) is the basic step that transforms the HDL representation of a design into technology-specific logic circuits. An ASIC vendor provides the logic circuits in a form called a “synthesis library”. Typical gate libraries include a few hundreds of combinational and sequential logic gates.

What are examples of ASIC devices? ›

From electronic toys, cell phones, and digital watches to communications satellites, avionics, and A.I. programs, the custom programming, compact size, and high reliability of ASIC chips make it a popular choice for industry, intelligence agencies, space programs, and defense systems.

What does the C library contain? ›

The C standard library provides macros, type definitions and functions for tasks such as string handling, mathematical computations, input/output processing, memory management, and several other operating system services.

What materials are used in ASIC chips? ›

In terms of hardware, ASIC chips are made from essential materials like silicon, gallium phosphide, gallium arsenide, and gallium nitride. At the structural level, ASIC chip modules are assembled using IP cores like external storage units, power managers, audio screen processors, and network circuits.

What is the difference between standard cell based ASIC and gate array based ASIC? ›

However, gate array ASICs are limited in the functions they can perform. Standard cell ASICs: Standard cell ASICs are semi-customizable to a greater degree than gate array ASICs. In standard cell ASICs, the silicon layers are comprised of library components, also called functional standard blocks.

References

Top Articles
Latest Posts
Recommended Articles
Article information

Author: Kelle Weber

Last Updated:

Views: 5479

Rating: 4.2 / 5 (53 voted)

Reviews: 92% of readers found this page helpful

Author information

Name: Kelle Weber

Birthday: 2000-08-05

Address: 6796 Juan Square, Markfort, MN 58988

Phone: +8215934114615

Job: Hospitality Director

Hobby: tabletop games, Foreign language learning, Leather crafting, Horseback riding, Swimming, Knapping, Handball

Introduction: My name is Kelle Weber, I am a magnificent, enchanting, fair, joyous, light, determined, joyous person who loves writing and wants to share my knowledge and understanding with you.