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

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

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

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

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

奈因PCB電路板設(shè)計(jì) ? 來(lái)源:麥克泰技術(shù) ? 作者:麥克泰 ? 2021-08-26 09:20 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

使用μC/Probe顯示測(cè)量值

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

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

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

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

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

總結(jié)

作為嵌入式開(kāi)發(fā)人員,我們有許多工具可以用來(lái)測(cè)試和驗(yàn)證我們的設(shè)計(jì)。μC/Probe提供了許多功能,允許用戶使用gauge、meter、numeric indictor、Excel或graph/plots來(lái)監(jiān)控應(yīng)用程序中的變量?;贑ortex-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)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • mcu
    mcu
    +關(guān)注

    關(guān)注

    147

    文章

    18925

    瀏覽量

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

    關(guān)注

    135

    文章

    9553

    瀏覽量

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

    關(guān)注

    30

    文章

    4968

    瀏覽量

    73979

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

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

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

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

    Cortex-M0 處理器介紹

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

    探索MCXA345/346:混合信號(hào)Arm Cortex - M33 MCU的卓越性能與應(yīng)用潛力

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

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

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

    Cortex-M產(chǎn)品的特色

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

    Cortex-M內(nèi)核中的精確延時(shí)的方法

    使用 CYCCNT寄存器來(lái)測(cè)量執(zhí)行某個(gè)任務(wù)所花的周期數(shù),這也可以用作時(shí)間基準(zhǔn)相關(guān)的目的(操作系統(tǒng)中統(tǒng)計(jì) CPU使用率可以用到它)?!?Cortex-M中的DWT它有一個(gè)32位的寄存器叫
    發(fā)表于 11-21 07:51

    Cortex-M級(jí)別的轉(zhuǎn)換

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

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

    STMicroelectronics的STM32C0x Arm^? ^Cortex ^?^ -M0+ 32位MCU安裝了高性能Arm
    的頭像 發(fā)表于 10-27 15:05 ?838次閱讀
    STM32C031x4/x6:面向主流應(yīng)用的<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技術(shù)手冊(cè)

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

    【RA-Eco-RA6M4開(kāi)發(fā)板評(píng)測(cè)】使用ULINK2開(kāi)發(fā)瑞薩MCU

    · 支持 ARM7、ARM9、Cortex-M、8051 和 C166 設(shè)備 · JTAG 速度高達(dá) 10MHz · 針對(duì)基于 ARM Corte
    發(fā)表于 09-25 23:08

    Analog Devices Inc. MAX32675C超低功耗Arm? Cortex?-M4F MCU數(shù)據(jù)手冊(cè)

    MCU基于帶浮點(diǎn)單元(FPU)的超低功耗Arm Cortex- M4,包括384KB(376KB用戶)閃存和160KB SRAM。在整個(gè)閃存、SRAM和緩存上實(shí)現(xiàn)糾錯(cuò)編碼(ECC),能
    的頭像 發(fā)表于 06-03 10:04 ?982次閱讀
    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>數(shù)據(jù)手冊(cè)

    tc397如何高精度(微秒級(jí)別)測(cè)量代碼執(zhí)行時(shí)間

    tc397如何高精度(微秒級(jí)別)測(cè)量代碼執(zhí)行時(shí)間
    發(fā)表于 04-21 07:31

    MSPM0G1505 80MHz Arm? Cortex-M0?+ MCU數(shù)據(jù)手冊(cè)

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

    MSPM0G3106 80MHz Arm? Cortex-M0?+ MCU數(shù)據(jù)手冊(cè)

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

    MSPM0C1103 24MHz Arm? Cortex-M0?+ MCU數(shù)據(jù)手冊(cè)

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