色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

MCU軟件基準測試實用技巧:編譯器優化能力評測指引

li5236 ? 來源:IAR Systems ? 作者:IAR Systems ? 2022-03-29 15:42 ? 次閱讀

MCU開發和應用中,工程師都需要進行MCU的能力測試,通用的做法是用Benchmark(基準)程序來測試。然而,在做基準測試時,編譯器的優化能力也在測試結果中有較為明顯的影響,同一套硬件平臺,選用不同的編譯器和不同的優化選項,可能得出的結果相差較大。

為了最大程度釋放MCU的性能,在基準測試中取得最理想的結果,往往需要工程師不僅對自身的硬件比較了解,更需要深入了解編譯器的優化原理,并靈活應用,才能在基準測試中發揮出MCU的全部性能。IAR Systems作為全球知名嵌入式工具廠商,其編譯器在優化能力上有獨特的優勢,MCU配合IAR的編譯器往往能夠得出較好的基準測試結果。

本文以已在MCU領域內廣泛使用的IAR Embedded Workbench開發工具套件為例,來分享MCU軟件基準測試應該注意的項目和以下技巧,從而幫助讀者能夠去生成業內最高效和最完備的代碼。利用以下項目和設置,工程師可以精準調整優化等級,最大限度地進行測試和提升所開發和應用代碼的性能。

poYBAGJCuFuAbhGVAADZAWuUulQ949.png

選擇代碼尺寸還是執行速度

利用IAR Embedded Workbench等開發工具套件,工程師可以對整個工程范圍或對單個文件設定優化級別和類型。在源代碼中,甚至可以對單個函數使用 #pragma optimize 指令來完成此操作。

優化的目的是減少代碼尺寸和提高執行速度。如果只能滿足其中一個目標,編譯器會根據用戶指定的設置進行優先處理。因此,在實際的軟件基準測試中,工程師可以嘗試各種設置來獲得最佳效果。舉個例子,由于函數內聯更側重于執行速度的優化,相較于采用通用代碼尺寸優化設置,采用函數內聯與通用代碼執行速度優化設置將獲得更小的程序代碼

pYYBAGJCuFuAB1K_AADejuqRXu0400.png

選擇小型內存模型

為了能夠充分地發揮MCU器件的性能和減少應用中的問題,軟件開發必須充分考慮MCU器件的內存等資源限制,因此需要為目標器件和項目選擇盡可能小的內存模型。小型內存模型的優點包括:

· 更小尺寸的地址

· 更小尺寸的指令

· 更小尺寸的指針

· 效率更高

· 代碼更少

諸如IAR Embedded Workbench這樣的成熟的開發工具套件也集成了相關評估功能,可以對內存模型進行多方面評估,從而幫助工程師去測試軟件的規模和優化設計。

選擇合適的運行時庫

默認情況下,運行時庫是以最高代碼尺寸優化級別進行編譯的。如果您想要對速度進行優化,請考慮重新編譯生成這些庫。可以通過配置選項來設置某些標準庫功能(如語言環境、文件描述符和多字節)最適合的級別。

根據具體需求,在庫選項中選擇 scanf 輸入和 printf 的格式。默認選項并非最小格式。

poYBAGJCuFuAPyqLAAExte1Juaw740.png

pYYBAGJCuFuAZipbAACjCF3a-w8595.png

使用正確的數據類型

數據類型與代碼尺寸或者執行速度息息相關,因此需要利用開發工具來對數據類型進行觀察和分析,以便找到適合硬件資源的類型。在IAR Embedded Workbench開發工具套件中,開發人員可以從以下幾個方面著手進行測試和優化:

· 選擇最適合您應用程序的的數據類型尺寸

· 盡量使用無符號字符型,這樣就能執行位操作而不是算術操作

poYBAGJCuFyALLTJAAAb1fU56_I713.png

檢查目標特定選項

檢查能提高性能的目標特定選項,這在日常的MCU設計和應用開發中往往需要工程師具有相當的經驗,但是通過使用諸如IAR Embedded Workbench這類成熟的開發工具套件則可以快速而完善地完成必要的性能檢查:

· 高效的尋址模式——可實現高效的內存訪問

· 使用特定的寄存器來處理常量/變量——代碼在寄存器上的操作效率比在內存上更高

· 偶對齊函數入口——偶對齊指令可以提高速度

· 字節對齊對象——更小的存儲空間需求,但可能生成更大的代碼尺寸

使用基準測試相關代碼

所有的MCU開發工具都應該提供基準測試相關代碼,但是成熟的通用開發工具的代碼庫都是這些提供商在相關領域經驗的濃縮,因此更為全面和高效。其中的重要經驗包括:

· 嵌入式系統的基準測試應該針對嵌入式程序的特點來設計。

· 實際的應用程序通常也適用于基準測試,但需要確保代碼的可執行性。鏈接器會刪除未引用的代碼和變量,但并非所有的鏈接器都具備這種功能。

· 確保測試代碼不受測試工具(測試相關函數)的影響。以下示例其實是對 printf() (測試相關函數)進行了基準測試。

pYYBAGJCuFyAUBB2AAA2GYGYZw8139.png

· 比較鏈接后生成的代碼。一款編譯器可能會采用內聯代碼,而另一款編譯器可能會調用庫。

· 充分了解用于執行基準測試的應用代碼!

總結

通過使用諸如IAR Embedded Workbench這類成熟的開發工具套件,發揮其在幾十年全球性應用中行匯聚和迭代出的知識,MCU設計和應用開發工程師可以快速完成上述這些必要的性能測試,同時也可以進一步有針對性地發揮MCU的性能,從而實現目標器件最優化的、軟硬件合一的功能。

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

    關注

    146

    文章

    17172

    瀏覽量

    351594
  • 編譯器
    +關注

    關注

    1

    文章

    1635

    瀏覽量

    49169
收藏 人收藏

    評論

    相關推薦

    Triton編譯器與GPU編程的結合應用

    Triton編譯器簡介 Triton編譯器是一種針對并行計算優化編譯器,它能夠自動將高級語言代碼轉換為針對特定硬件優化的低級代碼。Trit
    的頭像 發表于 12-25 09:13 ?241次閱讀

    Triton編譯器如何提升編程效率

    在現代軟件開發中,編譯器扮演著至關重要的角色。它們不僅將高級語言代碼轉換為機器可執行的代碼,還通過各種優化技術提升程序的性能。Triton 編譯器作為一種先進的
    的頭像 發表于 12-25 09:12 ?231次閱讀

    Triton編譯器優化技巧

    在現代計算環境中,編譯器的性能對于軟件的運行效率至關重要。Triton 編譯器作為一個先進的編譯器框架,提供了一系列的優化技術,以確保生成的
    的頭像 發表于 12-25 09:09 ?233次閱讀

    Triton編譯器的優勢與劣勢分析

    Triton編譯器作為一種新興的深度學習編譯器,具有一系列顯著的優勢,同時也存在一些潛在的劣勢。以下是對Triton編譯器優勢與劣勢的分析: 優勢 高效性能優化 : Triton
    的頭像 發表于 12-25 09:07 ?259次閱讀

    Triton編譯器在機器學習中的應用

    1. Triton編譯器概述 Triton編譯器是NVIDIA Triton推理服務平臺的一部分,它負責將深度學習模型轉換為優化的格式,以便在NVIDIA GPU上高效運行。Triton編譯器
    的頭像 發表于 12-24 18:13 ?398次閱讀

    TMS320C6000優化編譯器v7.4測試版用戶指南

    電子發燒友網站提供《TMS320C6000優化編譯器v7.4測試版用戶指南.pdf》資料免費下載
    發表于 12-24 17:42 ?0次下載
    TMS320C6000<b class='flag-5'>優化</b><b class='flag-5'>編譯器</b>v7.4<b class='flag-5'>測試</b>版用戶指南

    Triton編譯器與其他編譯器的比較

    的GPU編程框架,使開發者能夠編寫出接近手工優化的高性能GPU內核。 其他編譯器 (如GCC、Clang、MSVC等): 定位:通用編譯器,支持多種編程語言,廣泛應用于各種軟件開發場景
    的頭像 發表于 12-24 17:25 ?381次閱讀

    Triton編譯器功能介紹 Triton編譯器使用教程

    Triton 是一個開源的編譯器前端,它支持多種編程語言,包括 C、C++、Fortran 和 Ada。Triton 旨在提供一個可擴展和可定制的編譯器框架,允許開發者添加新的編程語言特性和優化技術
    的頭像 發表于 12-24 17:23 ?435次閱讀

    MSP430優化C/C++編譯器v21.6.0.LTS

    電子發燒友網站提供《MSP430優化C/C++編譯器v21.6.0.LTS.pdf》資料免費下載
    發表于 11-08 14:57 ?0次下載
    MSP430<b class='flag-5'>優化</b>C/C++<b class='flag-5'>編譯器</b>v21.6.0.LTS

    C7000優化C/C++編譯器

    電子發燒友網站提供《C7000優化C/C++編譯器.pdf》資料免費下載
    發表于 10-30 09:45 ?0次下載
    C7000<b class='flag-5'>優化</b>C/C++<b class='flag-5'>編譯器</b>

    Keil編譯器優化方法

    我們都知道,代碼是可以通過編譯器優化的,有的時候,為了提高運行速度或者減少代碼尺寸,會開啟優化選項。
    的頭像 發表于 10-23 16:35 ?629次閱讀
    Keil<b class='flag-5'>編譯器</b><b class='flag-5'>優化</b>方法

    人工智能編譯器與傳統編譯器的區別

    人工智能編譯器(AI編譯器)與傳統編譯器在多個方面存在顯著的差異。這些差異主要體現在設計目標、功能特性、優化策略、適用范圍以及技術復雜性等方面。以下是對兩者區別的詳細探討,旨在全面解析
    的頭像 發表于 07-17 18:19 ?1949次閱讀

    Meta發布基于Code Llama的LLM編譯器

    近日,科技巨頭Meta在其X平臺上正式宣布推出了一款革命性的LLM編譯器,這一模型家族基于Meta Code Llama構建,并融合了先進的代碼優化編譯器功能。LLM編譯器的推出,標
    的頭像 發表于 06-29 17:54 ?1520次閱讀

    SEGGER編譯器優化和安全技術介紹 支持最新C和C++語言

    SEGGER編譯器是專門為ARM和RISC-V微控制設計的優化C/C++編譯器。它建立在強大的Clang前端上,支持最新的C和C++語言功能。 除其他外,其主要功能包括: 1)?尺寸
    的頭像 發表于 06-04 15:31 ?1489次閱讀
    SEGGER<b class='flag-5'>編譯器</b><b class='flag-5'>優化</b>和安全技術介紹 支持最新C和C++語言

    英特爾宣布DPC++編譯器優化無效,2600項基準測試成績丟失

    根據公告,該編譯器有選擇性地運用了與SPEC代碼及數據集的先驗知識有關的轉換,僅致力于提升523.xalancbmk_r/623.xalancbmk_s基準性能,而這種優化形式的適用范圍相對狹窄。
    的頭像 發表于 02-19 13:53 ?581次閱讀
    主站蜘蛛池模板: 国产色精品久久人妻无码| 婷婷六月激情综合一区| 亚欧成人毛片一区二区三区四区 | 特级毛片AAAAAA| 国产美女裸身网站免费观看视频 | 亚洲中文字幕永久在线全国| 亚洲 在线 日韩 欧美| 果冻传媒在线播放 免费观看| 又大又硬又爽免费视频| 欧美阿v在线天堂| 国产传媒18精品A片在线观看| 亚洲欧美日韩综合影院| 国产精品系列在线观看| 伊人22222| 日本艳妓BBW高潮一19| 国产人妻午夜无码AV天堂| 2022年国产精品久久久久| 入禽太深免费观看| 久久免费看少妇高潮A片JA| 芭乐视频免费资源在线观看| 欧美激情视频一区二区| 国产乱辈通伦影片在线播放亚洲| 又爽又黄又粗又大免费视频| 青草影院天堂男人久久| 精品国产三级a| 成品片a免人看免费| 一本道久在线综合道| 日本不卡不码高清免费| 大睾丸内射老师| 在线观看国产小视频| 素人约啪第五季| 免费夜里18款禁用软粉色| 国产在线自天天人人| jizz日本美女| 色婷婷AV国产精品欧美毛片| 久久国产精品麻豆AV影视| 国产成人精品免费视频大| 亚洲 欧美 制服 校园 动漫| 欧美506070| 精品视频网站| 国产精品久久免费视频|