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

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

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

如何用串口進(jìn)行調(diào)試

CHANBAEK ? 來源:頭條號科G棧 ? 作者:頭條號科G棧 ? 2023-03-23 10:02 ? 次閱讀

串口是MCU最重要的一個通信端口,幾乎所有的嵌入式產(chǎn)品都會用到串口,可能是產(chǎn)品預(yù)研的時候用來調(diào)試,可能是與某一個外設(shè)連接收發(fā)數(shù)據(jù),還可能用來對產(chǎn)品進(jìn)行固件升級。這篇文章主要給大家介紹一下如何用串口進(jìn)行調(diào)試,也就是打印log。

打印log最常用的方法是printf,所以要解決的問題是將printf的輸出重定向到串口,然后通過串口將數(shù)據(jù)發(fā)送出去。

首先要配置串口,串口的配置包括:

1、 開啟串口和GPIO時鐘

2、 GPIO引腳模式配置

3、 串口波特率、數(shù)據(jù)位、停止位、校驗位的配置

4、 使能串口

代碼如下(使用stm32 LL庫):

pYYBAGQbszOACgoaAALZpgKCzk0231.jpg

此時,已經(jīng)可以通過串口來收發(fā)數(shù)據(jù)了,但是只能通過庫函數(shù)一個一個從數(shù)據(jù)寄存器讀寫單個字符,非常的不方便。

下面說一下如何重定向printf。這里我在Ubuntu下用make編譯源碼,所以重定向的方式與用keil有所區(qū)別。

首先要在源碼文件開頭包含頭文件#include ,然后在串口初始化時調(diào)用setvbuf(stdout, NULL, _IONBF, 0),設(shè)置buffer緩存為0,這樣一有數(shù)據(jù)就發(fā)送,不然會等到緩存滿或有回車換行符才發(fā)送。如果沒有這句,你的printf又沒n,log就會打不出來。

poYBAGQbszSALyXTAAAHLlnSrlc452.jpg

接下來是重定向的代碼

poYBAGQbszaABeIiAAEGeLJBQAA936.jpg

這里有兩個地方需要注意,第一,用gcc編譯需要加_write()函數(shù),然后在函數(shù)內(nèi)部調(diào)用__io_putchar()函數(shù)將字符串一個一個發(fā)送出去。第二,使用LL庫發(fā)送數(shù)據(jù),要查看發(fā)送寄存器是否為空或者發(fā)送是否完成標(biāo)志,否則發(fā)的太快會導(dǎo)致前面的數(shù)據(jù)還沒發(fā)完,后邊的數(shù)據(jù)又來了,后邊的覆蓋掉前面的,導(dǎo)致發(fā)送錯誤。

到此,就可以盡情使用printf調(diào)試了。

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

    關(guān)注

    146

    文章

    16667

    瀏覽量

    347764
  • 時鐘
    +關(guān)注

    關(guān)注

    10

    文章

    1673

    瀏覽量

    130955
  • 調(diào)試
    +關(guān)注

    關(guān)注

    7

    文章

    551

    瀏覽量

    33762
  • 串口
    +關(guān)注

    關(guān)注

    14

    文章

    1533

    瀏覽量

    75455
  • GPIO
    +關(guān)注

    關(guān)注

    16

    文章

    1175

    瀏覽量

    51513
收藏 人收藏

    評論

    相關(guān)推薦

    何用ESP32簡單進(jìn)行藍(lán)牙串口調(diào)試!

    串口調(diào)試工具對于廣大電子工程師和電子愛好者來說再熟悉不過了,常見的有USB轉(zhuǎn)TTL串口線,另外還有一些無線串口調(diào)試工具,通過藍(lán)牙、2.4G、
    發(fā)表于 05-01 11:17 ?1.9w次閱讀

    如何對USB轉(zhuǎn)串口模塊進(jìn)行調(diào)試

    目錄2、如何在USB轉(zhuǎn)串口模塊調(diào)試?3、如何用Arduino對JDY-40設(shè)置參數(shù)(其他單片機也可參考,需要自己寫代碼)?4、如何兩個模塊通信(透傳)?5、有沒有什么需要注意的? (請忽略我的靈魂
    發(fā)表于 01-18 08:17

    請問k210如何用串口進(jìn)行調(diào)試?

    k210如何用串口進(jìn)行調(diào)試?
    發(fā)表于 09-15 06:04

    串口調(diào)試軟件下載

    串口調(diào)試軟件下載 ????功能較強的串口調(diào)試軟件。既可可手動發(fā)送數(shù)據(jù),也可自動發(fā)
    發(fā)表于 01-11 20:03 ?10次下載
    <b class='flag-5'>串口</b><b class='flag-5'>調(diào)試</b>軟件下載

    串口調(diào)試助手

    串口調(diào)試助手
    發(fā)表于 03-15 12:15 ?62次下載
    <b class='flag-5'>串口</b><b class='flag-5'>調(diào)試</b>助手

    串口調(diào)試助手_Android版

    常用的串口調(diào)試助手,方便進(jìn)行串口數(shù)據(jù)顯示,
    發(fā)表于 11-19 15:27 ?0次下載

    串口調(diào)試工具

    串口調(diào)試工具 便于單片機下載 串口調(diào)試工具 串口調(diào)試工具
    發(fā)表于 11-20 16:35 ?41次下載

    UartAssist串口調(diào)試助手

    UartAssist串口調(diào)試助手是非常好的調(diào)試軟件
    發(fā)表于 07-14 18:14 ?33次下載

    串口調(diào)試工具

    串口調(diào)試工具
    發(fā)表于 12-28 10:16 ?171次下載

    串口調(diào)試助手怎么用_串口調(diào)試助手使用方法

    串口是嵌入式開發(fā)和單片機開發(fā)中不可缺少的外設(shè)設(shè)備,通用也要運用于整個平臺。所以如何利用串口調(diào)試助手是十分重要的,接下來為大家介紹下如何使用串口調(diào)試
    發(fā)表于 11-28 16:22 ?7.2w次閱讀
    <b class='flag-5'>串口</b><b class='flag-5'>調(diào)試</b>助手怎么用_<b class='flag-5'>串口</b><b class='flag-5'>調(diào)試</b>助手使用方法

    關(guān)于如何用示波器查看串口數(shù)據(jù)資料下載

    關(guān)于如何用示波器查看串口數(shù)據(jù)
    發(fā)表于 04-10 11:16 ?17次下載

    如何進(jìn)行單片機的串口調(diào)試詳細(xì)實例說明

    串口調(diào)試助手 發(fā)送一字節(jié)的數(shù)據(jù),單片機馬上會回發(fā)同樣的數(shù)據(jù)在串口調(diào)試助手上顯示,如果回發(fā)給串口調(diào)試
    發(fā)表于 07-08 17:14 ?1次下載
    如何<b class='flag-5'>進(jìn)行</b>單片機的<b class='flag-5'>串口</b><b class='flag-5'>調(diào)試</b>詳細(xì)實例說明

    串口調(diào)試助手工具

    串口調(diào)試助手非常有用串口調(diào)試工具
    發(fā)表于 08-22 09:34 ?20次下載

    何用串口軟件調(diào)試變頻器?

    每一個做工控的都必須要會利用串口調(diào)試軟件來和我們的外圍設(shè)備來做通訊測試。今天我們就來學(xué)習(xí)怎么用串口調(diào)試軟件控制臺達(dá)的這款變頻器。廢話不多說,直接進(jìn)入正題。
    發(fā)表于 03-16 15:47 ?1830次閱讀

    串口調(diào)試工具

    串口調(diào)試工具
    發(fā)表于 04-28 13:53 ?7次下載