上个月刚完成Ubuntu虚拟机的安装,本教程的基础是你已经安装好了Ubuntu的虚拟机,最好是和笔者版本接近的Ubuntu,具体安装方法已在之前的文章中介绍过了:
一、安装前准备
VCS安装文件可以去官方下载,也可以在本教程下面留下邮箱,看到私信发给你们。总共有四样东西:scl、synopsys installer、vcs、verdi,如下图所示:
scl:license在线安装工具,最后通过该工具注册license。
sysynopsys installer:synopsys软件安装工具,通过该软件安装VCS和Verdi。
vcs_mx_vO-2018.09-SP2:VCS Verilog+VHDL 混合仿真软件。
vcs_vO-2018.09-SP2:VCS Verilog仿真软件。
verdi-2018.9:Verdi软件。
另外,还需要license生成工具,涉及方法较为敏感,可留言私信我获取。需要说明的是:1.scl_keygen工具只能用于科学研究。2.win10系统打开报错,win7系统可以正常打开。3.一切后果自负。4.涉及知识产权,建议使用synopsys试用版license,或者购买正版license,支持正版。
如果你是个人兴趣爱好,那么可以留言私信我获取。
二、安装VCS、Verdi、scl软件
首先运行synopsysinstaller_v5.0目录下的./SynopsysInstaller_v5.0.run文件,安装installer,安装路径可以随便选择。安装好以后进入安装路径,建立以下文件夹:
其中,installer为刚才安装的路径,进入/installer/文件夹,运行./setup.sh,会调出安装界面,需要注意的是,第一次会让你选择安装包所在的位置,第二次选择安装的地点,这里笔者的安装地点为上面路径提前准备好的文件夹,其他一路next结束。安装过程自动进行,直到安装结束。
** 三、环境变量和端口设置**
环境变量可参考下面路径设置,只需要修改SynopsysList路径即可,提前设置好环境变量,后面会用到。 最后一行是license路径,后面生成好license后将Synopsys.dat放到该路径下,必须保持一致,否则注册失败。
#synopsys tools list
export SynopsysList=/home/alanwu/Documents/EDA/synopsys
export DVE_HOME=$SynopsysList/vcs/vcs-mx/O-2018.09-SP2/gui/dve
export VCS_HOME=$SynopsysList/vcs/vcs/O-2018.09-SP2
export VCS_MX_HOME=$SynopsysList/vcs/vcs-mx/O-2018.09-SP2
export LD_LIBRARY_PATH=$SynopsysList/verdi/verdi/Verdi_O-2018.09-SP2/share/PLI/VCS/LINUX64
export VERDI_HOME=$SynopsysList/verdi/verdi/Verdi_O-2018.09-SP2
export SCL_HOME=$SynopsysList/scl/scl/2018.06
#dve
export PATH=$PATH:$VCS_HOME/gui/dve/bin
alias dve="dve"
#VCS
export PATH=$PATH:$VCS_HOME/bin
alias vcs="vcs"
#VERDI
export PATH=$PATH:$VERDI_HOME/bin
alias verdi="verdi"
#scl
export PATH=$PATH:$SynopsysList/scl/scl/2018.06/linux64/bin
export VCS_ARCH_OVERRIDE=linux
#LICENCE
export LM_LICENSE_FILE=27000@alanwu
alias lmg_synopsys="lmgrd -c $SynopsysList/scl/scl/2018.06/admin/license/Synopsys.dat"
license端口号设置为27000,一般都是这个端口号不需要修改,使用hostname查询hostid名称,将其填在LM_LICENSE_FILE后面。建议license路径也按照图中的路径放置,放在scl安装好的软件文件夹路径下。
环境变量设置好后,需要对开放设置的2700端口号,使用下面语句开放端口号。firewall没有安装的,需要apt安装。
firewall-cmd --zone=public --add-port=27000/tcp --permanent
firewall-cmd --reload
有些虚拟机中的应用程序可能会占用27000端口号,因此可以使用下面的语句对2700端口号的应用程序进行管理:
#允许27000端口号运行
sudo ufw allow 27000
sudo ufw enable
sudo ufw reload
sudo ufw status
#查询27000端口号进行并kill占用进程
netstat -ap | grep 27000
kill -9 XXX(看到的占用端口的ID号)
一般来说虚拟机并没有进程占用该端口,所以kill不kill就无所谓了。
四、license生成和激活
生成之前在虚拟机上查询hostid和安装MAC地址,这里需要记住ether后面的6个8bit数值。
hostname
ifconfig
打开scl_keygen.exe工具,这里的话特别需要注意win10对于这些破解工具的拦截,为此笔者特地为了生成license又安装了一个win7的虚拟机。。。
将查询到的hostname和MAC号填在上图指示的位置,HOST ID Daemon和HOST ID Feature填相同的内容,生成的license日期也需要修改下,修改到你需要的日期。
填完以后点Generate,会在目录下生成最新的Synopsys.dat文件,同时界面也会给出生成的文件代码。
打开生成的Synopsys.dat文件,修改第二行路径,将该路径指到scl安装的对应snpslmd路径下:
保存后退出,将该文件复制到共享文件夹下,同时共享到Ubuntu下面。这里需要注意的是,不要复制界面上的,虽然文件内容一致,但是copy到Ubuntu下面有编码格式不一致的问题。如果在Ubuntu下面打开Synopsys.dat不显示乱码,则表示两者编码格式一致。
上述完成后,切换到Ubuntu下,运行lmg_synopsys命令激活,激活为自动过程,但是由于虚拟机的特性,需要每次启动虚拟机后注册激活一遍,最终显示激活完成。
lmg_synopsys
注意:激活完成后,verdi、vcs即可正常使用,但是可能会缺失一些.so库文件,根据提示apt安装即可。
版权归原作者 远古架构师alanwu 所有, 如有侵权,请联系我们删除。