mirror of
https://github.com/YosysHQ/yosys
synced 2025-04-05 17:14:08 +00:00
Convert todo comments to directives
Could be left in for final version, but my current thinking is not?
This commit is contained in:
parent
ce9e56db47
commit
d8b8880ad6
|
@ -59,6 +59,10 @@ latex_elements = {
|
||||||
'''
|
'''
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# include todos during rewrite
|
||||||
|
extensions.append('sphinx.ext.todo')
|
||||||
|
todo_include_todos = True
|
||||||
|
|
||||||
def setup(sphinx):
|
def setup(sphinx):
|
||||||
sys.path += [os.path.dirname(__file__) + "/../util"]
|
sys.path += [os.path.dirname(__file__) + "/../util"]
|
||||||
from RtlilLexer import RtlilLexer
|
from RtlilLexer import RtlilLexer
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
Scripting in Yosys
|
Scripting in Yosys
|
||||||
------------------
|
------------------
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
Yosys reads and processes commands from synthesis scripts, command line
|
Yosys reads and processes commands from synthesis scripts, command line
|
||||||
arguments and an interactive command prompt. Yosys commands consist of a command
|
arguments and an interactive command prompt. Yosys commands consist of a command
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
Typical phases of a synthesis flow
|
Typical phases of a synthesis flow
|
||||||
----------------------------------
|
----------------------------------
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
- Reading and elaborating the design
|
- Reading and elaborating the design
|
||||||
- Higher-level synthesis and optimization
|
- Higher-level synthesis and optimization
|
||||||
|
|
|
@ -12,3 +12,8 @@ Yosys Open SYnthesis Suite
|
||||||
test_suites
|
test_suites
|
||||||
|
|
||||||
appendix
|
appendix
|
||||||
|
|
||||||
|
TODOs
|
||||||
|
-----
|
||||||
|
|
||||||
|
.. todolist::
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
What is Yosys
|
What is Yosys
|
||||||
=============
|
=============
|
||||||
|
|
||||||
.. TODO: rewrite to not be a thesis abstract
|
.. todo:: rewrite to not be a thesis abstract
|
||||||
|
|
||||||
:Abstract:
|
:Abstract:
|
||||||
Most of today's digital design is done in HDL code (mostly Verilog or
|
Most of today's digital design is done in HDL code (mostly Verilog or
|
||||||
|
@ -125,7 +125,7 @@ In no particular order:
|
||||||
History of Yosys
|
History of Yosys
|
||||||
----------------
|
----------------
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
A Hardware Description Language (HDL) is a computer language used to describe
|
A Hardware Description Language (HDL) is a computer language used to describe
|
||||||
circuits. A HDL synthesis tool is a computer program that takes a formal
|
circuits. A HDL synthesis tool is a computer program that takes a formal
|
||||||
|
|
|
@ -4,7 +4,7 @@ Test suites
|
||||||
.. note:: Potentially significantly out of date information
|
.. note:: Potentially significantly out of date information
|
||||||
last updated circa 2015
|
last updated circa 2015
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
Continuously checking the correctness of Yosys and making sure that new features
|
Continuously checking the correctness of Yosys and making sure that new features
|
||||||
do not break old ones is a high priority in Yosys. Two external test suites
|
do not break old ones is a high priority in Yosys. Two external test suites
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
Optimization passes
|
Optimization passes
|
||||||
===================
|
===================
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
Yosys employs a number of optimizations to generate better and cleaner results.
|
Yosys employs a number of optimizations to generate better and cleaner results.
|
||||||
This chapter outlines these optimizations.
|
This chapter outlines these optimizations.
|
||||||
|
|
|
@ -1,8 +1,7 @@
|
||||||
Selections
|
Selections
|
||||||
----------
|
----------
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
|
|
||||||
Most Yosys commands make use of the "selection framework" of Yosys. It can be
|
Most Yosys commands make use of the "selection framework" of Yosys. It can be
|
||||||
used to apply commands only to part of the design. For example:
|
used to apply commands only to part of the design. For example:
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
Writing extensions
|
Writing extensions
|
||||||
==================
|
==================
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
This chapter contains some bits and pieces of information about programming
|
This chapter contains some bits and pieces of information about programming
|
||||||
yosys extensions. Don't be afraid to ask questions on the YosysHQ Slack.
|
yosys extensions. Don't be afraid to ask questions on the YosysHQ Slack.
|
||||||
|
@ -81,7 +81,7 @@ look at the output of ``dump`` and ``show`` before and after the command has
|
||||||
been executed can be helpful. The :doc:`/using_yosys/more_scripting/selections`
|
been executed can be helpful. The :doc:`/using_yosys/more_scripting/selections`
|
||||||
document has more information on using these commands.
|
document has more information on using these commands.
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
Creating modules from scratch
|
Creating modules from scratch
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
Command ordering
|
Command ordering
|
||||||
----------------
|
----------------
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
Intro to coarse-grain synthesis
|
Intro to coarse-grain synthesis
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
@ -36,7 +36,7 @@ The extract pass
|
||||||
with an instance of the module from the map file.
|
with an instance of the module from the map file.
|
||||||
- In a way the ``extract`` pass is the inverse of the techmap pass.
|
- In a way the ``extract`` pass is the inverse of the techmap pass.
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
.. figure:: ../../../images/res/PRESENTATION_ExAdv/macc_simple_test_00a.*
|
.. figure:: ../../../images/res/PRESENTATION_ExAdv/macc_simple_test_00a.*
|
||||||
:class: width-helper
|
:class: width-helper
|
||||||
|
@ -118,7 +118,7 @@ Preconditioning: ``macc_xilinx_swap_map.v``
|
||||||
|
|
||||||
Make sure ``A`` is the smaller port on all multipliers
|
Make sure ``A`` is the smaller port on all multipliers
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
.. literalinclude:: ../../../resources/PRESENTATION_ExAdv/macc_xilinx_swap_map.v
|
.. literalinclude:: ../../../resources/PRESENTATION_ExAdv/macc_xilinx_swap_map.v
|
||||||
:language: verilog
|
:language: verilog
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
Control and data flow
|
Control and data flow
|
||||||
=====================
|
=====================
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
The data- and control-flow of a typical synthesis tool is very similar to the
|
The data- and control-flow of a typical synthesis tool is very similar to the
|
||||||
data- and control-flow of a typical compiler: different subsystems are called in
|
data- and control-flow of a typical compiler: different subsystems are called in
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
Symbolic model checking
|
Symbolic model checking
|
||||||
-----------------------
|
-----------------------
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
Flow overview
|
Flow overview
|
||||||
=============
|
=============
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
:numref:`Figure %s <fig:Overview_flow>` shows the simplified data flow within
|
:numref:`Figure %s <fig:Overview_flow>` shows the simplified data flow within
|
||||||
Yosys. Rectangles in the figure represent program modules and ellipses internal
|
Yosys. Rectangles in the figure represent program modules and ellipses internal
|
||||||
|
|
|
@ -639,13 +639,15 @@ to extend the actual Verilog frontend.
|
||||||
Synthesizing Verilog arrays
|
Synthesizing Verilog arrays
|
||||||
---------------------------
|
---------------------------
|
||||||
|
|
||||||
.. TODO: these
|
.. todo::
|
||||||
|
|
||||||
Add some information on the generation of ``$memrd`` and ``$memwr`` cells and
|
Add some information on the generation of ``$memrd`` and ``$memwr`` cells and
|
||||||
how they are processed in the memory pass.
|
how they are processed in the memory pass.
|
||||||
|
|
||||||
Synthesizing parametric designs
|
Synthesizing parametric designs
|
||||||
-------------------------------
|
-------------------------------
|
||||||
|
|
||||||
Add some information on the ``RTLIL::Module::derive()`` method and how it is
|
.. todo::
|
||||||
used to synthesize parametric modules via the hierarchy pass.
|
|
||||||
|
Add some information on the ``RTLIL::Module::derive()`` method and how it is
|
||||||
|
used to synthesize parametric modules via the hierarchy pass.
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
.. role:: verilog(code)
|
.. role:: verilog(code)
|
||||||
:language: Verilog
|
:language: Verilog
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
.. _chapter:celllib:
|
.. _chapter:celllib:
|
||||||
|
|
||||||
|
|
|
@ -74,7 +74,7 @@ This has three advantages:
|
||||||
- First, it is impossible that an auto-generated identifier collides with an
|
- First, it is impossible that an auto-generated identifier collides with an
|
||||||
identifier that was provided by the user.
|
identifier that was provided by the user.
|
||||||
|
|
||||||
.. TODO: does opt_rmunused (still?) exist?
|
.. todo:: does opt_rmunused (still?) exist?
|
||||||
|
|
||||||
- Second, the information about which identifiers were originally provided by
|
- Second, the information about which identifiers were originally provided by
|
||||||
the user is always available which can help guide some optimizations. For
|
the user is always available which can help guide some optimizations. For
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
Yosys internals
|
Yosys internals
|
||||||
===============
|
===============
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
Yosys is an extensible open source hardware synthesis tool. It is aimed at
|
Yosys is an extensible open source hardware synthesis tool. It is aimed at
|
||||||
designers who are looking for an easily accessible, universal, and
|
designers who are looking for an easily accessible, universal, and
|
||||||
|
@ -38,4 +38,4 @@ can be used as reference to implement a similar system in any language.
|
||||||
techmap
|
techmap
|
||||||
extensions
|
extensions
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
.. _chapter:techmap:
|
.. _chapter:techmap:
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
Technology mapping
|
Technology mapping
|
||||||
==================
|
==================
|
||||||
|
@ -109,7 +109,7 @@ sensitive information from the Liberty file.
|
||||||
Techmap by example
|
Techmap by example
|
||||||
------------------
|
------------------
|
||||||
|
|
||||||
.. TODO: copypaste
|
.. todo:: copypaste
|
||||||
|
|
||||||
As a quick recap, the ``techmap`` command replaces cells in the design with
|
As a quick recap, the ``techmap`` command replaces cells in the design with
|
||||||
implementations given as Verilog code (called "map files"). It can replace
|
implementations given as Verilog code (called "map files"). It can replace
|
||||||
|
|
Loading…
Reference in a new issue