ARM uboot Legacy uImage 和 fit img (Flattened uImage Tree)原理介绍

本文介绍了ARM uboot中Legacy uImage和fit img(Flattened uImage Tree)的原理。Legacy uImage在zImage基础上添加了64字节头部,包含版本、加载位置等信息。FIT uImage则是为了符合Linux Flattened Device Tree标准,将参数整合到镜像中,简化启动流程。文章详细阐述了两者如何存储信息及生成过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文转载,ARM uboot Legacy uImage 和 fit img (Flattened uImage Tree)原理介绍_艾特号的博客-优快云博客

一、先谈谈uboot

uboot 是嵌入式领域中用到的操作系统内核引导工具。
因为嵌入式发展相对pc 领域要慢一点。所以我一般会把uboot当成是一个落后一点迷你一点的grub。(描述不是很准确,勿喷)

二、比较一下 Image 、zImage 、 Legacy uImage 和 FIT uImage 的区别

  1. 内核编译(make)之后会生成两个文件,一个Image,一个zImage,其中Image为内核映像文件,而zImage为内核的一种映像压缩文件,Image大约为4M,而zImage不到2M。
  2. Legacy uImage是 uboot 专用的映像文件。它是在zImage之前加上一个长度为 64 字节的“头”,说明这个内核的版本、加载位置、生成时间、大小等信息。从 0x40 (也就是第64位) 之后与zImage是一样的。

  3. FIT uImage 是在 Legacy uImage的基础上,为了满足Linux Flattened Device Tree(FDT)的标准,而重新改进和定义出来的一种映像文件格式。(下面再讲 FDT)

三、为什么会出现 Legacy uImage ,然后又出现 FIT uImage ?

        1. 最开始出现的是 Image,就一个普通的内核镜像。

        2. 然后为了节省空间,有了 zImage,进行了压缩可以节省空间。

 3. 至此,uboot 启动 一个Image或者 zImage,还必须要给它传递一些参数。

                 ●  镜像文件的类型,如kernel image、dtb文件、ramdisk image等等?

                 ●  镜像文件需要放在memory的哪个位置(加载地址)?

                 ●  镜像文件需要从memory哪个位置开始执行(执行地址)?

      &nb

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值