Makefile入门
相信大家对makefile都不陌生,在Linux下编写程序基本都离不开makefile的编写,我们都知道多个.c文件经过编译器编译后得到多个.o文件,这些文件是互相独立的,但最终我们要得到一个可正常运行的文件,很显然这个过程就是连接,将多个.o文件连接为一个文件,这个文件是.elf文件。下面来举个例子说明以下。
test.elf : part1.o part2.o
gcc -o test.elf part1.o part2.o //这种写法虽然太过原始,但能说明问题即可 %.o : %.c
gcc -o part1.o part2.o -c part1.c part2.c
上面gcc -o part1.o part2.o -c part1.c part2.c 这步将.c文件编译成对应的多个文件,注意-c表示只编译不连接,然后通过gcc -o test.elf part1.o part2.o连接为一个.elf文件,对于gcc而言,没有-c就意味着默认编译链接,这样就得到了一个文件,这是在PC机上运行的程序,但如果在ARM裸机上编写,那应该怎么实现了。
在ARM上裸机开发过程就变得复杂了,因为编译连接过程gcc已经帮你完成了,所以就不需要去管了,但是裸机就不一样了,这个连接过程我们还的去告诉编译器去做什么,幸运的是ARM开发下有一套完整的工具链,这个就是arm-linux-,这个工具链有三个最常用的工具,arm-linux-gcc arm-linux-linker arm-linux-objcopy
第一个工具是编译.c文件或者.s文件的,其输出文件为.o文件,第二个是连接器,是将多个.o文件连接为一个.elf文件的,最后一个工具是j将.elf文件转换为.bin文件以便烧录到Flash去的,下面用一个具体的例子说明三个工具的用法:
整个工程有.main.c hello.c hello.h main.lds文件:
#Makefile file
src=main.o hello.o
targ=main.bin #生成需要的二进制文件
armcc=arm-linux-gcc
armlin=arm-linux-ld
armobj=arm-linux-objcopy $(targ) : $(src)
armlin -Tmain.lds -o main.elf $^
armobj -O binary -S main.elf $@ %o : %c
armcc -o $@ -c $< .PHONY:clean
clean:
rm -f *.o *.elf
前面定义的变量就只替换的作用,其中
armlin -Tmain.lds -o main.elf $^
意思是将.main.o hello.o文件连接为一个main.elf文件,那按什么方式连接呢,这里用了-T就是说自定义连接过程,这个main.lds就是我们自己定义的连接方式,-o就是输出文件,这里需要注意的是-T后直接接着main.lds文件,中间没有空格,
armobj -O binary -S main.elf $@
意思是将main.elf文件转换为main,bin文件,-O表示输出文件格式,后面接的是binary表示二进制文件,-S是源文件,注意-O和-S都有大写,
armcc -o $@ -c $<
意思是将依赖文件的第一个文件编译为目标文件,其-c表示只编译不连接,因为连接过程在第一个。
下面来说main.elf文件:
SECTIONS{
. = 0X000; #表示起始地址,即连接时将该文件的首地址放在哪
. = ALIGN();#表示四个字节对齐,比如如果地址在0x3,则会自动移到0x4
.text :
{
*(.text)
}
. = 0x100; #注意.后面有空格
. = ALIGN(); #注意.后面有空格
.data : #注意.后面没有空格
{
*(.data)
}
.bss :
{
*(.bss)
}
}
#特别注意 .text : 中text与:之间有空格,这个必须有空格,否则编译出错
#同样.data和.bss也是一样
Makefile入门的更多相关文章
- vim+makefile入门编辑,编译,差错实例
vim+makefile入门编辑,编译,差错实例 vim makefile 编译 编写代码,一般在vim中编辑完后,输入:wq,在命令行下输入g++ hello.cc -o hello ,出现问题,打 ...
- 30天自制操作系统(二)汇编语言学习与Makefile入门
1 介绍文本编辑器 这部分可直接略过 2 继续开发 helloos.nas中核心程序之前的内容和启动区以外的内容先不讲了,因为还涉及到一些软盘方面的知识. 然后来讲的是helloos.nas这个文件 ...
- Makefile 入门(加减乘除实现)
Makefile 入门(加减乘除实现) 准备 使用任意Linux发行版即可,本文使用WSL Ubuntu. 开始之前,需要安装必要的工具: sudo apt install make g++ 开始 1 ...
- 挑战30天写操作系统-day2-汇编语言学习与Makefile入门
1.介绍文本编辑器 这里,我们直接采用自己windows电脑自带的文本编辑器即可以完成制作要求 2.继续开发 下面先是对昨天使用的helloos.nas文件内容进行详细解释 ; hello-os ; ...
- Makefile 入门与基本语法 分类: C/C++ ubuntu 2015-05-18 11:16 466人阅读 评论(0) 收藏
在我看来,学会写简单的Makefile,阅读较复杂的makefile,是每一个Linux程序员都必须拥有的基本素质.Makefile可以自动识别哪些源文件被更改过,需要重新编译,那些不需要.从而节省大 ...
- makefile入门-初步了解
自己开始学习makefile是由于VScode配置工程文件,看别人的配置不是很懂,于是决定入门学习下makefile. 先来说说makefile是做什么用的:makefile可以实现工程的自动化编译, ...
- Makefile入门教程
Makefile介绍 make是一个命令工具,它解释Makefile 中的指令(应该说是规则).在Makefile文件中描述了整个工程所有文件的编译顺序.编译规则.Makefile 有自己的书写格式. ...
- [ARM-LInux开发]linux设备驱动makefile入门解析
以下内容仅作参考,能力有限,如有错误还请纠正.对于一个普通的linux设备驱动模块,以下是一个经典的makefile代码,使用下面这个makefile可以完成大部分驱动的编译,使用时只需要修改一下要编 ...
- Makefile入门1
Linux中的编译脚本Makefile的讲解设计 概念 编译控制脚本(.c.h----->bin) Makefile最终要的是清晰编译链接的整个过程 Makefile的优化设计 工作原理 mak ...
随机推荐
- redis排序
1.sort 排序最常见的是sort命令,可以对列表或者有序集合排序,最简单的排序方式如下: > lpush list (integer) > lpush list (integer) & ...
- Sublime Text 3激活
Sublime Text 3激活方式: 一.修改hosts文件: 1:windows系统: 找到 C:\Windows\System32\drivers\etc\hosts 这个文件, 用 ...
- leetcode98
class Solution { public: vector<int> V; void postTree(TreeNode* node) { if (node != NULL) { if ...
- leetcode301
class Solution { public List<String> removeInvalidParentheses(String s) { List<String> a ...
- .NET MVC 过滤器使用
来看以下两种情况 1. 如果我们需要对某个模块做权限控制,通常的做法是写一个基类(BaseController),让这个基类继承Controller类,在BaseController的构造方法中进行权 ...
- 一个类似于jq的小型库
本人写了一个类似于jq的小型库,不过只是写了部分方法而已.并没有jq那么全面,下面就介绍下有哪些方法可以使用 第一个是选择器, 选择器比较简单 只支持ID选择器 $(‘#id_name’) Class ...
- typedef typename
所以根据上述两条分析, typedef typename RefBase::weakref_type weakref_type; 语句的真是面目是: typedef创建了存在类型的别名,而typen ...
- 微信小程序星星评价
https://www.jianshu.com/p/4d7359dfa040
- combox省市县三级联动
/** * Name 获取省份(初始化) */ function showProvince(id1, id2, id3) { var paramData = {}; $.ajax({ url: osp ...
- mysql5.5升级到5.7
一.首先把mysql服务停止,复制mysql5.5中的data文件夹中的内容(你需要的数据库),放在mysql5.7的data文件夹中; 二.启动切换mysql5.7版本,(我这用的是phpwamp, ...