aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRocketRoss <mr@radonn.co.za>2020-04-08 18:56:33 +0200
committerGitHub <noreply@github.com>2020-04-08 18:56:33 +0200
commit773ce85c588e04d8c9605a8d9513fb32deff6a8a (patch)
treeaf8abedfa0b286a22b0a924aef8f5f471aeb706e
parent921e989f6e638cd655835040839b2c003385ec38 (diff)
downloadghdl-773ce85c588e04d8c9605a8d9513fb32deff6a8a.tar.gz
ghdl-773ce85c588e04d8c9605a8d9513fb32deff6a8a.tar.bz2
ghdl-773ce85c588e04d8c9605a8d9513fb32deff6a8a.zip
Update Foreign.rst to reflect my learnings (#1195)
* Update Foreign.rst to reflect my learnings I found the page to be a little unclear in when and why to link to externally generated object files. It is a simple point in hindsight, but moving Linking foreign object files to GHDL to right after Foreign Declarations of Function makes it easier to see the link. I also added a Hint on how to pass command line arguments to ghdl_main, and wrote that the one code block is Python code (which wasn't immediately obvious to me at least). * Update Foreign.rst to reflect my learnings: Rev1 Move Linking... back to original spot. Better hint, and extra reference to simulation options. * Add reference-able label to --elab-run * Update Foreign.rst to reflect my learnings: Rev2 Clean up reference hint. * Update Foreign.rst to reflect my learnings: Rev3 Further clean reference hints. * Update Foreign.rst to reflect my learnings: Rev4 Improve hints. * Move and make -Wl,*.o hint generic, reference it * Do lables require an empty line to follow?? * Missed 'is' * Remove promise for example. * Remove promise again..... * Give up on referencing hint, just ref "linking... * Line feed reverted to LF Co-authored-by: Ross <radonnachie@gmail.com>
-rw-r--r--doc/using/Foreign.rst16
-rw-r--r--doc/using/InvokingGHDL.rst2
2 files changed, 16 insertions, 2 deletions
diff --git a/doc/using/Foreign.rst b/doc/using/Foreign.rst
index 7eda97a80..57ffc2ce3 100644
--- a/doc/using/Foreign.rst
+++ b/doc/using/Foreign.rst
@@ -62,6 +62,9 @@ The value of the attribute must start with ``VHPIDIRECT`` (an
upper-case keyword followed by one or more blanks). The linkage name of the
subprogram follows.
+The object file with the source code for the foreign subprogram must then be
+linked to GHDL, expanded upon in :ref:`Starting_a_simulation_from_a_foreign_program`.
+
.. _Restrictions_on_foreign_declarations:
Restrictions on foreign declarations
@@ -126,6 +129,12 @@ library.
Note the :file:`c` library is always linked with an executable.
+.. HINT::
+ The process for personal code is the same, provided the code is compiled to an object file.
+ Analysis must be made of the HDL files, then elaboration with `-Wl,personal.o toplevelEntityName` as arguments.
+ Additional object files are flagged separate `-Wl,*` arguments. The elaboration step will compile the executable with the custom resources.
+ Further reading (particularly about the backend restrictions) is at :ref:`Elaboration:command` and :ref:`Run:command`.
+
.. _Starting_a_simulation_from_a_foreign_program:
Wrapping and starting a GHDL simulation from a foreign program
@@ -140,6 +149,9 @@ in C:
extern int ghdl_main (int argc, char **argv);
+.. TIP::
+ Don't forget to list the object file of this entry point as per :ref:`Linking_with_foreign_object_files`.
+
in Ada:
.. code-block:: Ada
@@ -203,7 +215,7 @@ See :ref:`gccllvm-only-programs` for further details about ``--bind`` and ``--li
Dynamically loading foreign objects from GHDL
=============================================
-Instead of linking and building foreign objects along with GHDL, it is also possible to load foreign resources dinamically.
+Instead of linking and building foreign objects along with GHDL, it is also possible to load foreign resources dynamically.
In order to do so, provide the path and name of the shared library where the resource is to be loaded from. For example:
.. code-block:: VHDL
@@ -219,7 +231,7 @@ that all the libraries and sources analyzed by GHDL generate position independen
Furthermore, when the binary is built, argument ``-Wl,-pie`` needs to be provided.
PIE binaries can be loaded and executed from any language that supports C-alike signatures and types
-(C, C++, golang, Python, Rust, etc.). For example:
+(C, C++, golang, Python, Rust, etc.). For example, in Python:
.. code-block:: Python
diff --git a/doc/using/InvokingGHDL.rst b/doc/using/InvokingGHDL.rst
index 4deb96b7f..613fdaf05 100644
--- a/doc/using/InvokingGHDL.rst
+++ b/doc/using/InvokingGHDL.rst
@@ -108,6 +108,8 @@ See section :ref:`USING:Simulation`, for details on options.
.. index:: cmd elaborate and run
+.. _elab_and_run:command:
+
Elaborate and run [``--elab-run``]
----------------------------------