1. 概述
STM32 的 Bootloader 可以支持多種協(xié)議的,比如 USART,I2C,DFU 等等,USARTBootloader 是客戶使用 STM32 的時候常常會用到的協(xié)議??蛻粼谑褂?STM32F745 進行產(chǎn)品開發(fā)的時候,出現(xiàn)了使用 STM32CubeProgramer 無法通過 USART1 Bootloader 進行程序升級的問題。為了解決客戶的問題,我在 NUCLEO-F746ZG 開發(fā)板上,復現(xiàn)了同樣的現(xiàn)象,本文針對這個現(xiàn)象,分析了該問題的原因和解決方法,作為一個記錄。
2. 問題分析
STM32F745/6 USART1 Bootloader 使用的 TX 和 RX 分別是 PA9 和 PA10。而NUCLEO-F746ZG 開發(fā)板,默認情況下,板子上的 PA9 和 PA10 被用作 USB Vbus 和USB ID, 需要斷開板子上的 SB127 和 SB125 才能讓 PA9 和 PA10 被 USART1 使用。使用 STM32CubeProgrammer 下載工具,通過 USB-Serial 轉(zhuǎn)接板連上 NUCLEOF746ZG,如圖 1 所示,選擇 USART 協(xié)議,選擇對應的 USART1 端口,其它參數(shù)選用默認配置,然后連接 NUCLEO 開發(fā)板,結(jié)果出現(xiàn)連接失敗。對照著 UM1974,檢查連線沒有問題,確認了 BOOT 腳為高電平,MCU 也進入Bootloader 模式,同時參考 AN2606,確認 STM32F475/6 支持 USART1 Bootloader。測試 USART3 Bootloader,STM32CubeProgrammer 可以正常連接。
參考 AN3155 了解 UART Bootloader 的工作流程如圖 2,果斷使用串口終端,比較USART1 Bootloader 和 USART3 Bootloader 響應上位機的命令有何區(qū)別。
使用串口終端工具,分別連接 USART1,USART3,發(fā)送對應的 UART Bootloader 命令,得到下圖 3 的命令交互。
圖3.USART1 Bootloader Command Interaction
通過圖 3 的命令交互可以看出,當 USART1 Bootloader 收到 7F 命令的時候,返回的值是 FF 79,正常的情況下,應該返回 79。命令 7F 的作用是選擇對應的 USART Bootloader,返回 79 表示 MCU 正確的進入了 USART Bootloader 工作模式,在 USART1 Bootloader 中,STM32CubeProgrammer 發(fā)送 7F 命令收到的返回值是 FF 79,所以STM32CubeProgrammer 認為此時 MCU 沒有正確的進入 USART Bootloader 模式,因此連不上目標板。
顯然,這個多余的 FF 不應該是 Bootloader 發(fā)出來的,通過示波器,觀察 USART1TX 的 PA9 發(fā)現(xiàn),復位芯片之后,PA9 為低電平,而根據(jù)參考手冊,當 USART1 使能之后,此時 USART TX 應該為高電平才正常,所以懷疑這個異?,F(xiàn)象是 USART1 產(chǎn)生了錯誤的數(shù)據(jù)導致的。
針對這種現(xiàn)象,在 PA9 外部上拉,再進行測試,USART1 Bootloader 工作正常。
3. 問題解決
根據(jù)上面的分析,USART1 TX 沒有上拉導致了 USART1 Bootloader 無法正常工作,但通常情況下,我們使用 USART 的時候,TX,RX 是無需外加上拉的,為什么STM32F745/6 的 USART1 需要上拉,而 USART3 無需上拉呢?帶著這個問題,仔細閱讀了相關(guān)文檔,最終再 AN2606 V5.1(之前版本沒有注明)版本中,發(fā)現(xiàn)了這個區(qū)別,正是這個區(qū)別導致了這個問題。
4.總結(jié)
通過分析和解決這個問題,可見及時更新并仔細閱讀相關(guān)文檔是很重要的事情。針對這個問題,如果仔細閱讀了最新的 AN2606,就能很快定位產(chǎn)生問題的原因。當然,通過逐步分析這個問題,也進一步加深了對 Bootloader 的理解。
審核編輯:湯梓紅
-
STM32
+關(guān)注
關(guān)注
2295文章
11032瀏覽量
365237 -
串口
+關(guān)注
關(guān)注
15文章
1588瀏覽量
80001 -
開發(fā)板
+關(guān)注
關(guān)注
25文章
5687瀏覽量
104953 -
bootloader
+關(guān)注
關(guān)注
2文章
239瀏覽量
46722 -
USART1
+關(guān)注
關(guān)注
0文章
10瀏覽量
3914
原文標題:STM32F745 USART1 Bootloader 失敗原因分析與解決
文章出處:【微信號:mcugeek,微信公眾號:MCU開發(fā)加油站】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
STM32的USART1與USART2模塊串行數(shù)據(jù)通訊功能

STM32F051 USART1接收數(shù)據(jù)亂碼的原因?
【分享】stm32 串口中斷總結(jié):USART1
STM32F745通過FMC訪問FPGA順序被優(yōu)化
在stm32f745平臺上搭建ethernet通信程序
STM32F407 USART1控制RGB彩燈
如何通過USART1對STM32F7xx進行編程?
STM32F769BI使用USART1通過引導加載程序?qū)懭雋ex文件總是報錯的原因?
【STM32學習】(6)串口1的使用(USART1)

STM32F105 USART1/USART3 調(diào)試筆記

評論