找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
广告投放联系QQ68610888
查看: 27773|回复: 43

OpenWrt的主Makefile工作过程

 火.. [复制链接]
发表于 2012-2-5 21:20 | 显示全部楼层 |阅读模式
本文是本人对OpenWrt的Makefile的理解,并非转载。
OpenWrt是一个典型的嵌入式Linux工程,了解OpenWrt的Makefile的工作过程对提高嵌入式Linux工程的开发能力有极其重要意义。
OpenWrt的主Makefile文件只有100行,可以简单分为三部分,1~17行为前导部分,19~31为首次执行部分,33~101为再次执行部分。
        前导部分
CURDIR为make默认变量,默认值为当前目录。
前导部分主要把变量TOPDIR赋值为当前目录,把变量LC_ALL、LANG赋值为C,并使用变量延伸指示符export,把上述三个变量延伸到下层Makefile。
使用文件使用指示符include引入$(TOPDIR)/include/host.mk。在OpenWrt的主Makefile文件使用了多次include指示符,说明主Makefile文件被拆分成多个文件,被拆分的文件放在不同的目录。拆分的目的是明确各部分的功能,而且增加其灵活性。
在前导部分比较费解的是使用world目标,在makefile中基本规则为:
TARGETS : PREREQUISITES
COMMAND
...
        即makefile规则由目标、依赖、命令三部分组成,在OpenWrt的主Makefile文件的第一个目标world没有依赖和命令。它主要起到指示当make命令不带目标时所要执行的目标,没有设定依赖和命令部分表明此目标在此后将会有其他依赖关系或命令。world目标的命令需要进一步参考$(TOPDIR)/include/toplevel.mk和主Makefile文件的再次执行部分。
        首次执行部分
        OPENWRT_BUILD是区分首次执行与再次执行的变量。在首次执行时使用强制赋值指示符override把OPENWRT_BUILD赋值为1,并使用变量延伸指示符export把OPENWRT_BUILD延伸。在OPENWRT_BUILD使用强制赋值指示符override意味着make命令行可能引入OPENWRT_BUILD参数。
        引入$(TOPDIR)/include/debug.mk、$(TOPDIR)/include/depends.mk、$(TOPDIR)/include/toplevel.mk三个文件,由于TOPDIR是固定的,所以三个文件也是固定的。其中$(TOPDIR)/include/toplevel.mk的135行%::有效解释首次执行时world目标的规则。
        再次执行部分
        引入rules.mk、$(INCLUDE_DIR)/depends.mk、$(INCLUDE_DIR)/subdir.mk、target/Makefile、package/Makefile、tools/Makefile、toolchain/Makefile七个文件,rules.mk没有目录名,即引入与主Makefile文件目录相同的rules.mk。在rules.mk定义了INCLUDE_DIR为$(TOPDIR)/include,所以$(INCLUDE_DIR)/depends.mk实际上与首次执行时引入的$(TOPDIR)/include/depends.mk是同一个文件。
        四个子目录下的Makefile实际上是不能独立执行。主要利用$(INCLUDE_DIR)/subdir.mk动态建立规则,诸如$(toolchain/stamp-install)目标是靠$(INCLUDE_DIR)/subdir.mk的stampfile函数动态建立。在package/Makefile动态建立了$(package/ stamp-prereq)、$(package/ stamp-cleanup)、$(package/ stamp-compile)、$(package/ stamp-install)、$(package/ stamp-rootfs-prepare)目标。
        定义一些使用变量命名的目标,其变量的赋值位置在$(INCLUDE_DIR)/subdir.mk的stampfile函数中。目标只有依赖关系,可能说明其工作顺序,在$(INCLUDE_DIR)/subdir.mk的stampfile函数中有进一步说明其目标执行的命令,并为目标建立一个空文件,即使用变量命名的目标为真实的文件。
        定义一些使用固定的目标规则。
其中:clean是清除编译结果的目标,清除$(BUILD_DIR) $(BIN_DIR) $(BUILD_LOG_DIR)三个目录的用意是十分明确。暂时不知道为什么执行make target/linux/clean。
dirclean是删除所有编译过程产生的目录和文件的目标,执行dirclean目标依赖于clean,因此将执行clean目标所执行的命令,然后删除$(STAGING_DIR) $(STAGING_DIR_HOST) $(STAGING_DIR_TOOLCHAIN) $(TOOLCHAIN_DIR) $(BUILD_DIR_HOST) $(BUILD_DIR_TOOLCHAIN)目录,以及删除$(TMP_DIR)目录。上述目录的变量均在rules.mk定义。好像删除staging_dir目录就意味着删除staging_dir目录下的所有子目录,不知道为什么要强调删除$(STAGING_DIR_HOST) $(STAGING_DIR_TOOLCHAIN) $(TOOLCHAIN_DIR)目录。同样删除builde_dir目录就意味着删除builde_dir目录下的所有子目录,不知道为什么要强调删除$(BUILD_DIR_TOOLCHAIN)目录。
        tmp/.prereq_packages目标是对所需软件包的预处理。目标依赖于.config,即执行make menuconfig后将会进行一次所需软件包的预处理。不知什么原因在编译前删除tmp目录,执行时无法建立tmp/.prereq_packages文件。
        prereq应该是预请求目标,在OpenWrt执行Makefile时好像都要先执行prereq目标。
        prepare应该是准备目标,是world依赖的一个伪目标。依赖于文件.config和$(tools/stamp-install) $(toolchain/stamp-install)目标。
        world就是编译的目标。依赖于prepare为目标和前面提到的变量命名目标。采用取消隐含规则方式执行package/index目标。package/index目标在package/Makefile的92行定义。
        package/symlinks和package/symlinks-install是更新或安装软件包来源的目标,使用$(SCRIPT_DIR)/feeds脚本文件完成。
        package/symlinks-clean是清除软件包来源的目标,也是使用$(SCRIPT_DIR)/feeds脚本文件完成。
        最后使用伪目标.PHONY说明clean dirclean prereq prepare world package/symlinks package/symlinks-install package/symlinks-clean属于伪目标。通过伪目标说明可以知道可以执行的目标。

评分

参与人数 2恩山币 +2 收起 理由
scs*** + 1 一看就是觉得高端、大气、上档次!
ew*** + 1 牛啊

查看全部评分

我的恩山、我的无线 The best wifi forum is right here.
发表于 2012-3-3 12:27 | 显示全部楼层
{:soso_e153:}这么强悍的技术帖竟然会沉
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

发表于 2012-3-3 12:42 | 显示全部楼层
zhoutao0712 发表于 2012-3-3 12:27
这么强悍的技术帖竟然会沉

因为看不懂。
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

发表于 2012-3-3 21:36 | 显示全部楼层
顶了
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

发表于 2012-3-4 15:35 | 显示全部楼层
看不懂啊Ⅱ
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

发表于 2012-3-4 19:39 | 显示全部楼层
研究研究
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

发表于 2012-3-7 15:30 | 显示全部楼层
学习研究下,很想了解下!
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

发表于 2012-3-9 23:38 | 显示全部楼层
顶啊,苦寻组织,今天终于找到了, 见意搞个“开发板”讨论路由器嵌入式开发
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

发表于 2012-3-17 17:32 | 显示全部楼层
好东西,楼主还有没有关于Openwrt别的东西,谢谢分享了!
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

发表于 2012-4-5 16:13 | 显示全部楼层
大部分人用OP刷机来定制自己的功能, 很少有研究这么深入的
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

发表于 2012-5-19 10:38 | 显示全部楼层
顶起来
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

发表于 2012-5-19 11:01 | 显示全部楼层

顶起来
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

发表于 2012-5-19 11:28 | 显示全部楼层
这么强悍的技术帖竟然会沉
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

发表于 2012-8-9 15:58 | 显示全部楼层
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

发表于 2012-8-9 16:07 | 显示全部楼层
研究一下。
我的恩山、我的无线 The best wifi forum is right here.
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

有疑问请添加管理员QQ86788181|手机版|小黑屋|Archiver|恩山无线论坛(常州市恩山计算机开发有限公司版权所有) ( 苏ICP备05084872号 )

GMT+8, 2024-4-25 20:12

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

| 江苏省互联网有害信息举报中心 举报信箱:js12377 | @jischina.com.cn 举报电话:025-88802724 本站不良内容举报信箱:68610888@qq.com 举报电话:0519-86695797

快速回复 返回顶部 返回列表