diff options
author | Patrick Lehmann <Paebbels@gmail.com> | 2022-02-23 23:41:45 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-02-23 23:41:45 +0100 |
commit | 8fb84c1ca46c299996886dd22a7796817015c681 (patch) | |
tree | 024d4a6333005c406012af6453b1e74957b23eb5 /doc/internals | |
parent | 1325d61a595f90239a93e90c930c9bcbd725d3b3 (diff) | |
parent | a8913e8fa4ee1c92ee008a77487a614014c45fb6 (diff) | |
download | ghdl-8fb84c1ca46c299996886dd22a7796817015c681.tar.gz ghdl-8fb84c1ca46c299996886dd22a7796817015c681.tar.bz2 ghdl-8fb84c1ca46c299996886dd22a7796817015c681.zip |
Doc: add Overview diagram, fix shields in tables, use extlinks more
Diffstat (limited to 'doc/internals')
-rw-r--r-- | doc/internals/Overview.rst | 25 | ||||
-rw-r--r-- | doc/internals/img/internals.png | bin | 80333 -> 0 bytes | |||
-rw-r--r-- | doc/internals/index.rst | 34 |
3 files changed, 34 insertions, 25 deletions
diff --git a/doc/internals/Overview.rst b/doc/internals/Overview.rst deleted file mode 100644 index fd29f5832..000000000 --- a/doc/internals/Overview.rst +++ /dev/null @@ -1,25 +0,0 @@ -.. _INT:Overview: - -Overview -######## - -.. image:: img/internals.png - :width: 350px - :align: center - -`GHDL` is architectured like a traditionnal compiler. It has: - -* a driver (sources in :ghdlsrc:`src/ghdldrv <ghdldrv>`) to call the programs (compiler, assembler, linker) if needed. - -* a runtime library named GRT (sources in :ghdlsrc:`src/grt <grt>`) to help execution at run-time. This ensures that execution is cycle-accurate. - -* a front-end (sources in :ghdlsrc:`src/vhdl <vhdl>`) to parse and analyse VHDL. See :ref:`INT:Frontend` and :ref:`INT:AST`. - -* multiple back-ends to generate either code or netlists. - - * Three for :ref:`simulation <USING:Simulation>` (sources are in :ghdlsrc:`src/ortho <ortho>`): mcode, LLVM and GCC. See :ref:`BUILD`. - * Two for :ref:`synthesis <USING:Synthesis>` (sources in :ghdlsrc:`src/synth <synth>`): :ref:`--synth <Synth:command>` and :ref:`Synth:plugin`. - -The architecture is modular. For example, the front-end in the ``libghdl`` library is used for the language server. - -The main work is performed by the front-end, which is documented in the next chapter. diff --git a/doc/internals/img/internals.png b/doc/internals/img/internals.png Binary files differdeleted file mode 100644 index cc6714287..000000000 --- a/doc/internals/img/internals.png +++ /dev/null diff --git a/doc/internals/index.rst b/doc/internals/index.rst new file mode 100644 index 000000000..4614d0edc --- /dev/null +++ b/doc/internals/index.rst @@ -0,0 +1,34 @@ +.. _INT:Overview: + +Overview +######## + +.. figure:: ../_static/internals.png + :width: 100% + :align: center + + Architecture overview of the GHDL toolkit (CLI, libghdl, pyGHDL and ghdl-yosys-plugin). + +`GHDL` is architectured like a traditionnal compiler. It has: + +* a driver (sources in :ghdlsrc:`src/ghdldrv <ghdldrv>`) to call the programs (compiler, assembler, linker) if needed. + +* a runtime library named GRT (sources in :ghdlsrc:`src/grt <grt>`) to help execution at run-time. + This ensures that execution is cycle-accurate. + +* a front-end (sources in :ghdlsrc:`src/vhdl <vhdl>`) to parse and analyse VHDL. + See :ref:`INT:Frontend` and :ref:`INT:AST`. + +* multiple back-ends to generate either code or netlists. + + * Three for :ref:`simulation <USING:Simulation>` (sources are in :ghdlsrc:`src/ortho <ortho>`): mcode, LLVM and GCC. + See :ref:`BUILD`. + * Two for :ref:`synthesis <USING:Synthesis>` (sources in :ghdlsrc:`src/synth <synth>`): + :ref:`--synth <Synth:command>` and :ref:`Synth:plugin`. + +The architecture is modular and some of the components are available through the shared library ``libghdl``. +``libghdl`` is used by the :ref:`Synth:plugin`, the Language Server Protocol (LSP) server, and to fill the data of +pyVHDLModel (see :doc:`vhdlmodel:index`). + +The main work with regard to understanding the VHDL language is performed by the front-end, which is documented in the +next section. |