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

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

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

Event Recorder的使用

汽車電子技術(shù) ? 來源:嵌入式之入坑筆記 ? 作者: 嵌入式之入坑筆記 ? 2023-02-10 14:09 ? 次閱讀

單片機(jī)的軟件開發(fā)中,經(jīng)常會(huì)遇到各種各樣的問題,很多時(shí)候?yàn)榱硕ㄎ坏匠霈F(xiàn)bug的地方,我們可能會(huì)借助很多的手段或者工具。比如串口打印、MDK在線仿真上位機(jī)調(diào)試工具等等的。但是,有時(shí)候想要用串口打印輸出某些結(jié)果,而硬件設(shè)計(jì)又沒有預(yù)留串口,這種時(shí)候就感覺很不方便。我個(gè)人使用串口調(diào)試的頻率還是蠻多的,主要是簡(jiǎn)單易操作,可以在想要觀察運(yùn)行結(jié)果的代碼位置隨便加調(diào)試輸出,很方便定位問題。在硬件上沒有多余的串口預(yù)留的話,如果有外接仿真引腳出來的話,在MDK環(huán)境下就可以使用ST-LINK、J-LINK等的各種LINK進(jìn)行調(diào)試,實(shí)現(xiàn)printf輸出的功能,簡(jiǎn)直是不要太棒了!在MDK的開發(fā)IDE環(huán)境下,支持仿真調(diào)試的組件有好幾個(gè),我這里使用的是Event Recorder。這個(gè)組件功能是在MDK5.22的版本是哪個(gè)開始增加的,所以想要使用這個(gè)組件功能,需要將自己的MDK開發(fā)工具升級(jí)到5.22以上,建議是當(dāng)前最新的版本!

1、添加 Event Recorder 組件

1)打開你需要添加調(diào)試組件的項(xiàng)目工程,點(diǎn)擊如下圖所示的圖標(biāo):

pYYBAGPl3oOAdGhCAABKe-ugfoU937.png

2)選擇 “Compiler”,并按照如下勾選,勾選之后點(diǎn)擊“ok”即可。如下圖:

pYYBAGPl3pCAe2rzAACStiKdwfI693.png

勾選之后可以看到工程目錄上出現(xiàn)一個(gè)“Compiler”的選項(xiàng),說明組件添加成功了,如下圖:

pYYBAGPl3ueAXCjkAAB1gI1u5LI697.png

3)檢查組件的工程配置,如下:

pYYBAGPl3vKAW0OSAAFPC0GOVD4584.png

說明如下:

Number of Records:表示 Event Recorder 緩沖可以記錄的消息條數(shù)。Time Stamp Source:表示時(shí)間戳的來源其中,Time Stamp Source 有如下四種可以選擇,一般使用 DWT 時(shí)鐘周期計(jì)數(shù)器。如下圖:

poYBAGPl3v2AGp3GAAAS3zyYi8I176.png

至此,Event Record組件就已經(jīng)添加完成了。

2、printf 重定向

在Event Recorder 實(shí)現(xiàn)printf輸出需要使用MDK的 Debug 功能,輸出的效果就跟串口調(diào)試工具上的顯示效果是一樣的。Event Recorder 中的重定向代碼如下:

int fputc (int c, FILE * stream) {
#if (!defined(RTE_Compiler_IO_STDOUT) && !defined(RTE_Compiler_IO_STDERR))
  (void)c;
  (void)stream;
#endif
 
#ifdef RTE_Compiler_IO_STDOUT
  if (stream == &__stdout) {
#if (STDOUT_CR_LF != 0)
    if (c == 'n') stdout_putchar('r');
#endif
    return (stdout_putchar(c));
  }
#endif
 
#ifdef RTE_Compiler_IO_STDERR
  if (stream == &__stderr) {
#if (STDERR_CR_LF != 0)
    if (c == 'n') stderr_putchar('r');
#endif
    return (stderr_putchar(c));
  }
#endif
 
  return (-1);
}

注意:使用 Event Recorder 實(shí)現(xiàn)printf重定向時(shí),一定要取消掉自己的項(xiàng)目中原本的重定向!

1)進(jìn)入仿真調(diào)試模式,如下:

pYYBAGPl3wuALctGAAAxhoV4-D0964.png

2)選中 Debug(printf)Viewer 調(diào)試組件,如下圖:

poYBAGPl3xeAa7f9AAMXkalcjzg602.png

3)選擇仿真時(shí)周期更新,如下圖:

pYYBAGPl3ySAKl9XAAMsqzVAvhA382.png

4)添加初始化代碼,如下:

/* 初始化 EventRecorder 并開啟 */
   EventRecorderInitialize(EventRecordAll, 1U);
    EventRecorderStart();

5)全速運(yùn)行即可以看到結(jié)果。

poYBAGPl3zCAcgiIAABoQ7jU4M0498.png

示例:

測(cè)試代碼如下:

poYBAGPl3zqAQ9sXAAE-ZmJKzRU919.png

仿真結(jié)果如下:

poYBAGPl30aAKOp7AADfB0rjQW4368.png

鼠標(biāo)右鍵還可以對(duì) Debug(printf)Viewer 進(jìn)行設(shè)置,如下圖:

pYYBAGPl31SAbpRNAAFpwzo6K-U868.png

3、簡(jiǎn)單方便的時(shí)間測(cè)量功能

Event Recorder 也可以測(cè)量代碼運(yùn)行的時(shí)間,時(shí)間測(cè)量功能簡(jiǎn)單易用,僅需一個(gè)起始函數(shù),一個(gè)停止函數(shù)即可。

3.1、時(shí)間測(cè)量起始函數(shù)

EventStartG (slot)
或者
EventStopGv (slot, val1, val2)

函數(shù)說明:

1)函數(shù)中的字母 G 是表示分組 A,B,C,D,即實(shí)際調(diào)用函數(shù)為 EventStartA,EventStartB,EventStartC 和 EventStartD。2)函數(shù)的第一個(gè)形參 slot 的范圍是 0-15,也就是最大可以測(cè)量 16 路。3)函數(shù)后面的兩個(gè)形象 val1 和 val2 是 32 Bit變量,用戶可以用這兩個(gè)形參來傳遞變量數(shù)值給 Event Statistics 調(diào)試組件里面,用于圖形化展示。

3.2、時(shí)間測(cè)量結(jié)束函數(shù)

EventStopG (slot)
或者
EventStopGv (slot, val1, val2)

函數(shù)說明:

1)函數(shù)中的字母G是表示分組A,B,C,D,即實(shí)際調(diào)用函數(shù)為EventStopA,EventStopB,EventStopC 和 EventStopD。2)函數(shù)的第一個(gè)形參 slot 的范圍是 0-15,也就是最大可以測(cè)量 16 路。3)函數(shù)后面的兩個(gè)形象 val1 和 val2 是 32 位變量,用戶可以用這兩個(gè)形參來傳遞變量數(shù)值給 Event Statistics 調(diào)試組件里面,用于圖形化展示。

3.3、使用示例

1)添加初始化代碼

/* 初始化 EventRecorder 并開啟 */
EventRecorderInitialize(EventRecordAll, 1U);
EventRecorderStart();

2)在代碼前后加上起始和結(jié)束時(shí)間的測(cè)量API函數(shù),如下所示:

poYBAGPl32WAU9bLAAFVbwk3L8g506.png

3)選擇 Event Statistics 調(diào)試組件,如下:

pYYBAGPl33OAUz0FAAYRAqFym9E226.png

4)全速運(yùn)行,查看結(jié)果,如下:

pYYBAGPl33-AJECJAAFhG1Z328I392.png

從圖中可以看出,開始測(cè)量的位置是在 149 行處,結(jié)束測(cè)量的位置是在152 行處,下方的紅色方框處標(biāo)出了測(cè)量的最大時(shí)間和最小時(shí)間。

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

    關(guān)注

    6037

    文章

    44558

    瀏覽量

    635301
  • 軟件開發(fā)
    +關(guān)注

    關(guān)注

    0

    文章

    614

    瀏覽量

    27360
  • 上位機(jī)
    +關(guān)注

    關(guān)注

    27

    文章

    942

    瀏覽量

    54814
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    【原創(chuàng)專題教程第7期】終極調(diào)試組件Event Recorder,各種Link通吃,支持時(shí)間和功耗測(cè)量,printf打印,RTX5及中間件調(diào)試

    Recorder實(shí)現(xiàn)的串口打印,無(wú)需占用系統(tǒng)額外的硬件資源,而且速度超快,是替代串口調(diào)試的絕佳方式。5、Event Recorder的API可以在中斷和多任務(wù)環(huán)境中正常調(diào)用。最重要的是速度快。6、對(duì)于
    發(fā)表于 06-19 18:54

    靈動(dòng)微課堂 (第164講) | MM32F013x——Event Recorder使用方法

    Recorder則沒有以上的限制,Event Recorder是MDK在5.22版本加入的新功能,使用標(biāo)準(zhǔn)SWD的下載接口,基本上適用于各種Link,只要MDK v5.22以上的版本即可,支持時(shí)間測(cè)量、功耗測(cè)量
    發(fā)表于 04-23 11:21

    STM32F407的終極調(diào)試組件Event Recorder

    第8章 STM32F407的終極調(diào)試組件Event Recorder本章節(jié)為大家介紹終極調(diào)試方案Event Recoder,之所以叫終極解決方案,是因?yàn)樗蠰ink通吃,支持時(shí)間測(cè)量,功耗測(cè)量
    發(fā)表于 08-03 08:22

    移植Event Recorder調(diào)試工具

    、Output3.3、C/C++(AC6)3.4、Debug3.5、模板代碼(main.c)3.6、開始移植RTX53.6、隔離Device上的文件四、代碼4.1、main.h4.2、main.c五、DEBUG5.1、RTX RTOS六、細(xì)節(jié)補(bǔ)充6.1、移植Event Recor
    發(fā)表于 08-24 06:07

    Event Recorder是什么?Event Recorder的特色有哪些

    Event Recorder是什么?Event Recorder的特色有哪些?JTAG接口和SWD接口區(qū)別在哪?
    發(fā)表于 10-09 06:01

    請(qǐng)問一下Event Recorder的特色是什么?

    JTAG接口和SWD接口區(qū)別是什么? Event Recorder的特色是什么?
    發(fā)表于 10-11 07:00

    STM32H7的終極調(diào)試組件Event Recorder是什么

    STM32H7的終極調(diào)試組件Event Recorder是什么
    發(fā)表于 10-13 07:32

    怎樣使用keil的Event Recorder中間件進(jìn)行打印呢

    怎樣使用keil的Event Recorder中間件進(jìn)行打印呢?有何缺點(diǎn)?怎樣使用jlink-RTT Viewer組件進(jìn)行打?。坑泻稳秉c(diǎn)?
    發(fā)表于 01-19 06:44

    Event Recorder的特色主要有幾點(diǎn)

    1、最好使用比較新的cmsis庫(kù),否則添加event recorder將無(wú)法編譯通過2、rte設(shè)置如下:3、sct文件開辟一個(gè)NOINIT的sram區(qū)域,不開辟好像也可以,官網(wǎng)教程是開辟的。4
    發(fā)表于 01-19 06:27

    淺析基于GD32F427適配RTX4+調(diào)試組件Event Recorder

    :使用板載的GD_Link就能方便調(diào)試而不需要串口1.打開Manage Run_Time Enviornment -> Compiler 選項(xiàng)中Event Recorder
    發(fā)表于 12-21 09:39

    【STM32F429開發(fā)板用戶手冊(cè)】第8章 STM32F429的終極調(diào)試組件Event Recorder

    【STM32F429開發(fā)板用戶手冊(cè)】第8章 STM32F429的終極調(diào)試組件Event Recorder
    發(fā)表于 12-04 14:06 ?17次下載
    【STM32F429開發(fā)板用戶手冊(cè)】第8章 STM32F429的終極調(diào)試組件<b class='flag-5'>Event</b> <b class='flag-5'>Recorder</b>

    【STM32F407開發(fā)板用戶手冊(cè)】第8章 STM32F407的終極調(diào)試組件Event Recorder

    【STM32F407開發(fā)板用戶手冊(cè)】第8章 STM32F407的終極調(diào)試組件Event Recorder
    發(fā)表于 12-04 14:21 ?19次下載
    【STM32F407開發(fā)板用戶手冊(cè)】第8章 STM32F407的終極調(diào)試組件<b class='flag-5'>Event</b> <b class='flag-5'>Recorder</b>

    【STM32H7教程】第8章 STM32H7的終極調(diào)試組件Event Recorder

    【STM32H7教程】第8章 STM32H7的終極調(diào)試組件Event Recorder
    發(fā)表于 12-05 20:06 ?7次下載
    【STM32H7教程】第8章 STM32H7的終極調(diào)試組件<b class='flag-5'>Event</b> <b class='flag-5'>Recorder</b>

    MM32F013x——Event Recorder使用方法

    在前面幾個(gè)專題中介紹了Ozone、RTT-Viewer、J-Scope在MM32F013x上的使用方法,雖然以上的幾種方式簡(jiǎn)單方便,但是也僅僅局限于J-Link工具...
    發(fā)表于 01-25 18:22 ?2次下載
    MM32F013x——<b class='flag-5'>Event</b> <b class='flag-5'>Recorder</b>使用方法

    MM32F013x——Event Recorder使用方法

    在前面幾個(gè)專題中介紹了Ozone、RTT-Viewer、J-Scope在MM32F013x上的使用方法,雖然以上的幾種方式簡(jiǎn)單方便,但是也僅僅局限于J-Link工具。
    發(fā)表于 02-08 16:19 ?1次下載
    MM32F013x——<b class='flag-5'>Event</b> <b class='flag-5'>Recorder</b>使用方法