I.MX6Q(TQIMX6Q/TQE9)学习笔记——内核启动与文件系统挂载

经过前面的移植,u-boot已经有能力启动内核了,本文主要来看下如何通过之前移植的u-boot来启动内核。如果按照前面的文章完成了LTIB的编译,那么,Linux的内核应该就会出现rpm/BUILD/目录下,接下来,我们就开始移植这个3.0.35版本的内核到TQIMX6Q。

内核的编译

为了简化内核编译的过程,可以在内核目录下创建编译脚本,命名为build.sh,内容如下:

#!/bin/sh

export ARCH=arm
export CROSS_COMPILE=/opt/freescale/usr/local/gcc-4.6.2-glibc-2.13-linaro-multilib-2011.12/fsl-linaro-toolchain/bin/arm-none-linux-gnueabi-
make uImage -j8

为该脚本添加可执行权限:

chmod a+x build.sh

由于本文使用的内核镜像格式是uImage,因此会依赖u-boot编译时生成的工具——mkimage。该工具为u-boot目录的tools子目录下,可以将mkimage拷贝到/usr/bin或者/usr/local/bin目录下,当然也可以是用环境变量PATH,方法如下:

export PATH=$PATH:~/Projects/imx6/L3.0.35_4.1.0/ltib/rpm/BUILD/u-boot-2009.8/tools
安装路径需要根据自己的实际情况填写。完成以上操作之后就可以编译内核了,执行脚本程序:

./build.sh
内核的编译时间较长,需耐心等待,也与机器的配置有关。

内核启动尝试

内核编译完成后,uImage会出现在arch/arm/boot/目录下,将该镜像烧写到SD卡:

sudo dd if=arch/arm/boot/uImage of=/dev/sdb bs=512 seek=2048
sync
然后用SD卡启动开发板,按任意键打断u-boot启动,进入命令行,修改u-boot环境变量:

setenv bootargs_base 'setenv bootargs console=ttymxc0,115200'
setenv bootargs_mmc 'setenv bootargs ${bootargs} root=/dev/mmcblk1p1 rootwait rw'
setenv bootcmd_mmc 'run bootargs_base bootargs_mmc; mmc dev 1; mmc read ${loadaddr} 0x800 0x2000; bootm'
setenv bootcmd 'run bootcmd_mmc'
saveenv
以上指令的含义:

第一条:bootargs_base,维持默认状态,作用是在bootargs中指定串口终端及波特率。
第二条:bootargs_mmc,是MMC方式启动内核使用的bootargs特有参数。
第三条:bootcmd_mmc,是MMC方式启动特有的命令组合。
第四条:bootcmd是内核启动命令。
第五条:保存env到SD存储介质。

完成之后执行命令:

boot
或者重新上电开发板就可以启动内核了。

内核的修改

通过上面的设置,u-boot已经可以引导内核启动了,但是,内核启动后仅打印了一部分log,猜测是内核中UART的GPIO管脚配置不正确,开始一段log能打印出来是因为u-boot阶段配置好了UART,而内核中又将这两个引脚配置为其它用途了。首先来解决串口log问题,打开文件arch/arm/mach-mx6/board-mx6q_sabresd.h并作如下修改:

... ...
/* UART1 for debug */
// MX6Q_PAD_CSI0_DAT10__UART1_TXD,
MX6Q_PAD_SD3_DAT7__UART1_TXD,
// MX6Q_PAD_CSI0_DAT11__UART1_RXD,
MX6Q_PAD_SD3_DAT6__UART1_RXD,
... ...
其实,u-boot已经作过相应的修改,修改UART1相关的配置信息,除了以上修改之外,还需要将SD3与串口冲突的两个引脚:

/* USDHC3 */
MX6Q_PAD_SD3_CLK__USDHC3_CLK_50MHZ,
MX6Q_PAD_SD3_CMD__USDHC3_CMD_50MHZ,
MX6Q_PAD_SD3_DAT0__USDHC3_DAT0_50MHZ,
MX6Q_PAD_SD3_DAT1__USDHC3_DAT1_50MHZ,
MX6Q_PAD_SD3_DAT2__USDHC3_DAT2_50MHZ,
MX6Q_PAD_SD3_DAT3__USDHC3_DAT3_50MHZ,
// MX6Q_PAD_SD3_DAT4__USDHC3_DAT4_50MHZ,
// MX6Q_PAD_SD3_DAT5__USDHC3_DAT5_50MHZ,
// MX6Q_PAD_SD3_DAT6__USDHC3_DAT6_50MHZ,
// MX6Q_PAD_SD3_DAT7__USDHC3_DAT7_50MHZ,
MX6Q_PAD_NANDF_D0__GPIO_2_0,      /* SD3_CD */
MX6Q_PAD_NANDF_D1__GPIO_2_1,      /* SD3_WP */
注释掉以上四行。保存后重新编译内核并烧写到SD卡,重新启动开发板会发现内核已经可以正常打印启动Log了。接下来将LTIB编译生成的rootfs烧写到开发板,并使用编译好的内核挂载该文件系统。

挂载文件系统

文件系统的构建方式都差不多,这里就不再自己构建了,直接使用LTIB编译时生成的文件系统。

将SD卡插ubunut上,对该SD卡进行分区:

sudo fdisk /dev/sdb
然后如下操作:

Step1: 通过指令u切换到sectors模式。输入u后回车,fdisk会在sectors模式和cylinders模式间切换,这里切换到sectors模式。

Step2:通过d指令删除原来的分区。重复的输入d并回车,可以删除SD卡原有的分区,知道没有任何分区为止。

Step3:通过n指令新建分区。输入n并回车。

Step4:输入分区编号。这里输入数字1。

Step5:输入分区的起始位置。该位置是sectors为单位的,每个sector的大小为512B,这里偏移8M,给内核留下足够的存储空间,输入16384并回车。

Step6:输入分区的结束为止。直接使用默认值,即到达SD卡的末尾,故直接回车即可。

Step7:保存分区信息。输入指令w并回车。

这样就完成了SD卡的分区,接下来需要将该分区格式化

评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值