01
引言
STM32CubeIDE是ST官方推出的集成開發(fā)環(huán)境,集成了很多STM32的調(diào)試與開發(fā)工具。本文主要介紹如何使用SWV功能來打印輸出。
02
問題描述
客戶使用STM32CubeIDE開發(fā)環(huán)境,將Printf定位到串口上是正常的,但是在重定位到SWO上卻出現(xiàn)了無法打印的問題??蛻粢矃⒖剂司W(wǎng)上的教程,仍然無法實現(xiàn),不知道是什么原因。
STM32CubeIDE 版本:V1.6.1
硬件環(huán)境:Nucleo-G431RB
03
問題分析與定位
首先,我們需要查找資料,在《UM2609 STM32CubeIDE user guide》的第4章中,對SWV有比較詳細的介紹。此處推薦先查看官網(wǎng)文檔,這個文檔本身是非常權(quán)威的??赡苣阍诰W(wǎng)上也會找到關(guān)于SWV功能的介紹,但是這個文檔還是必須要看的,因為這個是源頭。
通過查看這個文檔,知道了實現(xiàn)SWV的簡單步驟如下:
第一步:在Pinout & Configuration選項中打開SWO的功能,此步驟是必須的。
第二步:重定位printf的接口函數(shù)。
這里有個簡單的方法,直接在syscalls.c文件中,改寫_write()函數(shù)的內(nèi)容,代碼如下所示。再在此文件中包含ITM_SendChar 實現(xiàn)的頭文件core_cmX.h,此文件一般都是已經(jīng)被包含在你所選擇的器件型號的頭文件中。
此處我們選擇的是stm32g431xx.h,直接放在此文件的開始處即可。
第三步:在main.c文件中包含stdio.h這個頭文件,并嘗試打印printf,此處注意,打印不能很頻繁,所以需要增加延時。
全局編譯一下,查看是否有錯誤,如果有錯誤,請對應(yīng)提示信息修改。編譯沒有錯誤之后,我們就可以進行下一步了。
編譯成功正確界面
第四步:配置仿真調(diào)試參數(shù)。打開SWV的調(diào)試功能。此處注意:Core Clock必須與你配置的時鐘是一致的。此處我配置是170MHz,與我的系統(tǒng)時鐘一致。
仿真調(diào)試配置界面
第五步:開始進入調(diào)試界面,并在調(diào)試界面中打開Windows--》Show;View--》SWV的ITM data Console窗口。注意,整個SWV其實是共用一個配置文件的,所以,當(dāng)你打開SWV內(nèi)的任意一個窗口都可以進行SWV 的配置。在這里我們只是為了查看Printf的內(nèi)容,所以就選擇了SWV ITM Data Console窗口。關(guān)于這里邊其他幾個部分的詳細說明參考UM2609的4.3章節(jié)的內(nèi)容。
此窗口打開后,需要新增一個Port端口。默認TIM中使用的就是0端口,所以我們直接選0即可。
選擇點擊配置按鈕對參數(shù)進行配置。配置情況如下:
SWV窗口配置界面
推薦先復(fù)位一下工程(可選項),然后“啟動跟蹤/start trace”。注意:此處是先啟動跟蹤,之后再讓程序運行起來,不能反序。
啟動跟蹤和開始運行
此時即可看到打印出來的內(nèi)容了。
最后打印輸出的狀態(tài)
04
小結(jié)
其實很多的內(nèi)容都已經(jīng)在手冊中有詳細的描述,但是因為英文或者是時間的問題,我們大部分人沒有時間和精力閱讀完所有的文檔的。所以在遇到問題時候,會阻塞你比較長時間。希望本文在你遇到困難的時候能夠給你一點啟示,幫你快速解決手中的問題。
編輯:jq
-
接口函數(shù)
+關(guān)注
關(guān)注
0文章
11瀏覽量
8291 -
Printf
+關(guān)注
關(guān)注
0文章
84瀏覽量
14147
原文標(biāo)題:工程師筆記 | STM32CubeIDE SWV功能簡介
文章出處:【微信號:STM32_STM8_MCU,微信公眾號:STM32單片機】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
評論