国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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
    +關注

    關注

    147

    文章

    18924

    瀏覽量

    397997
  • ARM
    ARM
    +關注

    關注

    135

    文章

    9552

    瀏覽量

    391825
  • 代碼
    +關注

    關注

    30

    文章

    4967

    瀏覽量

    73954

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

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    最小化ARM Cortex-M CPU功耗的方法與技巧分享

    ,并且為原始性能和整體代碼大小提供了靈活的解決方案。在Cortex-M內核上一個典型的Thumb-2應用程序與完全采用ARM指令完成的相同功能應用程序相比,代碼大小減小到25%之內,而
    發表于 01-21 06:19

    Cortex-M0 處理器介紹

    Cortex-M0 處理器簡介ARM公司的Cortex-M0應用于各種微控制器(MCU)中,并可讓研發工程師以8位的價位創造32位的的效能,并將傳統的8位和16位的處理器升級到更高效、
    發表于 01-16 08:04

    探索MCXA345/346:混合信號Arm Cortex - M33 MCU的卓越性能與應用潛力

    探索MCXA345/346:混合信號Arm Cortex - M33 MCU的卓越性能與應用潛力 在當今電子科技飛速發展的時代,微控制器(MCU
    的頭像 發表于 12-24 11:00 ?544次閱讀

    探秘MCXE315/316/317/31B:5V強勁Arm Cortex M7 MCU的卓越性能

    探秘MCXE315/316/317/31B:5V強勁Arm Cortex M7 MCU的卓越性能 在電子工程師的世界里,不斷尋求高性能、高可靠性的微控制器(
    的頭像 發表于 12-24 10:20 ?533次閱讀

    Cortex-M產品的特色

    與外部設備進行通信。 指令集:Cortex-M系列處理器支持ARM Thumb指令集,包括16位和32位的Thumb-2指令集,以及可選的DSP指令和浮點單元,提供了高性能的信號處理能力
    發表于 11-26 07:22

    Cortex-M內核中的精確延時的方法

    使用 CYCCNT寄存器來測量執行某個任務所花的周期數,這也可以用作時間基準相關的目的(操作系統中統計 CPU使用率可以用到它)。” Cortex-M中的DWT它有一個32位的寄存器叫
    發表于 11-21 07:51

    Cortex-M級別的轉換

    一、 簡述 Cortex-M 里面有特權級別的概念,不同級別可以設定不同的權限,如何轉換特權級別基本是本章的內容。 二、操作模式 ARM M 核操作模式有兩個: 線程(Thread)模式:在復位時或
    發表于 11-19 07:32

    STM32C031x4/x6:面向主流應用的Arm? Cortex?-M0+ 微控制器

    STMicroelectronics的STM32C0x Arm^? ^Cortex ^?^ -M0+ 32位MCU安裝了高性能Arm
    的頭像 發表于 10-27 15:05 ?829次閱讀
    STM32C031x4/x6:面向主流應用的<b class='flag-5'>Arm</b>? <b class='flag-5'>Cortex</b>?-<b class='flag-5'>M</b>0+ 微控制器

    MSPM0G1507 80MHz Arm? Cortex-M0?+ MCU技術手冊

    MSPM0G150x 微控制器 (MCU) 是 MSP 高度集成、超低功耗 32 位 MCU 系列的一部分,基于增強型 Arm Cortex-M0+ 32 位核心平臺,工作頻率高達 8
    的頭像 發表于 09-30 09:08 ?878次閱讀
    MSPM0G1507 80MHz <b class='flag-5'>Arm</b>? <b class='flag-5'>Cortex-M</b>0?+ <b class='flag-5'>MCU</b>技術手冊

    【RA-Eco-RA6M4開發板評測】使用ULINK2開發瑞薩MCU

    · 支持 ARM7、ARM9、Cortex-M、8051 和 C166 設備 · JTAG 速度高達 10MHz · 針對基于 ARM Corte
    發表于 09-25 23:08

    Analog Devices Inc. MAX32675C超低功耗Arm? Cortex?-M4F MCU數據手冊

    MCU基于帶浮點單元(FPU)的超低功耗Arm Cortex- M4,包括384KB(376KB用戶)閃存和160KB SRAM。在整個閃存、SRAM和緩存上實現糾錯編碼(ECC),能
    的頭像 發表于 06-03 10:04 ?974次閱讀
    Analog Devices Inc. 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>數據手冊

    tc397如何高精度(微秒級別)測量代碼執行時間

    tc397如何高精度(微秒級別)測量代碼執行時間
    發表于 04-21 07:31

    MSPM0G1505 80MHz Arm? Cortex-M0?+ MCU數據手冊

    MSPM0G150x 微控制器 (MCU) 是 MSP 高度集成、超低功耗 32 位 MCU 系列的一部分,該系列基于增強型 Arm Cortex-M0+ 32 位內核平臺,運行頻率高
    的頭像 發表于 04-15 14:08 ?1177次閱讀
    MSPM0G1505 80MHz <b class='flag-5'>Arm</b>? <b class='flag-5'>Cortex-M</b>0?+ <b class='flag-5'>MCU</b>數據手冊

    MSPM0G3106 80MHz Arm? Cortex-M0?+ MCU數據手冊

    MSPM0G310x 微控制器 (MCU) 是 MSP 高度集成、超低功耗 32 位 MCU 系列的一部分,基于增強型 Arm Cortex-M0+ 32 位內核平臺,運行頻率高達 8
    的頭像 發表于 04-15 11:44 ?1183次閱讀
    MSPM0G3106 80MHz <b class='flag-5'>Arm</b>? <b class='flag-5'>Cortex-M</b>0?+ <b class='flag-5'>MCU</b>數據手冊

    MSPM0C1103 24MHz Arm? Cortex-M0?+ MCU數據手冊

    MSPM0C110x 微控制器 (MCU) 是 MSP 高度集成的超低功耗 32 位 MCU 系列的一部分,基于增強型 Arm Cortex-M0+ 內核平臺,運行頻率高達 24MHz
    的頭像 發表于 04-15 09:39 ?1439次閱讀
    MSPM0C1103 24MHz <b class='flag-5'>Arm</b>? <b class='flag-5'>Cortex-M</b>0?+ <b class='flag-5'>MCU</b>數據手冊