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 -g -c led.S led.o

[root@cfm880 lesson3]# arm-linux-ld -Tled.lds -o led.elf led.o

[root@cfm880 lesson3]# ls

led.elf led.lds led.o led.S Makefile

[root@cfm880 lesson3]# arm-linux-objcopy -O binary led.elf led.bin

[root@cfm880 lesson3]# ls

led.bin led.elf led.lds led.o led.S Makefile

如果是命令太多,我们不可能手动输入太多命令

我们需要更有效的工具

[root@cfm880 lesson3]# make clean

rm *.o led.elf led.bin

[root@cfm880 lesson3]# make

arm-linux-gcc -g -o led.o -c led.S

arm-linux-ld -Tled.lds -o led.elf led.o

arm-linux-objcopy -O binary led.elf led.bin

[root@cfm880 lesson3]# ls

led.bin led.elf led.lds led.o led.S Makefile

把很多命令合成一个命令

make

需要自己编写Makefile文件完成自动编译

Makefile文件

all: led.o

arm-linux-ld -Tled.lds -o led.elf led.o

arm-linux-objcopy -O binary led.elf led.bin

 

led.o : led.S

arm-linux-gcc -g -o led.o -c led.S

 

.PHONY: clean

clean:

rm *.o led.elf led.bin

Makefile规则

Target:prerequisites

    Commad #一个tab

目标:依赖

    命令

Led.elf: led.o

arm-linux-ld -Tled.lds -o led.elf led.o

伪目标:只有命令没有依赖用.PHONY标明伪目标

clean:

rm *.o led.elf led.bin

arm-linux-gcc -g -o led.o -c led.S

[root@cfm880 lesson3]# ls

led.lds led.o led.S Makefile

[root@cfm880 lesson3]# make

arm-linux-ld -Tled.lds -o led.elf led.o

arm-linux-objcopy -O binary led.elf led.bin

 

make后没有参数默认第一条命令

变量

App1: app1.o func1.o func2.o

    Gcc app1.o func1.o func3.o –o app1

App2: app2.o func1.o func2.o –o app2

使用默认变量

Obj=func1.0 func2.o

App1: app1.o $(obj)

    Gcc app1.o $(obj) –o app1

App2:app2.o $(obj)

    Gcc app2.o $(obj) –o app2

直接使用系统定义的默认变量

$^:代表所有的依赖文件

$@:代表目标

$<:第一个依赖文件

简化Makefile

all: led.o

arm-linux-ld -Tled.lds -o led.elf $^

arm-linux-objcopy -O binary led.elf led.bin

 

led.o : led.S

arm-linux-gcc -g -o $@ -c $^

 

.PHONY: clean

clean:

rm *.o led.elf led.bin

通用规则

led.o : led.S

arm-linux-gcc -g -o $@ -c $^

main.o : main.S

arm-linux-gcc -g -o $@ -c $^

两条规则他们的命令一样,目标与依赖的名字只有后缀名不样

%.o : %.S

arm-linux-gcc -g -o $@ -c $^

可以替换上面两条语句

3. 使用技巧

回显:不需要打印命令

all: led.o

@arm-linux-ld -Tled.lds -o led.elf $^

@arm-linux-objcopy -O binary led.elf led.bin

 

led.o : led.S

@arm-linux-gcc -g -o $@ -c $^

 

.PHONY: clean

clean:

rm *.o led.elf led.bin

[root@cfm880 lesson3]# make

[root@cfm880 lesson3]# ls

led.bin led.elf led.lds led.o led.S Makefile

Makefile文件名加 –f 选项

[root@cfm880 lesson3]# mv Makefile file

[root@cfm880 lesson3]# make

make: *** 没有指明目标并且找不到 makefile。 停止。

[root@cfm880 lesson3]# make -f file

[root@cfm880 lesson3]# ls

file led.bin led.elf led.lds led.o led.S

1.3 Makefile 工程管理的更多相关文章

  1. Makefile 工程管理

    Makefile 工程管理 Makefile 规则 --变量 在Makefile中,用户除了可以自己定义变量外,还可以使用存在系统已经定义好的默认变量 $^:代表所有的依赖文件 $@:代表目标 $&l ...

  2. ARM裸机开发之交叉工具链和MakeFile工程管理

    一.交叉工具链 嵌入式Linux开发采用交叉开发,简单来说就是在宿主机(PC机)上面编译出能够在其他硬件平台上面运行的程序.在这个过程中,需要用到许多的交叉工具,这些交叉工具的集合就叫做交叉工具链.下 ...

  3. Makefile工程管理器及万能模板

    ​ Linux 环境下的程序员如果不会使用GNU make来构建和管理自己的工程,应该不能算是一个合格的专业程序员,至少不能称得上是 Unix程序员.在 Linux(unix )环境下使用GNU 的m ...

  4. 1-3 编程基础 makefile工程管理

    GNU make Linux程序员必须学会使用GNU make来构建和管理自己的软件工程.GNU的make能够使整个工程的编译.链接只需要一个命令就可以完成. makefile make在执行时,需要 ...

  5. 6、GNU makefile工程管理学习的一个例子

    在之前我们已经学习了一个文件的编译过程,但是做过项目的都知道,一个工程中的源文件不计其数,其按类型.功能.模块会分别放在若干个目录中,而这些文件如何编译就需要有一个编译规则,虽然现在很多大型的项目都是 ...

  6. linux应用程序设计--Makefile工程管理

    Makefile文件描述了整个工程的编译.链接等规则.包括:工程中哪些源文件需要编译以及如何编译:需要创建哪些库文件以及如何创建这些库文件.如何产生最终的可执行文件. Makefile相关术语 1.规 ...

  7. makefile工程管理

    个人理解吧,makefile就是写一个指定格式的文件,将一系列的编译.链接.转换等操作打包在一起,方便以后一键生成可执行的二进制文件而产生的.下面记录一下这种文件的写法,方便以后忘了来查询. make ...

  8. [国嵌笔记][017][Makefile工程管理]

    Makefile的用途 1.make能够使整个程序的编译.链接只需一个命令就可以完成 2.make的工作主要依赖于Makefile的文件.Makefile文件描述了整个程序的编译.链接等规则,使之自动 ...

  9. 学习总结:工程管理与makefile

    工程管理与makefile 一.为什么需要makefile和make 一个工程中的源文件可能很多,按照类型.功能.模块分别放在若干个目录中,为了有效地管理软件工程,更高效地编译整个工程,需要用到mak ...

随机推荐

  1. Map练习错误

    private Student findStuByNumber(String number) {              Student student=null ;       for(Stude ...

  2. angular2 - content projection-

    angular2中的内容映射: App.component: <my-day> <my-lucky> </my-lucky> </my-day> MyD ...

  3. JavaScript常用对象的方法和属性

    ---恢复内容开始--- 本文将简单介绍JavaScript中一些常用对象的属性和方法,以及几个有用的系统函数. 一.串方法 JavaScript有强大的串处理功能,有了这些串方法,才能编写出丰富多彩 ...

  4. aop配置

    前置通知 后置通知 环绕通知 异常通知 定义切面 aop-config 切入点 切面 通知 spring jdbc

  5. 用c#中的WebBrowser抢小米F码,抢小米手机以及自动测试实现原理

    首先是用c#中的WebBrowser控件打开登录网页,很简单,拖拽WebBrowser到Form上,然后给它的Url属性赋值.WebBrowser就会自动navigate to 这个网页. WebBr ...

  6. CMD:在当前文件夹下打开cmd命令

    对于电脑老鸟而言,在使用windows系统的过程中,经常需要在cmd窗口中输入一些命令进行操作.但是如果每一次都是在cmd窗口中用CD命令进行相应的文件夹目录,实在不便,尤其是在文件夹层次比较多而且带 ...

  7. contiki学习笔记---process结构体

    process,字面意义,进程,看看它的结构 struct process { struct process *next; #if PROCESS_CONF_NO_PROCESS_NAMES #def ...

  8. iScroll知识点

    1.如果你有一个复杂的DOM结构,最好在onload事件之后适当的延迟,再去初始化iScroll.最好给浏览器100或者200毫秒的间隙再去初始化iScroll. 2.iScroll作用于滚动区域的外 ...

  9. Microsoft Win32 to Microsoft .NET Framework API Map

    Microsoft Win32 to Microsoft .NET Framework API Map .NET Development (General) Technical Articles   ...

  10. sublime text2在windows中以命令行启动

    sublime text2在windows中以命令行启动   把执行文件添加到PATH中即可,如图: 如果你和我一样习惯了mac下的简写subl,那么需要在程序目录中新建一个批处理文件subl.bat ...