交叉編譯Linux核心for ARM 本文以三星S5PC100晶片為例,采用codesourcery公司出品的ARM平台交叉編譯工具鍊,編譯最新的核心源代碼2.6.33。 1. 交叉編譯工具鍊
1) 通路codesourcery官方網站下載下傳最新的ARM交叉編譯工具鍊,目前最新版本是arm-2009q3:
http://www.codesourcery.com/sgpp/lite/arm/portal/package5383/public/arm-none-linux-gnueabi/arm-2009q3-67-arm-none-linux-gnueabi-i686-pc-linux-gnu.tar.bz2 2) 解壓縮後,将其中的bin目錄加入PATH環境變量
解壓縮至/arm-2009q3:
# tar jxvf arm-2009q3-67-arm-none-linux-gnueabi-i686-pc-linux-gnu.tar.bz2 -C / 看看都提供了哪些工具鍊:
# ls -1 /arm-2009q3/bin/
arm-none-linux-gnueabi-addr2line
arm-none-linux-gnueabi-ar
arm-none-linux-gnueabi-as
arm-none-linux-gnueabi-c++
arm-none-linux-gnueabi-c++filt
arm-none-linux-gnueabi-cpp
arm-none-linux-gnueabi-g++
arm-none-linux-gnueabi-gcc
arm-none-linux-gnueabi-gcc-4.4.1
arm-none-linux-gnueabi-gcov
arm-none-linux-gnueabi-gdb
arm-none-linux-gnueabi-gdbtui
arm-none-linux-gnueabi-gprof
arm-none-linux-gnueabi-ld
arm-none-linux-gnueabi-nm
arm-none-linux-gnueabi-objcopy
arm-none-linux-gnueabi-objdump
arm-none-linux-gnueabi-ranlib
arm-none-linux-gnueabi-readelf
arm-none-linux-gnueabi-size
arm-none-linux-gnueabi-sprite
arm-none-linux-gnueabi-strings
arm-none-linux-gnueabi-strip 将bin目錄加入環境變量:
# export PATH=/arm-2009q3/bin:$PATH 2. 核心源代碼
1) 下載下傳最新的核心源代碼
可以到kernel.org下載下傳已經打包的核心源碼檔案,我這裡是通過git下載下傳的:
# git clone http://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git 2) 修改源碼根目錄下的Makefile:
針對ARM交叉編譯,需要修改兩個變量:
ARCH ?= arm
CROSS_COMPILE ?= arm-none-linux-gnueabi- 3) 檢視下目錄結構
# ls -1 /linux-2.6/arch/arm/
Kconfig
Kconfig-nommu
Makefile
boot/
common/
configs/
include/
kernel/
lib/
......
mach-s3c6410/
mach-s5pc100/
mach-s5pv210/
......
mm/
plat-s3c64xx/
plat-s5pc1xx/
......
這裡面包含了流行的ARM晶片支援,其中的“mach-s5pc100”就是我們需要編譯的目标平台。 目錄“configs”包含了各個ARM晶片的預設config檔案:
# ls -1 /linux-2.6/arch/arm/configs/
......
s3c2410_defconfig
s3c6400_defconfig
s5pc100_defconfig
s5pc110_defconfig
s5pv210_defconfig
...... 3. 編譯過程
1) 準備.config檔案
# cp -f /linux-2.6/arch/arm/configs/s5pc110_defconfig /linux-2.6/.config 2) 配置選項
# cd /linux-2.6/
# make menuconfig 3) 開始編譯
# make
......
LD arch/arm/boot/compressed/vmlinux
OBJCOPY arch/arm/boot/zImage
Kernel: arch/arm/boot/zImage is ready #zImage就是壓縮過的核心。 # file arch/arm/boot/compressed/vmlinux
vmlinux: ELF 32-bit LSB executable, ARM, version 1 (SYSV), statically linked, not stripped 4. 安裝新核心
# cp vmlinux ${TESTROOTFS}/boot/vmlinux-2.6.33
# cp System.map ${TESTROOTFS}/boot/System.map-2.6.33
# cp .config ${TESTROOTFS}/boot/config-2.6.33
# make INSTALL_MOD_PATH=${TESTROOTFS} modules_install 5. 驅動編譯
demo.c:
#include <linux/kernel.h>
#include <linux/module.h>
static int demo_init(void){
printk("demo init\n");
return 0;
}
static void demo_exit(void){
printk("demo exit\n");
}
module_init(demo_init);
module_exit(demo_exit);
MODULE_LICENSE("Dual BSD/GPL"); Makefile:
.PHONY: clean
obj-m := mod_template.o
#KDIR := /lib/modules/$(shell uname -r)/build
KDIR := /linux-2.6
PWD := $(shell pwd)
default:
$(MAKE) -C $(KDIR) M=$(PWD) modules
clean:
rm -rf *.ko *.o *.mod.* .H* .tm* .*cmd Module.symvers 6. 本文連結 http://sxg.cublog.cn http://blog.chinaunix.net/u/8754/showart_2189621.html