summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrahulp132020-03-31 18:15:27 +0530
committerrahulp132020-03-31 18:15:27 +0530
commit0b800c73eee4527a78bd28cc75f0da3670229927 (patch)
tree479fe104bc27e7fc8f9bf0f31ce6fda5eeb63465
parent8b781a1da9a05f3194d149d80610a4a3ac333f3d (diff)
downloadnghdl-0b800c73eee4527a78bd28cc75f0da3670229927.tar.gz
nghdl-0b800c73eee4527a78bd28cc75f0da3670229927.tar.bz2
nghdl-0b800c73eee4527a78bd28cc75f0da3670229927.zip
fully static bundle - staticx
-rw-r--r--Debian/readme.md76
1 files changed, 63 insertions, 13 deletions
diff --git a/Debian/readme.md b/Debian/readme.md
index 2da9deb..04e3647 100644
--- a/Debian/readme.md
+++ b/Debian/readme.md
@@ -1,4 +1,4 @@
-NGHDL Installer (Ubuntu)
+NGHDL Installer (Ubuntu OS)
====
@@ -8,20 +8,23 @@ Separate installers are required to resolve dependencies only for GHDL and are m
## NGDHL EXECUTABLE:
-1. Download `virtualenv` package as:
+1. Download `virtualenv` package and create virtual environment as:
$ pip install virtualenv
+ $ virtualenv -p /usr/bin/python3 nghdl
-2. Create a virtual environment as:
-
- $ virtualenv -p /usr/bin/python3 nghdl
+ OR
+
+ $ sudo apt install -y python3-venv
+ $ python3 -m venv nghdl
-3. Activate the virtual environment as:
+2. Activate the virtual environment as:
$ source nghdl/bin/activate
-4. Install all Python dependencies for eSim within the virtual environment as:
+3. Install all Python dependencies for NGHDL within the virtual environment as:
+ $ pip install wheel
$ pip install pyinstaller
$ pip install --upgrade 'setuptools<45.0.0'
$ sudo apt install build-essential python3-dev libqt4-dev qt4-dev-tools
@@ -40,9 +43,9 @@ Separate installers are required to resolve dependencies only for GHDL and are m
$ make
$ make install
-5. Now uninstall PyQt4, sip, matplotlib, numpy, dateutil and cycler globally (if any).
+4. Now uninstall PyQt4, sip, matplotlib, numpy, dateutil and cycler globally (if any).
-6. Test whether only NGHDL dependencies are available or not:
+5. Test whether only NGHDL dependencies are available or not:
$ pip freeze
@@ -50,43 +53,90 @@ Separate installers are required to resolve dependencies only for GHDL and are m
> - PyQt4
> - sip
-7. Create spec file as:
+6. Create spec file as:
$ pyi-makespec --onefile -n nghdl <path_to_nghdl>/src/ngspice_ghdl.py
-8. Add `PyQt4.sip` as hiddenimports in the generated spec file.
+7. Add `PyQt4.sip` as hiddenimports in the generated spec file.
-9. Create onefile executable using pyinstaller as:
+8. Create onefile executable using pyinstaller as:
$ pyinstaller -F --clean nghdl.spec
-10. Verify whether all NGHDL `src` files (`*.py`) have been included in `Analysis-00.toc` file under the build folder generated by PyInstaller.
+9. Verify whether all NGHDL `src` files (`*.py`) have been included in `Analysis-00.toc` file under the build folder generated by PyInstaller.
+
+
+## Fully-Static Bundled Version of NGHDL:
+
+1. To create a [fully-static bundled version](https://github.com/pyinstaller/pyinstaller/wiki/FAQ#GNULinux) of NGHDL (through PyInstaller), use a tool like [StaticX](https://github.com/JonathonReinhart/staticx/).
+
+2. To create fully-static NGHDL :
+
+ - Activate the virtual environment as:
+
+ $ source nghdl/bin/activate
+
+ - Install StaticX as:
+
+ $ pip install staticx
+ $ pip install patchelf-wrapper
+
+ - Create static NGHDL as:
+ $ staticx /path/to/executable/nghdl /path/to/output/executable/nghdl
+
+3. To verify if all dynamic libraries are removed :
+
+ - Type following command in a terminal :
+
+ $ ldd path/to/output/executable/nghdl
+
+ - Output of above command should be similar to ` not a dynamic executable`
## Differences in Ubuntu 14.04, Ubuntu 16.04 and above installers (w.r.t GHDL):
+
1. Dependency on gnat :
+
- Ubuntu 14.04 : gnat (v4.6)
+
- Ubuntu 16.04 : gnat-5 (v5.4)
+
- Ubuntu 18.04 : gnat-5 (v5.5)
+
2. Dependency on llvm :
+
- Available version on Ubuntu 14.04 : llvm (v3.4)
+
- Available version on Ubuntu 16.04 : llvm (v3.5)
+
- Available version on Ubuntu 18.04 : llvm (v6.0)
+
- Requires llvm version between 3.5 and 3.9 for compilation of GHDL with llvm config
+
- Ubuntu 18.04 requires installation of LLVM on target machine as it is used during runtime of GHDL as shared library.
+
3. Dependency on gcc :
+
- Ubuntu 14.04 and 16.04 : gcc (v5.4.0) is available without pie (i.e. position-independent executable)
+
- Ubuntu 18.04 : gcc (v7.4.0) is available with pie enabled as default option.
+
- Refer [this](https://github.com/ghdl/ghdl/issues/213) Github issue for dependency on gcc for Ubuntu 18.04 and above.
## GHDL Compilation:
+
1. Compilation of GHDL is OS specific and GHDL executables should be generated on that system for distribution on same OS configuration.
+
2. For distribution of GHDL (v0.36) on Ubuntu 14.04, directly use the llvm executable provided on GHDL's Github page.
+
3. For distribution of GHDL (v0.36) on Ubuntu 16.04 and above, follow the steps:
+
a. Download source code (v0.36) from GHDL's Github page.
+
b. Extract the tar file, open a terminal and change directory one-level inside.
+
c. First install gnat(v5) dependency as:
$ sudo apt install gnat-5