2013-01-05 04:13:26 -06:00
|
|
|
|
2013-02-27 02:41:04 -06:00
|
|
|
/-----------------------------------------------------------------------------\
|
|
|
|
| |
|
|
|
|
| yosys -- Yosys Open SYnthesis Suite |
|
|
|
|
| |
|
|
|
|
| Copyright (C) 2012 Clifford Wolf <clifford@clifford.at> |
|
|
|
|
| |
|
|
|
|
| Permission to use, copy, modify, and/or distribute this software for any |
|
|
|
|
| purpose with or without fee is hereby granted, provided that the above |
|
|
|
|
| copyright notice and this permission notice appear in all copies. |
|
|
|
|
| |
|
|
|
|
| THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
|
|
|
|
| WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
|
|
|
|
| MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
|
|
|
|
| ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
|
|
|
|
| WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
|
|
|
|
| ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
|
|
|
|
| OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
|
|
|
|
| |
|
|
|
|
\-----------------------------------------------------------------------------/
|
|
|
|
|
|
|
|
|
2013-01-05 04:13:26 -06:00
|
|
|
yosys -- Yosys Open SYnthesis Suite
|
|
|
|
===================================
|
|
|
|
|
2013-02-28 07:17:57 -06:00
|
|
|
This is a framework for RTL synthesis tools. It currently has
|
|
|
|
extensive Verilog-2005 support and provides a basic set of
|
|
|
|
synthesis algorithms for various application domains.
|
2013-01-05 04:13:26 -06:00
|
|
|
|
2013-02-28 07:17:57 -06:00
|
|
|
Yosys can be adapted to perform any synthesis job by combining
|
|
|
|
the existing passes (algorithms) using synthesis scripts and
|
2013-03-16 15:20:38 -05:00
|
|
|
adding additional passes as needed by extending the yosys C++
|
|
|
|
code base.
|
2013-01-05 04:13:26 -06:00
|
|
|
|
|
|
|
Yosys is free software licensed under the ISC license (a GPL
|
2013-03-16 15:20:38 -05:00
|
|
|
compatible license that is similar in terms to the MIT license
|
2013-01-05 04:13:26 -06:00
|
|
|
or the 2-clause BSD license).
|
|
|
|
|
|
|
|
|
2013-01-06 07:40:15 -06:00
|
|
|
Getting Started
|
|
|
|
===============
|
|
|
|
|
2013-03-18 13:26:35 -05:00
|
|
|
You need a C++ compiler with C++11 support (up-to-date CLANG or GCC is
|
|
|
|
recommended) and some standard tools such as GNU Flex, GNU Bison, and
|
|
|
|
GNU Make. The extensive tests require Icarus Verilog.
|
|
|
|
|
|
|
|
To configure the build system to use a specific set of compiler and
|
|
|
|
build configuration, use one of
|
|
|
|
|
|
|
|
$ make config-clang-debug
|
|
|
|
$ make config-gcc-debug
|
|
|
|
$ make config-release
|
|
|
|
|
|
|
|
For other compilers and build configurations it might be
|
|
|
|
necessary to make some changes to the config section of the
|
|
|
|
Makefile.
|
2013-01-06 07:40:15 -06:00
|
|
|
|
|
|
|
$ vi Makefile
|
2013-03-18 13:26:35 -05:00
|
|
|
|
|
|
|
To build Yosys simply type 'make' in this directory.
|
|
|
|
|
2013-01-06 07:40:15 -06:00
|
|
|
$ make
|
|
|
|
$ make test
|
|
|
|
$ sudo make install
|
|
|
|
|
2013-06-08 16:48:19 -05:00
|
|
|
To also build and install ABC (recommended) use the following commands:
|
|
|
|
|
|
|
|
$ make abc
|
|
|
|
$ sudo make install-abc
|
|
|
|
|
2013-03-16 15:20:38 -05:00
|
|
|
Yosys can be used with the interactive command shell, with
|
|
|
|
synthesis scripts or with command line arguments. Let's perform
|
2013-01-06 07:40:15 -06:00
|
|
|
a simple synthesis job using the interactive command shell:
|
|
|
|
|
|
|
|
$ ./yosys
|
|
|
|
yosys>
|
|
|
|
|
2013-03-16 15:20:38 -05:00
|
|
|
the command "help" can be used to print a list of all available
|
2013-02-28 07:17:57 -06:00
|
|
|
commands and "help <command>" to print details on the specified command:
|
|
|
|
|
|
|
|
yosys> help help
|
|
|
|
|
2013-01-06 07:40:15 -06:00
|
|
|
reading the design using the verilog frontend:
|
|
|
|
|
|
|
|
yosys> read_verilog tests/simple/fiedler-cooley.v
|
|
|
|
|
|
|
|
writing the design to the console in yosys's internal format:
|
|
|
|
|
|
|
|
yosys> write_ilang
|
|
|
|
|
2013-03-16 15:20:38 -05:00
|
|
|
convert processes ("always" blocks) to netlist elements and perform
|
2013-01-06 07:40:15 -06:00
|
|
|
some simple optimizations:
|
|
|
|
|
|
|
|
yosys> proc; opt
|
|
|
|
|
2013-04-27 07:41:46 -05:00
|
|
|
display design netlist using the yosys svg viewer:
|
2013-01-06 07:40:15 -06:00
|
|
|
|
2013-04-27 07:41:46 -05:00
|
|
|
yosys> show
|
|
|
|
|
|
|
|
the same thing using 'gv' as postscript viewer:
|
|
|
|
|
|
|
|
yosys> show -format ps -viewer gv
|
2013-01-06 07:40:15 -06:00
|
|
|
|
|
|
|
translating netlist to gate logic and perform some simple optimizations:
|
|
|
|
|
|
|
|
yosys> techmap; opt
|
|
|
|
|
|
|
|
write design netlist to a new verilog file:
|
|
|
|
|
|
|
|
yosys> write_verilog synth.v
|
|
|
|
|
|
|
|
a simmilar synthesis can be performed using yosys command line options only:
|
|
|
|
|
|
|
|
$ ./yosys -o synth.v -p proc -p opt -p techmap -p opt tests/simple/fiedler-cooley.v
|
|
|
|
|
|
|
|
or using a simple synthesis script:
|
|
|
|
|
|
|
|
$ cat synth.ys
|
|
|
|
read_verilog tests/simple/fiedler-cooley.v
|
|
|
|
proc; opt; techmap; opt
|
|
|
|
write_verilog synth.v
|
|
|
|
|
2013-01-16 10:32:11 -06:00
|
|
|
$ ./yosys synth.ys
|
2013-01-06 07:40:15 -06:00
|
|
|
|
|
|
|
It is also possible to only have the synthesis commands but not the read/write
|
|
|
|
commands in the synthesis script:
|
|
|
|
|
|
|
|
$ cat synth.ys
|
|
|
|
proc; opt; techmap; opt
|
|
|
|
|
|
|
|
$ ./yosys -o synth.v tests/simple/fiedler-cooley.v synth.ys
|
|
|
|
|
|
|
|
The following synthesis script works reasonable for all designs:
|
|
|
|
|
|
|
|
# check design hierarchy
|
|
|
|
hierarchy
|
|
|
|
|
|
|
|
# translate processes (always blocks) and memories (arrays)
|
|
|
|
proc; memory; opt
|
|
|
|
|
|
|
|
# detect and optimize FSM encodings
|
|
|
|
fsm; opt
|
|
|
|
|
|
|
|
# convert to gate logic
|
|
|
|
techmap; opt
|
|
|
|
|
|
|
|
If ABC (http://www.eecs.berkeley.edu/~alanmi/abc/) is installed and
|
2013-02-27 02:45:09 -06:00
|
|
|
a cell library is given in the liberty file mycells.lib, the following
|
2013-01-06 07:40:15 -06:00
|
|
|
synthesis script will synthesize for the given cell library:
|
|
|
|
|
|
|
|
# the high-level stuff
|
|
|
|
hierarchy; proc; memory; opt; fsm; opt
|
|
|
|
|
|
|
|
# mapping to internal cell library
|
2013-02-28 07:17:57 -06:00
|
|
|
techmap; opt
|
2013-01-06 07:40:15 -06:00
|
|
|
|
|
|
|
# mapping flip-flops to mycells.lib
|
|
|
|
dfflibmap -liberty mycells.lib
|
|
|
|
|
|
|
|
# mapping logic to mycells.lib
|
|
|
|
abc -liberty mycells.lib
|
|
|
|
|
|
|
|
# cleanup
|
|
|
|
opt
|
|
|
|
|
|
|
|
Yosys is under construction. A more detailed documentation will follow.
|
|
|
|
|
|
|
|
|
2013-01-05 04:13:26 -06:00
|
|
|
Unsupported Verilog-2005 Features
|
|
|
|
=================================
|
|
|
|
|
|
|
|
The following Verilog-2005 features are not supported by
|
|
|
|
yosys and there are currently no plans to add support
|
|
|
|
for them:
|
|
|
|
|
|
|
|
- Non-sythesizable language features as defined in
|
|
|
|
IEC 62142(E):2005 / IEEE Std. 1364.1(E):2002
|
|
|
|
|
|
|
|
- The "tri", "triand", "trior", "wand" and "wor" net types
|
|
|
|
|
2013-02-27 03:36:17 -06:00
|
|
|
- The "config" keyword and library map files
|
2013-01-05 04:13:26 -06:00
|
|
|
|
2013-02-27 03:36:17 -06:00
|
|
|
- The "disable", "primitive" and "specify" statements
|
2013-01-05 04:13:26 -06:00
|
|
|
|
|
|
|
- Latched logic (is synthesized as logic with feedback loops)
|
|
|
|
|
|
|
|
|
|
|
|
Verilog Attributes and non-standard features
|
|
|
|
============================================
|
|
|
|
|
|
|
|
- The 'full_case' attribute on case statements is supported
|
|
|
|
(also the non-standard "// synopsys full_case" directive)
|
|
|
|
|
2013-03-01 01:03:00 -06:00
|
|
|
- The 'parallel_case' attribute on case statements is supported
|
|
|
|
(also the non-standard "// synopsys parallel_case" directive)
|
|
|
|
|
2013-01-05 04:13:26 -06:00
|
|
|
- The "// synopsys translate_off" and "// synopsys translate_on"
|
|
|
|
directives are also supported (but the use of `ifdef .. `endif
|
|
|
|
is strongly recommended instead).
|
|
|
|
|
|
|
|
- The "nomem2reg" attribute on modules or arrays prohibits the
|
2013-03-16 15:20:38 -05:00
|
|
|
automatic early conversion of arrays to separate registers.
|
2013-01-05 04:13:26 -06:00
|
|
|
|
2013-03-24 05:13:32 -05:00
|
|
|
- The "mem2reg" attribute on modules or arrays forces the early
|
|
|
|
conversion of arrays to separate registers.
|
|
|
|
|
2013-01-05 04:13:26 -06:00
|
|
|
- The "nolatches" attribute on modules or always-blocks
|
|
|
|
prohibits the generation of logic-loops for latches. Instead
|
|
|
|
all not explicitly assigned values default to x-bits.
|
|
|
|
|
2013-03-25 11:13:14 -05:00
|
|
|
- The "nosync" attribute on registers prohibits the generation of a
|
|
|
|
storage element. The register itself will always have all bits set
|
|
|
|
to 'x' (undefined). The variable may only be used as blocking assigned
|
|
|
|
temporary variable within an always block. This is mostly used internally
|
|
|
|
by yosys to synthesize verilog functions and access arrays.
|
|
|
|
|
2013-03-28 03:20:10 -05:00
|
|
|
- The "placeholder" attribute on modules is used to mark empty stub modules
|
|
|
|
that have the same ports as the real thing but do not contain information
|
|
|
|
on the internal configuration. This modules are only used by the synthesis
|
|
|
|
passes to identify input and output ports of cells. The verilog backend
|
|
|
|
also does not output placeholder modules on default.
|
|
|
|
|
2013-01-05 04:13:26 -06:00
|
|
|
- In addition to the (* ... *) attribute syntax, yosys supports
|
|
|
|
the non-standard {* ... *} attribute syntax to set default attributes
|
|
|
|
for everything that comes after the {* ... *} statement. (Reset
|
|
|
|
by adding an empty {* *} statement.) The preprocessor define
|
2013-03-16 15:20:38 -05:00
|
|
|
__YOSYS_ENABLE_DEFATTR__ must be set in order for this feature to be active.
|
2013-01-05 04:13:26 -06:00
|
|
|
|
|
|
|
|
|
|
|
TODOs / Open Bugs
|
|
|
|
=================
|
|
|
|
|
|
|
|
- Write "design and implementation of.." document
|
|
|
|
|
2013-03-18 09:05:15 -05:00
|
|
|
- Source tree layout
|
|
|
|
- Data formats (c++ classes, etc.)
|
2013-03-24 05:23:54 -05:00
|
|
|
- Internal misc. frameworks (log, select)
|
2013-03-18 09:05:15 -05:00
|
|
|
- Build system and pass registration
|
|
|
|
- Internal cell library
|
|
|
|
|
2013-01-05 04:13:26 -06:00
|
|
|
- Implement missing Verilog 2005 features:
|
|
|
|
|
|
|
|
- Signed constants
|
2013-02-27 03:36:17 -06:00
|
|
|
- Constant functions
|
|
|
|
- Indexed part selects
|
|
|
|
- Multi-dimensional arrays
|
2013-03-16 15:20:38 -05:00
|
|
|
- ROM modeling using "initial" blocks
|
2013-02-27 03:36:17 -06:00
|
|
|
- The "defparam <cell_name>.<parameter_name> = <value>;" syntax
|
2013-03-16 15:20:38 -05:00
|
|
|
- Built-in primitive gates (and, nand, cmos, nmos, pmos, etc..)
|
|
|
|
- Ignore what needs to be ignored (e.g. drive and charge strengths)
|
2013-01-05 04:13:26 -06:00
|
|
|
- Check standard vs. implementation to identify missing features
|
|
|
|
|
2013-03-24 05:23:54 -05:00
|
|
|
- Miscellaneous TODO items:
|
|
|
|
|
|
|
|
- Actually use range information on parameters
|
|
|
|
- Add brief source code documentation to most passes and kernel code
|
|
|
|
- Implement mux-to-tribuf pass and rebalance mixed mux/tribuf trees
|
2013-03-28 06:26:17 -05:00
|
|
|
- Add 'edit' command for changing the design (delete, add, modify objects)
|
|
|
|
- Improve TCL support and add 'list' command for inspecting the design from TCL
|
2013-03-24 05:23:54 -05:00
|
|
|
- Additional internal cell types: $pla and $lut
|
|
|
|
- Support for registering designs (as collection of modules) to CellTypes
|
|
|
|
- Smarter resource sharing pass (add MUXes and get rid of duplicated cells)
|
|
|
|
- For pass' "fsm_detect" help: add notes what criteria lets it detect an FSM
|
|
|
|
- Better FSM state encoding
|
2013-03-18 16:06:53 -05:00
|
|
|
|