ARM Linux移植是一个系统性工程,涉及硬件适配、软件配置和调试优化等多个环节,以下是详细的移植步骤,分为准备阶段、Bootloader移植、内核移植、根文件系统制作与烧写,以及测试与调试五个核心部分。

移植前准备
硬件平台调研
明确目标硬件的处理器架构(如ARMv7、ARMv8)、具体型号(如Cortex-A53、Raspberry Pi 4)、外设接口(UART、Ethernet、SPI、I2C等)以及存储介质(eMMC、NAND Flash、SD卡),获取开发板原理图、数据手册和芯片参考设计,这是后续驱动适配的基础。软件环境搭建
- 交叉编译工具链:选择与目标架构匹配的工具链,如ARM 32位架构常用
arm-linux-gnueabihf-gcc,64位架构用aarch64-linux-gnu-gcc,工具链版本需与内核版本兼容(如Linux 5.4推荐gcc 7.x以上)。 - 开发主机系统:推荐Ubuntu 18.04/20.04,预装
build-essential、libncurses-dev等依赖包,用于内核编译和配置。 - 文档与源码:下载Linux内核源码(kernel.org)、U-Boot源码(denx.de)及BusyBox源码(busybox.net),确保版本稳定且社区支持良好。
- 交叉编译工具链:选择与目标架构匹配的工具链,如ARM 32位架构常用
Bootloader移植(以U-Boot为例)
Bootloader负责初始化硬件、加载内核和设备树,是系统启动的第一步。
获取与配置U-Boot
下载适用于目标开发板的U-Boot版本(或从厂商获取定制源码),进入源码目录后,执行:make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf <board>_defconfig # 如smdk2410_defconfig
若无现成配置,可基于相近开发板修改
configs/目录下的配置文件。修改设备树与编译
U-Boot依赖设备树描述硬件信息,需修改arch/arm/dts/下的设备树文件(如.dts),调整串口、时钟、存储控制器等节点,编译命令:make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf -j4
编译成功后生成
u-boot.bin,通过JTAG/SD卡烧写到开发板。基础功能测试
启动后通过串口进入U-Boot命令行,检查printenv环境变量,确保bootcmd(启动命令)和bootargs(内核参数)配置正确,如:setenv bootargs 'console=ttyS0,115200 root=/dev/mmcblk0p2 rw rootwait' saveenv
Linux内核移植
内核是系统的核心,需适配硬件驱动和系统调用。

内核配置
下载内核源码并解压,执行:make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf menuconfig
关键配置项:
- 处理器类型:选择对应CPU(如
ARMv7-A)。 - 设备树支持:启用
Device Tree Support和Device Tree Compiler。 - 驱动配置:开启串口(
Serial drivers)、网卡(Ethernet drivers)、存储(MMC/SD/SDIO)等外设驱动,关闭不需要的功能(如Sound card support)以减小内核体积。
- 处理器类型:选择对应CPU(如
编译内核与设备树
内核编译:make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf -j4 zImage dtbs
生成
arch/arm/boot/zImage(内核镜像)和arch/arm/boot/dts/<board>.dtb(设备树 blob)。适配设备树
根据硬件原理图修改.dts文件,- 调整串口节点(
compatible属性、寄存器地址)。 - 配置内存节点(
reg属性中的起始地址和大小)。 - 添加外设节点(如
ethernet、spi等),编译后替换开发板中的设备树文件。
- 调整串口节点(
根文件系统制作与烧写
根文件系统提供用户空间运行环境,常用BusyBox制作最小系统。
BusyBox配置与编译
下载BusyBox源码,执行:make menuconfig
勾选
Build static binary(静态编译),并选择必要的工具(如sh、ls、ifconfig等),编译安装:make CROSS_COMPILE=arm-linux-gnueabihf install
安装后生成
_install目录,包含bin、sbin、etc等子目录。
创建根文件系统
在_install目录下创建必要设备节点(mknod dev/console c 5 1)和配置文件(inittab、fstab),例如/etc/inittab:::sysinit:/etc/init.d/rcS ::askfirst:-/bin/sh
使用
genext2fs或mkfs.jffs2制作镜像文件:genext2fs -d _install -b 16384 -i 8192 rootfs.ext2
烧写与启动
将内核(zImage)、设备树(.dtb)和根文件系统(rootfs.ext2)通过U-Boot烧写到存储介质(如SD卡),并修改bootargs指向根文件系统位置:setenv bootargs 'console=ttyS0,115200 root=/dev/mmcblk0p2 rootfstype=ext2 rw rootwait' saveenv; bootz ${loadaddr} ${fdtaddr} ${fdtsize}
测试与调试
启动系统后,通过串口观察日志,检查内核是否正确识别硬件(如dmesg | grep mmc),网络是否可用(ifconfig eth0 up),文件系统是否挂载(df -h),若启动失败,可通过以下方式调试:
- 串口打印:在内核代码中添加
printk输出关键信息。 - 工具链调试:使用
arm-linux-gnueabihf-gdb连接开发板进行远程调试。
FAQs
Q1:ARM Linux移植中常见的启动失败原因有哪些?
A:常见原因包括:① 设备树配置错误(如内存节点地址不匹配);② 内核缺少必要驱动(如存储控制器或串口驱动未开启);③ 根文件系统路径错误(bootargs中root=参数指向的设备不存在);④ 硬件连接问题(如SD卡接触不良、串口波特率不匹配),可通过串口打印日志逐步定位问题。
Q2:如何选择合适的交叉编译工具链?
A:选择工具链需考虑三点:① 架构匹配:32位ARM选arm-linux-gnueabihf,64位选aarch64-linux-gnu;② 版本兼容:工具链的GCC版本需与内核版本适配(如Linux 5.10推荐GCC 8.x以上);③ 厂商优化:部分芯片厂商(如瑞芯微、全志)提供定制工具链,针对硬件性能优化,优先选择厂商推荐版本。
【版权声明】:本站所有内容均来自网络,若无意侵犯到您的权利,请及时与我们联系将尽快删除相关内容!
发表回复