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

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

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

I2C基礎(chǔ)知識(shí)入門簡(jiǎn)單介紹

GReq_mcu168 ? 來源:玩轉(zhuǎn)單片機(jī) ? 作者:玩轉(zhuǎn)單片機(jī) ? 2020-12-02 14:29 ? 次閱讀

廢話

I2C其實(shí)肝的我挺難受的,通訊協(xié)議這種規(guī)范往往可以摳出很多的細(xì)節(jié),看了波叔的文章《萬(wàn)變不離其宗之I2C總線要點(diǎn)總結(jié)》,很詳細(xì)。我打賭我還不會(huì)I2C,因?yàn)樯婕暗胶芏嗉夹g(shù)細(xì)節(jié),在實(shí)際項(xiàng)目中往往是會(huì)被忽略的問題,于是結(jié)合自己以前的項(xiàng)目經(jīng)驗(yàn),簡(jiǎn)單再總結(jié)一下I2C,由于認(rèn)知偏差,寫完之后,長(zhǎng)吁一口氣,感覺自己好像懂了。

目錄

背景

硬件層

數(shù)據(jù)傳輸協(xié)議

實(shí)際上如何工作?

單個(gè)主設(shè)備連接多個(gè)從機(jī)

多個(gè)主設(shè)備連接多個(gè)從機(jī)

總結(jié)

背景

I2C(Inter-Integrated Circuit),中文應(yīng)該叫集成電路總線,它是一種串行通信總線,使用多主從架構(gòu),是由飛利浦公司在1980年代初設(shè)計(jì)的,方便了主板、嵌入式系統(tǒng)手機(jī)與周邊設(shè)備組件之間的通訊。由于其簡(jiǎn)單性,它被廣泛用于微控制器傳感器陣列,顯示器,IoT設(shè)備,EEPROM等之間的通信。

I2C最重要的功能包括:

只需要兩條總線;

沒有嚴(yán)格的波特率要求,例如使用RS232,主設(shè)備生成總線時(shí)鐘;

所有組件之間都存在簡(jiǎn)單的主/從關(guān)系,連接到總線的每個(gè)設(shè)備均可通過唯一地址進(jìn)行軟件尋址;

I2C是真正的多主設(shè)備總線,可提供仲裁和沖突檢測(cè);

傳輸速度;

標(biāo)準(zhǔn)模式:Standard Mode=100Kbps

快速模式:Fast Mode=400Kbps

高速模式:High speed mode=3.4 Mbps

超快速模式:Ultra fast mode=5 Mbps

最大主設(shè)備數(shù):無(wú)限制;

最大從機(jī)數(shù):理論上是127;

以上是I2C的一些重要特點(diǎn),下面會(huì)進(jìn)一步對(duì)I2C進(jìn)行介紹。

硬件層

I2C協(xié)議僅需要一個(gè)SDA和SCL引腳。SDA是串行數(shù)據(jù)線的縮寫,而SCL是串行時(shí)鐘線的縮寫。這兩條數(shù)據(jù)線需要接上拉電阻

設(shè)備間的連接如下所示:

使用I2C,可以將多個(gè)從機(jī)(Slave)連接到單個(gè)主設(shè)備(Master),并且還可以有多個(gè)主設(shè)備(Master)控制一個(gè)或多個(gè)從機(jī)(Slave)。

假如希望有多個(gè)微控制器(MCU)將數(shù)據(jù)記錄到單個(gè)存儲(chǔ)卡或?qū)⑽谋撅@示到單個(gè)LCD時(shí),這個(gè)功能就非常有用。

I2C總線(SDA,SCL)內(nèi)部都使用漏極開路驅(qū)動(dòng)器(開漏驅(qū)動(dòng)),因此SDA和SCL可以被拉低為低電平,但是不能被驅(qū)動(dòng)為高電平,所以每條線上都要使用一個(gè)上拉電阻,默認(rèn)情況下將其保持在高電平;

上拉電阻的值取決于許多因素。德州儀器TI 建議 使用以下公式來計(jì)算正確的上拉電阻值:

其中是邏輯低電壓;

是邏輯低電流

信號(hào)的最大上升時(shí)間;

是總線(電線)電容;

具體如下所示:

根據(jù)上表,這里不難發(fā)現(xiàn)需要在做電阻選擇需要滿足幾個(gè)條件;

灌電流 最大值為;

另外I2C總線規(guī)范和用戶手冊(cè)還為低電平輸出電壓設(shè)置了最大值為0.4V

所以根據(jù)上述公式可以計(jì)算,對(duì)于5V的電源,每個(gè)上拉電阻阻值至少1.53kΩ,而對(duì)于3.3V的電源,每個(gè)電阻阻值至少967Ω。

如果覺得計(jì)算電阻值比較麻煩,也可以使用典型值 4.7kΩ。

上述推導(dǎo)過程可以參考 TI的文檔《I2C Bus Pullup Resistor Calculation》 https://www.ti.com/lit/an/slva689/slva689.pdf

最終在調(diào)試的時(shí)候,當(dāng)我們測(cè)量SDA或SCL信號(hào)并且邏輯LOW上的電壓高于0.4V時(shí),我們就知道可以知道灌電流太高了;

當(dāng)然,這并不意味著每當(dāng)灌電流超過3mA時(shí),設(shè)備就會(huì)立即停止工作。但是,在操作超出其規(guī)格的設(shè)備時(shí),應(yīng)始終小心,因?yàn)樗赡軐?dǎo)致通信故障,縮短其使用壽命甚至甚至永久損壞設(shè)備。

數(shù)據(jù)傳輸協(xié)議

主設(shè)備和從設(shè)備進(jìn)行數(shù)據(jù)傳輸時(shí)遵循以下協(xié)議格式。數(shù)據(jù)通過一條SDA數(shù)據(jù)線在主設(shè)備和從設(shè)備之間傳輸0和1的串行數(shù)據(jù)。串行數(shù)據(jù)序列的結(jié)構(gòu)可以分為,開始條件,地址位,讀寫位,應(yīng)答位,數(shù)據(jù)位,停止條件,具體如下所示;

開始條件

當(dāng)主設(shè)備決定開始通訊時(shí),需要發(fā)送開始信號(hào),需要執(zhí)行以下動(dòng)作;

先將SDA線從高壓電平切換到低壓電平;

然后將SCL從高電平切換到低電平;

在主設(shè)備發(fā)送開始條件信號(hào)之后,所有從機(jī)即使處于睡眠模式也將變?yōu)榛顒?dòng)狀態(tài),并等待接收地址位。

具體如下圖所示;

地址位

通常地址位占7位數(shù)據(jù),主設(shè)備如果需要向從機(jī)發(fā)送/接收數(shù)據(jù),首先要發(fā)送對(duì)應(yīng)從機(jī)的地址,然后會(huì)匹配總線上掛載的從機(jī)的地址;

I2C還支持10位尋址;

讀寫位

該位指定數(shù)據(jù)傳輸?shù)姆较颍?/p>

如果主設(shè)備需要將數(shù)據(jù)發(fā)送到從設(shè)備,則該位設(shè)置為0;

如果主設(shè)備需要往從設(shè)備接收數(shù)據(jù),則將其設(shè)置為1。

ACK / NACK

主機(jī)每次發(fā)送完數(shù)據(jù)之后會(huì)等待從設(shè)備的應(yīng)答信號(hào)ACK;

在第9個(gè)時(shí)鐘信號(hào),如果從設(shè)備發(fā)送應(yīng)答信號(hào)ACK,則SDA會(huì)被拉低;

若沒有應(yīng)答信號(hào)NACK,則SDA會(huì)輸出為高電平,這過程會(huì)引起主設(shè)備發(fā)生重啟或者停止;

數(shù)據(jù)塊

傳輸?shù)臄?shù)據(jù)總共有8位,由發(fā)送方設(shè)置,它需要將數(shù)據(jù)位傳輸?shù)浇邮辗健?/p>

發(fā)送之后會(huì)緊跟一個(gè)ACK/NACK位,如果接收器成功接收到數(shù)據(jù),則設(shè)置為0。否則,它保持邏輯“ 1”。

重復(fù)發(fā)送,直到數(shù)據(jù)完全傳輸為止。

停止條件

當(dāng)主設(shè)備決定結(jié)束通訊時(shí),需要發(fā)送開始信號(hào),需要執(zhí)行以下動(dòng)作;

先將SDA線從低電壓電平切換到高電壓電平;

再將SCL線從高電平拉到低電平;

具體如下圖所示;

實(shí)際上如何工作?

第一步:起始條件

主設(shè)備通過將SDA線從高電平切換到低電平,再將SCL線從高電平切換到低電平,來向每個(gè)連接的從機(jī)發(fā)送啟動(dòng)條件 :

第二步:發(fā)送從設(shè)備地址

主設(shè)備向每個(gè)從機(jī)發(fā)送要與之通信的從機(jī)的7位或10位地址,以及相應(yīng)的讀/寫位;

第三步:接收應(yīng)答

每個(gè)從設(shè)備將主設(shè)備發(fā)送的地址與其自己的地址進(jìn)行比較。如果地址匹配,則從設(shè)備通過將SDA線拉低一位以表示返回一個(gè)ACK位;

如果來自主設(shè)備的地址與從機(jī)自身的地址不匹配,則從設(shè)備將SDA線拉高,表示返回一個(gè)NACK位;

第四步:收發(fā)數(shù)據(jù)

主設(shè)備發(fā)送或接收數(shù)據(jù)到從設(shè)備;

第五步:接收應(yīng)答

在傳輸完每個(gè)數(shù)據(jù)幀后,接收設(shè)備將另一個(gè)ACK位返回給發(fā)送方,以確認(rèn)已成功接收到該幀:

第六步:停止通信

為了停止數(shù)據(jù)傳輸,主設(shè)備將SCL切換為高電平,然后再將SDA切換為高電平,從而向從機(jī)發(fā)送停止條件;

單個(gè)主設(shè)備連接多個(gè)從機(jī)

I2C總線上的主設(shè)備使用7位地址對(duì)從設(shè)備進(jìn)行尋址,可以使用128()個(gè)從機(jī)地址。

請(qǐng)使用4.7K上拉電阻將SDA和SCL線連接到Vcc;

多個(gè)主設(shè)備連接多個(gè)從機(jī)

多個(gè)主設(shè)備可以連接到一個(gè)或多個(gè)從機(jī);

當(dāng)兩個(gè)主設(shè)備試圖通過SDA線路同時(shí)發(fā)送或接收數(shù)據(jù)時(shí),同一系統(tǒng)中的多個(gè)主設(shè)備就會(huì)出現(xiàn)問題。

為了解決這個(gè)問題,每個(gè)主設(shè)備都需要在發(fā)送消息之前檢測(cè)SDA線是低電平還是高電平;

如果SDA線為低電平,則意味著另一個(gè)主設(shè)備可以控制總線,并且主設(shè)備應(yīng)等待發(fā)送消息。

如果SDA線為高電平,則可以安全地發(fā)送消息。

要將多個(gè)主設(shè)備連接到多個(gè)從機(jī),請(qǐng)使用下圖,其中4.7K上拉電阻將SDA和SCL線連接到Vcc:

總結(jié)

本文主要介紹I2C的入門基礎(chǔ)知識(shí),從I2C協(xié)議的硬件層,協(xié)議層進(jìn)行了簡(jiǎn)單介紹;作者能力有限,難免存在錯(cuò)誤和紕漏,請(qǐng)大佬不吝賜教。

責(zé)任編輯:xj

原文標(biāo)題:I2C基礎(chǔ)知識(shí)入門

文章出處:【微信公眾號(hào):玩轉(zhuǎn)單片機(jī)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

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

    關(guān)注

    9

    文章

    1933

    瀏覽量

    64727
  • 總線
    +關(guān)注

    關(guān)注

    10

    文章

    2896

    瀏覽量

    88228
  • I2C
    I2C
    +關(guān)注

    關(guān)注

    28

    文章

    1495

    瀏覽量

    124130

原文標(biāo)題:I2C基礎(chǔ)知識(shí)入門

文章出處:【微信號(hào):mcu168,微信公眾號(hào):硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    I2C總線上拉電阻阻值如何確定?

    導(dǎo)讀I2C總線在產(chǎn)品設(shè)計(jì)中被廣泛應(yīng)用,盡管其結(jié)構(gòu)簡(jiǎn)單,但經(jīng)常發(fā)生上拉電阻設(shè)計(jì)不合理的問題。本文將對(duì)I2C上拉電阻的選擇進(jìn)行簡(jiǎn)要分析。一根信號(hào)線上,通過電阻連接一個(gè)固定的高電平VCC,信號(hào)線初始、空閑
    的頭像 發(fā)表于 12-27 11:34 ?939次閱讀
    <b class='flag-5'>I2C</b>總線上拉電阻阻值如何確定?

    RISC V的I2C操作

    _0_io_scl_write(system_i2c_0_io_scl_write),.system_i2c_0_io_scl_read(system_i2c_0_io_scl_read),WriteEnable信號(hào)的處理
    的頭像 發(fā)表于 11-01 11:06 ?246次閱讀

    I2C協(xié)議的基礎(chǔ)知識(shí)

    本文從I2C協(xié)議的概述開始,描述協(xié)議的歷史、不同速度模式、物理層和數(shù)據(jù)幀結(jié)構(gòu),最后介紹I2C混合電壓系統(tǒng)中電平兼容性以及上拉電阻大小計(jì)算。
    的頭像 發(fā)表于 10-22 15:51 ?611次閱讀
    <b class='flag-5'>I2C</b>協(xié)議的<b class='flag-5'>基礎(chǔ)知識(shí)</b>

    使用USCI I2C主站

    電子發(fā)燒友網(wǎng)站提供《使用USCI I2C主站.pdf》資料免費(fèi)下載
    發(fā)表于 10-21 09:30 ?0次下載
    使用USCI <b class='flag-5'>I2C</b>主站

    I2C噪聲毛刺濾波

    電子發(fā)燒友網(wǎng)站提供《I2C噪聲毛刺濾波.pdf》資料免費(fèi)下載
    發(fā)表于 10-08 14:39 ?5次下載
    <b class='flag-5'>I2C</b>噪聲毛刺濾波

    了解I2C總線

    電子發(fā)燒友網(wǎng)站提供《了解I2C總線.pdf》資料免費(fèi)下載
    發(fā)表于 10-08 11:13 ?2次下載
    了解<b class='flag-5'>I2C</b>總線

    I2C基本指南

    電子發(fā)燒友網(wǎng)站提供《I2C基本指南.pdf》資料免費(fèi)下載
    發(fā)表于 09-10 09:40 ?0次下載
    <b class='flag-5'>I2C</b>基本指南

    CAN轉(zhuǎn)I2C橋接器

    電子發(fā)燒友網(wǎng)站提供《CAN轉(zhuǎn)I2C橋接器.pdf》資料免費(fèi)下載
    發(fā)表于 08-28 11:10 ?0次下載
    CAN轉(zhuǎn)<b class='flag-5'>I2C</b>橋接器

    UART轉(zhuǎn)I2C橋接器

    電子發(fā)燒友網(wǎng)站提供《UART轉(zhuǎn)I2C橋接器.pdf》資料免費(fèi)下載
    發(fā)表于 08-28 09:24 ?1次下載
    UART轉(zhuǎn)<b class='flag-5'>I2C</b>橋接器

    簡(jiǎn)單認(rèn)識(shí)I2C通信協(xié)議

    I2C(Inter-Integrated Circuit)通信協(xié)議是由飛利浦公司(現(xiàn)為恩智浦半導(dǎo)體)開發(fā)的一種簡(jiǎn)單、雙向二線制同步串行總線協(xié)議。自1982年發(fā)布以來,I2C協(xié)議因其高效、靈活和易于實(shí)現(xiàn)的特點(diǎn),在電子設(shè)備間的數(shù)據(jù)交
    的頭像 發(fā)表于 07-25 18:06 ?1598次閱讀

    I2C邏輯選型指南

    電子發(fā)燒友網(wǎng)站提供《I2C邏輯選型指南.pdf》資料免費(fèi)下載
    發(fā)表于 06-20 16:20 ?2次下載

    I2C總線協(xié)議的工作原理和尋址格式

    I2C(Inter-Integrated Circuit)總線協(xié)議,即集成電路總線協(xié)議,是一種用于連接微控制器及其外圍設(shè)備的串行總線協(xié)議。I2C總線以其簡(jiǎn)單的兩線制連接、高可靠性、高集成度和易于擴(kuò)展
    的頭像 發(fā)表于 05-27 15:47 ?1894次閱讀

    什么是I2C協(xié)議 I2C總線的控制邏輯

    在實(shí)際使用過程中,I2C比較容易出現(xiàn)的一個(gè)問題就是死鎖 ,死鎖在I2C中主要表現(xiàn)為:I2C死鎖時(shí)表現(xiàn)為SCL為高,SDA一直為低。
    發(fā)表于 03-12 09:17 ?1137次閱讀
    什么是<b class='flag-5'>I2C</b>協(xié)議 <b class='flag-5'>I2C</b>總線的控制邏輯

    詳解I2C接口協(xié)議

    I2C總線是由荷蘭皇家飛利浦Philips公司(現(xiàn)恩智浦NXP半導(dǎo)體)開發(fā)的一種簡(jiǎn)單的雙向兩線制總線協(xié)議標(biāo)準(zhǔn)。
    發(fā)表于 03-07 10:22 ?2205次閱讀
    詳解<b class='flag-5'>I2C</b>接口協(xié)議

    GD32 MCU硬件I2C不可靠不如軟件I2C?來看看紅楓派開發(fā)版的硬件I2C驅(qū)動(dòng)如何做到穩(wěn)得一批

    在一個(gè)評(píng)論中,看到網(wǎng)友對(duì)硬件I2C的討論,硬件I2C Busy找不到原因、軟件I2C穩(wěn)得一批。
    的頭像 發(fā)表于 02-23 09:37 ?2854次閱讀
    GD32 MCU硬件<b class='flag-5'>I2C</b>不可靠不如軟件<b class='flag-5'>I2C</b>?來看看紅楓派開發(fā)版的硬件<b class='flag-5'>I2C</b>驅(qū)動(dòng)如何做到穩(wěn)得一批