diff options
author | Fahim | 2016-02-03 14:34:48 +0530 |
---|---|---|
committer | Fahim | 2016-02-03 14:34:48 +0530 |
commit | 53e1c1467890592441c1612c9c6b3592e019fb97 (patch) | |
tree | 0ca307f48ba53111f52616115a2d445a07b1f112 | |
parent | 21ca9d6399d2d18162d9f8148b58990cb2580ba0 (diff) | |
download | nghdl-53e1c1467890592441c1612c9c6b3592e019fb97.tar.gz nghdl-53e1c1467890592441c1612c9c6b3592e019fb97.tar.bz2 nghdl-53e1c1467890592441c1612c9c6b3592e019fb97.zip |
Improve nghdl installation script
-rw-r--r-- | .gitignore | 1 | ||||
-rwxr-xr-x | install-nghdl.sh | 200 | ||||
-rw-r--r-- | ngspice-26.tar.gz | bin | 7037364 -> 0 bytes | |||
-rw-r--r-- | ngspice-nghdl.tar.gz | bin | 0 -> 7019178 bytes | |||
-rw-r--r-- | src/Appconfig.py | 1 | ||||
-rw-r--r-- | src/createKicadLibrary.py | 5 | ||||
-rwxr-xr-x | src/ngspice_ghdl.py | 91 |
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 Binary files differdeleted file mode 100644 index 9803580..0000000 --- a/ngspice-26.tar.gz +++ /dev/null diff --git a/ngspice-nghdl.tar.gz b/ngspice-nghdl.tar.gz Binary files differnew file mode 100644 index 0000000..4996cdc --- /dev/null +++ b/ngspice-nghdl.tar.gz 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) |