在之前我们已经学习了一个文件的编译过程,但是做过项目的都知道,一个工程中的源文件不计其数,其按类型.功能.模块会分别放在若干个目录中,而这些文件如何编译就需要有一个编译规则,虽然现在很多大型的项目都是直接用诸如CMake.Autotools.SCons等工具生成的,但是对于一些小项目,使用工具就没有什么必要了,而且对于项目编写来说,掌握Makefile的基本知识对我们来说也是很有必要的. 我们本篇文章所要讲解的就是这个编译规则的文件makefile的规则及如何进行编写.makefile定义了一系…
一.交叉工具链 嵌入式Linux开发采用交叉开发,简单来说就是在宿主机(PC机)上面编译出能够在其他硬件平台上面运行的程序.在这个过程中,需要用到许多的交叉工具,这些交叉工具的集合就叫做交叉工具链.下面列举嵌入式开发中常用的交叉工具. 1.交叉编译器    arm-linux-gcc 交叉编译器的命名十分有特色,前面两个字符串表明了他们可以使用的平台.例如:arm-linux-gcc说明用来编译出用于ARM平台的程序. 用法:arm-linux-gcc hello.c -o hello 2.交叉…
Makefile 工程管理 Makefile 规则 --变量 在Makefile中,用户除了可以自己定义变量外,还可以使用存在系统已经定义好的默认变量 $^:代表所有的依赖文件 $@:代表目标 $<:代表第一个依赖文件 Makefile使用技巧 --去回显 Makefile 中“#”字符后的内容被视作注释 @:取消回显 使用技巧 – 文件名 Make命令默认在当前目录下寻找名字为Makefile或者makefile的工程文件,当名字部位这两者之一时,可以使用如下方法指定: make –f 文件名…
GNU make Linux程序员必须学会使用GNU make来构建和管理自己的软件工程.GNU的make能够使整个工程的编译.链接只需要一个命令就可以完成. makefile make在执行时,需要一个命名为Makefile的文件.Makefile文件描述了整个工程的编译.链接等规则.其中包括:工程中哪些源文件需要编译以及如何编译:需要创建哪些库文件以及如何创建这些库文件.如何最后产生我们想要的可执行文件. Makefile(例) hello:main.o func1.o func2.o gc…
Makefile文件描述了整个工程的编译.链接等规则.包括:工程中哪些源文件需要编译以及如何编译:需要创建哪些库文件以及如何创建这些库文件.如何产生最终的可执行文件. Makefile相关术语 1.规则:用于说明如何生成一个或多个目标文件.在Makefile中,规则的顺序非常重要,因为Makefile中只应该有一个最终目标,其他目标都是为了生成该目标而产生的中间文件,所以一般第一条规则中的目标将被确认为最终的目标. 规则格式如下:targets : prerequisites command 目…
1. 为什么得用Makefile 单步命令生成led.bin [root@cfm880 lesson1]# cd .. [root@cfm880 Part1]# mkdir lesson3 [root@cfm880 Part1]# cd lesson3 [root@cfm880 lesson3]# chmod 777 ./ [root@cfm880 lesson3]# ls led.lds led.S Makefile [root@cfm880 lesson3]# arm-linux-gcc -…
​ Linux 环境下的程序员如果不会使用GNU make来构建和管理自己的工程,应该不能算是一个合格的专业程序员,至少不能称得上是 Unix程序员.在 Linux(unix )环境下使用GNU 的make工具能够比较容易的构建一个属于你自己的工程,整个工程的编译只需要一个命令就可以完成编译.连接以至于最后的执行.不过这需要我们投入一些时间去完成一个或者多个称之为Makefile 文件的编写. ​ 所要完成的Makefile 文件描述了整个工程的编译.连接等规则.其中包括:工程中的哪些源文件需要…
个人理解吧,makefile就是写一个指定格式的文件,将一系列的编译.链接.转换等操作打包在一起,方便以后一键生成可执行的二进制文件而产生的.下面记录一下这种文件的写法,方便以后忘了来查询. makefile文件一般格式(又叫规则): 目标文件名:依赖文件名 命令 就是这样,注意第二行,命令前面的空白不是用空格键敲出来的,而是用一个Tab键直接搞定.其中,目标文件只能有一个,而依赖文件可以有一个,可以有多个,甚至一个也没有.没有依赖文件的目标称为伪目标,通常是为了给某个操作命名方便以后直接使用.…
Makefile的用途 1.make能够使整个程序的编译.链接只需一个命令就可以完成 2.make的工作主要依赖于Makefile的文件.Makefile文件描述了整个程序的编译.链接等规则,使之自动完成. Makefile的构成 1.规则 targets(目标):prerequisties(依赖) command(命令) 注意:command前面是[tab]而不是空格,否则执行会出错 1.伪目标:只有目标和命令,没有依赖的规则称为伪目标,伪目标通常用 .PHONY:targets (也可以不写…
工程管理与makefile 一.为什么需要makefile和make 一个工程中的源文件可能很多,按照类型.功能.模块分别放在若干个目录中,为了有效地管理软件工程,更高效地编译整个工程,需要用到makefile 和 make 命令工具.Linux 程序员须学会写makefile,使用GNU make 来构建和管理自己的软件工程,利用makefile 进行编译,已成为了一种在工程方面的常见编译方法.makefile 带来的好处是"自动化编译",一旦写好,只需要一个make 命令,整个工程…