chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

MCU軟件基準(zhǔn)測試實(shí)用技巧:編譯器優(yōu)化能力評測指引

li5236 ? 來源:IAR Systems ? 作者:IAR Systems ? 2022-03-29 15:42 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

MCU開發(fā)和應(yīng)用中,工程師都需要進(jìn)行MCU的能力測試,通用的做法是用Benchmark(基準(zhǔn))程序來測試。然而,在做基準(zhǔn)測試時(shí),編譯器的優(yōu)化能力也在測試結(jié)果中有較為明顯的影響,同一套硬件平臺,選用不同的編譯器和不同的優(yōu)化選項(xiàng),可能得出的結(jié)果相差較大。

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

本文以已在MCU領(lǐng)域內(nèi)廣泛使用的IAR Embedded Workbench開發(fā)工具套件為例,來分享MCU軟件基準(zhǔn)測試應(yīng)該注意的項(xiàng)目和以下技巧,從而幫助讀者能夠去生成業(yè)內(nèi)最高效和最完備的代碼。利用以下項(xiàng)目和設(shè)置,工程師可以精準(zhǔn)調(diào)整優(yōu)化等級,最大限度地進(jìn)行測試和提升所開發(fā)和應(yīng)用代碼的性能。

poYBAGJCuFuAbhGVAADZAWuUulQ949.png

選擇代碼尺寸還是執(zhí)行速度

利用IAR Embedded Workbench等開發(fā)工具套件,工程師可以對整個(gè)工程范圍或?qū)蝹€(gè)文件設(shè)定優(yōu)化級別和類型。在源代碼中,甚至可以對單個(gè)函數(shù)使用 #pragma optimize 指令來完成此操作。

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

pYYBAGJCuFuAB1K_AADejuqRXu0400.png

選擇小型內(nèi)存模型

為了能夠充分地發(fā)揮MCU器件的性能和減少應(yīng)用中的問題,軟件開發(fā)必須充分考慮MCU器件的內(nèi)存等資源限制,因此需要為目標(biāo)器件和項(xiàng)目選擇盡可能小的內(nèi)存模型。小型內(nèi)存模型的優(yōu)點(diǎn)包括:

· 更小尺寸的地址

· 更小尺寸的指令

· 更小尺寸的指針

· 效率更高

· 代碼更少

諸如IAR Embedded Workbench這樣的成熟的開發(fā)工具套件也集成了相關(guān)評估功能,可以對內(nèi)存模型進(jìn)行多方面評估,從而幫助工程師去測試軟件的規(guī)模和優(yōu)化設(shè)計(jì)。

選擇合適的運(yùn)行時(shí)庫

默認(rèn)情況下,運(yùn)行時(shí)庫是以最高代碼尺寸優(yōu)化級別進(jìn)行編譯的。如果您想要對速度進(jìn)行優(yōu)化,請考慮重新編譯生成這些庫??梢酝ㄟ^配置選項(xiàng)來設(shè)置某些標(biāo)準(zhǔn)庫功能(如語言環(huán)境、文件描述符和多字節(jié))最適合的級別。

根據(jù)具體需求,在庫選項(xiàng)中選擇 scanf 輸入和 printf 的格式。默認(rèn)選項(xiàng)并非最小格式。

poYBAGJCuFuAPyqLAAExte1Juaw740.png

pYYBAGJCuFuAZipbAACjCF3a-w8595.png

使用正確的數(shù)據(jù)類型

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

· 選擇最適合您應(yīng)用程序的的數(shù)據(jù)類型尺寸

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

poYBAGJCuFyALLTJAAAb1fU56_I713.png

檢查目標(biāo)特定選項(xiàng)

檢查能提高性能的目標(biāo)特定選項(xiàng),這在日常的MCU設(shè)計(jì)和應(yīng)用開發(fā)中往往需要工程師具有相當(dāng)?shù)慕?jīng)驗(yàn),但是通過使用諸如IAR Embedded Workbench這類成熟的開發(fā)工具套件則可以快速而完善地完成必要的性能檢查:

· 高效的尋址模式——可實(shí)現(xiàn)高效的內(nèi)存訪問

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

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

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

使用基準(zhǔn)測試相關(guān)代碼

所有的MCU開發(fā)工具都應(yīng)該提供基準(zhǔn)測試相關(guān)代碼,但是成熟的通用開發(fā)工具的代碼庫都是這些提供商在相關(guān)領(lǐng)域經(jīng)驗(yàn)的濃縮,因此更為全面和高效。其中的重要經(jīng)驗(yàn)包括:

· 嵌入式系統(tǒng)的基準(zhǔn)測試應(yīng)該針對嵌入式程序的特點(diǎn)來設(shè)計(jì)。

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

· 確保測試代碼不受測試工具(測試相關(guān)函數(shù))的影響。以下示例其實(shí)是對 printf() (測試相關(guān)函數(shù))進(jìn)行了基準(zhǔn)測試。

pYYBAGJCuFyAUBB2AAA2GYGYZw8139.png

· 比較鏈接后生成的代碼。一款編譯器可能會采用內(nèi)聯(lián)代碼,而另一款編譯器可能會調(diào)用庫。

· 充分了解用于執(zhí)行基準(zhǔn)測試的應(yīng)用代碼!

總結(jié)

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

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

    關(guān)注

    147

    文章

    18983

    瀏覽量

    399621
  • 編譯器
    +關(guān)注

    關(guān)注

    1

    文章

    1672

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    單片機(jī)開發(fā)功能安全中編譯器

    的問題是,防御性編碼和外部數(shù)據(jù)訪問等實(shí)踐并不屬于編譯器認(rèn)可的領(lǐng)域。例如,C和C ++都沒有為內(nèi)存損壞留出任何余地,因此,除非在沒有這種損壞的情況下可以訪問旨在防止內(nèi)存損壞的代碼,否則在對代碼進(jìn)行優(yōu)化
    發(fā)表于 12-01 06:44

    性能突破 | SpacemiT-X60 在 LLVM 編譯器上實(shí)現(xiàn) 16% 顯著提升

    2025年10月,在北美RISC-V峰會上,Igalia編譯器工程師Mikhail發(fā)表專題演講《Unlocking15%MorePerformance
    的頭像 發(fā)表于 11-21 18:04 ?8932次閱讀
    性能突破 | SpacemiT-X60 在 LLVM <b class='flag-5'>編譯器</b>上實(shí)現(xiàn) 16% 顯著提升

    開源鴻蒙技術(shù)大會2025丨編譯器與編程語言分論壇:語言驅(qū)動(dòng)系統(tǒng)創(chuàng)新,編譯賦能生態(tài)繁榮

    在萬物智聯(lián)的時(shí)代背景下,操作系統(tǒng)底層能力的構(gòu)建離不開編程語言與編譯器的關(guān)鍵支撐。作為開源鴻蒙生態(tài)的核心技術(shù),語言設(shè)計(jì)與編譯器、虛擬機(jī)實(shí)現(xiàn)的進(jìn)步直接關(guān)系到開發(fā)效率、運(yùn)行性能與系統(tǒng)安全。本次分論壇聚焦
    的頭像 發(fā)表于 11-20 17:24 ?969次閱讀
    開源鴻蒙技術(shù)大會2025丨<b class='flag-5'>編譯器</b>與編程語言分論壇:語言驅(qū)動(dòng)系統(tǒng)創(chuàng)新,<b class='flag-5'>編譯</b>賦能生態(tài)繁榮

    通過優(yōu)化代碼來提高MCU運(yùn)行效率

    調(diào)用開銷。 使用 const 和 volatile 關(guān)鍵字,幫助編譯器進(jìn)行更好的優(yōu)化。 數(shù)據(jù)類型選擇 使用與MCU字長匹配的數(shù)據(jù)類型。在32位MCU上,int 和 uint32_t
    發(fā)表于 11-12 08:21

    Coremark測試集分析與性能優(yōu)化思路

    實(shí)際上暴露了編譯器優(yōu)化工作負(fù)載的能力,而不是MCU或CPU的功能”的問題。因此要?jiǎng)?chuàng)建不能在編譯時(shí)計(jì)算而必須在運(yùn)行時(shí)計(jì)算的工作,因此coreM
    發(fā)表于 10-24 08:21

    提高RISC-V在Drystone測試中得分的方法

    編譯器如何優(yōu)化生成的機(jī)器代碼也會影響Drystone的得分。優(yōu)化編譯器能夠生成更高效的機(jī)器代碼,從而提高性能。 提高 RISC-V 在 Drystone
    發(fā)表于 10-21 13:58

    請問如何在keil μVision 5上進(jìn)行ARM編譯器的代碼優(yōu)化?

    如何在keil μVision 5上進(jìn)行ARM編譯器的代碼優(yōu)化
    發(fā)表于 08-20 07:37

    邊緣設(shè)備AI部署:編譯器如何實(shí)現(xiàn)輕量化與高性能?

    、ASIC等)上高效執(zhí)行的機(jī)器代碼。AI編譯器在AI模型的部署和優(yōu)化中扮演著關(guān)鍵角色,能夠顯著提升模型的運(yùn)行效率和性能。 ? AI編譯器的主要功能 ? AI編譯器的主要功能包括模型
    的頭像 發(fā)表于 07-06 05:49 ?6730次閱讀

    編譯器功能安全驗(yàn)證的關(guān)鍵要素

    在汽車、工業(yè)、醫(yī)療等安全關(guān)鍵型應(yīng)用中,確保功能安全合規(guī)性需要嚴(yán)格的工具鏈驗(yàn)證。開發(fā)安全關(guān)鍵型軟件的企業(yè)必須遵守ISO 26262、IEC 61508、ISO 62304等國際標(biāo)準(zhǔn)對編譯器工具鏈進(jìn)行全面的驗(yàn)證。
    的頭像 發(fā)表于 07-05 13:37 ?1599次閱讀

    兆松科技發(fā)布高性能RISC-V編譯器ZCC 4.0.0版本

    近日,兆松科技(武漢)有限公司(以下簡稱“兆松科技”)宣布正式發(fā)布高性能 RISC-V 編譯器 ZCC 4.0.0 版本。新版本在性能優(yōu)化、廠商自定義指令支持和軟件庫等方面實(shí)現(xiàn)全面升級,并同步推出
    的頭像 發(fā)表于 06-27 14:48 ?3178次閱讀
    兆松科技發(fā)布高性能RISC-V<b class='flag-5'>編譯器</b>ZCC 4.0.0版本

    兆松科技ZCC編譯器全面支持芯來科技NA系列處理

    近日,兆松科技(武漢)有限公司(以下簡稱“兆松科技”)宣布正式發(fā)布高性能RISC-V編譯器ZCC 4.0.0版本。
    的頭像 發(fā)表于 06-11 09:56 ?1769次閱讀

    RISC-V架構(gòu)下的編譯器自動(dòng)向量化

    高性能算力生態(tài)的建設(shè),正投入編譯器自動(dòng)向量化優(yōu)化等多項(xiàng)關(guān)鍵技術(shù),全面助力RISC-V的高性能發(fā)展。RISC-V向量設(shè)計(jì)SpacemiT在現(xiàn)代CPU中,向量支持是算力的
    的頭像 發(fā)表于 06-06 16:59 ?1279次閱讀
    RISC-V架構(gòu)下的<b class='flag-5'>編譯器</b>自動(dòng)向量化

    RVCT編譯器是否比GNU的編譯器的代碼執(zhí)行速度更快?

    使用FX3S遇到了RVCT編譯器的問題。 1、在SDK的release note中有支持RVCT的描述, 但是在EZ USB Suite的設(shè)置中沒有找到RVCT的選項(xiàng), 請問支持的具體版本
    發(fā)表于 05-08 07:49

    HighTec編譯器全面支持芯馳科技車規(guī)MCU芯片E3650

    近日,HighTec與芯馳科技共同宣布HighTec編譯器套件將全面支持芯馳新一代旗艦智控MCU-E3650芯片。此次合作,進(jìn)一步豐富了芯馳車芯產(chǎn)品的工具鏈生態(tài),雙方將攜手為客戶提供高性能、高安全性的解決方案。
    的頭像 發(fā)表于 04-28 15:20 ?1854次閱讀

    HighTec編譯器全面適配紫光同芯THA6 Gen2系列產(chǎn)品

    近日,紫光同芯與全球領(lǐng)先的汽車級C/C++編譯器供應(yīng)商HighTec共同宣布,HighTec編譯器完成對紫光同芯THA6 Gen2系列產(chǎn)品的全面適配。此次合作實(shí)現(xiàn)了從指令集優(yōu)化到功能安全的全棧支持,是國產(chǎn)高端車規(guī)芯片與國際領(lǐng)先開
    的頭像 發(fā)表于 04-02 09:42 ?1220次閱讀