1.Makefile的作用

(1)决定编译哪些文件

(2)怎样编译这些文件

(3)怎样连接这些文件,最重要的是它们的顺序如何

2.Linux内核Makefile分类

*********************************************************************

顶层Makefile:它是所有Makefile文件的核心,从总体上控制着内核的编译、

连接

.config    :配置文件,在配置内核时生成,所有Makefile文件(包括顶层

目录及各级子目录)都是根据.config来决定使用哪些文件

arch/$(ARCH)/Makefile:对应于体系结构的Makefile,它用来决定哪些体系结

构相关的文件参与内核的生成,并提供一些规则来生成

特定格式的内核映像

scripts/Makefile.* : Makefile共用的通用规则、脚本等

kbuild Makefile :各级子目录下的Makefile,被上一层Makefile调用来编译

当前目录下的文件

*********************************************************************

3.根据Makefile的作用分析这5类文件

(1)决定编译哪些文件

Linux内核的编译过程从顶层Makefile开始,然后递归地进入各级子目录调用它们的Makefile,分为3个步骤:

(1)顶层Makefile决定内核根目录下哪些子目录将被编译进内核

在顶层Makefile中有如下内容:

init-y       := init/

drivers-y := drivers/ sound/ firmware/

net-y     := net/

libs-y       := lib/

core-y       := usr/

......................

core-y      += kernel/ mm/ fs/ ipc/ security/ crypto/ block/

顶层Makefile将这13个子目录分为5类,除去include目录和后面不包

含内核源码的目录外,还有一个arch目录在arch/$(ARCH)/Makefile中被包

含进内核,在顶层Makefile中直接包含了这个Makefile,如下所示:

452   include $(srctree)/arch/$(SRCARCH)/Makefile

(2)arch/$(ARCH)/Makefile决定arch/$(ARCH)目录下哪些文件、哪些目录将

被编译进内核

在arch/arm/Makefile中有如下内容:

100   head-y      := arch/arm/kernel/head$(MMUEXT).o

arch/arm/kernel/init_task.o

...............................................

196   core-y  += arch/arm/kernel/ arch/arm/mm/ arch/arm/common/

197   core-y  += $(machdirs) $(platdirs)

198   core-$(CONFIG_FPE_NWFPE)  += arch/arm/nwfpe/

199   core-$(CONFIG_FPE_FASTFPE)   += $(FASTFPE_OBJ)

200   core-$(CONFIG_VFP)    += arch/arm/vfp/

...............................................

204   libs-y    := arch/arm/lib/ $(libs-y)

第100行中MMUEXT在arch/arm/Makefile前面定义,对于没有MMU的处

理器,使用文件head-nommu.S;对于有MMU的处理器,使用head.S文件

CONFIG_XXXX在配置内核时定义,它的值有3种:y、m或空

编译内核时将依次进入init-y、core-y、libs-y、drivers-y和net-y

所列出的目录中执行它们的Makefile,每个子目录都会生成一个

built-in.o(libs-y所列的目录下,有可能生成lib.a文件)。最后,head-y

所表示的文件将和这些built-in.o、lib.a一起被连接成内核映像文件

vmlinux

(3)各级子目录下的Makefile决定所在目录下哪些文件将被编译进内核,哪

些文件将被编译成模块(驱动程序),进入哪些子目录继续调用它们的

Makefile

在配置内核时,生成配置文件“.config”,根据.config中定义的各

个变量决定编译哪些文件,Makefile使用如下语句间接包含.config文

件(因为包含的是"include/config/auto.conf"文件):

486   -include include/config/auto.conf

在"include/config/auto.conf"文件中,变量的值为y或m

1)obj-y用来定义哪些文件被编进(built-in)内核

obj-y中定义的.o文件由当前目录下的.c或.S文件编译生成,

它们连同下级子目录的built-in.o文件一起被组合成(使用

“$(LD)-R”命令)当前目录下的built-in.o文件,这个built-in.o

文件被它的上一层Makefile使用

2)obj-m用来定义哪些文件被编译成可加载模块(Loadable module)

obj-m中定义的.o文件由当前目录下的.c或.S文件编译生成,

它们被编译成模块,一个模块可以由一个或几个.o文件组成,对于

有多个源文件的模块,除在obj-m中增加一个.o文件外,还要定义

一个<module_name>-objs变量来告诉Makefile这个.o文件由哪些

文件组成

例如:

obj-$(CONFIG_ISDN) += isdn.o

isdn-objs := isdn_net_lib.o  isdn_v110.o  isdn_common.o

3)lib-y用来定义哪些文件被编成库文件

liy-y中定义的.o文件由当前目录下的.c或.S文件编译生成,

它们被打包成当前目录下的一个库文件:lib.a ;同时出现在

obj-y和lib-y中的.o文件,不会被包含进lib.a中,要把这个

lib.a编译进内核中,需要在顶层Makefile中libs-y变量中列出

当前目录

4)obj-y、obj-m还可以指定要进入的下一层子目录

obj-$(CONFIG_JFFS2_FS)   +=  jffs2/

(2)怎样编译这些文件----编译选项、连接选项是什么

这些选项可分为3类:

1)全局的

适用于整个内核代码,在顶层Makefile和arch/$(ARCH)/Makefile中

定义,这些选项的名称为CFLAGS(编译C文件的 选项)、AFLAGS(编译汇编

文件的选项)、LDFLAGS(连接文件的选项)、 ARFLAGS(制作库文件的选项)

2)局部的

在各个子目录中定义,针对当前Makefile中的所有文件,名称分别

为:EXTRA_CFLAGS、EXTRA_AFLAGS、EXTRA_LDFLAGS、EXTRA_ARFLAGS

3)个体的

仅适用于某个文件,如果想针对某个文件定义它的编译选项,可以使

用CFLAGS_$@, AFLAGS_$@,前者用于编译某个C文件,后者用于编译某

个汇编文件。$@表示某个目录文件

(3)怎样连接这些文件,它们的顺序如何

在顶层Makefile中,目录名的后面直接加上built-in.o或lib.a,表示

要连接进内核的文件,如下所示:

init-y      := $(patsubst %/, %/built-in.o, $(init-y))

core-y      := $(patsubst %/, %/built-in.o, $(core-y))

drivers-y   := $(patsubst %/, %/built-in.o, $(drivers-y))

net-y       := $(patsubst %/, %/built-in.o, $(net-y))

libs-y1     := $(patsubst %/, %/lib.a, $(libs-y))

libs-y2     := $(patsubst %/, %/built-in.o, $(libs-y))

libs-y      := $(libs-y1) $(libs-y2)

patsubst是个字符串处理函数,它的用法如下:

$( patsubst  pattern, replacement, text)

表示寻找“text”中符合格式“pattern”的字,用“replacement”代替

它们,比如init-y的初值为“init/”,经过变换后变为“init/built-in.o”

再如下所示:

vmlinux-init := $(head-y) $(init-y)

vmlinux-main := $(core-y) $(libs-y) $(drivers-y) $(net-y)

vmlinux-all  := $(vmlinux-init) $(vmlinux-main)

vmlinux-lds  := arch/$(SRCARCH)/kernel/vmlinux.lds

vmlinux-all表示所有构成映象文件vmlinux的目标文件,可知这些目标文件的顺序为head-y、init-y、core-y、libs-y、drivers-y、net-y

4.总结

(1)配置文件.config中定义了一系列的变量,Makefile将结合它们来决定哪些

文件被编译进内核、哪些文件被编译成模块、涉及哪些子目录

(2)顶层Makefile和arch/$(ARCH)/Makefile决定根目录下哪些子目录、

arch/$(ARCH)目录下哪些文件和目录将被编译进内核

(3)各级子目录下的Makefile决定所在目录下的哪些文件将被编译进内核,哪些

文件被编译成模块(即驱动程序),进入哪些子目录继续调用它们的Makefile

(4)顶层Makefile和arch/$(ARCH)/Makefile设置了可以影响所有文件的编译、

连接选项,即全局选项

(5)各级子目录下的Makefile中可以设置影响当前目录下所有文件的编译、连接

选项,即局部选项

(6)顶层Makefile按照一定的顺序组织文件,根据连接脚本arch/$(ARCH)

kernel/vmlinux.lds生成内核映象文件vmlinux

linux源码Makefile详解的更多相关文章

  1. linux源码Makefile详解(完整)【转】

    转自:http://www.cnblogs.com/Daniel-G/p/3286614.html 随着 Linux 操作系统的广泛应用,特别是 Linux 在嵌入式领域的发展,越来越多的人开始投身到 ...

  2. linux源码Makefile详解(完整)

    转自:http://www.cnblogs.com/Daniel-G/p/3286614.html 随着 Linux 操作系统的广泛应用,特别是 Linux 在嵌入式领域的发展,越来越多的人开始投身到 ...

  3. linux 源码安装详解

    ./configure是用来检测你的安装平台的目标特征的.比如它会检测你是不是有CC或GCC,并不是需要CC或GCC,它是个shell脚本.make是用来编译的,它从Makefile中读取指令,然后编 ...

  4. NopCommerce源码架构详解--初识高性能的开源商城系统cms

    很多人都说通过阅读.学习大神们高质量的代码是提高自己技术能力最快的方式之一.我觉得通过阅读NopCommerce的源码,可以从中学习很多企业系统.软件开发的规范和一些新的技术.技巧,可以快速地提高我们 ...

  5. NopCommerce源码架构详解

    NopCommerce源码架构详解--初识高性能的开源商城系统cms   很多人都说通过阅读.学习大神们高质量的代码是提高自己技术能力最快的方式之一.我觉得通过阅读NopCommerce的源码,可以从 ...

  6. Nop--NopCommerce源码架构详解专题目录

    最近在研究外国优秀的ASP.NET mvc电子商务网站系统NopCommerce源码架构.这个系统无论是代码组织结构.思想及分层都值得我们学习.对于没有一定开发经验的人要完全搞懂这个源码还是有一定的难 ...

  7. Hadoop3.1.1架构体系——设计原理阐述与Client源码图文详解 : 总览

    一.设计原理 1.Hadoop架构: 流水线(PipeLine) 2.Hadoop架构: HDFS中数据块的状态及其切换过程,GS与BGS 3.Hadoop架构: 关于Recovery (Lease ...

  8. Hadoop3.1.1源码Client详解 : 写入准备-RPC调用与流的建立

    该系列总览: Hadoop3.1.1架构体系——设计原理阐述与Client源码图文详解 : 总览 关于RPC(Remote Procedure Call),如果没有概念,可以参考一下RMI(Remot ...

  9. Hadoop3.1.1源码Client详解 : 入队前数据写入

    该系列总览: Hadoop3.1.1架构体系——设计原理阐述与Client源码图文详解 : 总览 紧接着上一篇: Hadoop3.1.1源码Client详解 : 写入准备-RPC调用与流的建立 先给出 ...

随机推荐

  1. mysql语句大全

    转自:http://www.cnblogs.com/yunf/archive/2011/04/12/2013448.html   1.说明:创建数据库 CREATE DATABASE database ...

  2. SharePoint 2010/SharePoint 2013 Custom Action: 基于Site Collection 滚动文字的通知.

    应用场景: 有时候我们的站点需要在每个页面实现滚动文字的通知,怎么在不修改Master Page的情况下实现这个功能?我们可以使用Javascript 和 Custom Action 来实现. 创建一 ...

  3. 面试问到:JDBC、hibernate、ibati

    一.JDBC.Connection(连接) 优点:运行高效.快捷. 缺点:代码多.异常多.不支持跨平台. 二.ibatis 1.根据jdbc的基本建立连接. 2.通过anntation+xml.jav ...

  4. ubuntu下修改ip重启系统ip不变

    今天同学问我ubuntu下ip如何写死,我想起这周在公司我们队长也问过我,我就在这把我实验的方法说一下. 打开终端: sudo vim /etc/network/interfaces 然后按如下修改: ...

  5. spring mvc 学习笔记【1】---前言

    扎扎实实地掌握好技术 ----------------------------------------------------------------------------------------- ...

  6. ios 框架学习笔记

    ios主要的系统层次: 一.Cocoa Touch 层:创建应用程序主要使用的框架. 1.关键技术: AirDrop:实现应用间通信. Text Kit:处理文本和排版. UIKit Dynamics ...

  7. Maven搭建webService (二) 创建服务端---使用web方式发布服务

    今天和大家分享 使用 web方式发布 webService 服务端.客户端 1.首先创建 一个web工程(增加Maven依赖) 2.增加Maven依赖包,如下: <!-- spring core ...

  8. The 10th Zhejiang Provincial Collegiate Programming Contest

    Applications http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5008 string set 专场 #include& ...

  9. GridView 服务端控件添加 js

    针对服务端控件的 CommandField “Delete” 添加 js $("#GridView1").find("a").each( function() ...

  10. Ignore files which are already versioned

    If you accidentally added some files which should have been ignored, how do you get them out of vers ...