2008-08-21 15:29:10 +02:00
|
|
|
MyHDL Release 0.6dev9
|
2006-10-12 20:32:06 +00:00
|
|
|
=====================
|
2003-01-30 17:30:38 +00:00
|
|
|
|
2005-12-27 14:33:57 +00:00
|
|
|
OVERVIEW
|
|
|
|
--------
|
|
|
|
|
|
|
|
The goal of the MyHDL project is to empower hardware designers with
|
|
|
|
the elegance and simplicity of the Python language.
|
|
|
|
|
|
|
|
MyHDL is a free, open-source (LGPL) package for using Python as a
|
|
|
|
hardware description and verification language. Python is a very high
|
|
|
|
level language, and hardware designers can use its full power to model
|
|
|
|
and simulate their designs. Moreover, MyHDL can convert a design to
|
2008-03-18 21:13:18 +00:00
|
|
|
Verilog or VHDL. In combination with an external synthesis tool, it
|
|
|
|
provides a complete path from Python to a silicon implementation.
|
2003-01-30 17:30:38 +00:00
|
|
|
|
2005-12-27 14:33:57 +00:00
|
|
|
Modeling
|
|
|
|
~~~~~~~~
|
|
|
|
|
|
|
|
Python's power and clarity make MyHDL an ideal solution for high level
|
|
|
|
modeling. Python is famous for enabling elegant solutions to complex
|
|
|
|
modeling problems. Moreover, Python is outstanding for rapid
|
2003-08-22 07:43:38 +00:00
|
|
|
application development and experimentation.
|
2003-08-08 13:41:03 +00:00
|
|
|
|
2005-12-27 14:33:57 +00:00
|
|
|
The key idea behind MyHDL is the use of Python generators to model
|
|
|
|
hardware concurrency. Generators are best described as resumable
|
|
|
|
functions. In MyHDL, generators are used in a specific way so that
|
|
|
|
they become similar to always blocks in Verilog or processes in VHDL.
|
|
|
|
|
|
|
|
A hardware module is modeled as a function that returns any number of
|
|
|
|
generators. This approach makes it straightforward to support features
|
|
|
|
such as arbitrary hierarchy, named port association, arrays of
|
|
|
|
instances, and conditional instantiation.
|
|
|
|
|
|
|
|
Furthermore, MyHDL provides classes that implement traditional
|
|
|
|
hardware description concepts. It provides a signal class to support
|
|
|
|
communication between generators, a class to support bit oriented
|
|
|
|
operations, and a class for enumeration types.
|
|
|
|
|
|
|
|
Simulation and Verification
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
The built-in simulator runs on top of the Python interpreter. It
|
|
|
|
supports waveform viewing by tracing signal changes in a VCD file.
|
|
|
|
|
2003-08-08 13:41:03 +00:00
|
|
|
With MyHDL, the Python unit test framework can be used on hardware
|
2005-12-27 14:33:57 +00:00
|
|
|
designs. Although unit testing is a popular modern software
|
|
|
|
verification technique, it is not yet common in the hardware design
|
|
|
|
world, making it one more area in which MyHDL innovates.
|
|
|
|
|
|
|
|
MyHDL can also be used as hardware verification language for VHDL and
|
|
|
|
Verilog designs, by co-simulation with traditional HDL simulators.
|
|
|
|
|
|
|
|
Conversion to Verilog
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
The converter to Verilog works on an instantiated design that has been
|
|
|
|
fully elaborated. Consequently, the original design structure can be
|
|
|
|
arbitrarily complex.
|
2003-02-14 11:42:55 +00:00
|
|
|
|
2005-12-27 14:33:57 +00:00
|
|
|
The converter automates certain tasks that are tedious or hard in
|
|
|
|
Verilog directly. Notable features are the possibility to choose
|
|
|
|
between various FSM state encodings based on a single attribute, the
|
|
|
|
mapping of certain high-level objects to RAM and ROM descriptions, and
|
|
|
|
the automated handling of signed arithmetic issues.
|
2004-02-02 10:47:49 +00:00
|
|
|
|
2003-08-08 13:41:03 +00:00
|
|
|
|
2003-01-30 22:36:49 +00:00
|
|
|
|
2003-01-30 17:30:38 +00:00
|
|
|
INSTALLATION
|
|
|
|
------------
|
|
|
|
|
2003-02-14 11:42:55 +00:00
|
|
|
If you have superuser power, you can install MyHDL as follows:
|
2003-01-30 22:36:49 +00:00
|
|
|
|
|
|
|
python setup.py install
|
|
|
|
|
|
|
|
This will install the package in the appropriate site-wide Python
|
|
|
|
package location.
|
|
|
|
|
|
|
|
Otherwise, you can install it in a personal directory, e.g. as
|
|
|
|
follows:
|
|
|
|
|
|
|
|
python setup.py install --home=$HOME
|
|
|
|
|
|
|
|
In this case, be sure to add the appropriate install dir to the
|
|
|
|
$PYTHONPATH.
|
|
|
|
|
|
|
|
If necessary, consult the distutils documentation in the standard
|
|
|
|
Python library if necessary for more details; or contact me.
|
|
|
|
|
2004-04-21 13:38:04 +00:00
|
|
|
You can test the proper installation as follows:
|
2003-03-06 22:16:03 +00:00
|
|
|
|
2004-04-21 13:38:04 +00:00
|
|
|
cd myhdl/test
|
|
|
|
python test_all.py
|
2003-01-30 22:36:49 +00:00
|
|
|
|
2003-05-15 09:30:34 +00:00
|
|
|
To install co-simulation support:
|
2003-05-14 09:12:21 +00:00
|
|
|
|
2003-05-15 09:30:34 +00:00
|
|
|
Go to the directory co-simulation/<platform> for your target platform
|
2004-12-28 17:04:43 +00:00
|
|
|
and following the instructions in the README.txt file.
|
2003-05-14 09:12:21 +00:00
|
|
|
|
2003-05-13 08:03:51 +00:00
|
|
|
|
2003-01-30 17:30:38 +00:00
|
|
|
DOCUMENTATION
|
|
|
|
-------------
|
|
|
|
|
2005-12-27 14:56:52 +00:00
|
|
|
The manual is available in various formats under the doc/
|
|
|
|
subdirectory.
|
|
|
|
|
|
|
|
An on-line version of the manual and extensive additional
|
|
|
|
documentation and support information can be found on the MyHDL
|
|
|
|
website:
|
|
|
|
|
|
|
|
http://myhdl.jandecaluwe.com
|
2003-01-30 22:36:49 +00:00
|
|
|
|
2003-05-13 08:03:51 +00:00
|
|
|
|
2003-01-30 17:30:38 +00:00
|
|
|
EXAMPLES
|
|
|
|
--------
|
2003-01-30 22:36:49 +00:00
|
|
|
|
|
|
|
See the example/ subdirectory for examples.
|
|
|
|
|
2003-05-13 08:03:51 +00:00
|
|
|
|
2003-01-30 22:36:49 +00:00
|
|
|
AUTHOR
|
|
|
|
------
|
|
|
|
Jan Decaluwe <jan@jandecaluwe.com>
|