aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoreine <6628437+eine@users.noreply.github.com>2020-01-14 17:21:33 +0000
committertgingold <tgingold@users.noreply.github.com>2020-01-14 18:21:33 +0100
commit30adf2657305b5ca1bcbd4e8f5f69b051f72ade9 (patch)
tree2d4cadd745306c8ae51f7d64d20b84c9488db238
parent7088606d2ee9da5a166153aca7d41311715bbd18 (diff)
downloadghdl-30adf2657305b5ca1bcbd4e8f5f69b051f72ade9.tar.gz
ghdl-30adf2657305b5ca1bcbd4e8f5f69b051f72ade9.tar.bz2
ghdl-30adf2657305b5ca1bcbd4e8f5f69b051f72ade9.zip
doc: add 'GSOC Ideas' (#1093)
-rw-r--r--doc/development/Documentation.rst14
-rw-r--r--doc/development/GSOC.rst119
-rw-r--r--doc/development/Roadmap.rst13
-rw-r--r--doc/using/Foreign.rst3
4 files changed, 138 insertions, 11 deletions
diff --git a/doc/development/Documentation.rst b/doc/development/Documentation.rst
new file mode 100644
index 000000000..2ae76ff5e
--- /dev/null
+++ b/doc/development/Documentation.rst
@@ -0,0 +1,14 @@
+.. _DEV:Documentation:
+
+Documentation
+#############
+
+* Development/Synthesis. Synthesis, ghdlsynth-beta, formal verification, etc. Copy the 'Usage' section from ghdlsynth's README (https://github.com/1138-4EB/ghdlsynth-beta#usage).
+* Development/libghdl. How to interact with GHDL through ``libghdl`` and/or ``libghdl-py``.
+* Development/Related Projects. Brief discussion about similarities/differences with other open source projects such as rust_hdl or pyVHDLParser.
+* Usage/Docker. Probably copy/convert :file:`README.md` and :file:`USE_CASES.md` in ghdl/docker :ghdlsharp:`166`.
+* Usage/Language Server.
+* Usage/Examples/Coverage. Code coverage in GHDL is a side effect of using GCC as a backend. In the future, GCC backend support might be dropped in favour of mcode and LLVM. To do so, code coverage with LLVM should be supported first. Anyway, comments/bits of info should be gathered somewhere in the docs, along with references to gcov, lcov, etc.
+* Usage/Examples/UART. Dossmatik's UART and unisim guides. We have ``*.doc`` sources to be converted to Sphinx.
+* Usage/Examples/Free Range VHDL. https://github.com/fabriziotappero/Free-Range-VHDL-book
+* It is possible to add waveforms with wavedrom, since there is a sphinx extension available.
diff --git a/doc/development/GSOC.rst b/doc/development/GSOC.rst
new file mode 100644
index 000000000..813a2aa64
--- /dev/null
+++ b/doc/development/GSOC.rst
@@ -0,0 +1,119 @@
+.. _DEV:GSOC:
+
+GSOC Ideas
+##########
+
+This page contains ideas for enhancing GHDL that can fit internship programs, such as `Google Summer of Code <https://summerofcode.withgoogle.com/>`_.
+
+VHDL frontend for Yosys
+=======================
+
+`Yosys <https://github.com/YosysHQ/yosys>`_ is an open-source synthesis tool with built-in Verilog support and partial SystemVerilog support. `ghdlsynth-beta <https://github.com/tgingold/ghdlsynth-beta>`_ is an experimental plugin for Yosys that allows to use GHDL (precisely, `libghdl <https://github.com/ghdl/ghdl#project-structure>`_) as a frontend for Yosys. Although functional, :ref:`DEV:Synthesis` is work in progress: multiple features are not supported yet, and others need to be tested for bugs.
+
+.. NOTE::
+ * `FOSSI GSOC 2019 | VHDL front-end for Yosys <https://fossi-foundation.org/gsoc19-ideas.html#vhdl-front-end--for-yosys>`_
+
+ * `FOSSI GSOC 2018 | VHDL Frontend for Yosys <https://fossi-foundation.org/gsoc18-ideas.html#vhdl-frontend-for-yosys>`_
+
+Profiling support
+=================
+
+Currently, GHDL does not include profiling features, which would allow to speed-up simulations and/or to detect hotspots in user designs.
+
+.. NOTE::
+ * `FOSSI GSOC 2018 | Profiling support <https://fossi-foundation.org/gsoc18-ideas.html#ghdl-profiling-support>`_
+
+ * :ghdlsharp:`60`
+
+Improve LLVM backend
+====================
+
+There are several possible enhancements to the current implementation of :ref:`BUILD:llvm`
+
+* Debugging is supported with LLVM 3.5 only, although up to version 9.0 is supported for simulation.
+* The C++ API of LLVM should be used instead of the C API.
+* There was no real try to find the best order of optimization passes. This can significantly improve performance, since GHDL is currently single-threaded and CPU-bound.
+* Code coverage is not supported.
+
+.. NOTE::
+ * `FOSSI GSOC 2018 | GHDL: Improve LLVM backend <https://fossi-foundation.org/gsoc18-ideas.html#ghdl-improve-llvm-backend>`_
+
+ * :ghdlsharp:`866`, :ghdlsharp:`744`, :ghdlsharp:`286`
+
+Support 64-bit with mcode on Windows
+====================================
+
+The built-in in-memory code generator (:ref:`BUILD:mcode`), is supported on 64 bit GNU/Linux, but not on Windows 64 bit. Compared to other backends, this would provide a lightweight and fast analyser, although it doesn't try to optimise.
+
+.. NOTE::
+ * `FOSSI GSOC 2018 | Support 64-bit with mcode on Windows <https://fossi-foundation.org/gsoc18-ideas.html#ghdl-support-64-bit-with-mcode-on-windows>`_
+
+ * :ghdlsharp:`657`
+
+Mixed-language (VHDL-Verilog)
+=============================
+
+Multiple proofs of concept exist for co-execution of HDL simulators with other tools, such as QEMU. However, there is no open-source solution that allows to co-simulate VHDL and Verilog sources using recent versions of the standards. Some possible approaches for this task are:
+
+* Use procedural interfaces, VPI or VHPIDIRECT (see :ref:`USING:Foreign`).
+
+* Transpile/convert the HDLs into a common intermediate representation.
+
+* Have GHDL use the API of another tool or the other way round.
+
+.. NOTE::
+ * `FOSSI GSOC 2018 | Framework for Mixed-Language Simulation <https://fossi-foundation.org/gsoc18-ideas.html#framework-for-mixed-language-simulation>`_
+
+ * `FOSSI GSOC 2017 | Open Source Mixed-Language HDL Simulation <https://fossi-foundation.org/gsoc17-ideas.html#open-source-mixed-language-hdl-simulation>`_
+
+ * :ghdlsharp:`908`, :ghdlsharp:`800`
+
+Mixed-signal (Digital-Analog)
+=============================
+
+Thre are three different approaches for mixed-signal simulation with GHDL:
+
+* Built-in VHDL-AMS support. It is currently possible to analyze VHDL-AMS files with GHDL (almost all the features are handled). However, it is analysis only (yet). A DAE solver needs to be pluged into GHDL compute the simulation.
+
+* Co-execution of GHDL and an analog simulator through VPI or VHPIDIRECT (see :ref:`USING:Foreign`).
+
+* Generation of simulation models from VHDL-AMS, like ADMS.
+
+.. NOTE::
+ * :ghdlsharp:`1052`, :ghdlsharp:`162`
+
+C APIs
+======
+
+Currently, GHDL can be wrapped in a foreign language (such as Ada or C) through VHPIDIRECT (see :ref:`USING:Foreign`). However, runtime management of the simulation is not supported. The API should be enhanced to support stepped execution. Moreover, interfacing with some types is not straightforward. Header files with the definition of those types would simplify data transference between language domains during simulation.
+
+.. NOTE::
+ * :ghdlsharp:`1059`, :ghdlsharp:`1053`, :ghdlsharp:`894`, :ghdlsharp:`819`, :ghdlsharp:`803`, :ghdlsharp:`800`
+
+Language server
+===============
+
+`ghdl-language-server <https://github.com/ghdl/ghdl-language-server>`_ is an experimental LSP server written in Python (which uses `libghdl-py <https://github.com/ghdl/ghdl#project-structure>`_), along with clients for different editors (e.g. VSCode, Emacs or Vim). Although functional, it is work in progress: multiple features are not supported yet, and others need to be tested for bugs.
+
+Project configuration file format
+=================================
+
+`ghdl-language-server <https://github.com/ghdl/ghdl-language-server>`_ supports a configuration file named `hdl-prj.json`. The format of this file is undocumented and lightly defined. This is because it would be desirable to use a configuration format that can be shared with other similar tools, such as `rust_hdl <https://github.com/kraigher/rust_hdl>`_ or `pyVHDLParser <https://github.com/Paebbels/pyVHDLParser>`_. In the context of GHDL, the same configuration file might be used for the language server, simulation, synthesis, etc.
+
+.. NOTE::
+ * `ghdl/ghdl-language-server#12 <https://github.com/ghdl/ghdl-language-server/issues/12>`_, `jeremiah-c-leary/vhdl-style-guide#312 <https://github.com/jeremiah-c-leary/vhdl-style-guide/issues/312>`_
+
+Packaging for Windows and/or macOS
+==================================
+
+GHDL can be installed with the most known package managers on GNU/Linux distributions (`apt`, `dnf`, `pacman`, etc.). However, this is not the case on Windows and/or macOS.
+
+On Windows, `PKGBUILD` files for MSYS2 are available, but not upstreamed. Nonetheless, it would be desirable to distribute an standalone package that does not depend on a ful MSYS2 installation (see :ref:`BUILD`).
+
+On macOS, a Homebrew formula might be written.
+
+Ideally, these packages would be built/generated and tested in a CI workflow.
+
+.. NOTE::
+ * `msys2/MINGW-packages#5757 <https://github.com/msys2/MINGW-packages/pull/5757>`_
+ * :ghdlsharp:`744`, `Homebrew/homebrew-cask#47256 <https://github.com/Homebrew/homebrew-cask/pull/47256>`_
diff --git a/doc/development/Roadmap.rst b/doc/development/Roadmap.rst
index 799ec7cbc..6577fd8e0 100644
--- a/doc/development/Roadmap.rst
+++ b/doc/development/Roadmap.rst
@@ -13,14 +13,7 @@ We have several axes for `GHDL` improvements:
* Style checks
* VITAL acceleration
-* Documentation
+.. toctree::
- * Development/Synthesis. Synthesis, ghdlsynth-beta, formal verification, etc. Copy the 'Usage' section from ghdlsynth's README (https://github.com/1138-4EB/ghdlsynth-beta#usage).
- * Development/libghdl. How to interact with GHDL through ``libghdl`` and/or ``libghdl-py``.
- * Development/Related Projects. Brief discussion about similarities/differences with other open source projects such as rust_hdl or pyVHDLParser.
- * Usage/Docker. Probably copy/convert :file:`README.md` and :file:`USE_CASES.md` in ghdl/docker :ghdlsharp:`166`.
- * Usage/Language Server.
- * Usage/Examples/Coverage. Code coverage in GHDL is a side effect of using GCC as a backend. In the future, GCC backend support might be dropped in favour of mcode and LLVM. To do so, code coverage with LLVM should be supported first. Anyway, comments/bits of info should be gathered somewhere in the docs, along with references to gcov, lcov, etc.
- * Usage/Examples/UART. Dossmatik's UART and unisim guides. We have ``*.doc`` sources to be converted to Sphinx.
- * Usage/Examples/Free Range VHDL. https://github.com/fabriziotappero/Free-Range-VHDL-book
- * It is possible to add waveforms with wavedrom, since there is a sphinx extension available.
+ Documentation
+ GSOC
diff --git a/doc/using/Foreign.rst b/doc/using/Foreign.rst
index 35e007ebc..7eda97a80 100644
--- a/doc/using/Foreign.rst
+++ b/doc/using/Foreign.rst
@@ -1,5 +1,6 @@
.. program:: ghdl
-.. FOREIGN:
+
+.. _USING:Foreign:
Interfacing to other languages
##############################