資料介紹
概覽我們先來看一下STM32 I2C硬件的結(jié)構(gòu)我們可以看見STM32的硬件I2C有兩個和數(shù)據(jù)有關(guān)的寄存器“數(shù)據(jù)寄存器(Data register)”(DR)和“數(shù)據(jù)移位寄存器(Data shift register)”(DSR),我們的軟件寫入的是DR, DSR用于I2C數(shù)據(jù)的移位發(fā)送和接收,DR和DSR的數(shù)據(jù)交換由硬件控制——發(fā)送時DSR為空,DR不為空時,硬件自動把DR的數(shù)據(jù)寫進(jìn)DSR;接收時DR為空,DSR不為空,硬件自動把DSR數(shù)據(jù)寫進(jìn)DR。連續(xù)數(shù)據(jù)傳輸時,這樣兩個寄存器的數(shù)據(jù)交換使得軟件讀出和寫入DR不會影響I2C總線中的數(shù)據(jù)接收和發(fā)送,使I2C的效率更高,這看起來十分美好,但是正是這個特點在某些情況下會變成電工們的噩夢,原因有二:1、硬件上,DR和DSR的交換機制存在缺陷。2、軟件上,因為DR和DSR一共能容納兩個字節(jié)的數(shù)據(jù),導(dǎo)致接收時候NACK的設(shè)置有一定的不可預(yù)料性。硬件硬件I2C上的缺陷,新版英文ErrSheet已經(jīng)寫得很清楚,就不引用了,這里只簡單說說要點和一些個人總結(jié)。1、EV7, EV7_1, EV6_1, EV6_3, EV2, EV8 和 EV3 必須在當(dāng)前字節(jié)傳輸前處理完成,不然,有可能會導(dǎo)致數(shù)據(jù)出錯。這幾個事件都涉及到DR和DSR,個人猜測(主要是有個”may be”才敢猜測)可能是讀出或者寫入DR的同時DSR被填滿或清空,導(dǎo)致數(shù)據(jù)出錯。理想情況下“讀出或者寫入DR的同時DSR被填滿或清空”是不可能發(fā)生的,中斷一來臨的時候,CPU馬上處理中斷請求,讀出或者寫入DR數(shù)據(jù),這時DSR的數(shù)據(jù)還是“新鮮滾熱辣”的,可能連一位都沒有接收或發(fā)送。但是,在實際使用時,可能有別的中斷優(yōu)先級比I2C的事件中斷要高,I2C事件沒有及時處理而出現(xiàn)了上述的情況。所以,ST建議把I2C的事件中斷設(shè)置成最高優(yōu)先級。2、產(chǎn)生STOP前DSR必須為空,不然,會導(dǎo)致DSR里的數(shù)據(jù)左移一位。這個沒什么好說的,就是一個硬件的BUG,保證發(fā)送STOP前DSR沒有數(shù)據(jù)就可以了。3、總線上,開始條件(S)后沒有進(jìn)行數(shù)據(jù)傳輸就馬上設(shè)置停止條件(P),或者S后忘記P會導(dǎo)致硬件I2C不能再次產(chǎn)生S,必須軟復(fù)位I2C。這個ST解釋成是,STM32嚴(yán)格按照了I2C的標(biāo)準(zhǔn),S之后沒有數(shù)據(jù)傳輸是不能P的。其實這點可以體諒,但是,這點如果沒有處理好,總線上的錯誤會導(dǎo)致STM32 I2C陷入癱瘓。軟件由于DR和DSR的存在,編程上需要一些技巧,新版英文ErrSheet和參考手冊(RM0008)都有相關(guān)的操作介紹(Closing the communication),排除硬件上的缺陷,編程的難點主要在接收時如何可靠地設(shè)置NACK上。在只有DSR的MCU上設(shè)置NACK是非常簡單的,在讀出倒數(shù)第二個數(shù)據(jù)前設(shè)置一下就可以了,但是個方法在似乎在STM32上行不通,因為STM32有DR和DSR,在倒數(shù)第二個數(shù)據(jù)被接收的時候(RxNE置位),馬上設(shè)置NACK,理想情況下沒有任何問題,NACK也被正確的發(fā)送,但是如果有其他更高優(yōu)先級的中斷打斷了這個過程,NACK就不能及時設(shè)置,導(dǎo)致從器件收到的是ACK沒有釋放總線……1、接收2個字節(jié)或1個字節(jié)時,切換GPIO模式為OD,然后軟件下拉SCL引腳,使硬件I2C發(fā)生時鐘延展,把下一個字節(jié)開始傳輸?shù)臅r機延后,設(shè)置完NACK后,再把GPIO設(shè)置回AFOD,但是這只能解決小于兩個字節(jié)的接收。2、大于2個字節(jié)用DMA,DMA可以說是特效藥,“屢試不爽”。不過要注意,接收大于或等于2個字節(jié)時才能使用DMA,不然不能產(chǎn)生EOT-1事件導(dǎo)致NACK不能正確發(fā)送。3、設(shè)置I2C事件中斷為最高優(yōu)先等級。方案讀到這里你可能會想,硬件有缺陷,軟件也得這么“猥瑣”,可以說是寸步難行。真的沒有其他辦法了嗎?其實,我們可以把DR和DSR兩個當(dāng)一個用,全部判斷BTF,不理會TxE和RxE,用時間來換穩(wěn)定性,慢點就慢點總比沒得用好。發(fā)送時:開始,發(fā)送寫地址,器件應(yīng)答,清ADDR,一字節(jié)數(shù)據(jù)到寫DR,硬件把DR數(shù)據(jù)寫入到DSR,當(dāng)DSR傳輸完畢時,DR也為空,BTF置位,這時我們再寫一字節(jié)數(shù)據(jù)到DR,如此循環(huán),最后一次BTF置位的時候發(fā)送P或者重起始(R)。這樣操作,“硬件把DR數(shù)據(jù)寫入到DSR”執(zhí)行的時間是我們可以預(yù)料的,不存在上面提及的沖突問題。接收時:1、接收一個字節(jié):按照ST給的方法。開始,發(fā)送讀地址,器件應(yīng)答,清ADDR前軟件下拉SCL,寫完NACK、STOP和DR后軟件再釋放SCL。RxNE時讀DR。2、接收兩個字節(jié):也是按照ST的方法。開始,發(fā)送讀地址,器件應(yīng)答,設(shè)置POS和ACK,下拉SCL,清ADDR,設(shè)置NACK,釋放SCL。BTF時,軟件拉低SCL,發(fā)送STOP,讀DR,釋放SCL,再讀DR。3、接收兩個以上字節(jié):開始,發(fā)送讀地址,器件應(yīng)答,直接清ADDR。BTF時,讀DR一次。再BTF,再讀DR一次,如此循環(huán)。倒數(shù)第二次BTF時設(shè)置NACK(注意DR和DSR各有一字節(jié)的數(shù)據(jù)),讀DR一次。再等到最后一次BTF時,軟件拉低SCL,發(fā)送STOP,讀DR,釋放SCL,再讀DR。干擾當(dāng)總線空閑時,無論是SCL的跳變(電平高低高),還是SDA的跳變,都會導(dǎo)致STM32的硬件I2C癱瘓,不能產(chǎn)生下一個S。當(dāng)總線正在傳輸數(shù)據(jù)時,總線上的信號干擾對STM32的硬件I2C來說是致命的。1、空閑時SDA跳變,會產(chǎn)生一個S和一個P,幸好這個P會產(chǎn)生一個中斷,我們可以用一個收到P就軟復(fù)位硬件I2C的策略。這樣能避免空閑時SDA跳變帶來的干擾。2、空閑時SCL跳變,這是一個I2C的錯誤信號,但是STM32卻會認(rèn)為這是一個S,所以SCL跳變會導(dǎo)致BUSY置位,而且不會像SDA跳變那樣會產(chǎn)生一個P中斷。如果在單主的情況下,你可以為I2C的S做一個超時,超時了就軟復(fù)位I2C就可以,當(dāng)然最簡單的方法還是空閑時關(guān)閉I2C(PE置零)。在多從機的情況下,只能等待別的主機發(fā)送的一個P,或者伺機軟復(fù)位。3、傳輸途中因干擾,產(chǎn)生總線錯誤(BERR)。單主接收途中出現(xiàn)BERR,可以在關(guān)閉硬件I2C后,連續(xù)模擬產(chǎn)生9個以上的SCL,在保證SDA為高電平的情況下軟復(fù)位I2C。4、傳輸途中因干擾,導(dǎo)致仲裁丟失(ARLO)。單主時和BERR的處理方法相同。(mbbeetchina)
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- STM32自舉程序中使用的I2C協(xié)議
- STM32 I2C存取實驗資料 17次下載
- STM32F 單片機硬件I2C Busy標(biāo)志導(dǎo)致的I2C卡死的處理辦法
- 硬件I2C與模擬I2C
- STM32F103硬件I2C Slave
- STM32的硬件I2C有BUG嗎?
- I2C基本用法及問題匯總資料下載
- I2C讀寫心得資料下載
- 內(nèi)置I2C模塊的STM32F030資料下載
- STM32庫實現(xiàn)的模擬無人機I2C的代碼和資料免費下載 6次下載
- 如何使用STM32單片機的硬件I2C讀取MPU6050的數(shù)據(jù)資料和程序免費下載 0次下載
- STM32duino的I2C資料說明 8次下載
- STM32F4的I2C總線的詳細(xì)源代碼程序資料免費下載 51次下載
- STM32硬件i2c,CubeMX,Hal庫 66次下載
- STM32硬件I2C例程 93次下載
- 海思Hi3566V100 I2C硬件設(shè)計要點 1618次閱讀
- I2C地址跳變問題的調(diào)試案例 1893次閱讀
- I2C通信沒反應(yīng)怎么辦? 3302次閱讀
- I2C通信協(xié)議及其工作原理 4991次閱讀
- Hi3861硬件i2c驅(qū)動oled 1583次閱讀
- Linux I2C驅(qū)動入門知識科普 1734次閱讀
- 基于MM32生態(tài)實現(xiàn)I2C接口通訊的方式 1706次閱讀
- I2C通信的詳細(xì)講解 13.6w次閱讀
- 什么是I2C通信協(xié)議? 7824次閱讀
- i2c總線用來做什么_i2c總線數(shù)據(jù)傳輸過程 7304次閱讀
- 基于MCS-51單片機I2C總線接口電路的設(shè)計 3457次閱讀
- 基于MSP430F5系列的硬件I2C的使用分享 3861次閱讀
- I2C總線的特點、控制技術(shù)與傳輸分析 1w次閱讀
- mpu6050對應(yīng)i2c地址是什么_如何讀取數(shù)據(jù) 2.4w次閱讀
- 《振南電子STM32視頻教程》第八講:I2C總線 1119次閱讀
下載排行
本周
- 1EMC電路設(shè)計工程師必備的EMC基礎(chǔ)
- 0.42 MB | 4次下載 | 2 積分
- 2AU3116 2×60W模擬輸入雙通道Class-D 音頻功率放大器數(shù)據(jù)手冊
- 1.19 MB | 1次下載 | 免費
- 3低壓降肖特基整流管SR340L數(shù)據(jù)手冊
- 0.78 MB | 1次下載 | 免費
- 4ZX8002E 觸摸調(diào)光LED集成IC數(shù)據(jù)手冊
- 2.27 MB | 次下載 | 免費
- 5SOD-323塑料封裝ESD保護(hù)二極管SD05T系列規(guī)格書
- 1.07 MB | 次下載 | 免費
- 6SOT-23塑料封裝ESD保護(hù)二極管SMxx Series系列規(guī)格書
- 0.93 MB | 次下載 | 免費
- 7高效率整流二極管HER151 THRU HER158數(shù)據(jù)手冊
- 0.54 MB | 次下載 | 免費
- 8低壓降肖特基整流管SL22 THRU SL210數(shù)據(jù)手冊
- 1.03 MB | 次下載 | 免費
本月
- 1三相逆變主電路的原理圖和PCB資料合集免費下載
- 27.35 MB | 111次下載 | 1 積分
- 2運算放大器基本電路中文資料
- 1.30 MB | 16次下載 | 免費
- 3蘋果iphone 11電路原理圖
- 4.98 MB | 11次下載 | 5 積分
- 4TL494工業(yè)用開關(guān)電源原理圖資料
- 0.22 MB | 10次下載 | 1 積分
- 5常用電子元器件介紹
- 3.21 MB | 8次下載 | 免費
- 6QW2893應(yīng)急燈專用檢測芯片
- 590.40 KB | 4次下載 | 免費
- 7相關(guān)協(xié)議信號總結(jié)
- 0.94 MB | 4次下載 | 免費
- 8EMC電路設(shè)計工程師必備的EMC基礎(chǔ)
- 0.42 MB | 4次下載 | 2 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935130次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費下載
- 340992 | 191390次下載 | 10 積分
- 5十天學(xué)會AVR單片機與C語言視頻教程 下載
- 158M | 183344次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81591次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費下載
- 0.02 MB | 73815次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65989次下載 | 10 積分
評論