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

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

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

MCUXpresso IDE下將應(yīng)用程序RW段分散鏈接的幾種方法

冬至子 ? 來(lái)源:痞子衡嵌入式 ? 作者:痞子衡 ? 2022-11-17 11:47 ? 次閱讀

早期的 MCU 芯片,一般都會(huì)嵌入內(nèi)部 Flash 和 RAM,并且 Flash 和 RAM 都只有一塊(即均在連續(xù)的映射地址范圍內(nèi)),因此在鏈接應(yīng)用程序時(shí)處理比較簡(jiǎn)單,程序 RO 段全部放在單一 Flash 空間,程序 RW 段全部放在單一 RAM 空間即可。

隨著時(shí)代發(fā)展,現(xiàn)在的 MCU 越來(lái)越高端了,比如那些 Cortex-M7 內(nèi)核的 MCU 中(最典型的代表 - 恩智浦 i.MXRT 系列)普遍引入了高速 TCM RAM,然后芯片內(nèi)部也還有一些普通 On-chip RAM,當(dāng)然芯片也能支持外擴(kuò)大容量 SDRAM、PSRAM 等,在這種情況下就出現(xiàn)了多塊地址空間不連續(xù)的 RAM 區(qū)域,這時(shí)候該如何鏈接程序 RW 段到這些分散的 RAM 空間里呢?

最近痞子衡在支持一個(gè)美國(guó)G客戶,客戶做項(xiàng)目選用的 MCUXpresso IDE,在這個(gè) IDE 下客戶沒(méi)有找到完美的 RW 段分散鏈接解決方案。今天痞子衡就給大家介紹一下 MCUXpresso IDE 下分散鏈接的幾種方法,也順便提一下 IAR、MDK 下的做法。

一、準(zhǔn)備開發(fā)環(huán)境

首先需要準(zhǔn)備好環(huán)境,包含必要的軟件,痞子衡的環(huán)境如下:

集成開發(fā)環(huán)境:MCUXpresso IDE_11.4.0_6224,點(diǎn)此下載

軟件開發(fā)包:SDK_2.10.0_EVK-MIMXRT1170(Toolchain需包含MCUXpresso IDE),點(diǎn)此下載

二、引入RW段分散鏈接問(wèn)題

我們先從 SDK 包里導(dǎo)入生成一個(gè)工程(就選最簡(jiǎn)單的 hello_world 吧)。工程導(dǎo)入成功后,會(huì)在 \\MCUXpressoIDE_11.4.0_6224\\workspace\\evkmimxrt1170_hello_world_demo_cm7 下看到 .project 工程文件,在 MCUXpresso IDE 下打開這個(gè)工程,然后調(diào)整工程設(shè)置 Memory 定義中順序如下:

圖片

原始 hello_world 程序里 RW 段大小為 264 bytes(包含 .data 和 .bss),再加上默認(rèn) 4KB Heap 和 4KB Stack,這鏈接在 256 KB 的 SRAM_DTC_cm7 空間里(Alias 名為 RAM)肯定是沒(méi)問(wèn)題的。

我們現(xiàn)在在 hello_world.c 文件里加兩個(gè)全局變量 s_buf1 和 s_buf2,再重新編譯工程,發(fā)現(xiàn)工程編譯不過(guò),因?yàn)槟J(rèn)鏈接配置下 IDE 把所有 RW 段全往 Alias 名為 RAM 的空間里放,導(dǎo)致 RAM 空間不夠用,但實(shí)際上芯片上還有很多空余 RAM2-8。怎么把空余 RAMx 利用起來(lái)?這就是問(wèn)題所在,后面我們會(huì)嘗試?yán)?RAM 和 RAM4 來(lái)解決問(wèn)題。

uint8_t s_buf1[1024 * 128] = {1};
uint8_t s_buf2[1024 * 256];

int main(void)
{
    s_buf1[0] = 0;
    s_buf2[0] = 0;

    // 代碼省略...
}

圖片

三、回顧IAR/MDK上解決方案

在研究 MCUXpresso IDE 下分散鏈接解決方案之前,我們先看看經(jīng)典 IDE 下是怎么實(shí)現(xiàn)的。

首先來(lái)看 IAR 下 RW 段分散鏈接解決方案,我們只需要修改對(duì)應(yīng)鏈接文件 MIMXRT1176xxxxx_cm7_flexspi_nor.icf 如下,注釋掉原來(lái) DATA_Region 和 DATA2_region 的分別定義,然后使用 | 運(yùn)算符將它們的 mem 空間連在一起組成新的 DATA_Region 即可,底下 IAR 鏈接器就會(huì)自動(dòng)分配 RW, ZI 段到這個(gè)新 DATA_Region 里。

define symbol m_data_start             = 0x20000000;
define symbol m_data_end               = 0x2003FFFF;

define symbol m_data2_start            = 0x202C0000;
define symbol m_data2_end              = 0x2033FFFF;

圖片

再來(lái)看 MDK 下 RW 段分散鏈接解決方案,我們也只需要修改對(duì)應(yīng)鏈接文件 MIMXRT1176xxxxx_cm7_flexspi_nor.scf 如下,需要新增加一個(gè) RW_m_data2 執(zhí)行域(注意語(yǔ)句擺放位置),在新執(zhí)行域中也按原 RW_m_data 域中一樣添加 .ANY (+RW +ZI) 即可,底下 MDK 鏈接器就會(huì)自動(dòng)分配 RW, ZI 段到這兩個(gè) RW_m_data 空間里。

#define m_data_start                   0x20000000
#define m_data_size                    0x00040000

#define m_data2_start                  0x202C0000
#define m_data2_size                   0x00080000

圖片

四、MCUXpresso IDE下幾種解決方案

現(xiàn)在回到主題 MCUXpresso IDE 下分散鏈接是怎么實(shí)現(xiàn)的,一共有三種方法:

4.1 借助 cr_section_macros.h 里的宏

第一種方法是借助 MCUXpresso IDE 自帶的頭文件 cr_section_macros.h 里的宏。用 __DATA(RamAliasName) 或者 __BSS(RamAliasName) 宏來(lái)修飾變量定義,這樣 MCUXpresso IDE 在鏈接時(shí)會(huì)自動(dòng)將該變量放到指定 RAMx 里。

圖片

4.2 借助 GNU C 的 attribute 機(jī)制

第二種方法本質(zhì)上與第一種一樣,只不過(guò)換個(gè)形式,需要借助 GNU C 里的 attribute 機(jī)制,即用 attribute ((section("UserSectionName"))) 語(yǔ)法來(lái)修飾變量定義,將其放到自定義程序段里,然后在 MCUXpresso IDE 鏈接配置設(shè)置界面 Extra linker script input sections 框里,將自定義程序段指定到具體 RAMx 里。

圖片

4.3 手動(dòng)修改 .ld 鏈接文件

前兩種方法雖然能解決問(wèn)題,但是遇到多源文件里大量變量定義時(shí)就比較麻煩了,不但需要挨個(gè)加相應(yīng)修飾代碼,而且也要手工計(jì)算好空間大?。ê侠砜刂谱远x段大小),隨著代碼增刪改動(dòng),做不到自適應(yīng)。那么在 MCUXpresso IDE 下有沒(méi)有像 IAR/MDK 解決方案那樣省心的方式呢?

答案當(dāng)然是有的!在 MCUXpresso IDE 鏈接配置設(shè)置界面去掉 Manage linker script 選項(xiàng)的勾選,將自動(dòng)生成的 evkmimxrt1170_hello_world_demo_cm7_Debug.ld 文件在同路徑下拷貝一份重新命名,然后在 Linker script 路徑里指定新的鏈接文件。

圖片

打開鏈接文件 evkmimxrt1170_hello_world_demo_cm7_Debug_User.ld,在里面分別找到 Main DATA/BSS SECTION 執(zhí)行域,跟在后面緊接著加上 Secondary DATA/BSS SECTION 執(zhí)行域就行了(仿照 Main Section 里的寫法,僅需要把 RAM 名字替換掉即可),底下 MCUXpresso IDE 鏈接器就會(huì)自動(dòng)分配 RW, ZI 段到這兩個(gè) RAM 空間里。

圖片

至此,MCUXpresso IDE下將應(yīng)用程序RW段分散鏈接的幾種方法便介紹完畢了,掌聲在哪里~~~

審核編輯:劉清

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

    關(guān)注

    7

    文章

    422

    瀏覽量

    55129
  • RAM
    RAM
    +關(guān)注

    關(guān)注

    8

    文章

    1354

    瀏覽量

    114429
  • Flash單片機(jī)
    +關(guān)注

    關(guān)注

    0

    文章

    111

    瀏覽量

    9377
  • MCU芯片
    +關(guān)注

    關(guān)注

    3

    文章

    246

    瀏覽量

    11348
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    設(shè)備驅(qū)動(dòng)程序通知應(yīng)用程序有哪幾種方法?

    請(qǐng)問(wèn)各位,設(shè)備驅(qū)動(dòng)程序通知應(yīng)用程序有哪幾種方法?
    發(fā)表于 04-27 07:10

    分享MCUXpresso IDE關(guān)鍵函數(shù)重定向到RAM中執(zhí)行的幾種方法

      大家好,我是痞子衡,是正經(jīng)搞技術(shù)的痞子。今天痞子衡給大家分享的是MCUXpresso IDE關(guān)鍵函數(shù)重定向到RAM中執(zhí)行的幾種方法。
    發(fā)表于 02-10 06:44

    MCUXpresso IDE應(yīng)用程序RW分散鏈接有哪幾種方法?

    MCUXpresso IDE應(yīng)用程序RW
    發(fā)表于 02-10 08:03

    如何示例項(xiàng)目導(dǎo)入MCUXpresso IDE

    使用 RT1050 板,并有這個(gè)例子。我閱讀了 RT1020 板支持 mc_pmsm 與板 FRDM-MC-LVPMSM 組合的文檔。我正在尋找如何示例項(xiàng)目導(dǎo)入 MCUXpresso IDE,有人可以幫助我嗎?
    發(fā)表于 03-16 08:15

    如何在MCUXpresso IDE上使用芯片上的所有SRAM?

    內(nèi)存放入 SRAM_OC2,SRAM_ITC_cm7 的內(nèi)存使用從 150% 減少到 140% .順便說(shuō)一句,在應(yīng)用程序鏈接到RAM時(shí)是否需要將SRAM_ITC_cm7設(shè)置為第一個(gè)?我已經(jīng)具有512KB的SRAM_OC1設(shè)置為
    發(fā)表于 04-14 08:01

    MIMXRT1060-EVK板 +MCUXpresso IDE如何恢復(fù)RT板?

    Provisioning Tool在串行下載模式進(jìn)行代碼下載或批量擦除,這種方法也可以恢復(fù)電路板,實(shí)際上只是讓內(nèi)核處于已知狀態(tài)。 SPT工具下載鏈接:https://www.nxp.com/design
    發(fā)表于 04-20 08:31

    MCUXpresso IDE在Flash調(diào)試的注意事項(xiàng)

    大家好,我是痞子衡,是正經(jīng)搞技術(shù)的痞子。今天痞子衡給大家介紹的是 MCUXpresso IDE 使用 J-Link 下載算法在 Flash 調(diào)試注意事項(xiàng)。 介紹一如何使用新生成的
    的頭像 發(fā)表于 12-23 13:53 ?981次閱讀

    痞子衡嵌入式:MCUXpresso IDE關(guān)鍵函數(shù)重定向到RAM中執(zhí)行的幾種方法

      大家好,我是痞子衡,是正經(jīng)搞技術(shù)的痞子。今天痞子衡給大家分享的是MCUXpresso IDE關(guān)鍵函數(shù)重定向到RAM中執(zhí)行的幾種方法。
    發(fā)表于 12-06 19:36 ?9次下載
    痞子衡嵌入式:<b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b><b class='flag-5'>下</b><b class='flag-5'>將</b>關(guān)鍵函數(shù)重定向到RAM中執(zhí)行的<b class='flag-5'>幾種方法</b>

    LPC1768 MCUXpresso IDE環(huán)境使用完整64K內(nèi)存的方法

    MCUXpresso IDE是NXP公司免費(fèi)提供的一款針對(duì)自家平臺(tái)的IDE簡(jiǎn)單來(lái)說(shuō)就是 Eclipses 外加GCC編譯器和自家芯片平臺(tái)的IDE在這種平臺(tái)下,也是默認(rèn)情況
    發(fā)表于 12-07 13:06 ?7次下載
    LPC1768 <b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b>環(huán)境<b class='flag-5'>下</b>使用完整64K內(nèi)存的<b class='flag-5'>方法</b>

    不同IDE應(yīng)用程序RW分散鏈接方法~

    今天痞子衡給大家介紹的是MCUXpresso IDE應(yīng)用程序RW
    發(fā)表于 12-07 13:21 ?9次下載
    不同<b class='flag-5'>IDE</b><b class='flag-5'>下</b><b class='flag-5'>應(yīng)用程序</b><b class='flag-5'>RW</b><b class='flag-5'>段</b><b class='flag-5'>分散</b><b class='flag-5'>鏈接</b>的<b class='flag-5'>方法</b>~

    MCUXpresso IDE下工程鏈接文件配置管理與自動(dòng)生成機(jī)制介紹

    我們知道不同 IDE 鏈接文件語(yǔ)法是不一樣的,而恩智浦 MCUXpresso IDE 底層編譯器是 Arm GCC,因此其
    的頭像 發(fā)表于 11-17 10:41 ?3060次閱讀
    <b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b>下工程<b class='flag-5'>鏈接</b>文件配置管理與自動(dòng)生成機(jī)制介紹

    MCUXpresso IDE下生成鏡像文件的方法及其與IAR,MDK差異

    MCUXpresso IDE下生成鏡像文件的方法及其與IAR,MDK差異
    的頭像 發(fā)表于 09-28 17:05 ?798次閱讀
    <b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b>下生成鏡像文件的<b class='flag-5'>方法</b>及其與IAR,MDK差異

    MCUXpresso IDE源碼制作成Lib庫(kù)方法及其與IAR,MDK差異

    MCUXpresso IDE源碼制作成Lib庫(kù)方法及其與IAR,MDK差異
    的頭像 發(fā)表于 11-07 17:13 ?1113次閱讀
    <b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b><b class='flag-5'>下</b><b class='flag-5'>將</b>源碼制作成Lib庫(kù)<b class='flag-5'>方法</b>及其與IAR,MDK差異

    如何在MCUXpresso IDE中測(cè)量能耗?

    如何在MCUXpresso IDE中測(cè)量能耗?
    的頭像 發(fā)表于 09-19 16:40 ?536次閱讀
    如何在<b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b>中測(cè)量能耗?

    MCUXpresso IDE下在線聯(lián)合調(diào)試雙核MCU工程的三種方法

    大家好,我是痞子衡,是正經(jīng)搞技術(shù)的痞子。今天痞子衡給大家分享的是MCUXpresso IDE下在線聯(lián)合調(diào)試i.MXRT1170雙核工程的三種方法。
    的頭像 發(fā)表于 08-08 15:18 ?439次閱讀
    <b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b>下在線聯(lián)合調(diào)試雙核MCU工程的三<b class='flag-5'>種方法</b>