vmlinux在链接时,使用的文件是在vmlinux-all中定义的所有文件,链接俄脚本是在arch/arm/kernel/vmlinux.lds中定义该如何
链接这些文件。
总结上面:
真个的 linux的源码是通过Makefile来实现项目的 管理的,顶层的Makefile定义了那些文件夹 中的 内容 被编译进内核,各级
的子目录下的Makefile决定该目录下的那些文件被编译进内核。 对于编译选项的设置的话,存在全局的,局部的和仅对一个文件
起作用的选项。
3.内核的Kconfig文件的 分析
在linux内核目录下,如果直接使用make menuconfig的话,出现的配置界面就是使用的是Kbuild来实现的。最终通过make
menuconfig生成的.config文件,最终这个.config文件被Makefile读取。具体的信息可以参见Documentation/kbuild/kconfig-language.txt
4.linux内核的配置选项
参考:
http://www.chinaunix.net/jh/4/1051808.html
http://www.linuxfocus.org/ChineseGB/July2002/article252.shtml
有十分丰富的资料。下面只是简单的介绍一下。
Code maturity level options -- 代码成熟度选项,一般不选
General setup -- 常规设置,除非很熟悉其中的内容,否则直接使用默认的选项即可
Loadable module support -- 一般的内核设置中都将这个功能打开,允许内核动态的加在某个模块
Block layer -- 块设备层,这里的参数主要是从总体上来 配置块设备的,一般使用默认值
System Type -- 选择与cpu的类型和开发板类型等信息
Bus Support -- 选择总线类型
Kernel Feature -- 设置内核的参数,比如是否支持内核枪战等特性
Boot Option -- 启动参数,一般采用默认的值
Floating point emulation -- 浮点原算仿真功能,目前的linux还不支持硬件的浮点运算,所以要选择一个,一般选择NWFPE math emulation
Userspace binary formats -- 内核支持的二进制格式,一般选择elf,a.out等格式
Power management options -- 电源选项
Networking -- 网络选项根据开发板的不同,可以适当的选择
Device Drivers -- 设备驱动程序,其中几乎包含了linux下所有的设备驱动程序
File systems -- 在其中选择支持的文件系统,比如yaffs2
Kernel hacking -- 内核监视,一般不选,kernel hacking往往会生成非常大或者非常慢(甚至又大又慢)的内核,甚至会引
起内核工作不稳定。如果一定要选,那么也最好不要选其中的"development"、"experimental"、"debugging"
项。
Security options -- 安全选项,一般使用默认值
Cryptographic options -- 加密选项,全部删除,一般不使用
Library routines -- 第三方的库文件,可以全不选,但是如果内核中的恰部分需要的话,会自动选上
5.linux内核启动过程
linux内核的启动过程分为两个阶段,首先第一个阶段是引导阶段,这部分的代码大多使用汇编语言来编写,主要的作用是
检查当前的内核是否支持当前架构的cpu,然后检查内核是否支持当前的开发板,如果能够通过检查的话,那么开始为
start_kernel函数作准备。
1设置也表,使能MMU
2.条用函数start_kernel 之前的 常规工作,包括设置数据段,清除bss段,call指令调用函数start_kernel
第二阶段主要是使用c语言来编写,调用一系列的函数来初始化相应的硬件。
到此准备工作完成,下面开始正真的代码的移植。。。