RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

什么是分散加載文件?

汽車電子技術(shù) ? 來源:wenzi嵌入式軟件 ? 作者: wenzid ? 2023-01-30 14:12 ? 次閱讀

什么是分散加載文件

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

如果不使用 scatter file 文件來指定,那么 ARM 鏈接器會按照默認的方式來生成映像文件,但是對于某些應(yīng)用場景來說,我們希望能夠?qū)⒁恍?shù)據(jù)放在指定的位置,這個時候,分散加載文件就發(fā)揮其作用了。

何時進行分散加載

在之前的一篇文章 [MCU 是如何從上電復(fù)位運行到 main 函數(shù)的?]中詳細敘述了MCU運行到 main 函數(shù)之前所做的操作。簡而言之,主要做了如下三個工作:

  • 堆棧以及堆的初始化
  • 定位中斷向量表
  • 調(diào)用 Reset Handler

下圖列出了ARM Cortex M4系列芯片的一個啟動流程,廠商不一樣,會存在細微的差別。

微信截圖_20230105161930.png

由上述啟動流程可以看到,分散加載操作是在 __main() 函數(shù)內(nèi)部完成的,緊接著,就運行 C 語言運行環(huán)境初始化 & C Library 的初始化。

分散加載的原理

在理解分散加載的原理之前,需要明白以下幾個概念:

  • Code: 為程序代碼部分
  • RO-Data: 表示程序定義的常量及const型數(shù)據(jù)
  • RW-Data:表示已經(jīng)初始化的靜態(tài)變量,變量有初值
  • ZI-Data: 表示未初始化的靜態(tài)變量,變量無初值

除此之外,因為分散加載的機制是將不同代碼放在不同的存儲空間,因此還需要了解代碼的映像文件的基本概念。ARM 映像文件其實就是源文件經(jīng)編譯器生成的目標(biāo)文件 .obj(object file)和相應(yīng)的 C/C++ 運行時庫( Runtime Library )經(jīng)過連接器的處理后,生成的 axf 格式的映像文件,它可以直接燒錄到目標(biāo)設(shè)備的 ROM 中直接運行或加載后運行。映像文件的組成如下所示:

!微信截圖_20230105161930.png

由上圖可以知道,映像文件由域(區(qū))、輸出段(節(jié))和輸入段(節(jié))的層次結(jié)構(gòu)組成:

  • 輸入段:輸入段包含代碼、初始化數(shù)據(jù),或描述未初始化的或在映像執(zhí)行之前必須設(shè)定為 0 的內(nèi)存片段。這些特性通過 RO 、 RW 和 ZI 這樣的屬性來表示。
  • 輸出段:一個輸出段由若干個具有相同 RO 、 RW 或 ZI 屬性的相鄰輸入段組成。輸出段的屬性與組成它的輸入段的屬性相同 。
  • 域:一個域由一個、兩個或者三個相鄰的輸出段組成。區(qū)中的輸出段根據(jù)其屬性排序。首先是 RO 輸出段,然后是 RW 輸出段,最后是 ZI 輸出段。域通常映射到物理內(nèi)存設(shè)備,如 ROM 、 RAM 或外圍設(shè)備。

ARM 映像文件各組成部分在存儲系統(tǒng)中的地址有兩種:

  • 裝載域
  • 運行域

微信截圖_20230105161930.png

在一個簡單的嵌入式計算機系統(tǒng)中,存儲器一般分為ROM和RAM。鏈接器生成的映像被分為“Read-Only”段和“Read-Write”段(包含已初始化數(shù)據(jù)和未初始化數(shù)據(jù))。通常來說,在程序下載的時候,他們會被下載到ROM上,而在程序開始執(zhí)行的時候,Read-Write段會從ROM被Copy到RAM,下面就是這個加載過程的示意圖。

裝載域和運行域示意圖")

裝載域和運行域示意圖

以上只是一個簡單的例子,但是在比較復(fù)雜的嵌入式系統(tǒng)中,其存儲器往往還包括ROM,SRAM,DRAM,F(xiàn)LASH等等,這個時候就需要分散加載文件了。

分散加載的語法

微信截圖_20230105161930.png

分散加載文件主要由一個加載時域(區(qū))和多個運行時域(區(qū))組成,其大致結(jié)構(gòu)如下圖所示:

在這里插入圖片描述")

在這里插入圖片描述

本次先介紹一種簡單的情況,一個Cortex M3系列的微控制器有Flash和RAM資源如下所示:

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

那么分散加載文件可以這么寫:

LR_IROM1 0x00000000 0x00040000        ;定義一個加載域,域基址為0x00000000,大小為0x00040000
{                                     ;對應(yīng)著實際的 Flash 的大小
    ER_IROM1 0x00000000 0x00040000    ;定義一個運行域,第一個運行域必須和加載域起始地址相同
    {
        *.o(RESER,+First)             ;將RESET最先加載到本域的起始地址,即RESET的起始地址為0
        .ANY(+RO)                     ;加載所有匹配目標(biāo)文件的只讀屬性數(shù)據(jù),包含:Code,RW-Data
    }

    RW_IRAM1 0x10000000 0x00008000    ;定義一個運行時域,域基址為0x10000000,域大小為 0x00008000
    {
        *(+RW+ZI)                   ;加載所有匹配目標(biāo)文件的RW-Data,ZI-Data
    }
}

總結(jié)

上述就是關(guān)于分散加載的敘述,所舉的例子比較簡單,在后續(xù)的文章中,將針對于其較為復(fù)雜的應(yīng)用進行闡述,歡迎關(guān)注wenzi嵌入式軟件公眾號~

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • ARM
    ARM
    +關(guān)注

    關(guān)注

    134

    文章

    9084

    瀏覽量

    367380
  • 映像
    +關(guān)注

    關(guān)注

    0

    文章

    9

    瀏覽量

    7208
  • 加載
    +關(guān)注

    關(guān)注

    0

    文章

    8

    瀏覽量

    11013
收藏 人收藏

    評論

    相關(guān)推薦

    Keil分散加載文件淺析

    ARM 映像文件其實就是源文件經(jīng)編譯器生成的目標(biāo)文件,一般是bin文件或者hex文件,可以直接燒錄到ROM中執(zhí)行(一般是內(nèi)部FLASH),這
    的頭像 發(fā)表于 11-17 10:00 ?2480次閱讀
    Keil<b class='flag-5'>分散</b><b class='flag-5'>加載文件</b>淺析

    ARM分散加載及應(yīng)用

    從ARM ELF目標(biāo)文件主要構(gòu)成出發(fā),詳細介紹了分散加載的基本原理、分散加載文件的語法、分散
    發(fā)表于 05-04 16:09

    STM32H7代碼運行在外置flash的部分相關(guān)資料分享

    )完全不夠用,所以需要外置QSPI Flash。但是使用外置QSPI Flash又引入了新的問題。問題一:需要自己寫分散加載文件首先介紹一下什么是分散加載文件:我們的代碼在編譯以后,需
    發(fā)表于 01-26 06:09

    單片機中的分散加載文件主要包括哪幾類呢

    單片機中的分散加載文件主要包括哪幾類呢?
    發(fā)表于 01-27 08:00

    IAR中將代碼全部放在ITCRAM中執(zhí)行的方法

    IAR中將代碼全部放在ITCRAM中執(zhí)行① 修改啟動文件,添加一個新的中斷向量表(具體代碼可以查看例程中example例程)。② 修改分散加載文件,將新的中斷向量表放到ITCRAM中③ 修改
    發(fā)表于 01-27 06:10

    什么是分散加載文件?

    分散加載的作用是什么?什么是分散加載文件?
    發(fā)表于 02-16 06:48

    請問怎樣去修改STM32F2中ROM分區(qū)的分散加載文件

    的sector。應(yīng)用程序跑在后面。但是這樣的作法弊端就是需要兩份程序。 另一個方法是我在想,通過修改鏈接文件,例如MDK下修改分散加載文件讓其中保存參數(shù)的sector不放任何東西。修改例如下面這樣
    發(fā)表于 07-22 10:10

    求助,關(guān)于mdk5分散加載文件的問題

    有沒有人能解釋一下,分散加載文件應(yīng)該怎么寫
    發(fā)表于 11-02 07:23

    周立功單片機:分散加載文件淺釋

    Scatter-Loading Description File 分散加載文件
    發(fā)表于 03-13 14:19 ?98次下載

    STM32H7代碼運行在外置flash的部分總結(jié)

    )完全不夠用,所以需要外置QSPI Flash。但是使用外置QSPI Flash又引入了新的問題。問題一:需要自己寫分散加載文件首先介紹一下什么是分散加載文件:我們的代碼在編譯以后,需
    發(fā)表于 12-02 10:36 ?26次下載
    STM32H7代碼運行在外置flash的部分總結(jié)

    單片機中分散加載文件介紹

    單片機中分散加載文件介紹
    發(fā)表于 12-03 10:51 ?2次下載
    單片機中<b class='flag-5'>分散</b><b class='flag-5'>加載文件</b>介紹

    IMXRT1052/1064 如何將代碼存放在ITCM中

    IAR中將代碼全部放在ITCRAM中執(zhí)行① 修改啟動文件,添加一個新的中斷向量表(具體代碼可以查看例程中example例程)。② 修改分散加載文件,將新的中斷向量表放到ITCRAM中③ 修改
    發(fā)表于 12-03 12:21 ?4次下載
    IMXRT1052/1064 如何將代碼存放在ITCM中

    ARM分散加載文件

    分散加載作用:可以將代碼放入不同的存儲空間。1.基本概念了解分散加載文件之前,首先需要了解Code、RO-Data、RW-Data、ZI-Data。Code:程序代碼RO-Data:程
    發(fā)表于 12-20 19:10 ?7次下載
    ARM<b class='flag-5'>分散</b><b class='flag-5'>加載文件</b>

    什么是分散加載文件?何時進行分散加載

    分散加載文件(scatter file)是一個文本文件,它的作用是可以用于描述 ARM 鏈接器生成映像文件所需要的信息。
    的頭像 發(fā)表于 09-14 10:38 ?2782次閱讀

    深入分析一下MDK的分散加載文件

    ARM C 庫提供了函數(shù) __user_setup_stackheap() 的多個實現(xiàn),并且可以根據(jù)分散文件中提供的信息自動選擇正確的一種。
    發(fā)表于 04-28 14:21 ?784次閱讀
    深入分析一下MDK的<b class='flag-5'>分散</b><b class='flag-5'>加載文件</b>
    RM新时代网站-首页