I2C是inter-integrated circuit的縮寫,又名為TWI,只需要用兩條物理線進(jìn)行傳輸,分別命名為SDA和SCL,用于傳輸serial data和serial clock。I2C工作時分為主從工作模式,而在同總線上可以存在多個主機(jī)。每一個連接到總線的器件都可以通過唯一的地址與總線連接,主機(jī)控制主機(jī)為發(fā)送器模式或是接收器模式。多個主機(jī)控制時可以通過沖突檢測和仲裁防止數(shù)據(jù)被破壞。I2C總線有幾種不同速率的工作模式,標(biāo)準(zhǔn)模式的速率為100kbps,快速模式下速率為400kbps,在高速模式下速率可達(dá)到3.4Mbps。整理下I2C基本的傳輸方式。
數(shù)據(jù)發(fā)送過程
發(fā)送從起始到結(jié)束為一次完整發(fā)送過程,如圖所示一次完整的發(fā)送過程,起始后先發(fā)送地址信息,R/W表示寫入或是讀取數(shù)據(jù),如果一次過程中,需要切換讀寫操作時,需要重新發(fā)送start。SDA線上的每個字節(jié)必須為8位,每次傳輸可以發(fā)送的字節(jié)數(shù)量不受限制,而每個字節(jié)后必須跟一個響應(yīng)位。從機(jī)在處理其他事件而不能接收數(shù)據(jù)時,可以通過控制SCL保持低電平來等待數(shù)據(jù)接收,等到準(zhǔn)備好繼續(xù)傳輸時,釋放SCL。在總線上每個模塊具有唯一的地址,當(dāng)然亦可以設(shè)計廣播地址,通知所有其他模塊。
啟動和停止
當(dāng)I2C不工作時,SDA和SCL一樣都處于高位HIGH,SCL保持為HIGH,SDA由HIGH變LOW時表示開始傳輸,而SCL保持HIGH,SDA由LOW變?yōu)镠IGH時表示停止傳輸。Sr和S完全相同,差別只是第一次Start之后沒有進(jìn)行stop,再次啟動Start。
數(shù)據(jù)產(chǎn)生
SDA上傳送的數(shù)據(jù)必須在時鐘高電平時保持穩(wěn)定,而數(shù)據(jù)的改變只有在SCL為低時進(jìn)行,而SCL由主機(jī)控制產(chǎn)生。
沖突仲裁
主機(jī)在總線空閑時候啟動傳輸。而當(dāng)總線上有多個主機(jī)時,可能產(chǎn)生同時啟動的沖突,因此需要仲裁。仲裁方式是,當(dāng)SCL線是高電平時,仲裁在SDA線發(fā)生 這樣在其他主機(jī)發(fā)送低電平時發(fā)送高電平的主機(jī)將斷開它的數(shù)據(jù)輸出級,因?yàn)榭偩€上的電平與它自己的電平不相同,總線上的電平總是在一個輸出為低時就為低。仲裁可以持續(xù)多位,當(dāng)丟失仲裁的主機(jī)同時具有從機(jī)功能時,需要立即切換從機(jī)狀態(tài)。
從機(jī)掛起數(shù)據(jù)發(fā)送示例
-
接收器
+關(guān)注
關(guān)注
14文章
2481瀏覽量
72219 -
總線
+關(guān)注
關(guān)注
10文章
2903瀏覽量
88398 -
I2C
+關(guān)注
關(guān)注
28文章
1495瀏覽量
124590
原文標(biāo)題:帶你理解I2C總線數(shù)據(jù)傳輸方式
文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
HT45R37使用I2C進(jìn)行數(shù)據(jù)傳輸的方法 (C語言)
I2C Guid I2C指南
基于CPLD的I2C總線接口設(shè)計
![基于CPLD的<b class='flag-5'>I2C</b>總線接口設(shè)計](https://file.elecfans.com/web2/M00/48/D4/pYYBAGKhtCeAG-9WAAARMiSSqA4093.jpg)
I2C總線的基礎(chǔ)知識
i2c總線用來做什么_i2c總線數(shù)據(jù)傳輸過程
硬件I2C與模擬I2C
![硬件<b class='flag-5'>I2C</b>與模擬<b class='flag-5'>I2C</b>](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
Linux I2C驅(qū)動入門知識科普
I2C傳輸發(fā)生timeout時
![<b class='flag-5'>I2C</b><b class='flag-5'>傳輸</b>發(fā)生timeout時](https://file1.elecfans.com/web2/M00/8D/7F/wKgaomS7et6AaJ8TAAHLHSxMZMk457.jpg)
I2C子系統(tǒng)SW Architecture
![<b class='flag-5'>I2C</b>子系統(tǒng)SW Architecture](https://file1.elecfans.com/web2/M00/8D/81/wKgaomS7jI6AcVIDAAFQF5uK5G8249.jpg)
I2C和I3C關(guān)于功耗和傳輸速率的對比
![<b class='flag-5'>I2C</b>和<b class='flag-5'>I3C</b>關(guān)于功耗和<b class='flag-5'>傳輸</b>速率的對比](https://file1.elecfans.com/web2/M00/8D/81/wKgaomS7kWeAL3F1AAJac4_4PfI629.jpg)
評論