下载内核
您可以从基于内核 4.4 的 github 克隆 Rockchip 内核存储库:
data:image/s3,"s3://crabby-images/e0a1b/e0a1bdd31bd8f9014f8f3084c5488defe55f3fe6" alt=""
支持的 SoC 和设备
瑞芯微内核 4.4 支持:
RK3036、RK3066、RK312X、RK3188、RK322X、RK3288、 RK3328、RK3368、 RK3399、PX30
配置和构建
对于 Linux 操作系统,您需要使用 rockchip_linux_defconfig
对于 ARM v7
data:image/s3,"s3://crabby-images/52864/52864764f9cefc1391b69f427c47eb7dfcb17b51" alt=""
适用于 ARM V8
data:image/s3,"s3://crabby-images/285d9/285d90a8497c578dc46f44f724ebc7ce6336448c" alt=""
然后你可以得到 Image/zImage 和 dtb 文件并用于 LInux Distro 启动。
瑞芯微 RKIMG 格式图片
RKIMG 是瑞芯微根据 Android 启动镜像定制的格式,通常只供内核开发者使用。它由瑞芯微 U-Boot 支持。
例如,使用以下命令构建 rk3399-evb:
data:image/s3,"s3://crabby-images/a888b/a888b2f8572e301445c17b0de3707ae0e0704348" alt=""
输出如下,boot.img 是带有rockchip header 的ramdisk,kernel 是带有rockchip header 的zImage/Image,resource 是dtb 和带有rockchip header 的boot logo。
data:image/s3,"s3://crabby-images/6fa0e/6fa0ec2a49c394e3bd2cd16a288c2af147d8e19d" alt=""
为发行版安装引导/内核
我们在 U-Boot 中使用发行版引导,因此我们需要为 U-Boot 创建一个引导分区,其中包含内核映像和 dtb。
data:image/s3,"s3://crabby-images/7763b/7763bf1096e11bddf3c93c972f12bbaa9afbbac7" alt=""
添加 extlinux/extlinux.conf 用于发行版引导。
data:image/s3,"s3://crabby-images/32a3c/32a3c2cd2315707f83f8fb0b32f283317e9ed4cf" alt=""
data:image/s3,"s3://crabby-images/6f8ab/6f8abd0a10583f948b7504f289c4f9982046f767" alt=""
对于 armv7
data:image/s3,"s3://crabby-images/63864/638648bd70d5365611f06565eda39dcba0c009ba" alt=""
您需要更改调试 UART 的基地址,您的板的根分区。
请参考 Rockchip Linux 分区定义 的 rootfs 分区和引导到闪存的位置。
在所有这些文件都准备好之后,我们将文件写入引导分区
armv8 的文件夹树(rk3399,rk3328):
data:image/s3,"s3://crabby-images/90806/90806f260bfe95f8c77f70289ac57118ed60dcfd" alt=""
armv7(rk3288) 的文件夹树,rootfs 是可选的,我们通常使用压缩的 'zImage':
data:image/s3,"s3://crabby-images/5a9b5/5a9b5296d26d8696d05e3fb41465b74f94ad290f" alt=""
生成 ext2fs 引导分区
通过 genext2fs:
data:image/s3,"s3://crabby-images/138e8/138e86ef326f3d8e6ad54e1aef1e781443afbbe0" alt=""
根据瑞芯微分区定义,你需要刷这个镜像来启动偏移为0x8000的分区。
生成fatfs引导分区
在fatfs中生成boot.img
下面的命令可以生成一个fatfs boot.img
data:image/s3,"s3://crabby-images/38065/380651b54a729d61b2c0fb53eb8f9c72ebf306cb" alt=""
完毕!
将此 boot.img 刷写到启动分区,在 Rockchip 分区定义中偏移 0x8000。
通过目标中的 U-Boot 更新 boot.img
刷机并启动 U-Boot 后,从默认分区表写入 gpt 表
data:image/s3,"s3://crabby-images/b3194/b31946aa19ceeb000a599e766ec3b7d9b06ccea9" alt=""
将目标连接到 PC 并在命令行中启动 ums:
data:image/s3,"s3://crabby-images/7ce62/7ce620c68418a4fd6691c771d2787dcdf0b3dce6" alt=""
我们应该能够看到一个设备连接到 PC,格式化并将数据复制到分区(例如 dev/sdb6)。
data:image/s3,"s3://crabby-images/dded9/dded9e2eccd45c6e53aa8699e83970c0d9c3c95a" alt=""
完毕!
从 U-Boot 启动
如果您使用 genext2fs 生成 boot.img,则需要在 U-Boot 命令行中写入 gpt 表:
data:image/s3,"s3://crabby-images/77b14/77b14367cf16657b944f61bfe6b6f497503cf7e3" alt=""
然后从 eMMC 启动或重置:
data:image/s3,"s3://crabby-images/ab204/ab2043a80484b4f119781522e42aff7a0fd8ea4b" alt=""
如果一切正常,您应该能够看到这样的 U-Boot 日志:
data:image/s3,"s3://crabby-images/7a67f/7a67f54d80b6ac7b525269871144214d69b72eb9" alt=""
原作者:Rockchip wiki
|