uboot命令行启动kernel

原文:https://blog.csdn.net/motianjie/article/details/131244104

uboot命令行启动内核
1:开机停留在uboot界面,即uboot处于board_r.c中的run_main_loop()的死循环中
2:确保rootfs,kernel和dts已烧写在emmc或者sd卡
3:

setenv bootargs " CONFIG_BOOTARGS_LOGLEVEL \
" root=${mmcroot} earlycon isolcpus=2,3" \

展开为setenv bootargs root=/dev/mmcblk0p1 rootwait rw earlycon isolcpus=2,3

bootargs
主要用来传递参数给内核,主要是传递调试串口,根文件系统位置以及用户自定义的参数
root
用来设置根文件系统的位置, root=/dev/mmcblk0p1表示根文件系统在/dev/mmcblk0p1中,必须指定root位置,否则无法正常启动
isolcpus
用来设置CPU 2,3隔离
4:ext4load mmc ${mmcdev}:${mmcpart_Startup_A} ${loadaddr} ${image}
展开为:ext4load mmc 0:5 0x80080000 Image-ETH
意思是从emmc 0号设备的第五分区加载名为Image-ETH的kernel至DDR 0x80080000位置,所以kernel应提前烧写至emmc第五分区中
5:ext4load mmc ${mmcdev}:${mmcpart_Startup_A} ${fdt_addr} ${fdt_file}
展开为ext4load mmc 0:5 0x83E00000 fsl-s32v234sbc-ETH.dtb
意思是从emmc 0号设备的第五分区加载名为fsl-s32v234sbc-ETH.dtb的设备树至DDR 0x83E00000 位置,所以设备树应提前烧写至emmc第五分区中
6:${boot_mtd} ${loadaddr} - ${fdt_addr}
展开为:booti 0x80080000 - 0x83E00000
意思为:启动Linux Kernel,运行完后则跳出uboot开始启动内核,完成uboot到内核的引导过程
————————————————
版权声明:本文为CSDN博主「motianjie」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/motianjie/article/details/131244104

posted @   MaxBruce  阅读(165)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2021-09-24 MvvmLight框架使用入门(三)
2021-09-24 C#将枚举类型转化为字符串及枚举类型常用操作
点击右上角即可分享
微信分享提示