笔记整理—什么是uboot&内核

前几章我们用大量的时间介绍了uboot干了什么,本章我们将要对kernel于uboot的区别进行说明。

uboot启动完成后,使用bootm可以去启动内核。

uboot其实是一个裸机程序,只是复杂一点几乎可以看作是一堆东西的初始化再加上指令实现的。

内核位于操作系统中的内核层,在内存上对设备访问与内存访问要高于应用层。

uboot的镜像叫uboot.bin。linux的镜像叫zImage。

系统有对内存的更细致化管理以及权限的管理,在系统启动后才有了应用层和驱动层一说。uboot->zImage->系统。

在不通电的情况下,一个软件、系统,如bootloader、kernel、rootfs等都以镜像的形式存储在介质中,当上电后才在内存中运行,这叫静态过程。

将镜像从sd卡读取->内存->进行初始化与框架建立->形成一个稳定的过程,这叫动态过程。

静态加载要求,uboot和kernel的分区表保持一致,与sd卡实际使用分区保持一致。

uboot的第一阶段进行重定位将第二阶段加载到DDR中(对于X210而言是0xc3e00000),这个地址就是uboot的链接地址。

内核启动:使用uboot启动内核将uboot从SD卡(介质)中读到DDR中(重定位)放在内核的链接地址(0x30008000)。

uboot的启动条件是无条件启动的,而kernel是需要uboot进行重定位才能启动的。

下一章将会讲述kernel的启动过程与do_boot函数。

相关推荐
量子炒饭大师2 分钟前
【Linux系统编程】Cyberpunk在霓虹丛林中构建堡垒 ——【关于shell命令及其运行原理】
linux·运维·服务器·shell
夜猫子ing2 分钟前
《嵌入式 Linux 控制服务从零搭建(一):项目立意与架构总览》
linux·嵌入式硬件
IT大白鼠2 分钟前
主流Linux文件系统稳定性及性能分析
linux·运维·服务器·文件系统
南境十里·墨染春水7 分钟前
linux学习进展 I/O复用函数初步
linux·运维·学习
武帝为此10 分钟前
【C语言进程与线程】
c语言·开发语言
LinuxGeek102412 分钟前
Linux内核“Dirty Frag”漏洞(CVE-2026-43284)修复方案
linux·运维·服务器
曦夜日长16 分钟前
Linux系统篇,权限(一):用户创建与切换、权限及角色定义与修改、文件权限二进制表示
linux·运维·服务器
原来是猿16 分钟前
应用层【协议再识/序列化与反序列化】
linux·运维·服务器·网络·网络协议·tcp/ip
Byte Wizard22 分钟前
C语言指针深入浅出4
c语言·开发语言
北风toto30 分钟前
log4j中文日志乱码问号-Linux启动jar包,输出中文日志变成问号?
linux·log4j·jar