0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

什么是分散加载文件?

汽车电子技术 来源:wenzi嵌入式软件 作者: wenzid 2023-01-30 14:12 次阅读

什么是分散加载文件

分散加载文件(scatter file)是一个文本文件,它的作用是可以用于描述 ARM 链接器生成映像文件所需要的信息

如果不使用 scatter file 文件来指定,那么 ARM 链接器会按照默认的方式来生成映像文件,但是对于某些应用场景来说,我们希望能够将一些数据放在指定的位置,这个时候,分散加载文件就发挥其作用了。

何时进行分散加载

在之前的一篇文章 [MCU 是如何从上电复位运行到 main 函数的?]中详细叙述了MCU运行到 main 函数之前所做的操作。简而言之,主要做了如下三个工作:

  • 堆栈以及堆的初始化
  • 定位中断向量表
  • 调用 Reset Handler

下图列出了ARM Cortex M4系列芯片的一个启动流程,厂商不一样,会存在细微的差别。

微信截图_20230105161930.png

由上述启动流程可以看到,分散加载操作是在 __main() 函数内部完成的,紧接着,就运行 C 语言运行环境初始化 & C Library 的初始化。

分散加载的原理

在理解分散加载的原理之前,需要明白以下几个概念:

  • Code: 为程序代码部分
  • RO-Data: 表示程序定义的常量及const型数据
  • RW-Data:表示已经初始化的静态变量,变量有初值
  • ZI-Data: 表示未初始化的静态变量,变量无初值

除此之外,因为分散加载的机制是将不同代码放在不同的存储空间,因此还需要了解代码的映像文件的基本概念。ARM 映像文件其实就是源文件经编译器生成的目标文件 .obj(object file)和相应的 C/C++ 运行时库( Runtime Library )经过连接器的处理后,生成的 axf 格式的映像文件,它可以直接烧录到目标设备的 ROM 中直接运行或加载后运行。映像文件的组成如下所示:

!微信截图_20230105161930.png

由上图可以知道,映像文件由域(区)、输出段(节)和输入段(节)的层次结构组成:

  • 输入段:输入段包含代码、初始化数据,或描述未初始化的或在映像执行之前必须设定为 0 的内存片段。这些特性通过 RO 、 RW 和 ZI 这样的属性来表示。
  • 输出段:一个输出段由若干个具有相同 RO 、 RW 或 ZI 属性的相邻输入段组成。输出段的属性与组成它的输入段的属性相同 。
  • 域:一个域由一个、两个或者三个相邻的输出段组成。区中的输出段根据其属性排序。首先是 RO 输出段,然后是 RW 输出段,最后是 ZI 输出段。域通常映射到物理内存设备,如 ROM 、 RAM 或外围设备。

ARM 映像文件各组成部分在存储系统中的地址有两种:

  • 装载域
  • 运行域

微信截图_20230105161930.png

在一个简单的嵌入式计算机系统中,存储器一般分为ROM和RAM。链接器生成的映像被分为“Read-Only”段和“Read-Write”段(包含已初始化数据和未初始化数据)。通常来说,在程序下载的时候,他们会被下载到ROM上,而在程序开始执行的时候,Read-Write段会从ROM被Copy到RAM,下面就是这个加载过程的示意图。

装载域和运行域示意图")

装载域和运行域示意图

以上只是一个简单的例子,但是在比较复杂的嵌入式系统中,其存储器往往还包括ROM,SRAM,DRAM,FLASH等等,这个时候就需要分散加载文件了。

分散加载的语法

微信截图_20230105161930.png

分散加载文件主要由一个加载时域(区)和多个运行时域(区)组成,其大致结构如下图所示:

在这里插入图片描述")

在这里插入图片描述

本次先介绍一种简单的情况,一个Cortex M3系列的微控制器有Flash和RAM资源如下所示:

  • Flash基址:0x00000000,大小256KB;
  • RAM基址:0x10000000,大小32KB

那么分散加载文件可以这么写:

LR_IROM1 0x00000000 0x00040000        ;定义一个加载域,域基址为0x00000000,大小为0x00040000
{                                     ;对应着实际的 Flash 的大小
    ER_IROM1 0x00000000 0x00040000    ;定义一个运行域,第一个运行域必须和加载域起始地址相同
    {
        *.o(RESER,+First)             ;将RESET最先加载到本域的起始地址,即RESET的起始地址为0
        .ANY(+RO)                     ;加载所有匹配目标文件的只读属性数据,包含:Code,RW-Data
    }

    RW_IRAM1 0x10000000 0x00008000    ;定义一个运行时域,域基址为0x10000000,域大小为 0x00008000
    {
        *(+RW+ZI)                   ;加载所有匹配目标文件的RW-Data,ZI-Data
    }
}

总结

上述就是关于分散加载的叙述,所举的例子比较简单,在后续的文章中,将针对于其较为复杂的应用进行阐述,欢迎关注wenzi嵌入式软件公众号~

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • ARM
    ARM
    +关注

    关注

    134

    文章

    8651

    浏览量

    361782
  • 映像
    +关注

    关注

    0

    文章

    9

    浏览量

    7179
  • 加载
    +关注

    关注

    0

    文章

    8

    浏览量

    10956
收藏 人收藏

    评论

    相关推荐

    Keil分散加载文件浅析

    ARM 映像文件其实就是源文件经编译器生成的目标文件,一般是bin文件或者hex文件,可以直接烧录到ROM中执行(一般是内部FLASH),这
    的头像 发表于 11-17 10:00 1222次阅读
    Keil<b class='flag-5'>分散</b><b class='flag-5'>加载文件</b>浅析

    ARM分散加载及应用

    从ARM ELF目标文件主要构成出发,详细介绍了分散加载的基本原理、分散加载文件的语法、分散
    发表于 05-04 16:09

    使用QSPI FLASH来存放程序代码

    使用QSPI FLASH来存放程序代码,可以把程序的部分或者整个程序都存放在QSPI FLASH中运行。这里介绍两种不同的方法。一、通过分散加载文件的方式本文中使用的是正点原子北极星板子的例程,跑马灯实验。例程比较简单,主要是看分散
    发表于 08-12 07:19

    STM32H7代码运行在外置flash的部分相关资料分享

    )完全不够用,所以需要外置QSPI Flash。但是使用外置QSPI Flash又引入了新的问题。问题一:需要自己写分散加载文件首先介绍一下什么是分散加载文件:我们的代码在编译以后,需
    发表于 01-26 06:09

    单片机中的分散加载文件主要包括哪几类呢

    单片机中的分散加载文件主要包括哪几类呢?
    发表于 01-27 08:00

    IAR中将代码全部放在ITCRAM中执行的方法

    IAR中将代码全部放在ITCRAM中执行① 修改启动文件,添加一个新的中断向量表(具体代码可以查看例程中example例程)。② 修改分散加载文件,将新的中断向量表放到ITCRAM中③ 修改
    发表于 01-27 06:10

    什么是分散加载文件

    分散加载的作用是什么?什么是分散加载文件
    发表于 02-16 06:48

    请问怎样去修改STM32F2中ROM分区的分散加载文件

    的sector。应用程序跑在后面。但是这样的作法弊端就是需要两份程序。 另一个方法是我在想,通过修改链接文件,例如MDK下修改分散加载文件让其中保存参数的sector不放任何东西。修改例如下面这样
    发表于 07-22 10:10

    求助,关于mdk5分散加载文件的问题

    有没有人能解释一下,分散加载文件应该怎么写
    发表于 11-02 07:23

    周立功单片机:分散加载文件浅释

    Scatter-Loading Description File 分散加载文件
    发表于 03-13 14:19 94次下载

    STM32H7代码运行在外置flash的部分总结

    )完全不够用,所以需要外置QSPI Flash。但是使用外置QSPI Flash又引入了新的问题。问题一:需要自己写分散加载文件首先介绍一下什么是分散加载文件:我们的代码在编译以后,需
    发表于 12-02 10:36 25次下载
    STM32H7代码运行在外置flash的部分总结

    单片机中分散加载文件介绍

    单片机中分散加载文件介绍
    发表于 12-03 10:51 2次下载
    单片机中<b class='flag-5'>分散</b><b class='flag-5'>加载文件</b>介绍

    IMXRT1052/1064 如何将代码存放在ITCM中

    IAR中将代码全部放在ITCRAM中执行① 修改启动文件,添加一个新的中断向量表(具体代码可以查看例程中example例程)。② 修改分散加载文件,将新的中断向量表放到ITCRAM中③ 修改
    发表于 12-03 12:21 4次下载
    IMXRT1052/1064 如何将代码存放在ITCM中

    ARM分散加载文件

    分散加载作用:可以将代码放入不同的存储空间。1.基本概念了解分散加载文件之前,首先需要了解Code、RO-Data、RW-Data、ZI-Data。Code:程序代码RO-Data:程
    发表于 12-20 19:10 7次下载
    ARM<b class='flag-5'>分散</b><b class='flag-5'>加载文件</b>

    什么是分散加载文件?何时进行分散加载

    分散加载文件(scatter file)是一个文本文件,它的作用是可以用于描述 ARM 链接器生成映像文件所需要的信息。
    的头像 发表于 09-14 10:38 2347次阅读