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

makefile在IC设计中的使用笔记

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的内容,笔记先记到这里,这是一个工具,还是要多用才会熟能生巧。后续有修改或补充再增删文件内容……

相关文章:

makefile在IC设计中的使用笔记

1 makefile在IC设计中的地位 关于makefile的详细介绍可以参考第一个连接,里面的内容很多也很详细。但在数字IC设计中,并不会把所有的用法都用到,下面记录一下主要用到的规则。 2 IC设计涉及到的主要用法 2.1 变量的定义和使用 在makefile…...

Suno声称在受版权保护的音乐上训练模型属于“合理使用“

继美国唱片业协会(RIAA) 最近对音乐生成初创公司 Udio 和 Suno 提起诉讼之后,Suno 在周四提交的一份法庭文件中承认,该公司确实使用了受版权保护的歌曲来训练其人工智能模型。但它声称,根据合理使用原则,这…...

Java | Leetcode Java题解之第316题去除重复字母

题目&#xff1a; 题解&#xff1a; class Solution {public String removeDuplicateLetters(String s) {boolean[] vis new boolean[26];int[] num new int[26];for (int i 0; i < s.length(); i) {num[s.charAt(i) - a];}StringBuffer sb new StringBuffer();for (in…...

Taro学习记录

一、安装taro-cli 二、项目文件 三、项目搭建 1、Eslint配置 在项目生成的 .eslintrc 中进行配置 {"extends": ["taro/react"], //一个配置文件&#xff0c;可以被基础配置中的已启用的规则继承"parser": "babel/eslint-parser…...

Spring Cache框架详解

Spring Cache框架详解 Spring Cache是Spring框架提供的一个强大的缓存抽象层&#xff0c;旨在简化缓存技术的集成和使用。自Spring 3.1版本开始&#xff0c;Spring Cache就被引入以支持在Spring应用程序中添加缓存功能。随着Spring版本的迭代&#xff0c;Spring Cache的功能日…...

解决Html iframe 内嵌video标签导致视频无法全屏展示的问题

原因&#xff1a; 由于浏览器的安全策略所限制的。为了防止恶意网站利用全屏播放功能进行滥用或欺骗用户&#xff0c;浏览器对iframe中的视频播放做了限制。 在iframe标签中播放视频时&#xff0c;浏览器会根据安全策略阻止视频全屏播放。这是因为iframe标签中的内容被认为是第…...

谷粒商城实战笔记-110~114-全文检索-ElasticSearch-查询

文章目录 一&#xff0c;110-全文检索-ElasticSearch-进阶-两种查询方式二&#xff0c;111-全文检索-ElasticSearch-进阶-QueryDSL基本使用&match_all三&#xff0c;112-全文检索-ElasticSearch-进阶-match全文检索四&#xff0c;113-全文检索-ElasticSearch-进阶-match_ph…...

【开源】嵌入式Linux(IMX6U)应用层综合项目(1)--云平台调试APP

目录 1.简介 1.1功能介绍 1.2技术栈介绍 1.3演示视频 1.4硬件介绍 2.软件设计 2.1连接阿里云 2.2云平台调试UI 2.3Ui_main.c界面切换处理文件 2.4.main函数 3.结尾&#xff08;附网盘链接&#xff09; 1.简介 此文章并不是教程&#xff0c;只能当作笔者的学习分享&…...

AI人工智能分析王楚钦球拍被踩事件的真相

在2024年巴黎奥运会乒乓球混双决赛的热烈氛围中&#xff0c;中国队王楚钦与孙颖莎以出色的表现夺得金牌&#xff0c;然而&#xff0c;赛后发生的一起意外事件——王楚钦的球拍被踩坏&#xff0c;引起了广泛关注和热议。为了探寻这一事件的真相&#xff0c;我们可以借助AI人工智…...

C++客户端Qt开发——多线程编程(一)

多线程编程&#xff08;一&#xff09; ①QThread 在Qt中&#xff0c;多线程的处理一般是通过QThread类来实现。 QThread代表一个在应用程序中可以独立控制的线程&#xff0c;也可以和进程中的其他线程共享数据。 QThread对象管理程序中的一个控制线程。 run() 线程的入口…...

安装pnpm

安装pnpm&#xff08;Performant npm&#xff09;&#xff0c;即高性能的npm包管理工具&#xff0c;可以通过多种方式进行。以下是详细的安装步骤&#xff1a; 一、通过npm全局安装 打开命令行工具&#xff1a;在你的计算机上打开命令行工具&#xff0c;例如Windows的CMD、Pow…...

CSS平移实现双开门效果

CSS平移实现双开门效果 一共要三张图片&#xff0c;一张作为父级背景&#xff0c;两张为兄弟左右布局 父子结构布局 一张作为父级背景&#xff0c;两张为兄弟左右布局。之后添加鼠标悬停效果&#xff0c;两张子图分别从左右平移 [外链图片转存失败,源站可能有防盗链机制,建议…...

3096. 得到更多分数的最少关卡数目

3096. 得到更多分数的最少关卡数目 题目链接&#xff1a;3096. 得到更多分数的最少关卡数目 代码如下&#xff1a; class Solution { public:int minimumLevels(vector<int>& possible) {int s0;//两个玩家能得到的分数和for(int x:possible){sx0?-1:1;}int t0;/…...

AGI思考探究的意义、价值与乐趣Ⅳ

探究in context或Prompt对于LLM来说其根本意义&#xff0c;in context & Prompt Learning带给我们更深一层的提示是什么&#xff1f; 文章里的探索希望能够将in context或Prompt置身于一个更全局的视角来看待&#xff1a;将其视为在真实世界中时空认知流形所映射为数据流形…...

《数据结构》(C语言版)第1章 绪论(上)

第1章 绪论 1.1 数据结构的研究内容1.2 基本概念和术语 1.1 数据结构的研究内容 N.沃思&#xff08;Niklaus Wirth)教授提出&#xff1a; 程序算法数据结构 电子计算机的主要用途 早期&#xff1a;主要用于数值计算 后来&#xff1a;非数值计算&#xff0c;复杂的具有一定结构…...

【Pyhton】数据类型之详讲字符串(上)

本篇文章将详细讲解字符串&#xff1a; 1、定义 定义字符串时&#xff0c;字符串的内容被双引号&#xff0c;单引号&#xff0c;三单引号&#xff0c;三双引号中的其中一个被括住。 例如&#xff1a; 双引号&#xff1a; v1"haha" 单引号&#xff1a; v1hahah…...

算法小白的进阶之路(力扣6~8)

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 非常期待和您一起在这个小…...

【期货】收盘点评。昨天说的,p2409棕榈油在今天或者周一会走出行情

收盘点评 昨天说的&#xff0c;p2409棕榈油在今天或者周一会走出行情。事实就是如此。震荡了几天了&#xff0c;波幅不大的来回震荡&#xff0c;其实主力是不想震荡的&#xff0c;但是不震荡自己的货和行情走不出来。所以我昨天就说&#xff0c;应该就是这一两天会走出一波小行…...

LBS 开发微课堂|Polyline绘制优化:效果更丰富,性能更佳!

为了让广大的开发者 更深入地了解 百度地图开放平台的技术能力 轻松掌握满满的技术干货 更加简单地接入 开放平台的服务 我们特别推出了 “位置服务&#xff08;LBS&#xff09;开发微课堂” 系列技术案例 第一期的主题是 《Polyline 绘制优化升级》 你还想了解哪些…...

VS Code设置C++编译器路径

C_Cpp.default.compilerPath是C/C编译器路径; python.condaPath是conda路径....

在软件开发中正确使用MySQL日期时间类型的深度解析

在日常软件开发场景中&#xff0c;时间信息的存储是底层且核心的需求。从金融交易的精确记账时间、用户操作的行为日志&#xff0c;到供应链系统的物流节点时间戳&#xff0c;时间数据的准确性直接决定业务逻辑的可靠性。MySQL作为主流关系型数据库&#xff0c;其日期时间类型的…...

超短脉冲激光自聚焦效应

前言与目录 强激光引起自聚焦效应机理 超短脉冲激光在脆性材料内部加工时引起的自聚焦效应&#xff0c;这是一种非线性光学现象&#xff0c;主要涉及光学克尔效应和材料的非线性光学特性。 自聚焦效应可以产生局部的强光场&#xff0c;对材料产生非线性响应&#xff0c;可能…...

stm32G473的flash模式是单bank还是双bank?

今天突然有人stm32G473的flash模式是单bank还是双bank&#xff1f;由于时间太久&#xff0c;我真忘记了。搜搜发现&#xff0c;还真有人和我一样。见下面的链接&#xff1a;https://shequ.stmicroelectronics.cn/forum.php?modviewthread&tid644563 根据STM32G4系列参考手…...

质量体系的重要

质量体系是为确保产品、服务或过程质量满足规定要求&#xff0c;由相互关联的要素构成的有机整体。其核心内容可归纳为以下五个方面&#xff1a; &#x1f3db;️ 一、组织架构与职责 质量体系明确组织内各部门、岗位的职责与权限&#xff0c;形成层级清晰的管理网络&#xf…...

SpringBoot+uniapp 的 Champion 俱乐部微信小程序设计与实现,论文初版实现

摘要 本论文旨在设计并实现基于 SpringBoot 和 uniapp 的 Champion 俱乐部微信小程序&#xff0c;以满足俱乐部线上活动推广、会员管理、社交互动等需求。通过 SpringBoot 搭建后端服务&#xff0c;提供稳定高效的数据处理与业务逻辑支持&#xff1b;利用 uniapp 实现跨平台前…...

[Java恶补day16] 238.除自身以外数组的乘积

给你一个整数数组 nums&#xff0c;返回 数组 answer &#xff0c;其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法&#xff0c;且在 O(n) 时间复杂度…...

pikachu靶场通关笔记22-1 SQL注入05-1-insert注入(报错法)

目录 一、SQL注入 二、insert注入 三、报错型注入 四、updatexml函数 五、源码审计 六、insert渗透实战 1、渗透准备 2、获取数据库名database 3、获取表名table 4、获取列名column 5、获取字段 本系列为通过《pikachu靶场通关笔记》的SQL注入关卡(共10关&#xff0…...

【Oracle】分区表

个人主页&#xff1a;Guiat 归属专栏&#xff1a;Oracle 文章目录 1. 分区表基础概述1.1 分区表的概念与优势1.2 分区类型概览1.3 分区表的工作原理 2. 范围分区 (RANGE Partitioning)2.1 基础范围分区2.1.1 按日期范围分区2.1.2 按数值范围分区 2.2 间隔分区 (INTERVAL Partit…...

html css js网页制作成品——HTML+CSS榴莲商城网页设计(4页)附源码

目录 一、&#x1f468;‍&#x1f393;网站题目 二、✍️网站描述 三、&#x1f4da;网站介绍 四、&#x1f310;网站效果 五、&#x1fa93; 代码实现 &#x1f9f1;HTML 六、&#x1f947; 如何让学习不再盲目 七、&#x1f381;更多干货 一、&#x1f468;‍&#x1f…...

2025季度云服务器排行榜

在全球云服务器市场&#xff0c;各厂商的排名和地位并非一成不变&#xff0c;而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势&#xff0c;对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析&#xff1a; 一、全球“三巨头”…...