【数字IC验证快速入门】4、熟悉数字IC验证中常用的Linux基本操作
导读:作者有幸在中国电子信息领域的排头兵院校“电子科技大学”攻读研究生期间,接触到前沿的数字IC验证知识,旁听到诸如华为海思、清华紫光、联发科技等业界顶尖集成电路相关企业面授课程,对数字IC验证有了一些知识积累和学习心得。为帮助想入门前端IC验证的朋友,思忱一二后,特开此专栏,以期花最短的时间,走最少的弯路,学最多的IC验证技术知识。
文章目录
一、Linux基础
1.1、Linux的特点
1.1.1、多任务系统
- 在Linux系统汇总可以同时执行多个任务
1.1.2、多用户系统
- 对多用户的支持使得多个用户能在同一时间登陆和使用系统,多个终端和键盘可以同时与同一台计算机建立连接。
- 一个用户能够在不同终端多次登陆同一个系统
- 无论从开发小组还是某个使用者角度看,都有一个很大优越性:一个工作组的成员能同时访问同一些数据。
1.2、Shell简介
shell脚本能提高用户操作和管理员进行系统管理的效率,一般操作步骤:
- 1、编辑器编写脚本程序
- 2、shell做解释程序,非交互地执行脚本,两种执行方式:
- 用shell命令执行脚本文件:
source xxx - 给脚本文件添加执行权限,用
./ xxx执行命令
- 用shell命令执行脚本文件:
1.3、Shell命令示例
whoami:查看用户自己当前使用的账户名who:查看当前有哪些用户登录到系统中w:查看有哪些用户登录在线,同时显示用户当前的工作clear:清屏命令。
1.4、Linux树型目录结构
- Linux系统以文件目录的方式来组织和管理系统中的所有文件。
- 所谓文件目录就是将所有文件的说明信息采用树型结构组织起来,即常说的目录。
- 系统建立每一个目录时,都会自动设定两个目录文件:
.- 当前目录;..- 父目录
1.4.1、根目录
- Linux文件系统的树型层次以根目录
/为起点,所有其他的目录都由根目录派生二来用户可以浏览整个系统,可以进入任何一个已授权进入的目录,访问哪里的文件。 - 根目录(系统目录)是Linux系统中的特殊目录。Linux是一个多用户系统,操作系统本身的驻留程序存放在以根目录开始的专用目录中。
1.5、Linux文件系统
1.5.1、绝对路径
- 又称全路径名,指以根目录打头的路径名。绝对路径名确定文件位置和工作目录无关。
1.5.2、相对路径
- 由这个文件所在的路径引起的跟其它文件(或文件夹)的路径关系。
- 显示当前目录:
pwd(Present Work Directory) - 复制当前目录下的代码到用户目录:
cp -rf ./asic_flow ~ - 进入当前工作目录:
cd [目录名](Change Directory)cd ~: 返回home目录cd ..: 返回上一级目录
1.6、常用基本命令
1.6.1、创建目录
mkdir <-m模式> [目录](Make Directory)- 选项
<-m模式>:建立目录时,设置目录的权限。(-m用的比较少) - 尖括号里的是可选的,方括号是必须有的!
- eg:
mkdir tmp
- eg:
- 需要帮助
mkdir --help
- 选项
1.6.2、链接文件
ln <选项> [目标] [链接名](Link )ln <选项> [目标] [目录]- 作用:给系统中已有的某个文件制定另一个可用于访问它的名称
- 软链接:
ln -s source des - 通过将文件夹1和2关联,那么访问文件夹1就可以知道文件夹2里面的东西,链接的文件夹是不占内存空间的,能看到,但是不能更改我的东西。
1.6.3、文件显示(初级)
ls <选项> [文件目录列表]:(List)- 选项:
-a(all),-l(long),-t(time),-s(size),-R(Recursive)(注意该选项是大写),--version,--help-a所有文件,-l显示文件格式,-t和-s用的少,-R展开子级目录
- eg:
ls --help | more:分屏显示|:表示管道符,在一个命令行同时执行左右两个命令。more:分屏显示- 按空格可以显示下一页
- eg:
ls -rta /etc:递归显示目录/etc下所有的文件及目录,并按文件的最新修改时间排序显示。 - 常用的命令是:
ls -al,简写命令为:ll
1.6.4、- rw- r-- r--释义
- 第一位:文件类型,每一类用一个字符来表示:
-:常规文件d:目录文件l:链接文件p:管道设备文件b:块特殊设备文件c:字符特殊设备文件
- 其余9位:文件权限由三个字符串组成:文件所有者(
u,user)的权限、组中其他人(g,group)的权限、系统中其他人(o,other)的权限。- 每个字符串又由三个字符组成,依次表示对文件读(
r),写(w)、执行(x)权限
- 每个字符串又由三个字符组成,依次表示对文件读(
1.6.5、改变文件/目录权限
chmod <选项> [文件和目录列表]
- 1
- 1)使用字符串设置权限
chmod ugo+r xxx等价于chmod a+r xxx(+表示增加属性,a代表all)chmod ug+w,o-w xxx yyychmod -R a+r *
- 2)使用八进制设置权限
- 三个八进制数字分别表示
u/g/o的权限 - 读
r(4)、写w(2)、执行x(1) - eg:
chmod 777 xxx等价于chmod a+rwx xxx - eg:
chmod 772 xxx等价于chmod ug+rwx,o+w xxx
- 三个八进制数字分别表示
1.6.6、文件显示(高级)
more <选项> [文件]
- 1
- 显示问价那内容,每次显示一屏文本。退出按
Q。 - 选项:
-num:指定一个整数,表示一屏显示多少行+num:从行号num开始显示-c:不滚屏,在显示下一屏之前先清屏
- eg:
more xxx
less <选项> [文件]
- 1
- 分屏显示文件的内容,按
PageUp,PageDown翻页,退出按Q。More只能通过空格向下翻页! - eg:
less xxx
head <选项> [文件]
- 1
- 显示指定文件的开头若干行,显示行数的默认值为10。
- eg:
head xxx - 选项:
-n:显示前面n行,eg:head -5 xxx-q:不显示文件的标题,eg:head -q xxx-v:时钟显示文件的标题,eg:head -v xxx-c n:显示前面的n个字节,eg:head -c 10 xxx
tail <选项> [文件]
- 1
- 显示指定文件的结尾若干行,显示行数的默认值为10。
cat <选项> [文件]
- 1
- 链接文件并打印(显示)到标注输出设备(屏幕)上
ctrl+s:停止滚屏ctrl+q:恢复滚屏ctrl+c:中断命令
| 选项 | 说明 |
|---|---|
-b |
计算所有非空输出行,开始为1 |
-e |
在每行末尾显示$符号 |
-n |
计算所有输出行,开始为1 |
-s |
将相连的多个空行用单一空行代替 |
1.6.7、文件(目录)复制
cp <选项> [源文件 ] [目标文件]
cp <选项> [源文件目录] [目标目录]
- 1
- 2
| 选项 | 说明 |
|---|---|
-i |
提示是否覆盖已存在的目标文件(默认有) |
-p |
保持原先文件的所有者,组权限和时间标志(默认有) |
-f |
强制覆盖,不加提示 |
-r |
递归拷贝目录,将所有非目录文件当普通文件拷贝 |
-v |
详细,显示文件的复制速度 |
-a |
拷贝文件夹 |
1.6.8、快速复制粘贴(重要,可提高工作效率)
- 鼠标左键拖曳选择需要复制的内容
- 鼠标中键进行粘贴
1.6.9、创建文件
touch [文件名]
- 1
- eg:
touch new.txt
1.6.10、删除文件
rm <选项> [文件列表]
- 1
| 选项 | 说明 |
|---|---|
-r |
递归将目录以下文件逐层删除 |
-i |
删除前询问确认 |
-f |
指定强行删除无需确认,即使原文件属性设为只读 |
-v |
详细显示文件的删除速度 |
1.6.11、移动文件
mv <-f | -i> [文件1] [文件2]
mv <-f | -i> [目录1] [目录2]
mv <-f | -i> [文件列表] [目录]
- 1
- 2
- 3
| 选项 | 说明 |
|---|---|
-f |
若目标文件已存在,不提示直接覆盖已有文件 |
-i |
若目标文件有同名,则先询问是否覆盖已有文件 |
-v |
详细显示文件的移动速度 |
1.6.12、文件内容统计
wc <选项> 文件列表
- 1
- 统计指定文件中的字节数、字数、行数。
| 选项 | 说明 |
|---|---|
-c |
统计字节数 |
-l |
统计行数 |
-w |
统计字数 |
1.6.13、查找文件
find 目录 -name 文件名
- 1
- eg:
find ./ -name error:在当前目录下查找名为error的文件。 - eg:
find ./ -name "*.v":在当前目录下查找所有的.v文件 - eg:
find ./ -name *test*:在当前目录下查找名字中间有test字样的文件
1.6.14、查找文件内容
grep <选项> [匹配字符串] [文件列表]
- 1
- eg:
grep error *:所有文件内容中含有error字样的文件 - eg:
grep error * -r:-r表示递归查找 - eg:
grep error * -i:-i表示不区分大小写(ignore) - eg:
grep "err*" *:*表示通配符(通配符只能在后面加!)
grep只能查找固定的字符,egrep = grep -e (extend)可以查找正则表达式
查找文件里面的内容 -r会对当前目录下的文件夹里面的内容进行查找,查找的时间也稍微长一点,不加只会查找当前目录下的文件,也可以使用通配符,还可以指定文件,但是就不用加通配符*了。
1.6.15、排序
sort <选项> [文件列表]
- 1
- 默认按照第一个数字大小进行排列
-n就是按照数字大小的方式排列
1.6.16、比较文件内容
diff <参数> [源文件1] [目标文件2]
- 1
| 选项 | 说明 |
|---|---|
-b |
忽略空格造成的不同 |
-q |
只报告什么地方不同,不报告具体的不同信息 |
-i |
忽略大小写的变化 |
-r |
在比较目录时比较所有子目录 |
-s |
两个文件相同时才报告 |
-v |
在标准输出上输出版本信息并退出 |
-y |
结果并列放置 |
- eg:
diff file1 file2 -y - eg:
diff -r dir1 dir2 -y
注:用
gvimdiff更方便!
1.6.17、重定向
重定向:将文件的标准输出重新定向输出到文件,或将数据文件作为另一程序的标准输入内容。
- 1)输出重定向(重要)
ls -l > file.txt:将内容输出到新文件file.txt中ls -l >> file.txt:将内容输出到已有文件后面
- 2)输入重定向
grep keyword < file.txt直接从file.txt里面找keyword,等价于grep keyword file.txt。用的比较少,输出用的多。
1.6.18、管道
管道符|,通常放在两个命令之间,将前一个命令的输出作为下一个命令的输入。
Linux通常是一个命令,但是想在原来的基础上在运行一个,就需要管道符。管道符核心:上一个命令的结果就是下一个命令的输入。
- eg:
cat sample.txt | grep "High" | wc -l:显示sample.txt这个文件,显示内容中搜索High,最后再统计一下High行有多少!
1.6.19、文件/文件夹打包、压缩和解压缩
tar文件打包:tar <主选项> <辅选项> [存档文件名] [文件或目录列表]
-
常用选项:
c(create,打包)/z(使用gzip压缩)/v(verbose,详细的)/f(file,文件夹)/x(extract,解包)/j(使用bzip2压缩) -
1)将
/home目录下所有文件和目录存档,存档名为archive.tar:tar -cvf archive.tar /home -
2)解包存档文件
archive.tar:tar -xvf archive.tar -
3)不解包存档文件
archive.tar,只查看内容:tar -tvf archive.tar -
4)将
/home目录下所有文件和目录存档,并对存档文件压缩,压缩后文件名archive.tar.gz:tar -czvf archive.tar.gz /home -
5)解包以及解压缩
archive.tar.gz:tar -xzvf archive.tar.gz
1.6.20、关闭应用程序
kill <选项> [应用程序PID]
- 1
| 选项 | 说明 |
|---|---|
-15 |
通知应用程序关闭(不加选项也是默认-15) |
-9 |
强制关闭应用程序 |
1.7、常用系统命令
1.7.1、命令别名(快捷键)
- 为了提高效率,给复杂操作起别名。(注意,等号前后不能有空格)
- eg:
alias ll='ls -al' - eg:
alias sc='source ~/.bashrc'
- eg:
- 使用
alias -p查看现有别名设置
1.7.2、查看进程
- 查看自己使用的进程:
ps -u - 查看大家使用的进程:
ps -ef - 查看实时进程:
top(使用这个较多)- 实时进程
top比较占资源,及时q退出
- 实时进程
1.7.3、查看控件占用
- 查看自己空间占用:
du -sh(disk usage) - 查看自己各目录的占用情况:
du -h、du -h --max-depth=1(当前目录下的第一级目录)
1.7.4、联机帮助
- 1)显示命令的使用方法
man <选项> [命令名]
- 2)help命令:查看所有Shell命令的用法
- eg:查看cd命令的使用方法:
cd --help
- eg:查看cd命令的使用方法:
- 3)whereis命令:寻找一个命令所在的位置
whereis <选项> [命令名]
- 4)which命令:输出命令的全路径到屏幕上 (更常用)
1.7.5、一些高级用法
- 1)
history可查看先前的指令 - 2)
向上方向键可用来执行最近的指令 - 3)
;来间隔几个指令,可以让指令顺序执行(管道符号异曲同工) - 4)
tab键可以直接补齐系统中有的指令 - 5)利用
管道符可以实现多个指令的组合使用:ps -ef | grep vsim
- 6)
ctrl+z:挂起 - 7)
fg:恢复 - 8)
ctrl+c:终止
参考
文章来源: recclay.blog.csdn.net,作者:ReCclay,版权归原作者所有,如需转载,请联系作者。
原文链接:recclay.blog.csdn.net/article/details/117832490
- 点赞
- 收藏
- 关注作者
评论(0)