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

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

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

3天內不再提示

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

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

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

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

測量執行時間的方法

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

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

Cortex-M周期計數器

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

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

使用DWT周期計數器測量代碼執行時間

我們可以通過讀取代碼段前后的循環計數器的值來測量并計算代碼片段的執行時間,如下所示。

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

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

在代碼執行期間可能會發生中斷,因此每次執行此序列獲得時間值可能并不相同,我們也可以在測量期間禁用中斷以移除中斷的影響。但建議在測量中允許中斷,因為它們會影響代碼的時間期限。

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

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

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

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

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

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

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

使用μC/Probe顯示測量值

在應用中添加測量,監控四個代碼片段的執行時間,并通過μC/Probe顯示測量結果。

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

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

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

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

總結

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

責任編輯:haq

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

    關注

    146

    文章

    17458

    瀏覽量

    354442
  • ARM
    ARM
    +關注

    關注

    134

    文章

    9207

    瀏覽量

    371057
  • 代碼
    +關注

    關注

    30

    文章

    4857

    瀏覽量

    69524

原文標題:教你一招:在ARM Cortex-M MCU上測量代碼執行時間

文章出處:【微信號:pcbgood,微信公眾號:奈因PCB電路板設計】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Arm Cortex-A320 CPU助力嵌入式設備實現高能效AI計算

    ,要確定適合特定 AI 應用的處理器,系統開發者需要通過比較基于 Arm Cortex-A、Arm Cortex-MArm Ethos
    的頭像 發表于 02-27 17:17 ?347次閱讀
    <b class='flag-5'>Arm</b> <b class='flag-5'>Cortex</b>-A320 CPU助力嵌入式設備實現高能效AI計算

    充電樁CCC認證什么時候執行

    充電樁CCC認證的執行時間表如下:
    的頭像 發表于 12-25 17:12 ?458次閱讀

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

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

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

    檢測(SEC-DED),確保為要求苛刻的應用提供超可靠的代碼執行。 *附件:MAX32675C超低功耗Arm? Cortex?-M4F
    的頭像 發表于 11-28 11:50 ?587次閱讀
    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開發板試用】原創測量代碼行時間

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

    實際項目開發中為何選擇ARM? Cortex?-M4 內核的HK32MCU

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

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

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

    【GD32 MCU 入門教程】二、GD32 MCU 燒錄說明 (2)SWD/JTAG在線下載

    Cortex-M內核中。調試系統支持串行(SW)調試和跟蹤功能,部分型號也支持JTAG調試。調試和跟蹤功能具體請參考下列文檔:
    的頭像 發表于 08-08 17:34 ?976次閱讀
    【GD32 <b class='flag-5'>MCU</b> 入門教程】二、GD32 <b class='flag-5'>MCU</b> 燒錄說明 (2)SWD/JTAG在線下載

    基于ARM Cortex-M3單片機研發的國產指紋芯片 - P1032BF1

    指紋芯片 - P1032BF1是一款基于ARM Cortex-M3的單片機,專為Wi-Fi /藍牙通信控制而設計;可應用于智能鎖;支持大型程序代碼和擁有大型嵌入式SRAM,也可用于一般的MCU
    的頭像 發表于 07-10 09:22 ?753次閱讀
    基于<b class='flag-5'>ARM</b> <b class='flag-5'>Cortex-M</b>3單片機研發的國產指紋芯片 - P1032BF1

    深度探討:無人機干擾器干擾執行時間的關鍵影響因素

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

    請問stm32cubeIDE仿真怎么看程序執行時間

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

    兆易創新正式推出全新GD32E235系列超值型MCU,擴充Cortex-M23產品陣容

    兆易創新正式推出全新GD32E235系列超值型MCU,進一步擴充Cortex-M23內核產品陣容。首顆同系列產品Arm Cortex-M23內核GD32E230 系列
    的頭像 發表于 03-27 11:15 ?1081次閱讀
    兆易創新正式推出全新GD32E235系列超值型<b class='flag-5'>MCU</b>,擴充<b class='flag-5'>Cortex-M</b>23產品陣容

    Cortex-M0+內核介紹

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

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

    把stack heap全分配到ccmram發現函數執行時間也沒有什么改善,附圖是我的結果 函數執行速度非但沒有改善,反而發現在ccmram執行很不穩定; 測試手段:用定時器3計數來實現該函數
    發表于 03-27 08:23

    兆易創新推出GD32F5系列Cortex-M33內核MCU

    兆易創新GigaDevice宣布,正式推出GD32F5系列高性能微控制器,該系列MCU基于Arm? Cortex?-M33內核,旨在滿足各類高要求應用場景的需求。
    的頭像 發表于 03-16 09:58 ?1444次閱讀
    主站蜘蛛池模板: 第一次处破女18分钟免费 | 九九免费的视频 | 中文字幕午夜福利片 | 色婷婷综合久久久久中文一区二区 | 亚洲专区区免费 | 久久只有这里有精品4 | www.亚洲天堂| 国产免费啪嗒啪嗒视频看看 | 免费可以看污动画软件 | 麻1豆传媒2021精品 | 顶级欧美不卡一区二区三区 | 免费成人高清在线视频 | 琪琪午夜福利免费院 | 动漫美女人物被黄漫在线看 | 国产精品日本无码久久一老A | 亚洲一区在线观看无码欧美 | 欧美xxxx83d | 国产福利高清在线视频 | 精品无码一区二区三区中文字幕 | 免费人成网站在线观看10分钟 | av免费网站不卡观看 | 收集最新中文国产中文字幕 | 精品一成人岛国片在线观看 | 第一次处破女高清电影 | 日本理论片午午伦夜理片2021 | 最好看中文字幕国语 | 精品国产人成亚洲区 | 成人性生交片无码免费看 | 男女边吃奶边做边爱视频 | 亚洲AV无码久久流水呻蜜桃久色 | 青柠在线观看免费完整版 | 久久伊人影视 | 男人的天堂久久精品激情a 男人的天堂黄色片 | 精品国产乱码久久久久久人妻 | 7756短视频| 高清bblxx手机在线观看 | 亚洲精品高清中文字幕完整版 | 青青伊人影院 | 打扑克床上视频不用下载免费观看 | 在线欧美免费人成视频 | 精品无码人妻一区二区免费AV |