summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFahim2016-02-03 14:34:48 +0530
committerFahim2016-02-03 14:34:48 +0530
commit53e1c1467890592441c1612c9c6b3592e019fb97 (patch)
tree0ca307f48ba53111f52616115a2d445a07b1f112
parent21ca9d6399d2d18162d9f8148b58990cb2580ba0 (diff)
downloadnghdl-53e1c1467890592441c1612c9c6b3592e019fb97.tar.gz
nghdl-53e1c1467890592441c1612c9c6b3592e019fb97.tar.bz2
nghdl-53e1c1467890592441c1612c9c6b3592e019fb97.zip
Improve nghdl installation script
-rw-r--r--.gitignore1
-rwxr-xr-xinstall-nghdl.sh200
-rw-r--r--ngspice-26.tar.gzbin7037364 -> 0 bytes
-rw-r--r--ngspice-nghdl.tar.gzbin0 -> 7019178 bytes
-rw-r--r--src/Appconfig.py1
-rw-r--r--src/createKicadLibrary.py5
-rwxr-xr-xsrc/ngspice_ghdl.py91
7 files changed, 154 insertions, 144 deletions
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..0d20b64
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1 @@
+*.pyc
diff --git a/install-nghdl.sh b/install-nghdl.sh
index af73fe8..ab0a1eb 100755
--- a/install-nghdl.sh
+++ b/install-nghdl.sh
@@ -17,10 +17,10 @@
# REVISION: ---
#===============================================================================
-ngspice="ngspice-26"
-src_loc=".esim-nghdl"
+ngspice="ngspice-nghdl"
+config_dir="$HOME/.nghdl"
config_file="config.ini"
-cur_dir=`pwd`
+src_dir=`pwd`
#Will be used to take backup of any file
sysdate="$(date)"
@@ -30,9 +30,17 @@ timestamp=`echo $sysdate|awk '{print $3"_"$2"_"$6"_"$4 }'`
#All functions goes here
function addghdlPPA
{
- echo "Adding ghdl PPA to install latest ghdl version"
- sudo add-apt-repository ppa:pgavin/ghdl
- sudo apt-get update
+ ghdlppa="pgavin/ghdl"
+ #Checking if ghdl ppa is already exist
+ grep -h "^deb.*$ghdlppa*" /etc/apt/sources.list.d/* > /dev/null 2>&1
+ if [ $? -ne 0 ]
+ then
+ echo "Adding ghdl PPA to install latest ghdl version"
+ sudo add-apt-repository -y ppa:pgavin/ghdl
+ sudo apt-get update
+ else
+ echo "ghdl is available in synaptic"
+ fi
}
function installDependency
@@ -45,6 +53,93 @@ function installDependency
sudo apt-get install -y bison
}
+
+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 exist"
+ echo "Leaving ngspice installation"
+
+
+ else
+
+ #Extracting Ngspice to Home Directory
+ tar -xzvf $ngspice.tar.gz -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 "Installing Ngspice....."
+ echo "------------------------------------"
+ sleep 5
+ ../configure --enable-xspice --disable-debug --prefix=$HOME/$ngspice/install_dir/ --exec-prefix=$HOME/$ngspice/install_dir/
+ make
+ make install
+ if [ "$?" == 0 ];then
+ echo "Ngspice Installed sucessfully"
+ else
+ echo "There was some error in 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 synmlink"
+ sudo ln -sf $src_dir/src/ngspice_ghdl.py nghdl
+ fi
+ cd $pwd
+
+}
+
+#####################################################################
+# Script start from here #
+#####################################################################
echo "Enter proxy details if you are connected to internet thorugh proxy"
echo -n "Is your internet connection behind proxy? (y/n): "
@@ -80,6 +175,13 @@ if [ $getProxy == "y" -o $getProxy == "Y" ];then
#Calling functions
addghdlPPA
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 [ $getProxy == "n" -o $getProxy == "N" ];then
echo "Install without proxy"
@@ -87,11 +189,14 @@ elif [ $getProxy == "n" -o $getProxy == "N" ];then
#Calling functions
addghdlPPA
installDependency
-
if [ $? -ne 0 ];then
- echo -e "\n\n\nERROR: Unable to install required packages. Please check your internet connection.\n\n"
- exit 0
+ echo -e "\n\n\nERROR: Unable to install required packages. Please check your internet connection.\n\n"
+ exit 0
fi
+ installNgspice
+ createConfigFile
+ createSoftLink
+
else
echo "Please select the right option"
@@ -99,83 +204,6 @@ else
fi
-#Checking if ngspice-26 directory is already present in Home directory
-if [ -d $HOME/$ngspice ];then
- echo "$ngspice directory already exist taking its backup"
- mv $HOME/$ngspice $HOME/$ngspice.$timestamp
-fi
-
-
-#Extracting Ngspice to Home Directory
-tar -xzvf $ngspice.tar.gz -C $HOME
-
-if [ "$?" == 0 ];then
- echo "Ngspice extracted sucessfuly to $HOME "
- #change to ngspice-26 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 "Installing Ngspice....."
- echo "------------------------------------"
- sleep 5
- ../configure --enable-xspice --disable-debug --prefix=$HOME/$ngspice/install_dir/ --exec-prefix=$HOME/$ngspice/install_dir/
- make
- make install
- if [ "$?" == 0 ];then
- echo "Ngspice Installed sucessfully"
- else
- echo "There was some error in installing ngspice"
- fi
-
-else
- echo "Unable to extract ngspice tar file"
- exit 1;
-fi
-
-#Creating directory to put source
-if [ -d "$HOME/$src_loc" ];then
- echo "(.)esim-nghdl directory already in $HOME,removing it and copying new code"
- rm -rf ~/$src_loc
- mkdir -p ~/$src_loc
-else
- mkdir -p ~/$src_loc
-fi
-
-#Change to current directory
-cd $cur_dir
-cp -rv src/* ~/$src_loc/
-
-#Copying LICENSE file
-cp LICENSE ~/$src_loc/
-
-#Creating config.ini file and adding configuration information
-
-cd ~/$src_loc/
-touch $config_file
-
-echo "[NGSPICE]" >> $config_file
-echo "NGSPICE_HOME = $HOME/$ngspice" >> $config_file
-echo "DIGITAL_MODEL = %(NGSPICE_HOME)s/src/xspice/icm/ghdl" >> $config_file
-echo "RELEASE = %(NGSPICE_HOME)s/release" >> $config_file
-
-
-## Creating softlink
-cd /usr/local/bin
-if [[ -L nghdl ]];then
- echo "Symlink was already present"
- sudo unlink nghdl
- sudo ln -sf ~/$src_loc/ngspice_ghdl.py nghdl
-
-else
- echo "Creating synmlink"
- sudo ln -sf ~/$src_loc/ngspice_ghdl.py nghdl
-fi
-
-
diff --git a/ngspice-26.tar.gz b/ngspice-26.tar.gz
deleted file mode 100644
index 9803580..0000000
--- a/ngspice-26.tar.gz
+++ /dev/null
Binary files differ
diff --git a/ngspice-nghdl.tar.gz b/ngspice-nghdl.tar.gz
new file mode 100644
index 0000000..4996cdc
--- /dev/null
+++ b/ngspice-nghdl.tar.gz
Binary files differ
diff --git a/src/Appconfig.py b/src/Appconfig.py
index 3e31b27..f35d290 100644
--- a/src/Appconfig.py
+++ b/src/Appconfig.py
@@ -2,7 +2,6 @@ import os.path
class Appconfig:
- nghdl_src_loc = ".esim-nghdl"
xml_loc = "/opt/eSim/src/modelParamXML/"
lib_loc = os.path.expanduser('~')
esimFlag = 0
diff --git a/src/createKicadLibrary.py b/src/createKicadLibrary.py
index 19559ce..3513f5e 100644
--- a/src/createKicadLibrary.py
+++ b/src/createKicadLibrary.py
@@ -16,9 +16,12 @@ class AutoSchematic(QtGui.QWidget):
self.xml_loc = Appconfig.xml_loc
self.lib_loc = Appconfig.lib_loc
self.kicad_nghdl_lib = 'eSim_kicad.lib'
+ #Reading all varibale from config.ini
self.parser = SafeConfigParser()
- self.parser.read(os.path.join(self.home, Appconfig.nghdl_src_loc+'/config.ini'))
+ self.parser.read(os.path.join(self.home, os.path.join('.esim','config.ini')))
+ self.src_home = self.parser.get('SRC','SRC_HOME')
+
def createKicadLibrary(self):
xmlFound = None
for root, dirs, files in os.walk(self.xml_loc):
diff --git a/src/ngspice_ghdl.py b/src/ngspice_ghdl.py
index 1ec690b..0a9e88c 100755
--- a/src/ngspice_ghdl.py
+++ b/src/ngspice_ghdl.py
@@ -21,11 +21,16 @@ class Mainwindow(QtGui.QWidget):
QtGui.QMainWindow.__init__(self)
print "Initializing.........."
self.home = os.path.expanduser("~")
- licensefile = os.path.join(os.path.join(self.home, Appconfig.nghdl_src_loc), "LICENSE")
- fileopen = open(licensefile, 'r')
- print fileopen.read()
+ #Reading all varibale from config.ini
self.parser = SafeConfigParser()
- self.parser.read(os.path.join(self.home, Appconfig.nghdl_src_loc+'/config.ini'))
+ self.parser.read(os.path.join(self.home, os.path.join('.nghdl','config.ini')))
+ self.ngspice_home = self.parser.get('NGSPICE','NGSPICE_HOME')
+ self.release_dir = self.parser.get('NGSPICE','RELEASE')
+ self.src_home = self.parser.get('SRC','SRC_HOME')
+ self.licensefile = self.parser.get('SRC','LICENSE')
+ #Printing LICENCE file on terminal
+ fileopen = open(self.licensefile, 'r')
+ print fileopen.read()
self.file_list = [] #to keep the supporting files
self.initUI()
@@ -43,7 +48,6 @@ class Mainwindow(QtGui.QWidget):
self.ledit = QtGui.QLineEdit(self)
self.sedit = QtGui.QTextEdit(self)
self.process = QtCore.QProcess(self)
- #self.terminal = QtGui.QWidget(self)
self.termedit = QtGui.QTextEdit(self)
self.termedit.setReadOnly(1)
pal = QtGui.QPalette()
@@ -52,8 +56,6 @@ class Mainwindow(QtGui.QWidget):
self.termedit.setPalette(pal)
self.termedit.setStyleSheet("QTextEdit {color:white}")
- #self.process.start('xterm',['-into', str(self.terminal.winId())])
-
#Creating gridlayout
grid = QtGui.QGridLayout()
grid.setSpacing(5)
@@ -62,7 +64,6 @@ class Mainwindow(QtGui.QWidget):
grid.addWidget(self.sedit, 2, 0, 4, 1)
grid.addWidget(self.addbtn, 2, 1)
grid.addWidget(self.removebtn, 3, 1)
- #grid.addWidget(self.terminal, 6, 0,10,1)
grid.addWidget(self.termedit, 6, 0, 10, 1)
grid.addWidget(self.uploadbtn, 17, 0)
grid.addWidget(self.exitbtn,17, 1)
@@ -86,16 +87,16 @@ class Mainwindow(QtGui.QWidget):
def browseFile(self):
print "Browse button clicked"
self.filename = QtGui.QFileDialog.getOpenFileName(self, 'Open File', '.')
- print "Path file :", self.filename
self.ledit.setText(self.filename)
+ print "Vhdl file uploaded to process :", self.filename
def addFiles(self):
- print "Add Files button clicked"
+ print "Starts adding supporting files"
title = self.addbtn.text()
for file in QtGui.QFileDialog.getOpenFileNames(self, title):
- print "Supporting file :", file
self.sedit.append(str(file))
self.file_list.append(file)
+ print "Supporting Files are :",self.file_list
def removeFiles(self):
@@ -112,24 +113,23 @@ class Mainwindow(QtGui.QWidget):
self.file_list.remove(file)
if nonvhdl_count > 0:
- QtGui.QMessageBox.about(self,'Message','''<b>Important Message.</b><br/><br/>This accepts only <b>.vhdl</b> file ''')
+ QtGui.QMessageBox.about(self,'Message','''<b>Important Message.</b><br/><br/>Supporting files should be <b>.vhdl</b> file ''')
def createModelDirectory(self):
print "Create Model Directory Called"
self.digital_home=self.parser.get('NGSPICE','DIGITAL_MODEL')
- print "Digital Home",self.digital_home
os.chdir(self.digital_home)
print "Current Working Directory Changed to",os.getcwd()
self.modelname = os.path.basename(str(self.filename)).split('.')[0]
- print "Model name is :",self.modelname
+ print "Model to be created :",self.modelname
# Looking if model directory is present or not
if os.path.isdir(self.modelname):
print "Model Already present"
ret = QtGui.QMessageBox.critical(self, "Critical",'''<b>The Model already exist.Do you want to overwrite it?</b><br/>
<b>If yes press ok else cancel it and change the name of you vhdl file</b>''', QtGui.QMessageBox.Ok, QtGui.QMessageBox.Cancel)
if ret == QtGui.QMessageBox.Ok:
- print "Overwriting existing model"
+ print "Overwriting existing model "+self.modelname
cmd="rm -rf "+self.modelname
#process = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, shell=True)
subprocess.call(cmd, shell=True)
@@ -141,25 +141,25 @@ class Mainwindow(QtGui.QWidget):
else:
- print "Creating new model directory"
+ print "Creating model "+self.modelname+" directory"
os.mkdir(self.modelname)
def addingModelInModpath(self):
- print "Adding Model in Modpath file",self.modelname,self.digital_home
+ print "Adding Model "+self.modelname+" in Modpath file "+self.digital_home
#Adding name of model in the modpath file
#Check if the string is already in the file
with open(self.digital_home+"/modpath.lst",'a+') as f:
flag = 0
for line in f:
if line.strip() == self.modelname:
- print "Found model"
+ print "Found model "+self.modelname+" in the modpath.lst"
flag = 1
break
else:
pass
if flag == 0:
- print "Adding model name into modpath.lst"
+ print "Adding model name "+self.modelname+" into modpath.lst"
f.write(self.modelname+"\n")
else:
print "Model name is already into modpath.lst"
@@ -168,29 +168,31 @@ class Mainwindow(QtGui.QWidget):
def createModelFiles(self):
print "Create Model Files Called"
os.chdir(self.cur_dir)
- print "Current Working directory changed to ",self.cur_dir
- cmd = "python ~/"+Appconfig.nghdl_src_loc+"/model_generation.py "+str(self.ledit.text())
+ print "Current Working directory changed to "+self.cur_dir
+ cmd = "python "+self.src_home+"/src/model_generation.py "+str(self.ledit.text())
stdouterr = os.popen4(cmd)[1].read()
print stdouterr
#Moving file to model directory
- path=self.digital_home+"/"+self.modelname
+ path=os.path.join(self.digital_home,self.modelname)
shutil.move("cfunc.mod",path)
shutil.move("ifspec.ifs",path)
#Creating directory inside model directoy
+ print "Creating DUT directory at "+os.path.join(path,"DUTghdl")
os.mkdir(path+"/DUTghdl/")
+ print "Copying required file to DUTghdl directory"
shutil.move("connection_info.txt",path+"/DUTghdl/")
shutil.move("start_server.sh",path+"/DUTghdl/")
shutil.move("sock_pkg_create.sh",path+"/DUTghdl/")
shutil.move(self.modelname+"_tb.vhdl",path+"/DUTghdl/")
shutil.copy(str(self.filename),path+"/DUTghdl/")
- shutil.copy(os.path.join(self.home, Appconfig.nghdl_src_loc)+"/ghdlserver/compile.sh",path+"/DUTghdl/")
- shutil.copy(os.path.join(self.home, Appconfig.nghdl_src_loc)+"/ghdlserver/uthash.h",path+"/DUTghdl/")
- shutil.copy(os.path.join(self.home, Appconfig.nghdl_src_loc)+"/ghdlserver/ghdlserver.c",path+"/DUTghdl/")
- shutil.copy(os.path.join(self.home, Appconfig.nghdl_src_loc)+"/ghdlserver/ghdlserver.h",path+"/DUTghdl/")
- shutil.copy(os.path.join(self.home, Appconfig.nghdl_src_loc)+"/ghdlserver/Utility_Package.vhdl",path+"/DUTghdl/")
- shutil.copy(os.path.join(self.home, Appconfig.nghdl_src_loc)+"/ghdlserver/Vhpi_Package.vhdl",path+"/DUTghdl/")
+ shutil.copy(os.path.join(self.home, self.src_home)+"/src/ghdlserver/compile.sh",path+"/DUTghdl/")
+ shutil.copy(os.path.join(self.home, self.src_home)+"/src/ghdlserver/uthash.h",path+"/DUTghdl/")
+ shutil.copy(os.path.join(self.home, self.src_home)+"/src/ghdlserver/ghdlserver.c",path+"/DUTghdl/")
+ shutil.copy(os.path.join(self.home, self.src_home)+"/src/ghdlserver/ghdlserver.h",path+"/DUTghdl/")
+ shutil.copy(os.path.join(self.home, self.src_home)+"/src/ghdlserver/Utility_Package.vhdl",path+"/DUTghdl/")
+ shutil.copy(os.path.join(self.home, self.src_home)+"/src/ghdlserver/Vhpi_Package.vhdl",path+"/DUTghdl/")
for file in self.file_list:
shutil.copy(str(file), path+"/DUTghdl/")
@@ -211,10 +213,6 @@ class Mainwindow(QtGui.QWidget):
def readStdOutput(self):
self.termedit.append(QtCore.QString(self.process.readAllStandardOutput()))
-
-
-
-
def runMake(self):
print "run Make Called"
@@ -222,22 +220,13 @@ class Mainwindow(QtGui.QWidget):
os.chdir(self.release_home)
try:
cmd = " make"
- print "Running Make"
+ print "Running Make command in "+self.release_home
path = os.getcwd()
- #subprocess.call(cmd,shell=True)
- #command = "cd "+path +";"+cmd +";"+"make install"
- #command = "cd "+path +";"+cmd
- #self.args = ['-into', str(self.terminal.winId()),'-hold','+s','-e', command]
- #self.process.start('xterm', self.args)
-
self.process.start(cmd)
self.process.setProcessChannelMode(QtCore.QProcess.MergedChannels)
QtCore.QObject.connect(self.process, QtCore.SIGNAL("readyReadStandardOutput()"), self, QtCore.SLOT("readStdOutput()"))
-
- print "pid ------ >",self.process.pid()
+ print "make command process pid ---------- >",self.process.pid()
- #stdouterr = os.popen4(cmd)[1].read()
- #self.tedit.append(stdouterr)
except:
print "There is error in 'make' "
quit()
@@ -248,15 +237,6 @@ class Mainwindow(QtGui.QWidget):
cmd = " make install"
print "Running Make Install"
path = os.getcwd()
- print "cwd------------>", path
- #subprocess.call(cmd,shell=True)
- #command = "cd "+path+ ";"+cmd
- #self.args = ['-into', str(self.terminal.winId()),'-hold','-e', command]
- #self.process.start('xterm', self.args)
- #self.process.waitForFinished(-1)
- #stdouterr = os.popen4(cmd)[1].read()
- #self.tedit.append(stdouterr)
-
try:
self.process.close()
except:
@@ -285,10 +265,9 @@ class Mainwindow(QtGui.QWidget):
pass
try:
self.file_extension = os.path.splitext(str(self.filename))[1]
- print "File extension",self.file_extension
- print "Parser Content:",self.parser.get('NGSPICE', 'NGSPICE_HOME')
+ print "Uploaded File extension :"+self.file_extension
self.cur_dir = os.getcwd()
- print "My Current Working Directory",self.cur_dir
+ print "Current Working Directory :"+self.cur_dir
self.checkSupportFiles()
if self.file_extension == ".vhdl":
self.createModelDirectory()
@@ -361,7 +340,7 @@ class FileRemover(QtGui.QWidget):
def removeFiles(self):
for path in self.marked_list:
- print path, "is removed"
+ print path +" is removed"
self.sedit.append(path + " removed")
self.files.remove(path)