拿到内核,首先进行编译选项配置,make menuconfig,对内核编译选项作配置,
最后保存的结果会存放在源码目录下的.config文件下。对应的模块的值被赋值成Y,N,M
Y表示要编译进内核,N表示不编译进内核也不编译成模块,M将代码编译成模块通过insmod插入使用。
这个配置界面是专门有个系统维护的,如果我们要把自己的东西添加到编译选项中去,得使用Kconfig文件。
建立Kconfig
menuconfig SHREK6410_DRV 在配置界面里的名称,也就是一个大的集合,包括下面好多选项
bool "Drivers for shrek6410 board" 右面的英文为对于这个选项的注释,bool 表示这个选项的类型,只能选择TRUE/FALSE
help
Test driver for s3c6410
if SHREK6410_DRV 如果上面的menuconfig SHREK6410_DRV 选择了,则会出现一下的选项,如果上面的没有选择则一下的选项则不显示
config CHAR01 SHREK6410_DRV这个大选项下面的第一个小功能模块,tristate表示有三种选择,Y,N,M
tristate "char driver for single file"
help
char01
endif
对应模块的配置选项会保存在.config中如下所示
CONFIG_MY_6410_DRV=y
CONFIG_CHAR01=y
然后编写Makefile
obj-$(CONFIG_CHAR01) += mem_test01.o
CONFIG_CHAR01随着配置文件的配置而改变,当makefile的时候会根据.config将CONFIG_CHAR01对应的值替换到Makefile中(Y,N,M),其实
obj-y,obj-n,obj-m这三个变量,然后根据配置文件就将模块添加到对应的变量上,内核Makefile对三个变量实行不同的编译方法,这就是
内核Makefile和Kconfig联合使用的原理。
Kconfig需要被添加到上一层的Kconfig以便于被找到。但是2.6.28内核需要将Kconfig目录添加到arch/arm/Kconfig中去,
source "drivers/arm-drv/Kconfig"
了解了这么些内容之后可以对内核进行配置和编译了:
修改大内核的Makefile
Makefiel中 := ?==之间的区别,:=会把文件中所有的定义一下都被替换,=则不是一下全部替换完,而是用一个替换一个,
?=则表示,如果在之前没有定过的则现在定义,如果之前定义过的那就不定义了
ARCH := arm 使用arm-linux-gcc编译
CROSS_COMPILE := arm-linux-
然后进行make menuconfig配置
然后make编译内核,存放在arch/arm/boot/zImage下面,这个就可以用于板子的启动了。
内核编译的大流程:
编译成.o的文件,并且选项是y的.o文件--->通过ld连接成vmlinux(这个是具有ELF头)的文件---->通过objcopy去掉ELF头,成为vmlinux.bin
---->通过gzip压缩有成为vmlinux.bin.gz文件---->然后将gz的解压程序和vmlinux.bin存放在一起---->成为了zImage
然后通过make module_install将.ko的文件拷贝到/lib/modules/目录下
然后使用make install安装
最后将zImage复制到/boot的目录下,然后应该就可以引导了PC了
Kconfig、Makefile及编译使用.rar
如果有些模块不想和内核一起编译,当然也可以利用内核的Makefile为你的代码进行单独的定制,Makefile编写如下:
obj-m := led_test.o
KERNEL := /lib/modules/`uname -r`/build //填写内核Makefile所在的目录
all:
make -C $(KERNEL) M=`pwd` modules //-C 表示调用KERNEL目录下的Makefile
install:
make -C $(KERNEL) M=`pwd` modules_install
depond -A //检测模块建的以来关系
clean:
make -C $(KERNEL) M=`pwd` clean
阅读(599) | 评论(0) | 转发(0) |