OpenWrt make menuconfig 构建过程「建议收藏」

OpenWrt make menuconfig 构建过程「建议收藏」OpenWrtmakemenuconfig构建过程1.课题背景之前在《20190614OpenWrt如何添加驱动以及应用程序谢艺华-遗留问题解答》文档的问题7中,承诺要写一个关于makemenuconfig的构架过程。于是就决定花点时间熟悉一下流程,方便以后的工作。2.分析过程2.1OpenWrt目录下的Makefile分析makemenuconfig的过程也…

大家好,又见面了,我是你们的朋友全栈君。

OpenWrt make menuconfig 构建过程

1.课题背景

之前在《20190614 OpenWrt如何添加驱动以及应用程序 谢艺华-遗留问题解答》文档的问题7中,承诺要写一个关于make menuconfig的构架过程。于是就决定花点时间熟悉一下流程,方便以后的工作。

2. 分析过程

2.1 OpenWrt目录下的Makefile

分析make menuconfig的过程也就是分析Makefile的过程,于是我们就从最上层的Makefile 开始。

我们看到它的目标是world,并且ifneq ($(OPENWRT_BUILD),1)成立,所以走的是上面的逻辑。如图:

OpenWrt make menuconfig 构建过程「建议收藏」

 

通过分析,debug.mk,depends.mk,toplevel.mk。发现menuconfig的目标在topleve.mk中。debug.mk和depends.mk只是一些变量和函数的定义。所以我们重心就是在toplevel.mk上。

 

2.2 toplevel.mk

我们可以看到menuconfig的目标依赖和命令如下:

OpenWrt make menuconfig 构建过程「建议收藏」

 

  1. scripts/config/mconf是该文件中一个目标,如图:

OpenWrt make menuconfig 构建过程「建议收藏」

它的作用就是编译,再scripts/config目录下生成mconf可执行文件。

  1. prepare-tmpinfo是该文件中的一个目标,待会再陈述。
  2. FORCE作用是强制去执行,因为我们知道,Makefile的原理是,只有当依赖文件中比目标文件要新,才会去执行相应的命令。所以有FORCE,就一定会执行。
  3.  下面的shell语句:

if [ \! -e .config -a -e $(HOME)/.openwrt/defconfig ]; then \

          cp $(HOME)/.openwrt/defconfig .config; \

        fi

的意思是:当前目录下的.config不存在并且$(HOME)/.openwrt/defconfig存在,就将$(HOME)/.openwrt/defconfig拷贝一份为.config。由于我们不存在$(HOME)/.openwrt/defconfig。所以可以不用在意

  1. $<  Config.in中的$<是自动化变量,表示依赖中的第一个目标名,即scripts/config/mconf。

最终就是:scripts/config/mconf Config.in。你可以尝试再终端输入该命令,看一下是什么效果。

 

现在再来看一下prepare-tmpinfo这个目标。如图:

OpenWrt make menuconfig 构建过程「建议收藏」

第一行命令似乎没有什么作用;我就不赘诉了。

重点是第三行和第四行,我们可知是调用了scan.mk生成了packageinfo和targetinfo文件,具体的内容,我们待会再说。

后面根据shell语句进行处理:

OpenWrt make menuconfig 构建过程「建议收藏」

其中,-nt是newer than的意思,用于判断文件的新旧,若t比f新,则为真。metadata.pl是perl语言文件,具体作用不清楚,不过应该是根据f文件生成t。

后面的几句都是类似的了,都是用于生成一些临时文件。

 

2.3 scan.mk

 

scan.mk中的目标是all,如图:

OpenWrt make menuconfig 构建过程「建议收藏」

其中,$(TMP_DIR)/.$(SCAN_TARGET)为依赖,因为scan.mk中的内容较多,大多是一些正则表达的内容,所以接下来我主要介绍思路,不会介绍过于详细,依赖如图:

OpenWrt make menuconfig 构建过程「建议收藏」

命令中progress只是打印,不需要关心。其中-cat 表示出错也不提示,$(FILELIST)目标如下图:

OpenWrt make menuconfig 构建过程「建议收藏」

 

其中FIND_L表示find -l,,命令行:

$(call FIND_L, $(SCAN_DIR)) $(SCAN_EXTRA) -mindepth 1 $(if $(SCAN_DEPTH),-maxdepth $(SCAN_DEPTH)) -name Makefile | xargs grep -aHE ‘call $(GREP_STRING)’ | sed -e ‘s#^$(SCAN_DIR)/##’ -e ‘s#/Makefile:.*##’ | uniq | awk -v of=$(OVERRIDELIST) -f include/scan.awk > $@

表示在$(SCAN_DIR)目录中进行搜索Makefile的文件,再将所有的Makefile以’call $(GREP_STRING)’字符串进行过滤,将其保存到$(FILELIST)中。

 

之前《如何在OpenWrt中添加应用程序和驱动程序》的ppt中介绍过,添加的每个Makefile在最后一句都是有

$(eval $(call BuildPackage,Packagename)),语句。因此在这里就会起到作用。由于篇幅关系,我们只要知道它会根据Package中的Makefile内容生成tmp/.packageinfo文件即可。其内容如图:

 

OpenWrt make menuconfig 构建过程「建议收藏」

2.4 Config.in

在toplevel.mk中我们知道最终执行的是scripts/config/mconf Config.in。来生成图形界面,我们来看一下Config.in的内容:

OpenWrt make menuconfig 构建过程「建议收藏」

从内容可知,Config.in的作用类似于一个配置文件,告诉mconf应该加载的文件路径。我们看一下tmp/.config-package.in里面的内容,如图:

OpenWrt make menuconfig 构建过程「建议收藏」

有过linux内核开发经验的人可以看出,这里面的语法和linux 内核中Kconfig的语法一致。因此OpenWrt图形界面显示的语法和linux的是一样的,只不过是通过它的package机制进行了转化。

3 总结

通过上面的分析,我认为大致流程可概括如下:

  1. 顶层Makefile调用toplevel.mk,执行其中的menuconfig 目标。
  2. toplevel.mk的任务有以下几个:
    1. 编译script/config/mconf
    2. 调用scan.mk生成tmp/.packageinfo文件
    3. 使用metadata.pl脚本根据tmp/.packageinfo生成tmp/.config-package文件
    4. 调用script/config/mconf Config.in 生成图形配置界面
  3. scan.mk的作用就是扫描package和target目录下的Makefile,根据Makefile中的内容生成tmp/.packageinfo,供metadata.pl使用
  4. Config.in 只是配置文件,作为mconf的参数。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/145132.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 接口测试面试题及答案(最新java面试题及答案)

    接口测试面试题及答案(最新java面试题及答案)Http与Https的区别:Http与Https的区别:HTTP的URL以http:// 开头,而HTTPS的URL以https:// 开头HTTP是不安全的,而HTTPS是安全的HTTP标准端口是80,而HTTPS的标准端口是443在OSI网络模型中,HTTP工作于应用层,而HTTPS的安全传输机制工作在传输层HTTP无法加密,而HTTPS对传输的数据进行加密HTT…

  • Unbound classpath container: &#39;JRE System Library [jdk17060]&#39; in project ***

    Unbound classpath container: &#39;JRE System Library [jdk17060]&#39; in project ***

  • 由oracle数据库生成pdm文件「建议收藏」

    若数据源里没有oracle驱动程序直接在“控制面板—管理工具—-数据源(ODBC)”打开数据源配置,发现只有SQLServer的驱动,其他的都没有了。解决方法是:C:\Windows\SysWOW64在该目录下找到:odbcad32.exe这个文件,双击打开。点击添加按钮,选择 oracleinoraDb10g_home1驱动,然后就可用添加连接Oracle的O

  • Wget 下载系列小记|使用linux centos wget下载 oracle 数据库| How do I download oracle databases on centos using wge…

    Wget 下载系列小记|使用linux centos wget下载 oracle 数据库| How do I download oracle databases on centos using wge…一、wget下载说明1、普通版wget”download_url”-Ofile_nameORcurl”download_url”-ofile_name2wget–load-cookies=./cookies.txt–no-check-certificate”file_url”-Ofile_nameORcurl–location–cooki…

  • dump 分析工具_一键全扒网站工具

    dump 分析工具_一键全扒网站工具ProcDumpProcDump是一个命令行实用程序,其主要目的是监视应用程序的CPU峰值,并在峰值期间生成崩溃转储,管理员或开发人员可以使用它来确定峰值的原因。ProcDump还包括挂起窗口监视(使用与Windows和任务管理器使用的窗口挂起相同的定义)、未处理的异常监视,并且可以根据系统性能计数器的值生成转储。它还可以作为一个通用的进程转储实用程序,您可以将其嵌入到其他脚本中。官网DebugDiag调试诊断工具(DebugDiag)旨在帮助解决任何用户模式进程中的挂起、性能缓慢、内存泄漏

  • 手机解锁侧面好用还是屏下指纹好用_侧边指纹怎么锁屏

    手机解锁侧面好用还是屏下指纹好用_侧边指纹怎么锁屏说起手机解锁方式,目前智能手机市场上基本上都采用的是屏下指纹、后置指纹和侧面指纹。不少人觉得在一些表现上侧面指纹不如其他两种解锁方式,其实你低估了侧面指纹,它远远比你想象中的还强大!一、外观一体化相比那些搭载后置指纹解锁技术的手机,手机搭载侧面指纹会更加的美观。它既不破坏手机正面屏幕,也不破坏背面机身的完整性,保证了机身的一体化。二、增大用户的解锁姿势相比后置指纹和屏下指纹解锁,侧面指纹简直…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号