本文转自:自己的微信公众号《集成电路设计及EDA教程》

《Perl Tk在IC设计中的应用、Windows、Linux平台下的安装-各种错误的摸索解决》

Perl在IC设计中有什么用?

  Perl在IC设计中有非常广泛的应用,几乎是每个数字IC设计工程师必须掌握的一门技能。

它在Verilog自动生成,Trace RTL,抓取处理EDA工具生成的各种数据、报告,开发设计EDA工具,IC设计流程自动化,数据可视化(将各种大数据处理并以形象的图形界面展示出来)等方面都有应用,且可以非常方便的结合shell,Makefile,Tk等增强其功能。

什么是Perl?

  Perl 是 Practical Extraction and Report Language 的缩写,可翻译为 “实用报表提取语言”,是 Larry Wall 于 1987 创建的,作为一种简化其编程工作的手段。从其创建以来,Perl 已经发展成为全球使用的语言,目前是大多数管理员和开发人员的必备工具。

什么是 Perl/Tk 模块?

  Perl/Tk 模块(也称 pTk 或 ptk)是一个专门用来创建小部件或其他通用图形对象以构成图形用户界面 (GUI) 的 Perl 模块。

使用该模块可以非常方便地开发一个图形用户界面(GUI),从而让IC设计的流程在更加自动化的基础上更方便IC designer进行控制和管理。如下图所示,我们可以将IC设计的各个阶段非常方便的做成一个GUI,并且其中的变量设置也可以嵌入GUI,非常方便。

  这个内容在网易云课程《Calibre DRC教程-一键搞定DRC》中也有所介绍。

  里面很多部件(如下图所示)可以让我们将其设计的更加像一个EDA工具一样,且这个EDA工具是完全定制的,完全符合个人使用习惯,你可以为所欲为。

  我们知道在IC设计中有很多数据,但是直接看的话非常不形象,且对比也比较麻烦,但是我们可以用Perl Tk来将这些数据转换为图形,这样非常方便理解。如下图所示:

  使用 Perl/Tk 模块的一个主要优势是最终产生的应用程序可以跨平台运行,这意味着,同一 GUI 应用程序可用于 UNIX?、Linux?、Macintosh、Microsoft? Windows? 或其他任何安装了 Perl 和 Perl/Tk 模块的操作系统。

如何获得 Perl/Tk 模块

  尽管 Perl 一般会安装在计算机上,Perl/Tk 模块却并非如此。

  1. 检查是否安装了Perl

  在安装Perl Tk前,必须验证是否安装了 Perl ,在命令行中(Windows的cmd中或者Linux的Terminal中)输入 :

  perl --version

  如下图所示:

  如果没有安装,可以用yum进行安装。

  2. 检查是否安装了Perl/Tk

  在找到 Perl 或将其安装到您的计算机上之后,下一步则是确定是否需要安装 Perl/Tk 模块。检查是否安装了模块的一种简单方法是在命令提示符下键入 perl -e "use module " 。若要验证是否安装了 Perl/Tk 模块,请执行以下命令:

  perl -e "use Tk"

  如果发现有该模块,该命令将执行,并返回一个命令提示符。

  但是,如果未发现该模块,则将显示类似以下内容的错误消息:

  Can't locate Tk.pm in @INC (@INC contains: /usr/local/lib64/perl5 /usr/local/share/perl5 /usr/lib64/perl5/vendor_perl /usr/share/perl5/vendor_perl /usr/lib64/perl5 /usr/share/perl5 .) at -e line 1.

  BEGIN failed--compilation aborted at -e line 1.

  注意:Perl 是区分大小写的,此处用的是Tk,不能写成:perl –e "use tk" 。

  如果未发现该模块,下一步则是下载并安装该模块。您可以用多种方法完成此操作。

  3. 安装Perl/Tk

  3.1 Windows平台安装

  如果您使用的是 Windows,可以使用 Perl Package Manager (PPM)进行安装。在命令提示符中,输入 ppm 以启动 GUI

  查找并下载安装 Tk 模块:

  完成安装后,通过执行 perl –e “use Tk” 重新验证 Perl 是否可找到该模块。如下图所示,为安装成功。

  3.2 Unix或者Linux平台安装

  方法一:使用CPAN安装

  先输入su登录root账户。

  如果您使用的是 UNIX 或 Linux,下载和安装 Perl 模块的一种方法是使用 Comprehensive Perl Archive Network (CPAN)。在命令提示符中输入以下命令:

  perl -MCPAN -e shell

  直接回车得到:

       install Bundle::CPAN

  安装过程如下:

       reload cpan

  install Tk

  检查是否安装成功

  再次执行:

  perl -e "use Tk"

  发现可以了

  但是,这种方法在有的虚拟机上安装却不行,这样的话需要靠第二种方法:

  方法二:下载安装包进行安装

  在另外一个虚拟机上发现:

cpan[7]> install Tk

Running install for module 'Tk'

SREZIC/Tk-804.034.tar.gz

Has already been unwrapped into directory /root/.cpan/build/Tk-804.034-0

SREZIC/Tk-804.034.tar.gz

No 'Makefile' created

, not re-running

  发现不行,网上找到另一种方法:

  登录www.cpan.org搜索Tk,后下载Tk - a graphical user interface toolkit for Perl,

  进入解压缩出来的那个文件夹(Tk-804.033)执行,perl Makefile.Pl 然后make 然后make install 就完事了。perl -e "use Tk"没有任何输出。Tk包就能用了。

自己尝试了一下,发现还是不行,报错:

[root@IC Tk-804.034-0]# perl Makefile.PL

/usr/bin/perl is installed in /usr/lib64/perl5 okay

PPM for perl5.010001

Test Compiling config/perlrx.c

Test Compiling config/pmop.c

Test Compiling config/pregcomp2.c

Test Compiling config/regexp511.c

Test Compiling config/signedchar.c

Test Compiling config/Ksprintf.c

Test Compiling config/svtrv.c

Test Compiling config/copstashset.c

Test Compiling config/tod.c

Test Compiling -DTIMEOFDAY_TZ config/tod.c

TZ gettimeofday()

Using -L/usr/lib64 to find /usr/lib64/libX11.so.6.3.0

Cannot find X include files via /include

Cannot find X include files anywhere.

You probably need to install the X11 development package first.

On Debian or Ubuntu, this is the package libx11-dev.

On CentOS, RedHat, or Fedora, this is the package libX11-devel.

Please see README.linux for more information.

  之后重新运行perl Make.PL就行了

  输入make && make install就可以安装了。

  方法二中可能出现的错误:

  一个虚拟机按照方法二安装没有问题,可是同样的方法在令一个虚拟机上却不行,在make过程中总是出现下面的错误:

    1. PNG12_0 '{global:' > libpng.vers.new

    2. /bin/bash: PNG12_0:找不到命令

    3. make[1]: *** [libpng.vers] 错误 127

    4. make[1]:正在离开目录 `/work/SKIA/3rdparty/libpng-1.2.16'

    5. make: *** [all] 错误 2

    6. rm -f libpng.vers libpng.vers.new

    7. PNG12_0 '{global:' > libpng.vers.new

    8. /bin/bash: PNG12_0:找不到命令

    9. make: *** [libpng.vers] 错误 127

后来google出一个解决方案:将 Makefile中 有libpng.vers的全部注掉,这真是。。。

然后make check

make && make install没有问题

最后回到Tk安装目录下make && make install即可。没有报错:

perl -e "use Tk"也没有报错了:

自己写的gui也可以启动了:


网易云课堂视频课程

链接:https://study.163.com/course/introduction/1005909004.htm

《Calibre DRC教程-一键搞定DRC》

《Calibredrv教程-提高流程自动化》

《搭建IC设计的EDA虚拟机/服务器》

 

Perl Tk在IC设计中的应用、Windows、Linux平台下的安装-各种错误的摸索解决的更多相关文章

  1. IC 设计中DFT的Boundary Scan功能

    在很大规模的IC设计中,往往会有一些各种各样的bug出现,不论是在前期design的过程,还是在post silicon流片回来chip的flaw,都会导致chip的功能的失败,时钟频率无法达到期望频 ...

  2. 机器学习在IC设计中的应用(二)--根据GBA时序结果来预测PBA

    本文转自:自己的微信公众号<集成电路设计及EDA教程> <机器学习在IC设计中的应用(二)--根据GBA时序结果来预测PBA> AOCV AOCV全称:Advanced OCV ...

  3. 全世界最详细的图形化VMware中linux环境下oracle安装(二)【weber出品必属精品】

    <ORACLE 10.2.05版本的升级补丁安装> 首先我们解压 $ unzip p8202632_10205_LINUX.zip 解压后我们会发现多出了个文件夹,他是:Disk1,进入D ...

  4. 全世界最详细的图形化VMware中linux环境下oracle安装(一)【weber出品必属精品】

    安装流程:前期准备工作--->安装ORACLE软件--->安装升级补丁--->安装odbc创建数据库--->安装监听器--->安装EM <前期准备工作> 安装 ...

  5. [Linux]centOS7下RPM安装Perl

    1.下载rpm依赖包,依照顺序安装. perl-parent-0.225-244.el7.noarch   perl-HTTP-Tiny-0.033-3.el7.noarch   perl-podla ...

  6. 全世界最详细的图形化VMware中linux环境下oracle安装(三)【weber出品必属精品】

    数据库软件和数据库都建好了,基本上可以说完成90%的工作,但是美中不足的就是企业管理器还没有安装好,现在我们就开始安装企业管理器吧. 安装之前我们先将补丁给补上.补丁我们也是采用禁默安装.补丁:p83 ...

  7. 系统中提示未找到/usr/bin/ld: cannot find -lxxx错误的通用解决方法

    在linux环境编译应用程式或lib的source code时常常会出现如下的错误讯息: 代码如下: /usr/bin/ld: cannot find -lxxx 这些讯息会随着编译不同类型的sour ...

  8. 数字IC前后端设计中的时序收敛(五)--Max Transition违反的修复方法

    本文转自:自己的微信公众号<数字集成电路设计及EDA教程> 里面主要讲解数字IC前端.后端.DFT.低功耗设计以及验证等相关知识,并且讲解了其中用到的各种EDA工具的教程. 考虑到微信公众 ...

  9. 数字IC前后端设计中的时序收敛(四)--Max Capacitance违反的修复方法

    本文转自:自己的微信公众号<数字集成电路设计及EDA教程> 里面主要讲解数字IC前端.后端.DFT.低功耗设计以及验证等相关知识,并且讲解了其中用到的各种EDA工具的教程. 考虑到微信公众 ...

随机推荐

  1. MediatorPattern(中介者模式)-----Java/.Net

    中介者模式(Mediator Pattern)是用来降低多个对象和类之间的通信复杂性.这种模式提供了一个中介类,该类通常处理不同类之间的通信,并支持松耦合,使代码易于维护.中介者模式属于行为型模式.

  2. 「洛谷P3469」[POI2008]BLO-Blockade 解题报告

    P3469[POI2008]LO-Blockade 题意翻译 在Byteotia有n个城镇. 一些城镇之间由无向边连接. 在城镇外没有十字路口,尽管可能有桥,隧道或者高架公路(反正不考虑这些).每两个 ...

  3. NSOperationQueue队列依赖相关思考

    添加依赖后,队列中网络请求任务有依赖关系时,任务结束判定以数据返回为准还是以发起请求为准? waitUntilFinished方法容易误解. 依赖关系 // // ViewController.m / ...

  4. AcWing 243. 一个简单的整数问题2 | 树状数组

    传送门 题目描述 给定一个长度为N的数列A,以及M条指令,每条指令可能是以下两种之一: 1.“C l r d”,表示把 A[l],A[l+1],…,A[r] 都加上 d. 2.“Q l r”,表示询问 ...

  5. VScode(一):C/C++ & MinGW & Code Runner

    目录 1 VScode配置安装 2 MinGW配置安装 2.1 MinGW下载安装 2.2 MinGW环境配置 3 VScode编译C/C++ 3.1 扩展插件安装 3.2 项目配置 3.2.1 配置 ...

  6. [Micropython]TPYBoard v202 智能WIFI远控小车

    转载请注明文章来源,更多教程可自助参考docs.tpyboard.com,QQ技术交流群:157816561,公众号:MicroPython玩家汇 前言---------------------- 之 ...

  7. FJUT-1370 记录一次解题过程

    题目在福工院的1370 首先看题目,好家伙,全英文 那么大致的题意就是.有几个城市同在一条线上(相当于在x轴上),max i是第i个城市到其他所有城市的距离中的最大值,min i也就是所有中最小的. ...

  8. feign架构 原理解析

    什么是feign? 来自官网的解释:Feign makes writing java http clients easier 在使用feign之前,我们怎么发送请求? 拿okhttp举例: publi ...

  9. qiniuLive 连麦流程介绍

    本文出自APICloud官方论坛 qiniuLive 封装了七牛直播云服务平台的移动端开放 SDK.该模块包括视频流采集和视频流播放两部分 iOS连麦流程图: Android连麦流程图: 以下部分代码 ...

  10. Git将一个项目同时从本地推送到GitHub和Gitee

    前言 博主是根据自己的情况写这篇博文的,每个人遇到的情况和需求可能不一样哈,所以初始的步骤也不一定一致,但是同时推送到Github和Gitee的步骤都会是一致滴! Gitee拉取Github仓库 直接 ...