mirror of
https://github.com/myhdl/myhdl.git
synced 2024-12-14 07:44:38 +08:00
MyHDL Release 0.6dev7 ===================== 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 Verilog. In combination with an external synthesis tool, it provides a complete path from Python to a silicon implementation. 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 application development and experimentation. 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. With MyHDL, the Python unit test framework can be used on hardware 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. 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. INSTALLATION ------------ If you have superuser power, you can install MyHDL as follows: 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. You can test the proper installation as follows: cd myhdl/test python test_all.py To install co-simulation support: Go to the directory co-simulation/<platform> for your target platform and following the instructions in the README.txt file. DOCUMENTATION ------------- 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 EXAMPLES -------- See the example/ subdirectory for examples. AUTHOR ------ Jan Decaluwe <jan@jandecaluwe.com>
Description
Languages
Python
86.2%
C
5.9%
Verilog
5.8%
VHDL
1.2%
Shell
0.5%
Other
0.4%