I2C總線(xiàn)之(二)---時(shí)序
1.空閑狀態(tài) I2C總線(xiàn)總線(xiàn)的SDA和SCL兩條信號線(xiàn)同時(shí)處于高電平時(shí),規定為總線(xiàn)的空閑狀態(tài)。此時(shí)各個(gè)器件的輸出級場(chǎng)效應管均處在截止狀態(tài),即釋放總線(xiàn),由兩條信號線(xiàn)各自的上拉電阻把電平拉高。 2.起始位與停止位的定義:
- 起始信號:當SCL為高期間,SDA由高到低的跳變;啟動(dòng)信號是一種電平跳變時(shí)序信號,而不是一個(gè)電平信號。
- 停止信號:當SCL為高期間,SDA由低到高的跳變;停止信號也是一種電平跳變時(shí)序信號,而不是一個(gè)電平信號。
3.ACK
發(fā)送器每發(fā)送一個(gè)字節,就在時(shí)鐘脈沖9期間釋放數據線(xiàn),由接收器反饋一個(gè)應答信號。 應答信號為低電平時(shí),規定為有效應答位(ACK簡(jiǎn)稱(chēng)應答位),表示接收器已經(jīng)成功地接收了該字節;應答信號為高電平時(shí),規定為非應答位(NACK),一般表示接收器接收該字節沒(méi)有成功。對于反饋有效應答位ACK的要求是,接收器在第9個(gè)時(shí)鐘脈沖之前的低電平期間將SDA線(xiàn)拉低,并且確保在該時(shí)鐘的高電平期間為穩定的低電平。 如果接收器是主控器,則在它收到最后一個(gè)字節后,發(fā)送一個(gè)NACK信號,以通知被控發(fā)送器結束數據發(fā)送,并釋放SDA線(xiàn),以便主控接收器發(fā)送一個(gè)停止信號P。
如下圖邏輯分析儀的采樣結果:釋放總線(xiàn)后,如果沒(méi)有應答信號,sda應該一直持續為高電平,但是如圖中藍色虛線(xiàn)部分所示,它被拉低為低電平,證明收到了應答信號。這里面給我們的兩個(gè)信息是:1)接收器在SCL的上升沿到來(lái)之前的低電平期間拉低SDA;2)應答信號一直保持到SCL的下降沿結束;正如前文紅色標識所指出的那樣。

4.數據的有效性:
I2C總線(xiàn)進(jìn)行數據傳送時(shí),時(shí)鐘信號為高電平期間,數據線(xiàn)上的數據必須保持穩定,只有在時(shí)鐘線(xiàn)上的信號為低電平期間,數據線(xiàn)上的高電平或低電平狀態(tài)才允許變化。 我的理解:雖然只要求在高電平期間保持穩定,但是要有一個(gè)提前量,也就是數據在SCL的上升沿到來(lái)之前就需準備好,因為在前面I2C總線(xiàn)之(一)---概述一文中已經(jīng)指出,數據是在SCL的上升沿打入到器件(EEPROM)中的。
5.數據的傳送:
在I2C總線(xiàn)上傳送的每一位數據都有一個(gè)時(shí)鐘脈沖相對應(或同步控制),即在SCL串行時(shí)鐘的配合下,在SDA上逐位地串行傳送每一位數據。數據位的傳輸是邊沿觸發(fā)。
評論