18video性欧美19sex,欧美高清videosddfsexhd,性少妇videosexfreexxx片中国,激情五月激情综合五月看花,亚洲人成网77777色在线播放

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

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

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

基于 IAR Embedded Workbench 的自研 MCU 芯片軟件函數(shù)與變量內(nèi)存布局優(yōu)化精控方法

安芯 ? 來源:jf_29981791 ? 作者:jf_29981791 ? 2025-04-30 16:38 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

嵌入式軟件開發(fā)領域,MCU芯片軟件的架構(gòu)設計與內(nèi)存布局的精細規(guī)劃對系統(tǒng)性能和穩(wěn)定性起著關鍵作用。本文檔聚焦于IAR Embedded Workbench環(huán)境下,為自研MCU芯片軟件提供了一套詳盡的函數(shù)和變量指定section放置方法與操作流程,兼具過程記錄與詳細說明,旨在打造一份實用的參考指南,助力開發(fā)者精準掌控程序的內(nèi)存分布與執(zhí)行邏輯。文檔涵蓋從默認section表的介紹,到多種放置手段的闡釋,以及實際配置示例的展示,為后續(xù)的開發(fā)工作奠定堅實基礎。

IAR Embedded Workbench作為一款廣受認可的嵌入式開發(fā)工具,具備豐富的功能與靈活的配置選項。在該環(huán)境下,軟件開發(fā)者可巧妙運用多種方法,將函數(shù)和變量精準放置于指定的section中。這一操作對于優(yōu)化程序的內(nèi)存使用效率、提升系統(tǒng)響應速度以及增強代碼的可維護性具有重要意義。例如,通過將特定的代碼或數(shù)據(jù)放置在合適的內(nèi)存區(qū)域,可以充分利用MCU芯片的硬件特性,實現(xiàn)更高效的緩存利用、減少內(nèi)存訪問延遲等效果。

文檔深入淺出地講解了多種放置方式,包括使用@操作符、#pragma location命令、GCC風格的attribute屬性以及#pragma default_variable_attributes和#pragma default_function_attributes命令等,開發(fā)者可根據(jù)實際需求靈活選擇。同時,還提供了諸如as32x601_rom.icf、Port_MemMap.h和Port.c等實際配置示例,涵蓋了從內(nèi)存區(qū)域定義、section分配到函數(shù)與變量屬性設置的完整流程,為開發(fā)者提供了直觀且易于實踐的參考。

默認section表

IAR Embedded Workbench中有很多默認的section用于放置對應的變量和函數(shù):

除了用于您的應用程序的ELF部分之外,這些工具還出于多種目的使用許多其他ELF段:

  • 以.debug開頭的段通常包含DWARF格式的調(diào)試信息。
  • 以.iar.debug開頭的段包含IAR格式的補充調(diào)試信息
  • 以.comment開頭的段包含用于構(gòu)建文件的工具和命令行
  • 以.rel或.rela開頭的段包含ELF重定位信息
  • 以.symtab開頭的段包含文件的符號表
  • 以.strtab開頭的段包含符號表中符號的名稱
  • 以.shstrtab開頭的段包含各段的名稱。

將變量放到指定的section

使用@操作符

可以使用 @ 將變量放到指定的section:

staticuint32_t TaskCounter @".mcal_const_cfg" = 1;

使用 #pragma location 命令

可以使用 #pragma location命令將變量放到指定的section:

#pragma location = ".mcal_const_cfg"staticuint32_t TaskCounter = 1;

使用 GCC 風格的屬性 attribute ((section ))

可以使用 GCC 風格的屬性 attribute ((section ))將變量放到指定的section:

staticuint32_t TaskCounter attribute ((section (".mcal_const_cfg"))) = 1;

使用 #pragma default_variable_attributes 命令

上面的方法可以將單個變量放到指定的section,如果需要將多個變量放到指定的section,上面的方法會顯得有點繁瑣。可以使用 #pragma default_variable_attributes 命令將多個變量放到指定的section:

#pragma default_variable_attributes = @ ".mcal_const_cfg"staticuint32_t TaskCounter = 1; staticuint32_t TaskLedRedCounter = 2; #pragma default_variable_attributes =

將函數(shù)放到指定的section

使用@操作符

可以使用 @ 將函數(shù)放到指定的section:

voidStartTaskLedRed(void *argument) @ ".mcal_text";

使用 #pragma location 命令

可以使用 #pragma location命令將函數(shù)放到指定的section:

#pragma location = ".mcal_text"voidStartTaskLedRed(void *argument);

使用 GCC 風格的屬性 attribute ((section ))

可以使用 GCC 風格的屬性 attribute ((section ))將函數(shù)放到指定的section:

voidStartTaskLedRed(void *argument) attribute ((section (".mcal_text")));

使用 #pragma default_variable_attributes 命令

上面的方法可以將單個函數(shù)放到指定的section,如果需要將多個函數(shù)放到指定的section,上面的方法會顯得有點繁瑣??梢允褂?#pragma default_function_attributes命令將多個函數(shù)放到指定的section:

#pragma default_function_attributes = @ ".mcal_text"voidStartTaskLedRed(void *argument); voidStartTaskLedGreen(void *argument); voidStartTaskLedBlue(void *argument); #pragma default_function_attributes =

使用示例

as32x601_rom.icf

/****************************************************************************** * FILE VERSION / define exported symbol _link_file_version_2 = 1; / * SPECIALS // * * MEMORY REGIONS / define symbol ICFEDIT_region_FLASH_start = 0x10000000; define symbol ICFEDIT_region_FLASH_end = 0x11FFFFFF; define symbol ICFEDIT_region_SRAM0_start = 0x20000000; define symbol ICFEDIT_region_SRAM0_end = 0x2001FFFF; define symbol ICFEDIT_region_SRAM1_start = 0x20020000; define symbol ICFEDIT_region_SRAM1_end = 0x2003FFFF; define symbol ICFEDIT_region_SRAM2_start = 0x20040000; define symbol ICFEDIT_region_SRAM2_end = 0x2005FFFF; define symbol ICFEDIT_region_SRAM3_start = 0x20060000; define symbol ICFEDIT_region_SRAM3_end = 0x2007FFFF; / * * SIZES / define symbol ICFEDIT_size_cstack = 0x2000; define symbol ICFEDIT_size_proc_stack = 0x0; define symbol ICFEDIT_size_heap = 0x2000; / * * BUILD FOR ROM *****************************************************************************/ keep symbol __iar_cstart_init_gp; define memory mem with size = 4G; define region ROM_region = mem:[from ICFEDIT_region_FLASH_start to ICFEDIT_region_FLASH_end ]; define region RAMCODE_region = mem:[from ICFEDIT_region_SRAM0_start to ICFEDIT_region_SRAM0_end ]; define region RAM_region = mem:[from ICFEDIT_region_SRAM1_start to ICFEDIT_region_SRAM1_end ] | mem:[from ICFEDIT_region_SRAM2_start to ICFEDIT_region_SRAM2_end ]; initialize by copy { readwrite }; do not initialize { section .noinit }; define block CSTACK with alignment = 16, size = CSTACK_SIZE { }; define block HEAP with alignment = 16, size = HEAP_SIZE { }; define block RW_DATA { rw section .data}; define block RW_DATA_INIT { ro section .data_init}; define block RW_BSS {rw section .bss}; define block RW_DATA_ALL with static base GPREL { block RW_DATA, block RW_BSS }; "STARTUP" : place at start of ROM_region { readonly section .init }; place in ROM_region { readonly, block RW_DATA_INIT }; place in ROM_region { readonly section .text, section .mcal_text, section .access_code_rom}; place in ROM_region { readonly section .rodata, section .mcal_const_cfg, section .mcal_const, section .mcal_const_no_cacheable}; place in RAMCODE_region { readwrite section .text, section .ramcode, block RW_DATA_ALL }; place in RAM_region { readwrite, block CSTACK, block HEAP }; place in RAM_region { section .mcal_data, section .dma_dest_buffer, section .mcal_shared_data }; place in RAM_region { section .mcal_bss, section .mcal_bss_no_cacheable, section .dma_dest_buffer_bss, section .mcal_shared_bss };

第13、14行:定義FLASH,起始地址和結(jié)束地址。 第41行:定義了ROM_region區(qū)域,起始地址和結(jié)束地址。 第63行:定義一個名為 ROM_region 的內(nèi)存區(qū)域,并將三個只讀代碼段 .text、.mcal_text 和 .access_code_rom 放置在這個區(qū)域內(nèi)。。

Port_MemMap.h

#define MEMMAP_MISSMATCH_CHECKER#if defined (_IAR_C_AS32x601_)#ifdef PORT_START_SEC_CODE#undef PORT_START_SEC_CODE#undef MEMMAP_MISSMATCH_CHECKER#pragma default_function_attributes = @ ".mcal_text"#endif#ifdef PORT_STOP_SEC_CODE#undef PORT_STOP_SEC_CODE#undef MEMMAP_MISSMATCH_CHECKER#pragma default_function_attributes =#endif#endif#ifdef MEMMAP_MISSMATCH_CHECKER#error"MemMap.h, No valid section define found."#endif

第1行:定義了一個宏 MEMMAP_MISSMATCH_CHECKER,用于檢查包含的正確的符號。 第3行:定義了一個ifdef,當定義了 IAR_C_AS32x601 時,會執(zhí)行下面的代碼。 第5行:定義了一個ifdef,當定義了 PORT_START_SEC_CODE 時,會執(zhí)行下面的代碼。 第11行:定義了一個ifdef,當定義了 PORT_STOP_SEC_CODE 時,會執(zhí)行下面的代碼。 第19行:定義了一個ifdef,當定義了 MEMMAP_MISSMATCH_CHECKER 時,說明輸入定義錯誤,將會拋出一個錯誤。

Port.c

#define PORT_START_SEC_CODE#include"Port_MemMap.h" FUNC(void, PORT_CODE) Port_Init(P2CONST(Port_ConfigType, AUTOMATIC, PORT_APPL_CONST) ConfigPtr) { #if (PORT_ENABLE_DEV_ERROR_DETECT == STD_ON)/* When PostBuild is used and #(Variants) > 1, the input parameter 'ConfigPtr' is mandatory to be different than NULL_PTR. * In case of error, return immediately and report DET errors. */#if (PORT_PRECOMPILE_SUPPORT == STD_ON)if (NULL_PTR != ConfigPtr) { #elseif (NULL_PTR == ConfigPtr) { #endif/* (PORT_PRECOMPILE_SUPPORT == STD_ON) *//* If development error detection for the Port module is enabled: * The function shall raise the error PORT_E_INIT_FAILED if the parameter ConfigPtr is Null Pointer.*/ (void)Det_ReportError((uint16)PORT_MODULE_ID, PORT_INSTANCE_ID, PORT_INIT_ID, PORT_E_INIT_FAILED); } else { #endif/* (PORT_ENABLE_DEV_ERROR_DETECT == STD_ON) */#if (PORT_PRECOMPILE_SUPPORT == STD_ON) l_PortConfig_ptr = &Port_PreCompileConfig_st; /* Avoid compiler warning */ (void)ConfigPtr; #else/* (PORT_PRECOMPILE_SUPPORT == STD_OFF) */ l_PortConfig_ptr = ConfigPtr; #endif/* (PORT_PRECOMPILE_SUPPORT == STD_ON) *//* Initializes the Port driver with the given configuration */ Port_LLDriver_Init(l_PortConfig_ptr); #if (PORT_ENABLE_DEV_ERROR_DETECT == STD_ON) } #endif/* (PORT_ENABLE_DEV_ERROR_DETECT == STD_ON) */ } #define PORT_STOP_SEC_CODE#include"Port_MemMap.h"

第1行:定義了一個宏 PORT_START_SEC_CODE,將會執(zhí)行#pragma default_function_attributes = @ ".mcal_text",會將函數(shù)放置在.mcal_text區(qū)域。 第32行:定義了一個宏 PORT_STOP_SEC_CODE,會結(jié)束函數(shù)的默認屬性設置。

效果示例

審核編輯 黃宇

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

    關注

    147

    文章

    18419

    瀏覽量

    380617
  • IAR
    IAR
    +關注

    關注

    5

    文章

    392

    瀏覽量

    38194
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    如何在 IAR Embedded Workbench for ARM 開發(fā)環(huán)境中啟用可配置數(shù)據(jù)閃存并設置大小?

    如何在 IAR Embedded Workbench for ARM 開發(fā)環(huán)境中啟用可配置數(shù)據(jù)閃存并設置大小?
    發(fā)表于 08-26 07:49

    請問如何在 IAR Embedded Workbench for ARM 開發(fā)環(huán)境中啟用可配置數(shù)據(jù)閃存并設置大???

    如何在 IAR Embedded Workbench for ARM 開發(fā)環(huán)境中啟用可配置數(shù)據(jù)閃存并設置大???
    發(fā)表于 08-20 06:23

    Arm CEO:公司正在芯片

    據(jù)外媒路透社報道,Arm CEO Rene Haas透露,Arm正在投資開發(fā)自有芯片,并計劃將部分利潤投資于制造自己的芯片和其他組件。與之對應的是Arm預測的下一財季經(jīng)營業(yè)績也會因為
    的頭像 發(fā)表于 07-31 11:49 ?376次閱讀

    「芯生態(tài)」杰發(fā)科技AC7870攜手IAR開發(fā)工具鏈,助推汽車電子全棧全域智能化落地

    IAR Embedded Workbench for Arm已全面支持杰發(fā)科技AutoChips車規(guī)級MCU AC7870,為其提供涵蓋開發(fā)、調(diào)試、
    的頭像 發(fā)表于 07-22 12:06 ?382次閱讀
    「芯生態(tài)」杰發(fā)科技AC7870攜手<b class='flag-5'>IAR</b>開發(fā)工具鏈,助推汽車電子全棧全域智能化落地

    高端芯片,服務器芯片傳來好消息!

    電子發(fā)燒友網(wǎng)報道(文/黃晶晶)當前,處理器已經(jīng)跨過了能用的階段,逐漸走向好用,但無論是消費級還是服務器級都面臨著如何在性能上接近國外高端產(chǎn)品,以及生態(tài)上如何更加完善的問題。國內(nèi)廠商對于服務器芯片
    的頭像 發(fā)表于 05-18 09:25 ?7188次閱讀
    高端<b class='flag-5'>芯片</b><b class='flag-5'>自</b><b class='flag-5'>研</b>,服務器<b class='flag-5'>芯片</b>傳來好消息!

    MCU芯片閃存驅(qū)動的實現(xiàn):OpenOCD詳細過程記錄與操作指南

    功能強大的開源調(diào)試工具,廣泛應用于嵌入式系統(tǒng)開發(fā)中,為系統(tǒng)調(diào)試與程序燒錄提供了重要支持。 隨著MCU芯片項目的不斷推進,如何實現(xiàn)其與OpenOCD的無縫對接成為關鍵問題之一。而閃存
    的頭像 發(fā)表于 05-08 10:51 ?1729次閱讀
    <b class='flag-5'>自</b><b class='flag-5'>研</b><b class='flag-5'>MCU</b><b class='flag-5'>芯片</b>閃存驅(qū)動的實現(xiàn):OpenOCD詳細過程記錄與操作指南

    IAR全面支持芯馳科技車規(guī)MCU芯片E3650

    2025年4月22日,全場景智能車芯引領者芯馳科技與全球嵌入式軟件開發(fā)解決方案領導者IAR正式宣布,IAR Embedded Workbench
    的頭像 發(fā)表于 04-23 15:45 ?1022次閱讀

    如何將項目從IAR遷移到Embedded Studio

    本文描述如何將IAR EWARM項目遷移到SEGGER Embedded Studio(簡稱SES)中。
    的頭像 發(fā)表于 02-25 17:11 ?892次閱讀
    如何將項目從<b class='flag-5'>IAR</b>遷移到<b class='flag-5'>Embedded</b> Studio

    傳DeepSeek芯片,廠商們要把AI成本打下來

    電子發(fā)燒友網(wǎng)報道(文/黃晶晶)日前業(yè)界消息稱,DeepSeek正廣泛招募芯片設計人才,加速芯片布局,其
    的頭像 發(fā)表于 02-16 00:09 ?3618次閱讀
    傳DeepSeek<b class='flag-5'>自</b><b class='flag-5'>研</b><b class='flag-5'>芯片</b>,廠商們要把AI成本打下來

    FRED應用:LED發(fā)光顏色優(yōu)化

    ” 色度值優(yōu)化函數(shù)定義 X和y色度坐標優(yōu)化函數(shù)需要彩色圖像計算他們的值。輸入變量g_ana 是分析面“屏幕”的節(jié)點數(shù)。這里,只有中心像素點
    發(fā)表于 01-17 09:39

    FRED應用:LED發(fā)光顏色優(yōu)化

    ” 色度值優(yōu)化函數(shù)定義 X和y色度坐標優(yōu)化函數(shù)需要彩色圖像計算他們的值。輸入變量g_ana 是分析面“屏幕”的節(jié)點數(shù)。這里,只有中心像素點
    發(fā)表于 01-07 08:51

    IAR與紫光同芯合作,全面支持THA6系列汽車芯片

    近日,全球領先的嵌入式系統(tǒng)開發(fā)軟件解決方案提供商IAR與業(yè)內(nèi)知名的芯片及解決方案提供商紫光同芯攜手宣布,最新版本的IAR Embedded
    的頭像 發(fā)表于 12-27 11:46 ?1516次閱讀

    蘋果計劃2025年起采用藍牙Wi-Fi芯片

    近日,據(jù)最新報道,蘋果公司為了減少對博通(Broadcom)的依賴,并進一步提升其設備的性能和能效,已經(jīng)制定了一項重要的芯片計劃。據(jù)悉,從2025年開始,蘋果將正式啟用
    的頭像 發(fā)表于 12-18 14:22 ?1337次閱讀

    IAR Systems最新版開發(fā)環(huán)境全面賦能芯海科技32位MCU芯片

    隨著IAR Embedded Workbench for Arm 9.32版本對芯??萍?b class='flag-5'>MCU系列的全面支持,雙方將攜手為開發(fā)者提供更加高效、便捷的開發(fā)體驗,共同推動物聯(lián)網(wǎng)、工業(yè)控制、
    的頭像 發(fā)表于 11-14 14:47 ?1191次閱讀
    <b class='flag-5'>IAR</b> Systems最新版開發(fā)環(huán)境全面賦能芯海科技32位<b class='flag-5'>MCU</b><b class='flag-5'>芯片</b>

    蘋果5G芯片或于明年亮相

    蘋果公司正加速推進其5G芯片的研發(fā)進程,有望最快在明年推出首款5G調(diào)制解調(diào)器。這一舉措對高通而言,無疑構(gòu)成了巨大的挑戰(zhàn)。
    的頭像 發(fā)表于 11-12 15:24 ?1239次閱讀