在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

單片機(jī)調(diào)試過程中的調(diào)試組件導(dǎo)致的問題

茶話MCU ? 來源:工程師曾玲 ? 2018-12-30 17:12 ? 次閱讀

?在我們的單片機(jī)調(diào)試過程中,經(jīng)常會遇到類似如下因第3只眼而導(dǎo)致的問題。何謂第3只眼呢?不妨先看看幾個實例就知道了。

第一個案例,與ADC轉(zhuǎn)換標(biāo)志位有關(guān)的問題。遇到該問題是一種較為頻繁的情形。

經(jīng)常有人在做STM32 ADC應(yīng)用,進(jìn)行代碼單步調(diào)試時發(fā)現(xiàn),明明啟動了ADC轉(zhuǎn)換就是等不到轉(zhuǎn)換結(jié)束的那一刻,即總是檢測不到EOC等于1的時候。有時讓人直急得冒汗!比方類似下面的情形,開啟了ADC轉(zhuǎn)換指令,然后等待ADC轉(zhuǎn)換結(jié)束。

在那藍(lán)色圓圈的代碼處,查詢等待EOC等于1,可就是等不到它為1的時候。是怎么回事呢?

原來,STM32芯片ADC的轉(zhuǎn)換結(jié)束標(biāo)志EOC位,具有讀清零的特性。當(dāng)你調(diào)試時打開外設(shè)寄存器顯示欄時,那調(diào)試組件在不停的讀取它。當(dāng)你單步操作去讀取該標(biāo)志位時往往先被調(diào)試組件讀過了。即使它之前被置位過,但因調(diào)試組件的讀取后又被清零。當(dāng)你單步慢悠悠去讀它時,結(jié)果讀到的往往是0,你就查不到為1的那一刻,此時我們可能會傻傻的等和著急。

?當(dāng)然,如果你將右邊ADC外設(shè)寄存器顯示欄關(guān)閉就不會出現(xiàn)上述問題了。

第二個案例??,與UART狀態(tài)寄存器標(biāo)志位有關(guān)的問題。遇到該問題也是較為頻繁的情形。

某STM32用戶使用STM32F2系列芯片的UART外設(shè)及相關(guān)功能。他發(fā)現(xiàn)明明接收完畢,發(fā)送標(biāo)志TC位也置位了,可就是不進(jìn)IDLE空閑中斷。當(dāng)然,相關(guān)中斷使能都已正常使能無誤。實際情形是這樣的:

STM32F205的UART5發(fā)送指令(循環(huán)發(fā)送一個字節(jié)一個字節(jié)地發(fā))給wifi芯片,WiFi芯片會返回相應(yīng)數(shù)據(jù)過來,所以,正常來講uart5會收到一幀數(shù)據(jù)之后應(yīng)該進(jìn)入串口接收IDLE中斷.這是客戶所期望的。

他將斷點(diǎn)打在UART中斷服務(wù)程序的檢查到IDLE中斷請求位等于1后的入口處。就像下面截圖的樣子。他甚至在右邊的UART寄存器顯示欄都看到IDLE被置位過的痕跡了,可就是進(jìn)不到相關(guān)代碼里去,怎么回事呢?

?因為他開啟了UART寄存器顯示窗口,意味著調(diào)試組件在不停幫他讀了UART相關(guān)寄存器,其中包括DR和SR寄存器。當(dāng)他在中斷代碼里再去讀SR寄存器里的IDLE標(biāo)志位時,讀回來的結(jié)果總是0,所以中斷程序沒法進(jìn)一步走下去。對于他這里,嚴(yán)格地說是響應(yīng)了中斷,只是沒法進(jìn)一步進(jìn)入相關(guān)中斷服務(wù)代碼區(qū)。

其實,對于stm32f2芯片UART的IDLE中斷請求標(biāo)志位的清零會遵循一個訪問序列,即讀DR寄存器,然后讀SR寄存器就可將IDLE位清零。

o4YBAFwkl_WAf9s4AABN-9NNghQ511.png

當(dāng)然,解決上面問題的辦法也很簡單,調(diào)試跟蹤時,將右邊UART的外設(shè)寄存器顯示欄關(guān)閉就好。

第三個案例,與讀取RTC日歷有關(guān)的問題。一個較為隱蔽而容易誤導(dǎo)人的問題。

曾有人反饋說STM32F4和STM32L4的RTC脫機(jī)運(yùn)行跑不起來,不運(yùn)行。具體表現(xiàn)就是日歷時間不動、不更新。奇怪的是,調(diào)試時候不論單步還是全速運(yùn)行,查看日歷寄存器都顯示正常運(yùn)行,數(shù)據(jù)也正確。

可當(dāng)燒錄代碼到芯片后,通過調(diào)試助手查看日歷的數(shù)據(jù)則原地不動了,感覺RTC沒有運(yùn)行??蛻粲肧TM32F4和STM32L4的板都測試過,出現(xiàn)同樣問題。懷疑STM32F4和L4芯片的RTC是否有BUG【反正找不到原因了就想芯片bug?】。

查看其測試代碼,就是讀RTC的日歷,很簡單。如下?:

while(1){

HAL_RTC_GetTime(&hrtc,&rtcTime,RTC_FORMAT_BIN);?printf( ...... );HAL_Delay(1000);}

?從上面代碼不難看出就是不停地去讀當(dāng)前的時、分、秒時間。STM32參考手冊在關(guān)于RTC日歷讀取操作部分有相關(guān)描述。為了讀取時間的一致性,讀取日歷操作要求先讀時分秒然后還得讀日期,這樣做為一個完整的操作。所以在讀取TIME【時分秒】后,硬件會將當(dāng)前日歷值鎖住,直到讀取了日期寄存器。否則當(dāng)你讀了TIME而不讀DATE的話,再去讀TIME時還是原來的值維持不變。顯然,客戶這里的代碼只有讀取TIME時間的語句,沒有讀取DATE日期的代碼。這是問題?根本原因之所在。

但是,為什么同樣代碼在調(diào)試情況下又能正常運(yùn)行呢??那是因為他在調(diào)試時打開著RTC寄存器外設(shè)顯示窗口,雖然用戶代碼沒去讀DATE,但調(diào)試組件幫忙讀了DATE寄存器,所以感覺上一切風(fēng)調(diào)雨順,也就沒能及時發(fā)現(xiàn)問題,一直到程序燒進(jìn)芯片后才發(fā)現(xiàn)異常癥狀。

到此,結(jié)合上述3個案例的分享介紹,我們應(yīng)該明白了那個第3只眼了,即調(diào)試組件。個別寄存器或寄存器位具有“讀則變”或“讀有效”的特性。我們在調(diào)試時候要注意類似細(xì)節(jié),調(diào)試時也不必時刻將那個外設(shè)寄存器顯示欄開啟掛在那里。其實,除了這個寄存器顯示欄外,我們還可以利用其它輸出,比方示波器、printf,或者WATCH窗口等來輔助觀察運(yùn)行狀態(tài)或結(jié)果。

既然這里把調(diào)試組件稱之為第3只眼,那另外兩只眼呢?這個不難想到CPUDMA

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

    關(guān)注

    6058

    文章

    44821

    瀏覽量

    644620
  • adc
    adc
    +關(guān)注

    關(guān)注

    99

    文章

    6611

    瀏覽量

    547723

原文標(biāo)題:單片機(jī)調(diào)試過程中的第3只眼

文章出處:【微信號:stmcu832,微信公眾號:茶話MCU】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    單片機(jī)串口模塊調(diào)試方法

    筆者在調(diào)試某Cortex-M3內(nèi)核單片機(jī)時遇到一個問題,此單片機(jī)不具備在線仿真功能,因此調(diào)試代碼時只能使用UART輸出Log的方式調(diào)試
    發(fā)表于 07-28 15:48 ?1783次閱讀
    <b class='flag-5'>單片機(jī)</b>串口模塊<b class='flag-5'>調(diào)試</b>方法

    USMART調(diào)試過程是怎樣的

    什么是USMART?USMART是正點(diǎn)原子團(tuán)隊為其STM32開發(fā)平臺開發(fā)的一種類似linux的shell的調(diào)試工具。具體工作過程是通過串口發(fā)送命令給單片機(jī),然后單片機(jī)收到命令之后調(diào)用
    發(fā)表于 01-13 06:41

    5G14433和MCS-51單片機(jī)接口電路的調(diào)試過程

    通過5G14433芯片與MCS一51單片機(jī)接rm電路的實例,說明了硬件電路的調(diào)試過程
    發(fā)表于 11-12 14:36 ?23次下載

    電源設(shè)計調(diào)試過程中的異常現(xiàn)象分析

    調(diào)試過程中所看到的一些異?,F(xiàn)象,以及后來的解決辦法。其實很多工程師認(rèn)為設(shè)計電源是非常重經(jīng)驗的一門技術(shù),要見多識廣。這種經(jīng)
    發(fā)表于 10-09 10:49 ?1757次閱讀

    單片機(jī)開發(fā)過程中硬件調(diào)試技巧

    本文結(jié)合作者在單片機(jī)開發(fā)過程中體會,討論硬件調(diào)試的技巧。當(dāng)硬件設(shè)計從布線到焊接安裝完成之后,就開始進(jìn)入硬件調(diào)試階段
    發(fā)表于 06-01 16:09 ?1.4w次閱讀

    單片機(jī)驅(qū)動DM9000網(wǎng)卡芯片詳細(xì)調(diào)試過程

    單片機(jī)驅(qū)動DM9000網(wǎng)卡芯片詳細(xì)調(diào)試過程
    發(fā)表于 11-02 11:03 ?0次下載

    淺析STM32調(diào)試過程中的幾個相關(guān)問題

    總的來講,單片機(jī)調(diào)試單片機(jī)開發(fā)工作必不可少的環(huán)節(jié)。不管你愿不愿意,調(diào)試過程中總會有各種不期而遇的問題出現(xiàn)在我們面前來磨礪我們。這里分享幾點(diǎn)STM32
    的頭像 發(fā)表于 01-21 13:50 ?5613次閱讀

    使用單片機(jī)驅(qū)動DM9000網(wǎng)卡芯片的詳細(xì)調(diào)試過程資料免費(fèi)下載

    本文主要介紹單片機(jī)驅(qū)動DM9000E網(wǎng)卡芯片的詳細(xì)過程。從網(wǎng)卡電路的連接,到網(wǎng)卡初始化相關(guān)程序調(diào)試,再到ARP協(xié)議的實現(xiàn),一步一步詳細(xì)介紹調(diào)試過程。如果有時間也會把UDP和TCP通訊實
    發(fā)表于 08-27 17:30 ?14次下載
    使用<b class='flag-5'>單片機(jī)</b>驅(qū)動DM9000網(wǎng)卡芯片的詳細(xì)<b class='flag-5'>調(diào)試過程</b>資料免費(fèi)下載

    STM32單片機(jī)OBG調(diào)試接口的介紹

    OBG在單片機(jī)的解釋STM32單片機(jī)的內(nèi)核(Cortex-M3)含有硬件調(diào)試模塊,支持多種復(fù)雜的調(diào)試操作,硬件
    的頭像 發(fā)表于 01-26 16:45 ?5926次閱讀
    STM32<b class='flag-5'>單片機(jī)</b><b class='flag-5'>中</b>OBG<b class='flag-5'>調(diào)試</b>接口的介紹

    OBG調(diào)試接口在單片機(jī)的應(yīng)用解析

    OBG在單片機(jī)的解釋STM32單片機(jī)的內(nèi)核(Cortex-M3)含有硬件調(diào)試模塊,支持多種復(fù)雜的調(diào)試操作,硬件
    發(fā)表于 03-30 15:19 ?2285次閱讀
    OBG<b class='flag-5'>調(diào)試</b>接口在<b class='flag-5'>單片機(jī)</b><b class='flag-5'>中</b>的應(yīng)用解析

    電磁流量計調(diào)試過程中存在的問題以及解決措施

    對流量計內(nèi)部設(shè)置參數(shù)進(jìn)行仔細(xì)檢查,還需要調(diào)試顯示數(shù)據(jù)情況和信號反饋情況,查看它們是否處于正常運(yùn)行狀態(tài)下。接下來就詳細(xì)介紹電磁流量計調(diào)試過程中存在的問題以及解決措施。
    的頭像 發(fā)表于 10-27 09:08 ?1644次閱讀

    單片機(jī)常用的調(diào)試方法

    單片機(jī)程序調(diào)試過程中,串口打印調(diào)試方法是非常重要的手段,在使用串口調(diào)試時,我們更多的是使用printf。但是下面我們不介紹printf,介紹一下另外幾種我們常用的
    的頭像 發(fā)表于 04-04 14:58 ?5308次閱讀

    單片機(jī)開發(fā)調(diào)試工具有哪些?

    單片機(jī)調(diào)試是一個有條不紊的過程,用于查找和減少單片機(jī)程序的錯誤數(shù)量,使其按預(yù)期工作。有時候,單片機(jī)
    的頭像 發(fā)表于 07-07 12:29 ?1829次閱讀

    STMCU應(yīng)用過程中與電源相關(guān)的案例分享

    我們在從事STM32單片機(jī)的應(yīng)用開發(fā)及調(diào)試過程中,往往會碰到各類異常。其中有不少比例的問題跟電源有關(guān)。
    的頭像 發(fā)表于 08-04 14:52 ?743次閱讀
    STMCU應(yīng)用<b class='flag-5'>過程中</b>與電源相關(guān)的案例分享

    單片機(jī)基本io功能調(diào)試過程

    單片機(jī)基本IO功能的調(diào)試過程涉及多個步驟,旨在確保IO口能夠正確地執(zhí)行輸入和輸出操作。以下是一個調(diào)試過程,涵蓋了從準(zhǔn)備階段到實際測試的關(guān)鍵步驟: 一、準(zhǔn)備階段 確定單片機(jī)型號和IO口
    的頭像 發(fā)表于 09-14 14:38 ?1120次閱讀
    主站蜘蛛池模板: 丁香网五月网 | 亚洲偷图色综合色就色 | 在线天堂网www资源种子 | 1024手机最新手机在线 | 一级日本高清视频免费观看 | 国产一区二区三区乱码 | 成人国内精品久久久久影院 | 免费观看激色视频网站bd | 中文字幕在线视频第一页 | 人阁色第四影院在线观看 | 欧美成人一区二区三区在线电影 | 色婷婷视频 | 一级看片免费视频 | 免费二级c片观看 | 四虎1515hh永久久免费 | 三级黄色在线观看 | 婷婷激情小说 | 91九色porny蝌蚪 | 视频一区二区三区在线观看 | a天堂资源 | 美女网站色免费 | 亚洲一区二区三区中文字幕5566 | aa小视频| 日本三级s级在线播放 | 性感美女福利视频 | 国产乱码精品一区二区三区四川人 | 久操天堂 | 日本免费人成在线网站 | 久久久网站亚洲第一 | 国产成人永久在线播放 | 天天干夜干 | 国模吧一区二区三区精品视频 | 手机看片福利盒子 | 国产香蕉久久精品综合网 | 免费人成激情视频在线观看冫 | 中文一区二区 | www.男人的天堂 | 午夜免费啪视频观看网站 | 看看一级毛片 | 爽好舒服老师快点 | 日本不卡免费高清一级视频 |