当前位置: 首页 > news >正文

做淘宝客网站用什么程序好南宁网络推广品牌

做淘宝客网站用什么程序好,南宁网络推广品牌,网站注册建设,app在线生成器1 makefile在IC设计中的地位 关于makefile的详细介绍可以参考第一个连接,里面的内容很多也很详细。但在数字IC设计中,并不会把所有的用法都用到,下面记录一下主要用到的规则。 2 IC设计涉及到的主要用法 2.1 变量的定义和使用 在makefile…

1 makefile在IC设计中的地位

关于makefile的详细介绍可以参考第一个连接,里面的内容很多也很详细。但在数字IC设计中,并不会把所有的用法都用到,下面记录一下主要用到的规则。

2 IC设计涉及到的主要用法

2.1 变量的定义和使用

在makefile的使用过程中,存在变量的定义和使用。首先,关于变量的定义包括了环境变量的定义和普通变量的定义,也包括了从makefile执行命令行输入的变量。变量的定义方式有几种下面只给出其中一种。

一般来说makefile在执行过程中会自动加载环境变量,如果在某些情况下不能自动加载识别,可以通过变量定义的方式实现。

在makefile文件中定义普通变量

variable = xxxxx

test_case = case_name

如果makefile的命令行输入了variable的值,则会用命令行的值代替makefile文件中定义的值。比如:

make sim test_case=case_name_0

注:上一句中的sim是makefile中的一个target,表示之行makefile中的sim目标,其中test_case为case_name_0

这里就用case_name_0代替了makefile文件中预先定义的case_name。

变量的引用格式如下:

$(test_case)

变量也可以传递,比如

variable1 = henghenghaha

variable2 = tuntuntutu

variable3 = $(variable1)_$(variable_2)

variable3展开后则是henghenghaha_tuntuntutu

变量还可以追加,比如发现variable1少了个后缀,

则可以使用如下方法追加:

variable1+=后缀

当然变量追加一般用不到,如果真少了什么可以直接在该变量定义处修改。

2.2 目标定义

标准的makefile语法格式如下,包含了目标target,依赖文件filename,和相应的命令行语句(用table键开头)

target:filename

        命令行1

        命令行2

如果没有依赖文件,则称为伪目标。而在IC设计的flow中用得最多的是伪目标,比如,编译-compile,仿真-sim,打开波形-verdi,清除生成的文件-clean。

注:伪目标不能和任何一个相关文件同名,如果同名,则需在makefile的前面显式声明伪目标名,如下:

.PHONY : clean

2.3 命令行的定义

命令行是指在该目标下要执行的操作,每一行代表一组相关命令。每两行之间的命令没有关系,即该命令依赖于前面命令的执行结果,则需要将它们放在同一行中,并用分号隔开。

如果要在target中先进到subdir目录下,新建一个new_file的文件,则应该如下写

target:cd /subdir; mkdir new_file

如果写成如下这样,则表示先进到subdir目录,然后在makefile当前目录新建一个new_file的文件。

target:cd /subdirmkdir new_file

2.4 通配符的使用

常用到的通配符有*,*代表任意符号。

*.v指所有的.v文件

2.5 makefile的错误处理

makefile是按照顺序一行一行的执行的,如果其中某条指令的结果出现错误则会导致后续指令的之行。但可以通过设置忽略出现的错误,继续往下之行,方法有两种:

局部方法,在出错的命令前加减号-,用于忽略该条指令的错误结果,不影响后续的指令执行,如:

clean :-rm -rf *.o

 全局的方法,定义相关参数,用-i或者--ignore--errors或者-k或者--keep--going

2.6 显式打印信息

@echo $(test_case)

则会打印出具体的test_case的名字 

2.7 条件语句的使用

在满足A条件时之行A组命令,在满足B条件时执行B组命令时需要用到条件语句,这里的条件格式如下:

ifeq($(variable_a),A)
xxxxx
endif或者ifeq($(varialbe_a),A)
xxxxx
else
xxxxx
endif

当然ifeq和ifneq的用法一样,前者是条件等于时执行,后者是条件不等时之行。$(varialbe_a)是变量,A是目标值或者参考值。 

2.8 举例

1 vcs_options = -V -Mupdate -full64 -debug_pp -sverilog +v2k +notimingcheck +no_tchk_msg \
2               -p $(VERDI_HOME)/share/PLI/VCS/linux64/verdi_tab \
3               $(VERDI_HOME)/share/PLI/VCS/linux64/pli.a \
4               +vcs_v2k+pathpulse+delay_mode_path+fsdb+sva_success \
5               +vcs+initreg+config \
6               -cm line+cond+tgl+fsm+branch -cm_dir ../../cov/$(TC).vdb -cm_hier ../cov_config.f \
7               +error+1000\
8               +nospecify \
9               +lint=TFIPC-L \
10              -assert report=../../log/$(tc_name)_assert.report+verbose \
11              +define+vcs+sdfverbose+ASIC+FSDB+BT_EMPTY+$(DF)+$(TARGET)+$(TC)+RD=0.1 \
12              -Marchive=128+noinline-transport-pathpulse -timescale=1ns/1ps -notice 
13
14 find_testcase:15 matlab:
16    matlab xxxxxxxxx 
17
18 compile:
19    vcs $(VCS_OPTIONs) \
20    +incdir+../../tb/reg_model/ \
21    -f ../../tb/reg_model/reg_model.f \
22    -y ../../tb/reg_model/ +libext+.v \
23    -f ../../filelist/design.f \
24    ./$(tc_name).sv \
25    -f ../../filelist/tb.f \
26    -top $(TB_SIM_TOP) \
27    -l ../../log/$(tc_name)_vcs_compile.log \
28    ./simv +ntb_random_seed=$(seed) +no_pulse_msg +fsdb+force+region +fsdb+sva_success 29    -cm line+cond+tgl+fsm+branch \
30    -l ../../log/$(tc_name)_vcs_sim.log; \
31    mv -f ./*.fsdb /fsdb/ \
32    perl log_check.pl -TC $(tc_name)
33
34
35 verdi:
36    @echo $(tc_name)
37    @test -d $(tc_name) || mkdir -p ./$(tc_name)
38    @echo "verdi -sv -logdir . +systemverdilogext+.sv+define+ASIC+$(DF)+$(TARGET)+$(TC)+RD=0.1 \\"    >vdrun
39    @echo "+incdir+../../tb/reg_model/ "\
40    @echo "-f ../../tb/reg_model/reg_mode.f" \
41    @echo "-y ../../tb/reg_model/ +llibext+.v" \
42    @echo "-f ../../filelist/design.f \\" >>vdrun
43    @echo "./$(tc_name).sv \\"   >>vdrun
44    @echo "-f ../../filelist/tb.f \\"   >>vdrun
45    @echo "-ssf /fsdb/*.fsdb \\"   >>vdrun
46    @echo "-top $(TB_SIM_TOP)" "&" >>vdrun
47    mv vdrun ./$(tc_name); cd/$(tc_name); source ./vdrun; cd ../

 例子是功能仿真makefile的部分内容,里面涉及到了变量的定义和使用,目标的建立,命令的执行等内容。

3 相关链接:

Makefile教程(绝对经典,所有问题看这一篇足够了)-CSDN博客

Makefile入门(介绍、规则、语法、函数、实例)_mak file 单冒号-CSDN博客

 最近在思考flow的东西,所以再次梳理整理了一下makefile的内容,笔记先记到这里,这是一个工具,还是要多用才会熟能生巧。后续有修改或补充再增删文件内容……

http://www.shuangfujiaoyu.com/news/60148.html

相关文章:

  • 做网站要服务器和什么软件温州seo外包公司
  • 网站会员系统方案优化搜索引擎
  • 如何在门户网站做推广方案免费个人网站建设
  • 建设银行社保网站网络营销的模式有哪些
  • 无锡企业网站设计免费推广平台
  • 网站建设方式优化方案官网电子版
  • 淘乐惠网站怎么做百度怎样发布作品
  • 网站建设找哪家公司好关键词排名点击软件首页
  • 怎么免费建公司网站seo主要做哪些工作
  • 综合门户网站源码免费发帖的平台有哪些
  • 电商网购系统成都网站seo服务
  • 1 设计一个企业网站安全优化大师
  • 建网站公司下载快手seo服务商技术好的公司
  • 西安专业网站建设百度网盘网址
  • 3.15网站建设在线超级外链工具
  • 怎么把自己做的网站放到网上搜索引擎营销的方式
  • 网站备案完了怎么做搜索引擎营销有哪些方式
  • linux网站服务器搭建职业培训机构哪家最好
  • 大足建网站的怎样做关键词排名优化
  • 有没有专门做淘宝客的网站百度企业网盘
  • 设计网站页面出现问题企业培训考试app
  • 手机免费在线搭建网站建立一个企业网站需要多少钱
  • 乐山市建设局网站网站建设的重要性
  • 全国电商排名前20名关键词长尾词优化
  • 网站建设流程图百度销售推广
  • 湖南大型网站建设常用的网络营销方法有哪些
  • 怎么做社交网站今日的重大新闻
  • 苹果手机网站建设软件推广软文范例100字
  • 购物网站建设 属于信息系统管理与设计么自己的产品怎么推广
  • 万网 wordpress smtp在线seo工具