summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrahulp132020-02-14 16:40:29 +0530
committerrahulp132020-02-14 16:40:29 +0530
commit026446c131be62253033b046de14e58eca9616b4 (patch)
tree5799cc10c0920902287263c6b7e2f01ed5291f04
parent983f3a24b7c12f9c236546fb81277f05a3c3c95a (diff)
downloadnghdl-026446c131be62253033b046de14e58eca9616b4.tar.gz
nghdl-026446c131be62253033b046de14e58eca9616b4.tar.bz2
nghdl-026446c131be62253033b046de14e58eca9616b4.zip
updated ghdl installation for ubuntu 16+
-rwxr-xr-xDebian/Ubuntu 16.04+/install-nghdl.sh (renamed from Debian/Ubuntu 18.04/install-nghdl.sh)63
-rw-r--r--Debian/Ubuntu 16.04/ghdl-0.36.tar.xzbin9220896 -> 0 bytes
-rwxr-xr-xDebian/Ubuntu 16.04/install-nghdl.sh278
-rw-r--r--Debian/Ubuntu 18.04/ghdl-0.36.tar.xzbin3866028 -> 0 bytes
-rw-r--r--Debian/readme.md42
5 files changed, 33 insertions, 350 deletions
diff --git a/Debian/Ubuntu 18.04/install-nghdl.sh b/Debian/Ubuntu 16.04+/install-nghdl.sh
index ca529c7..0078427 100755
--- a/Debian/Ubuntu 18.04/install-nghdl.sh
+++ b/Debian/Ubuntu 16.04+/install-nghdl.sh
@@ -14,7 +14,7 @@
# NOTES: ---
# AUTHOR: Fahim Khan, Rahul Paknikar
# ORGANIZATION: eSim, FOSSEE group at IIT Bombay
-# CREATED: Wednesday 22 January 2020 16:30
+# CREATED: Friday 14 February 2020 16:30
# REVISION: ---
#===============================================================================
@@ -33,6 +33,8 @@ timestamp=`echo $sysdate|awk '{print $3"_"$2"_"$6"_"$4 }'`
function installDependency
{
+ echo "Installing dependencies for ghdl-0.36 LLVM................"
+
echo "Installing Make..........................................."
sudo apt install -y make
if [ $? -ne 0 ]; then
@@ -54,6 +56,13 @@ function installDependency
exit 1
fi
+ echo "Installing Clang................................."
+ sudo apt-get install -y clang
+ if [ $? -ne 0 ]; then
+ echo -e "\n\n\"Clang\" dependency couldn't be installed.\nKindly resolve above \"apt-get\" errors and try again."
+ exit 1
+ fi
+
echo "Installing Zlib1g-dev....................................."
sudo apt install -y zlib1g-dev
if [ $? -ne 0 ]; then
@@ -91,47 +100,25 @@ function installDependency
if [ $? -ne 0 ]; then
tar -xJf ghdl-0.36.tar.xz
if [ "$?" == 0 ]; then
- echo "ghdl-0.36 successfully extracted.................."
- echo "Changing directory to ghdl-0.36 installation......"
+ echo "ghdl-0.36 successfully extracted..."
+ echo "Changing directory to ghdl-0.36 installation..."
cd ghdl-0.36/
- #Copy compiled ghdl to system path
- sudo cp bin/* /usr/local/bin/
- #Make it executable
- sudo chmod 755 /usr/local/bin/ghdl*
- if [ $? -ne 0 ]; then
- echo "Unable to install ghdl-0.36 LLVM (@bin)"
- echo "Exiting installation..."
- exit 1
- fi
-
- sudo cp include/* /usr/local/include/
- #Make it accessible
- sudo chmod 755 /usr/local/include/vpi_user.h
- if [ $? -ne 0 ]; then
- echo "Unable to install ghdl-0.36 LLVM (@include)"
- echo "Exiting installation..."
- exit 1
- fi
-
- sudo cp -r lib/* /usr/local/lib/
- #Make it accessible
- sudo chmod -R 755 /usr/local/lib/ghdl/
- if [ $? -ne 0 ]; then
- echo "Unable to install ghdl-0.36 LLVM (@lib)"
- echo "Exiting installation..."
- exit 1
- fi
-
- echo "Removing unused part of ghdl-0.36 LLVM..."
- rm -rf ../ghdl-0.36
- echo "GHDL installed successfully......................."
+ echo "Configuring ghdl-0.36 build as per requirements..."
+ #Other configure flags can be found at - https://github.com/ghdl/ghdl/blob/master/configure
+ sudo ./configure --with-llvm-config=/usr/bin/llvm-config-3.9
+ echo "Building the install file for ghdl-0.36 LLVM..."
+ sudo make -j$(nproc)
+ echo "Installing ghdl-0.36 LLVM..."
+ sudo make install
+ echo "Removing unused part of ghdl-0.36 LLVM....."
+ sudo rm -rf ../ghdl-0.36
else
echo "Unable to extract ghdl-0.36 LLVM"
echo "Exiting installation"
exit 1
fi
else
- echo "GHDL already exists..."
+ echo "GHDL already exists....."
echo "Leaving ghdl-0.36 LLVM installation"
fi
@@ -187,11 +174,9 @@ function installNgspice
sudo chmod 755 /usr/bin/ngspice
echo "Added softlink for Ngspice"
fi
-
else
echo "There was some error while installing Ngspice"
fi
-
else
echo "Unable to extract Ngspice tar file"
exit 1;
@@ -282,8 +267,10 @@ elif [ $option == "--uninstall" ];then
sudo rm -rf $HOME/ngspice-nghdl $HOME/.nghdl /usr/share/kicad/library/eSim_Nghdl.lib /usr/local/bin/nghdl /usr/bin/ngspice
echo "Removing libxaw7-dev..............."
sudo apt purge -y libxaw7-dev
- echo "Removing GHDL............."
+ echo "Removing GHDL......................"
sudo rm -rf /usr/local/bin/ghdl /usr/local/bin/ghdl1-llvm /usr/local/lib/ghdl /usr/local/lib/libghdlvpi.so /usr/local/include/vpi_user.h
+ echo "Removing LLVM......................"
+ sudo apt-get remove -y llvm-3.9
echo "Removing GNAT-5...................."
sudo apt purge -y gnat-5
else
diff --git a/Debian/Ubuntu 16.04/ghdl-0.36.tar.xz b/Debian/Ubuntu 16.04/ghdl-0.36.tar.xz
deleted file mode 100644
index 30cd636..0000000
--- a/Debian/Ubuntu 16.04/ghdl-0.36.tar.xz
+++ /dev/null
Binary files differ
diff --git a/Debian/Ubuntu 16.04/install-nghdl.sh b/Debian/Ubuntu 16.04/install-nghdl.sh
deleted file mode 100755
index f1214c7..0000000
--- a/Debian/Ubuntu 16.04/install-nghdl.sh
+++ /dev/null
@@ -1,278 +0,0 @@
-#!/bin/bash
-#===============================================================================
-# FILE: install-nghdl.sh
-#
-# USAGE: ./install-nghdl.sh --install
-# or
-# ./install-nghdl.sh --uninstall
-#
-# DESCRIPTION: It is installation script for ngspice and ghdl work (nghdl).
-#
-# OPTIONS: ---
-# REQUIREMENTS: ---
-# BUGS: ---
-# NOTES: ---
-# AUTHOR: Fahim Khan, Rahul Paknikar
-# ORGANIZATION: eSim, FOSSEE group at IIT Bombay
-# CREATED: Wednesday 22 January 2020 16:30
-# REVISION: ---
-#===============================================================================
-
-ngspice="ngspice-nghdl"
-ghdl="ghdl-0.36"
-config_dir="$HOME/.nghdl"
-config_file="config.ini"
-src_dir=`pwd`
-
-#Will be used to take backup of any file
-sysdate="$(date)"
-timestamp=`echo $sysdate|awk '{print $3"_"$2"_"$6"_"$4 }'`
-
-
-#All functions goes here
-function installDependency
-{
-
- echo "Installing Make..........................................."
- sudo apt install -y make
- if [ $? -ne 0 ]; then
- echo -e "\n\n\"Make\" dependency couldn't be installed.\nKindly resolve above errors and try again."
- exit 1
- fi
-
- echo "Installing GNAT-5........................................."
- sudo apt install -y gnat-5
- if [ $? -ne 0 ]; then
- echo -e "\n\n\"GNAT\" dependency couldn't be installed.\nKindly resolve above errors and try again."
- exit 1
- fi
-
- echo "Installing Zlib1g-dev....................................."
- sudo apt install -y zlib1g-dev
- if [ $? -ne 0 ]; then
- echo -e "\n\n\"Zlib1g-dev\" dependency couldn't be installed.\nKindly resolve above errors and try again."
- exit 1
- fi
-
- # Specific dependency for nvidia graphic cards
- echo "Installing graphics dependency for ngspice souce build"
- echo "Installing libxaw7........................................"
- sudo apt install -y libxaw7
- if [ $? -ne 0 ]; then
- echo -e "\n\n\"libxaw7\" dependency couldn't be installed.\nKindly resolve above errors and try again."
- exit 1
- fi
-
- echo "Installing libxaw7-dev...................................."
- sudo apt install -y libxaw7-dev
- if [ $? -ne 0 ]; then
- echo -e "\n\n\"libxaw7-dev\" dependency couldn't be installed.\nKindly resolve above \"apt-get\" errors and try again."
- exit 1
- fi
-
-
- echo "Installing GHDL-0.36 LLVM................................."
- grep -h "ghdl" /usr/local/bin/ghdl > /dev/null
- if [ $? -ne 0 ]; then
- tar -xJf ghdl-0.36.tar.xz
- if [ "$?" == 0 ]; then
- echo "ghdl-0.36 successfully extracted.................."
- echo "Changing directory to ghdl-0.36 installation......"
- cd ghdl-0.36/
- #Copy compiled ghdl to system path
- sudo cp bin/* /usr/local/bin/
- #Make it executable
- sudo chmod 755 /usr/local/bin/ghdl*
- if [ $? -ne 0 ]; then
- echo "Unable to install ghdl-0.36 LLVM (@bin)"
- echo "Exiting installation..."
- exit 1
- fi
-
- sudo cp include/* /usr/local/include/
- #Make it accessible
- sudo chmod 755 /usr/local/include/vpi_user.h
- if [ $? -ne 0 ]; then
- echo "Unable to install ghdl-0.36 LLVM (@include)"
- echo "Exiting installation..."
- exit 1
- fi
-
- sudo cp -r lib/* /usr/local/lib/
- #Make it accessible
- sudo chmod -R 755 /usr/local/lib/ghdl/
- if [ $? -ne 0 ]; then
- echo "Unable to install ghdl-0.36 LLVM (@lib)"
- echo "Exiting installation..."
- exit 1
- fi
-
- echo "Removing unused part of ghdl-0.36 LLVM..."
- rm -rf ../ghdl-0.36
- echo "GHDL installed successfully......................."
- else
- echo "Unable to extract ghdl-0.36 LLVM"
- echo "Exiting installation"
- exit 1
- fi
- else
- echo "GHDL already exists..."
- echo "Leaving ghdl-0.36 LLVM installation"
- fi
-
-}
-
-
-function installNgspice
-{
-
- echo "Installing Ngspice........................................"
- #Checking if ngspice-nghdl directory is already present in Home directory
- if [ -d $HOME/$ngspice ];then
- echo "$ngspice directory already exists at $HOME"
- echo "Leaving Ngspice installation..."
- else
- #Extracting Ngspice to Home Directory
- cd $src_dir
- tar -xJf $ngspice.tar.xz -C $HOME
- if [ "$?" == 0 ];then
- echo "Ngspice extracted sucessfuly to $HOME"
- #change to ngspice-nghdl directory
- cd $HOME/$ngspice
- #Make local install directory
- mkdir -p install_dir
- #Make release directory for build
- mkdir -p release
- #Change to release directory
- cd release
- echo "Configuring Ngspice..."
- sleep 2
- ../configure --enable-xspice --disable-debug --prefix=$HOME/$ngspice/install_dir/ --exec-prefix=$HOME/$ngspice/install_dir/
-
- #dirty fix for adding patch to ngspice base code
- cp $src_dir/src/outitf.c $HOME/$ngspice/src/frontend
-
- make -j$(nproc)
- make install
- if [ "$?" == 0 ];then
- echo "Removing previously installed Ngspice (if any)..."
- sudo apt-get purge -y ngspice
-
- echo "Ngspice installed sucessfully................."
- echo "Adding softlink for the installed Ngspice....."
-
- sudo rm /usr/bin/ngspice
- sudo ln -s $HOME/$ngspice/install_dir/bin/ngspice /usr/bin/ngspice
- if [ $? -ne 0 ];then
- echo "Failed to add Ngspice softlink............"
- echo "Remove earlier installations at /usr/bin/ngspice and try again..."
- exit 1
- else
- #Make it executable
- sudo chmod 755 /usr/bin/ngspice
- echo "Added softlink for Ngspice"
- fi
-
- else
- echo "There was some error while installing Ngspice"
- fi
-
- else
- echo "Unable to extract Ngspice tar file"
- exit 1;
- fi
- fi
-
-}
-
-
-function createConfigFile
-{
-
- #Creating config.ini file and adding configuration information
- #Check if config file is present
- if [ -d $config_dir ];then
- rm $config_dir/$config_file && touch $config_dir/$config_file
- else
- mkdir $config_dir && touch $config_dir/$config_file
- fi
-
- echo "[NGSPICE]" >> $config_dir/$config_file
- echo "NGSPICE_HOME = $HOME/$ngspice" >> $config_dir/$config_file
- echo "DIGITAL_MODEL = %(NGSPICE_HOME)s/src/xspice/icm/ghdl" >> $config_dir/$config_file
- echo "RELEASE = %(NGSPICE_HOME)s/release" >> $config_dir/$config_file
- echo "[SRC]" >> $config_dir/$config_file
- echo "SRC_HOME = $src_dir" >> $config_dir/$config_file
- echo "LICENSE = %(SRC_HOME)s/LICENSE" >> $config_dir/$config_file
-
-}
-
-
-function createSoftLink
-{
-
- ## Creating softlink
- cd /usr/local/bin
- if [[ -L nghdl ]];then
- echo "Symlink was already present"
- sudo unlink nghdl
- sudo ln -sf $src_dir/src/ngspice_ghdl.py nghdl
- else
- echo "Creating symlink"
- sudo ln -sf $src_dir/src/ngspice_ghdl.py nghdl
- if [ $? -ne 0 ];then
- echo "Failed to add NGHDL softlink"
- echo "Remove earlier installations at /usr/local/bin/nghdl and try again..."
- exit 1
- else
- #Make it executable
- sudo chmod 755 nghdl
- echo "Added softlink for NGHDL..............................."
- fi
- fi
- cd $pwd
-
-}
-
-
-#####################################################################
-# Script start from here #
-#####################################################################
-
-###Checking if file is passsed as argument to script
-
-if [ "$#" -eq 1 ];then
- option=$1
-else
- echo "USAGE : "
- echo "./install-nghdl.sh --install"
- exit 1;
-fi
-
-##Checking flags
-if [ $option == "--install" ];then
-
- #Calling functions
- installDependency
- if [ $? -ne 0 ];then
- echo -e "\n\n\nERROR: Unable to install required packages. Please check your internet connection.\n\n"
- exit 0
- fi
- installNgspice
- createConfigFile
- createSoftLink
-
-elif [ $option == "--uninstall" ];then
- echo "Removing NGHDL....................."
- sudo rm -rf $HOME/ngspice-nghdl $HOME/.nghdl /usr/share/kicad/library/eSim_Nghdl.lib /usr/local/bin/nghdl /usr/bin/ngspice
- echo "Removing libxaw7-dev..............."
- sudo apt purge -y libxaw7-dev
- echo "Removing GHDL............."
- sudo rm -rf /usr/local/bin/ghdl /usr/local/bin/ghdl1-llvm /usr/local/lib/ghdl /usr/local/lib/libghdlvpi.so /usr/local/include/vpi_user.h
- echo "Removing GNAT-5...................."
- sudo apt purge -y gnat-5
-else
- echo "Please select the proper operation."
- echo "--install"
- echo "--uninstall"
-fi
diff --git a/Debian/Ubuntu 18.04/ghdl-0.36.tar.xz b/Debian/Ubuntu 18.04/ghdl-0.36.tar.xz
deleted file mode 100644
index a4a161f..0000000
--- a/Debian/Ubuntu 18.04/ghdl-0.36.tar.xz
+++ /dev/null
Binary files differ
diff --git a/Debian/readme.md b/Debian/readme.md
index 97fe533..e655257 100644
--- a/Debian/readme.md
+++ b/Debian/readme.md
@@ -1,12 +1,12 @@
-Debian Installer Documentation
+Ubuntu Installer Documentation
====
-It contains all the documenation for installers on Debian (Ubuntu 14.04 and above).
+It contains all the documenation for installers on Ubuntu 14.04 and above.
Separate installers are required to resolve dependencies only of GHDL and are mentioned below.
-## Differences in Ubuntu 14.04, Ubuntu 16.04 and Ubuntu 18.04 installers:
+## Differences in Ubuntu 14.04, Ubuntu 16.04 and above installers:
1. Dependency on gnat :
- Ubuntu 14.04 : gnat (v4.6)
- Ubuntu 16.04 : gnat-5 (v5.4)
@@ -29,17 +29,11 @@ Separate installers are required to resolve dependencies only of GHDL and are me
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 dependency as:
+ c. First install gnat(v5) dependency as:
$ sudo apt install gnat-5
- d. Install llvm dependency and verify that version of llvm is between 3.5 and 3.9
-
- - For Ubuntu 16.04 :
-
- $ sudo apt install llvm
-
- - For Ubuntu 18.04 :
+ d. Install llvm(v3.9) dependency as:
$ sudo apt install llvm-3.9
@@ -47,28 +41,8 @@ Separate installers are required to resolve dependencies only of GHDL and are me
$ sudo apt install clang
-
f. To compile GHDL, type following commands:
- $ mkdir -p install_dir
- $ mkdir -p release
- $ cd release/
-
- - For Ubuntu 16.04 :
-
- $ ../configure --with-llvm-config --prefix=<absolute_path_to_install_dir>
-
- - For Ubuntu 18.04 :
-
- $ ../configure --with-llvm-config=/usr/bin/llvm-config-3.9 --prefix=<absolute_path_to_install_dir>
-
- $ make
- $ make install
-
- f. GHDL executables will be made in install_dir folder which can be used for distribution.
- g. Note that target machine should have the same version of gnat and OS as that of the source machine on which GHDL was compiled.
-
-
-## How to package GHDL executable with NGHDL?
-1. Rename `install_dir` directory to the `ghdl-<version>` and compress it to `.tar.xz` format.
-2. Place this compressed file along with the installer file (`install-nghdl.sh`) in the `nghdl` folder.
+ $ sudo ./configure --with-llvm-config=/usr/bin/llvm-config-3.9
+ $ sudo make
+ $ sudo make install