笔记整理—内核!启动!—uboot部分(1)

2024-09-01 07:36

本文主要是介绍笔记整理—内核!启动!—uboot部分(1),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        常规启动时,各镜像都在SD卡中的各种分区中,内核放在kernel分区,从SD卡到DDR的连接处(内核不需要进行重定位,直接从链接处启动)。uboot从sd卡分区读使用movi命令。

        使用fastboot指令可以查看分区情况;movi read可以用于读取kernel,读取完成后使用bootm启动。

对于x210而言是
movi read kernel 0x30008000
bootm 0x30008000

        kernel指sd卡中的kernel分区,是uboot规定的raw分区,uboot支持远程启动,不用将内核烧写到sd卡中,调试很方便。可使用远程服务器tftp/nfs服务器进行使用。

对于x210而言
tftp 0x30008000 zImage-qt
bootm 0x30008000

        意思就是从tftp服务器下载名为zImage-qt的文件到0x30008000的本地内存地址,bootm启动本地内存为0x30008000的内核。

        tftp/nfs服务器下载方式一般用于产品开发;而movi read方法一般用于产品生产。

        bootm指令就是对应了do_bootm函数(命令前加do_xxx可以找到相关的函数)如:

cmd_bootm.c中的do_bootm函数

        do_bootm干了什么:(一行写不下,又英文自动转行,所以用图片代替了)

        kernel还要着如下的常见形式:vmlinuxz、zImage、uImage。

        uboot在编译后通常会产生两种镜像:u-boot是elf格式,在操作系统下能直接执行,但不能进行烧录下载;u-boot.bin使用arm-linux-objcopy转u-boot得到的文件,用于烧录与下载,u-boot.bin就成了(img)镜像。

        在linux内核编译中,会生成一个elf的vmlinux或者vmlinuxz的可执行程序,一般情况下是无法进行烧录的,而且文件大小较大(78M)。

        嵌入式操作系统烧录一般用objcopy工具进行烧录转为镜像文件,但内核不像uboot带有.bin后缀而是叫做Image文件大小为7.5M。

        objcopy压缩文件大小,去除了不需要的部分,原则上该内核已经可以烧录,但还可以进行压缩并在其头部加上解压代码(得到zImage),实现自解压。

        uboot还要另一种内核形式uImage,是从zImage加工得到的。区别在于uImage是uboot加工的,而zImage是linux加工的。

        一个uboot是否支持zImage的启动在于其是否定义了CONFIGE_ZIMAGE_BOOT宏进行的条件编译(mkImage工具)。

        do_bootm在after_header_check之前做文件校验(什么类型的镜像,按照什么样的方法来校验)。

        魔数:代表了某种特定的事物,一般占4个字节,对应x210而言0x016f2818代表zImage。

        一个指令bootm 0x30008000。其中argc=2,argv[0]=bootm,argv[1]=0x30008000。bootm就算不带参数也能执行,会从CFG_LOAD_ADDR的地址运行。

        在zImage头部开始的36~39字节存放着标志着zImage的魔数。从这取出与LINUX_ZIMAGE_MAGIC进行对比,可使用二进制的阅读方法打开这个二进制文件会看到18 28 6F 01这三个数值,看着数字是反的这是大小端的问题。

        image_heater_t是uboot启动内核的标准启动结构头,zImage头信息也是一个数据结构头,但启动时会进行一定的改变,改变完的image_heater_t才能用于zImage的启动(hdr)。

        image结构体源于hdr,在加工后构成完整的images全局变量。

        使用说该过程可归结为:zImage校验->修改zImage头信息->初始化images全局变量->完成校验->after_header_check。

        LEGACY意味废弃的;遗留的。

        uImage的启动方式,在do_bootm函数中,LEGACY是uImage的启动方式,是uboot最早的一种启动版本,但后面被替代了,新的方法为设备树方式(FIT)。设备树是目前的一种新的启动方式,其更新非常快,本集合不会涉及设备树启动方式。

        先写到这,下一章将从boot_get_kernel继续对kernel启动过程进行说明。

这篇关于笔记整理—内核!启动!—uboot部分(1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1126327

相关文章

快速修复一个Panic的Linux内核的技巧

《快速修复一个Panic的Linux内核的技巧》Linux系统中运行了不当的mkinitcpio操作导致内核文件不能正常工作,重启的时候,内核启动中止于Panic状态,该怎么解决这个问题呢?下面我们就... 感谢China编程(www.chinasem.cn)网友 鸢一雨音 的投稿写这篇文章是有原因的。为了配置完

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Redis在windows环境下如何启动

《Redis在windows环境下如何启动》:本文主要介绍Redis在windows环境下如何启动的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Redis在Windows环境下启动1.在redis的安装目录下2.输入·redis-server.exe

解决SpringBoot启动报错:Failed to load property source from location 'classpath:/application.yml'

《解决SpringBoot启动报错:Failedtoloadpropertysourcefromlocationclasspath:/application.yml问题》这篇文章主要介绍... 目录在启动SpringBoot项目时报如下错误原因可能是1.yml中语法错误2.yml文件格式是GBK总结在启动S

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

新特性抢先看! Ubuntu 25.04 Beta 发布:Linux 6.14 内核

《新特性抢先看!Ubuntu25.04Beta发布:Linux6.14内核》Canonical公司近日发布了Ubuntu25.04Beta版,这一版本被赋予了一个活泼的代号——“Plu... Canonical 昨日(3 月 27 日)放出了 Beta 版 Ubuntu 25.04 系统镜像,代号“Pluc

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

一文带你了解SpringBoot中启动参数的各种用法

《一文带你了解SpringBoot中启动参数的各种用法》在使用SpringBoot开发应用时,我们通常需要根据不同的环境或特定需求调整启动参数,那么,SpringBoot提供了哪些方式来配置这些启动参... 目录一、启动参数的常见传递方式二、通过命令行参数传递启动参数三、使用 application.pro