吴忠躺衫网络科技有限公司

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

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

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

如何測量ARM Cortex-M MCU代碼的執(zhí)行時間

奈因PCB電路板設(shè)計(jì) ? 來源:麥克泰技術(shù) ? 作者:麥克泰 ? 2021-08-26 09:20 ? 次閱讀

在許多實(shí)時應(yīng)用中,如電機(jī)控制、發(fā)動機(jī)控制、無線通信等時間敏感的應(yīng)用,CPU可能花費(fèi)不到5%的時間執(zhí)行代碼。這些嵌入式系統(tǒng)通常用C語言編寫,開發(fā)人員可能會使用到匯編語言優(yōu)化代碼,以滿足時間期限(deadline)要求。測量部分代碼的實(shí)際執(zhí)行時間可以幫助我們找到代碼中的時間關(guān)鍵點(diǎn)。

本文將展示如何輕松測量和顯示基于Cortex-M MCU的代碼片段的執(zhí)行時間。

測量執(zhí)行時間的方法

有很多方法可以測量代碼執(zhí)行時間。嵌入式工程師經(jīng)常使用數(shù)字輸出和示波器。我們可以在監(jiān)視的代碼執(zhí)行之前,設(shè)置輸出為高電平,代碼執(zhí)行后將輸出設(shè)置為低電平。當(dāng)然,在執(zhí)行此操作之前需要進(jìn)行大量設(shè)置工作:找到易于探測的輸出引腳,將端口配置為輸出,編寫代碼,編譯等等。獲得信號后,你可能需要對其進(jìn)行一段時間的監(jiān)測以查看其運(yùn)行時間的最小值和最大值。

測量執(zhí)行時間的另一種方法是使用具有跟蹤功能的調(diào)試工具。你只需運(yùn)行代碼、查看跟蹤、手動計(jì)算增量時間并將CPU周期轉(zhuǎn)換為微秒。不幸的是,跟蹤僅提供一次執(zhí)行實(shí)例,你可能需要進(jìn)一步查看跟蹤捕獲以找到最壞情況的執(zhí)行時間,這可能是一個乏味的過程。

Cortex-M周期計(jì)數(shù)器

Cortex-M的處理器上的 CoreSight調(diào)試端口包含一個32位自由運(yùn)行計(jì)數(shù)器,用于CPU時鐘周期計(jì)數(shù)。計(jì)數(shù)器是調(diào)試監(jiān)視和跟蹤 (DWT) 模塊的一部分,可輕松用于測量代碼的執(zhí)行時間。啟用和初始化該功能所需的代碼如下:

e2b842d0-e411-11eb-a97a-12bb97331649.png

使用DWT周期計(jì)數(shù)器測量代碼執(zhí)行時間

我們可以通過讀取代碼段前后的循環(huán)計(jì)數(shù)器的值來測量并計(jì)算代碼片段的執(zhí)行時間,如下所示。

e2c254fa-e411-11eb-a97a-12bb97331649.png

無符號數(shù)delta表示被測代碼的實(shí)際執(zhí)行時間(以CPU時鐘周期為單位)。

在代碼執(zhí)行期間可能會發(fā)生中斷,因此每次執(zhí)行此序列獲得時間值可能并不相同,我們也可以在測量期間禁用中斷以移除中斷的影響。但建議在測量中允許中斷,因?yàn)樗鼈儠绊懘a的時間期限。

e2ca3cd8-e411-11eb-a97a-12bb97331649.png

如果被測量的代碼包含條件語句、循環(huán)或任何可能導(dǎo)致變化的東西,那么獲得的值可能不代表最壞情況下的執(zhí)行時間。要解決此問題,可以簡單地添加一個峰值檢測,如下所示。在進(jìn)行任何測量之前,需要聲明 max 并將其初始化為最小值(即 0)。

e2d42626-e411-11eb-a97a-12bb97331649.png

同樣,如果需要了解最短執(zhí)行時間,min只需在測量之前聲明并初始化為最大計(jì)數(shù)值(即 0xFFFFFFFF)。代碼如下:

e2dc8636-e411-11eb-a97a-12bb97331649.png

執(zhí)行時間還取決于 CPU是否配備cache,某些Cortex-M4和Cortex-M7處理器集成了Cache。如果 系統(tǒng)使用了指令或數(shù)據(jù)cache,則同一代碼段的多次測量結(jié)果可能會不一致。你可以考慮禁用cache來衡量最壞的情況。

大多數(shù)調(diào)試器能夠?qū)崟r顯示這些變量值。我們可以使用Global聲明顯示的變量以保留其值并允許實(shí)時監(jiān)控。這些值代表CPU時鐘周期,但大多數(shù)調(diào)試器無法為顯示目的縮放變量。假設(shè)CPU時鐘速度為16 MHz,顯示70.19微秒比顯示1123個周期要方便得多。實(shí)際上有一種更好的方式來顯示實(shí)時變量,使用μC/Probe實(shí)時監(jiān)控工具,它還提供了縮放能力,以易讀的形式查看變量值。

使用μC/Probe顯示測量值

在應(yīng)用中添加測量,監(jiān)控四個代碼片段的執(zhí)行時間,并通過μC/Probe顯示測量結(jié)果。

下圖顯示了使用 IAR的LiveWatch(左)和 μC/Probe 的Tree View控件(右)的原始測量值。elapsed_time_tbl[] 是一個數(shù)組,用于存儲不同代碼片段的測量值。

你還可以將min/max/current值分配給gauge和numeric indicator控件,如下圖所示。這里的值以微秒為單位顯示,示例中CPU以80 MHz 運(yùn)行,使用了0.0125的縮放因子。僅顯示最長執(zhí)行時間。

uC/Probe還可以與Microsoft的Excel連接,從而在電子表格中顯示實(shí)時值,如下圖所示。

e31cca0c-e411-11eb-a97a-12bb97331649.png

總結(jié)

作為嵌入式開發(fā)人員,我們有許多工具可以用來測試和驗(yàn)證我們的設(shè)計(jì)。μC/Probe提供了許多功能,允許用戶使用gauge、meter、numeric indictor、Excel或graph/plots來監(jiān)控應(yīng)用程序中的變量。基于Cortex-M處理器的DWT 周期計(jì)數(shù)器功能和μC/Probe,我們可以輕松實(shí)現(xiàn)Cortex-M MCU應(yīng)用的設(shè)計(jì)驗(yàn)證工作。

責(zé)任編輯:haq

聲明:本文內(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)注

    146

    文章

    17322

    瀏覽量

    352651
  • ARM
    ARM
    +關(guān)注

    關(guān)注

    134

    文章

    9168

    瀏覽量

    369217
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4827

    瀏覽量

    69054

原文標(biāo)題:教你一招:在ARM Cortex-M MCU上測量代碼執(zhí)行時間

文章出處:【微信號:pcbgood,微信公眾號:奈因PCB電路板設(shè)計(jì)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    充電樁CCC認(rèn)證什么時候執(zhí)行

    充電樁CCC認(rèn)證的執(zhí)行時間表如下:
    的頭像 發(fā)表于 12-25 17:12 ?317次閱讀

    如何使用Ozone分析Cortex-M異常

    Ozone可以幫助用戶快速分析和查找導(dǎo)致CPU故障的軟件bug。本文解釋如何使用Ozone的調(diào)試功能,深入了解Cortex-M架構(gòu)上的這些錯誤。
    的頭像 發(fā)表于 11-29 11:14 ?923次閱讀
    如何使用Ozone分析<b class='flag-5'>Cortex-M</b>異常

    MAX32675C超低功耗Arm? Cortex?-M4F MCU

    檢測(SEC-DED),確保為要求苛刻的應(yīng)用提供超可靠的代碼執(zhí)行。 *附件:MAX32675C超低功耗Arm? Cortex?-M4F
    的頭像 發(fā)表于 11-28 11:50 ?496次閱讀
    MAX32675C超低功耗<b class='flag-5'>Arm</b>? <b class='flag-5'>Cortex</b>?-<b class='flag-5'>M</b>4F <b class='flag-5'>MCU</b>

    【RA-Eco-RA2E1-48PIN-V1.0開發(fā)板試用】原創(chuàng)測量代碼運(yùn)行時間

    應(yīng)用在所有Cortex-M處理器上,不限內(nèi)核版本。 加入keil工程 添加文件目錄 在hal_entry()里面添加如下函數(shù)代碼 while里面實(shí)現(xiàn)流水燈,同時測量流水燈執(zhí)行時間
    發(fā)表于 11-06 15:32

    實(shí)際項(xiàng)目開發(fā)中為何選擇ARM? Cortex?-M4 內(nèi)核的HK32MCU

    ?Cortex?-M4內(nèi)核的HK32F407芯片的深度知識,并圍繞各類實(shí)際案例詳細(xì)解讀了如何選型,為何選擇ARM?Cortex?-M4內(nèi)核的
    的頭像 發(fā)表于 10-22 17:19 ?489次閱讀
    實(shí)際項(xiàng)目開發(fā)中為何選擇<b class='flag-5'>ARM</b>? <b class='flag-5'>Cortex</b>?-<b class='flag-5'>M</b>4 內(nèi)核的HK32<b class='flag-5'>MCU</b>?

    基于瑞薩Arm Cortex-M85 MCU Feather SOM的解決方案

    開源社區(qū)已經(jīng)從傳統(tǒng)的黑客聚集地逐漸擴(kuò)展到家庭、辦公室以及工業(yè)應(yīng)用等廣泛領(lǐng)域。在這個過程中,瑞薩的Arm Cortex-M85 MCU Feather SOM憑借著卓越的性能和豐富的功能,為開源硬件愛好者和專業(yè)開發(fā)者提供了強(qiáng)大的支
    的頭像 發(fā)表于 08-19 17:32 ?576次閱讀

    深度探討:無人機(jī)干擾器干擾執(zhí)行時間的關(guān)鍵影響因素

    隨著無人機(jī)技術(shù)的廣泛應(yīng)用,無人機(jī)干擾器作為防御和管控?zé)o人機(jī)的重要工具,其在軍事、民用及公共安全等領(lǐng)域發(fā)揮著重要作用。然而,無人機(jī)干擾器的干擾執(zhí)行時間直接決定了其有效性和實(shí)用性。本文將深入探討無人機(jī)干擾器干擾執(zhí)行時間的影響因素,并對這些因素進(jìn)行詳細(xì)解析。
    的頭像 發(fā)表于 05-29 09:27 ?624次閱讀

    請問stm32cubeIDE仿真怎么看程序執(zhí)行時間

    就想keil仿真那樣,可以時刻監(jiān)視程序執(zhí)行時間,cubeide怎么在仿真debug時,監(jiān)視程序時間呢?
    發(fā)表于 04-02 07:47

    Cortex-M0+內(nèi)核介紹

    ARM Cortex-M0+是2012年3月14日ARM公司發(fā)布的一款低功耗效率、能效最高的ARM處理器,可用于存在設(shè)計(jì)約束的嵌入式應(yīng)用。它具有最小的硅面積和極少的
    的頭像 發(fā)表于 03-27 09:13 ?1149次閱讀
    <b class='flag-5'>Cortex-M</b>0+內(nèi)核介紹

    G431CB把stack heap全分配到ccmram,代碼執(zhí)行速度并未改善是怎么回事?

    把stack heap全分配到ccmram發(fā)現(xiàn)函數(shù)執(zhí)行時間也沒有什么改善,附圖是我的結(jié)果 函數(shù)執(zhí)行速度非但沒有改善,反而發(fā)現(xiàn)在ccmram執(zhí)行很不穩(wěn)定; 測試手段:用定時器3計(jì)數(shù)來實(shí)現(xiàn)該函數(shù)
    發(fā)表于 03-27 08:23

    兆易創(chuàng)新推出GD32F5系列Cortex-M33內(nèi)核MCU

    兆易創(chuàng)新GigaDevice宣布,正式推出GD32F5系列高性能微控制器,該系列MCU基于Arm? Cortex?-M33內(nèi)核,旨在滿足各類高要求應(yīng)用場景的需求。
    的頭像 發(fā)表于 03-16 09:58 ?1315次閱讀

    業(yè)界首款基于Arm Cortex-M85處理器的MCU

    所有RA8系列MCU均利用Arm Cortex-M85處理器和Arm的Helium技術(shù)所帶來的高性能,結(jié)合矢量/SIMD指令集擴(kuò)展,能夠在數(shù)字信號處理器(DSP)和機(jī)器學(xué)習(xí)(ML)的實(shí)
    發(fā)表于 03-05 14:14 ?799次閱讀
    業(yè)界首款基于<b class='flag-5'>Arm</b> <b class='flag-5'>Cortex-M</b>85處理器的<b class='flag-5'>MCU</b>

    Arm Helium技術(shù)誕生的由來 為何不直接采用Neon?

    經(jīng)過 Arm 研究團(tuán)隊(duì)多年的不懈努力,Arm 于 2019 年推出了適用于 Armv8?M 架構(gòu)的 Arm Cortex-M 矢量擴(kuò)展技術(shù)
    的頭像 發(fā)表于 02-29 17:01 ?2531次閱讀
    <b class='flag-5'>Arm</b> Helium技術(shù)誕生的由來 為何不直接采用Neon?

    Cortex-M85內(nèi)核單片機(jī)如何快速上手

    2022年4月,Arm推出了全新的MCU級內(nèi)核Cortex-M85。截止目前(2024年2月),Cortex-M85是最新、最強(qiáng)的Cortex-M
    發(fā)表于 02-29 09:35 ?809次閱讀
    <b class='flag-5'>Cortex-M</b>85內(nèi)核單片機(jī)如何快速上手

    ARM?Cortex?-M23 32位MCU數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《ARM?Cortex?-M23 32位MCU數(shù)據(jù)表.pdf》資料免費(fèi)下載
    發(fā)表于 02-22 14:32 ?0次下載
    <b class='flag-5'>ARM</b>?<b class='flag-5'>Cortex</b>?-<b class='flag-5'>M</b>23 32位<b class='flag-5'>MCU</b>數(shù)據(jù)表
    百家乐官网平台哪个有在线支付呢| 网上百家乐官网新利| 百家乐官网扑克片礼服| 免邮百家乐官网布桌| 茅台百家乐的玩法技巧和规则 | 百家乐官网网上真钱娱乐网| 百家乐押注方法| 博彩旅游业| 百家乐官网大赢家书籍| 百家乐一直下注庄家| 六合彩生肖表| 百家乐官网怎么玩请指教| 大发888打法888| 百家乐官网网站源码| 百家乐破解分| 澳门百家乐官网国际| 缅甸百家乐娱乐场开户注册| 儋州市| 明珠百家乐官网的玩法技巧和规则| 澳门赌百家乐能赢钱吗| 网络赌博| 长赢百家乐官网赌徒| 网上棋牌是真的吗| 免费百家乐官网追号软件| 人民币棋牌游戏| 24山择日财丁贵日| 大发888娱乐场漏洞| 百家乐官网网上真钱娱乐场| 大发888真人游戏| 最好百家乐官网的玩法技巧和规则| 皇冠现金网网址| 百家乐官网路单| 百家乐娱乐真人娱乐| 百家乐官网噢门棋牌| 大发888全部的网站地址| 玩百家乐官网的高手| 百家乐玩法| 百家乐官网怎么骗人| 大发888怎么开户| 赌博百家乐的路单| 漯河市|