Makefile介绍
make 工具如 GNU make、System V make 和 Berkeley make 是用来组织应用程序编译过程的基本工具,但是每个 make 工具之间又有所不同。不同的make工具的makefile 的结构大部分相同,在很多编译过程中,makefile 自己完全是由其他软件生成的;如autoconf/automake 程序就用来开发编译程序。有时可能会要求我们直接编写 makefile( 其实是改写)。目前我工作平台是Linux,我的基本需求是能够读懂GUN Makefile,并且能够根据自己的设计的需求改写Makefile。什么是make? Linux 自带的文档解释的非常清楚:
The purpose of the make utility is to determine automatically which pieces of a large program need to be recompiled, and issue the commands to recompile them. In fact, make is not limited to programs. You can use it to describe any task where some files must be updated automatically from others whenever the others change.
1 Makefile 里有什么?
Makefile里主要包含了五个东西:显示规则、隐晦规则、变量定义、文件指示和注释。在Makefile中的命令,必须要以[Tab] 键开始。
2 make的工作方式
GUN的make 工作时执行步骤如下:
(1) 读入所有的Makefile;
(2) 读入被include 的其他Makefile;
(3) 初始化文件中的变量;
(4) 推导隐晦规则,并分析所有规则;
(5) 为所有的目标文件创建依赖关系链;
(6) 根据依赖关系,决定哪些目标要重新生成;
(7) 执行生成命令。
3 Makefile的规则
Makefile的规则包含两个部分,一个是依赖关系,一个是生成目标的方法。在Makefile中规则的顺序是很重要的,Makefile中只有一个最终目标,一般第一条规则中的目标将被确立为最终目标。
依赖性规则的格式
target: dependencies
instructions
4 通用生成目标
通用生成目标应该表示什么,以及它们该如何命名已经有了一组良好的约定。遵从这些会让自己的makefile 更容易理解和使用。
all
生成工程中所有可以执行者。它通常是第一个生成目标,因此它往往是开发者不带参数键入make就能执行的那一个。
test
运行程序的自动测试套件。
clean
删除make all 时产生的所有文件。
dist
dist是distribution的缩写,制作源文件档案,它可以作为在另一台机器上重新编译的单元。
install
在系统目录中安装项目工程的可执行文件和文档,以让普通用户访问。
uninstall
删除由make install 安装在系统目录中的所有文件。
问题:
1 在开发ASIC过程都可以用Makefile 和shell脚本自动化完成任务,二者有什么区别?
2 make 工具适合于EDA工具吗?比如VCS仿真和Vivado综合?
参考文献:
[1] 陈皓. 跟我一起写Makefile.
[2] 徐海兵. GUN make中文手册.
[3] 调试 make. http://www.ibm.com/developerworks/cn/linux/l-debugmake.html
[4] Eric. Raymond. UNIX编程艺术. 电子工业出版社. 2013,6.
Makefile介绍的更多相关文章
- 跟我一起写Makefile:MakeFile介绍
makefile 介绍 make命令执行时,需要一个 makefile 文件,以告诉make命令如何去编译和链接程序. 首先,我们用一个示例来说明makefile的书写规则.以便给大家一个感性认识.这 ...
- (转)Makefile介绍
2. Makefile介绍 make命令执行时,需要一个Makefile文件,以告诉make命令需要怎么样的去编译和链接程序. 首先,我们用一个示例来说明Makefile的书写规则.以便给大家一个感性 ...
- [转] Makefile 基础 (1) —— Makefile 介绍
该篇文章为转载,是对原作者系列文章的总汇加上标注. 支持原创,请移步陈浩大神博客:(最原始版本) http://blog.csdn.net/haoel/article/details/2886 我转自 ...
- Makefile 介绍
makefile:是告诉编译器(交叉工具链)如何去编译.链接一个工程的规则. 一.概述 什 么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为 ...
- 第一篇 make与makefile介绍
我们在Linux系统中学习C语言或者C++语言时,大多数时候只是用gcc命令或者g++命令在命令行进行简单的编译.链接即可得到最终的可执行文件,进一步即可验证所写C/C++语言的正确性.但是,在大型工 ...
- GNU Make chapter 2 —— Makefile 介绍
Makefile是由一系列的rule规则组成,这些rule都遵循以下形式: target ... : prerequisites ... command ... ... target(目标) 一般来说 ...
- CFLAGS/CPPFLAGS/CXXFLAGS in Makefile介绍
先来看一张关于Makefile中的常见预定义变量. CFLAGS 表示用于 C 编译器的选项,CXXFLAGS 表示用于 C++ 编译器的选项.这两个变量实际上涵盖了编译和汇编两个步骤.大多数程序和库 ...
- makefile介绍1.0
1.gcc参数 -o指定生成文件名 -c只编译不链接 2.makefile标准格式 CC=gcc #编译器变量,#代表注释 SRCS=main.cpp\#源文件变量 a.cpp\ b.cpp\ c.c ...
- GNU autotools自动生成Makefile 介绍
一.目的 使用autotools工具来帮助我们自动地生成符合自由软件惯例的makefile(这样就可以像常见的GNU程序一样,只要使用"./configure", "ma ...
- make和makefile介绍
<strong>先附上一个比较简单的,测试代码用的Makefile</strong> </pre><pre code_snippet_id="463 ...
随机推荐
- import data from excel to sql server
https://www.c-sharpcorner.com/article/how-to-import-excel-data-in-sql-server-2014/ 需要注意的是,第一次是选择sour ...
- codeforces 667C C. Reberland Linguistics(dp)
题目链接: C. Reberland Linguistics time limit per test 1 second memory limit per test 256 megabytes inpu ...
- python中的异常处理try/except/finally/raise
异常发生在程序执行的过程中,如果python无法正常处理程序就会发生异常,导致整个程序终止执行,python中使用try/except语句可以捕获异常. try/except 异常的种类有很多,在不确 ...
- 4、html的body内标签之input系列
一.input标签与form表单 <!DOCTYPE html> <html lang="en"> <head> <meta charse ...
- ASP.NET Core MVC 2.x 全面教程_ASP.NET Core MVC 13. 安装前端库
前端库使用npm进行安装,需要先建立webpack.json文件 因为我们没有使用npm安装任何库,所以npm的文件夹是空的 这里是用于开发时构建时引用的库写在这里 这里用到bootStrap 开发时 ...
- hdoj5671 BestCoder Round #81 (div.2)
对于交换行.交换列的操作,分别记录当前状态下每一行.每一列是原始数组的哪一行.哪一列即可. 对每一行.每一列加一个数的操作,也可以两个数组分别记录.注意当交换行.列的同时,也要交换增量数组. 输出时通 ...
- 基于FBX SDK的FBX模型解析与加载 -(一)
http://blog.csdn.net/bugrunner/article/details/7210511 1. 简介 FBX是Autodesk的一个用于跨平台的免费三维数据交换的格式(最早不是由A ...
- poj 2406 Power Strings【kmp】
kmp,根据next数组的性质如果有答案的话就是n/(n-(ne[n]+1)),否则是1 搬来打算用SA后来发现必须用DC3就没写 #include<iostream> #include& ...
- poj 1743 Musical Theme【二分+SA】
差分,然后二分长度mid,判断是把height按照min不小于mid分组,取最大最小的sa位置看是否>=mid即可,注意差分后最后答案要+1 #include<iostream> # ...
- JVM的参数详解
今天就整理下JVM的参数!相对而已JVM有很多参数,但对于一般开发人员执行知道和堆栈大小,GC.远程调试的参数即可. JVM Parameters 首先需要说明的是JVM的参数形式: -X 开头的参数 ...