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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

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

I2C基礎知識入門簡單介紹

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

廢話

I2C其實肝的我挺難受的,通訊協(xié)議這種規(guī)范往往可以摳出很多的細節(jié),看了波叔的文章《萬變不離其宗之I2C總線要點總結(jié)》,很詳細。我打賭我還不會I2C,因為涉及到很多技術細節(jié),在實際項目中往往是會被忽略的問題,于是結(jié)合自己以前的項目經(jīng)驗,簡單再總結(jié)一下I2C,由于認知偏差,寫完之后,長吁一口氣,感覺自己好像懂了。

目錄

背景

硬件

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

實際上如何工作?

單個主設備連接多個從機

多個主設備連接多個從機

總結(jié)

背景

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

I2C最重要的功能包括:

只需要兩條總線;

沒有嚴格的波特率要求,例如使用RS232,主設備生成總線時鐘;

所有組件之間都存在簡單的主/從關系,連接到總線的每個設備均可通過唯一地址進行軟件尋址;

I2C是真正的多主設備總線,可提供仲裁和沖突檢測

傳輸速度;

標準模式:Standard Mode=100Kbps

快速模式:Fast Mode=400Kbps

高速模式:High speed mode=3.4 Mbps

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

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

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

以上是I2C的一些重要特點,下面會進一步對I2C進行介紹。

硬件層

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

設備間的連接如下所示:

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

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

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

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

其中是邏輯低電壓;

是邏輯低電流

信號的最大上升時間;

是總線(電線)電容;

具體如下所示:

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

灌電流 最大值為;

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

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

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

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

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

當然,這并不意味著每當灌電流超過3mA時,設備就會立即停止工作。但是,在操作超出其規(guī)格的設備時,應始終小心,因為它可能導致通信故障,縮短其使用壽命甚至甚至永久損壞設備。

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

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

開始條件

當主設備決定開始通訊時,需要發(fā)送開始信號,需要執(zhí)行以下動作;

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

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

在主設備發(fā)送開始條件信號之后,所有從機即使處于睡眠模式也將變?yōu)榛顒訝顟B(tài),并等待接收地址位。

具體如下圖所示;

地址位

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

I2C還支持10位尋址;

讀寫位

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

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

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

ACK / NACK

主機每次發(fā)送完數(shù)據(jù)之后會等待從設備的應答信號ACK;

在第9個時鐘信號,如果從設備發(fā)送應答信號ACK,則SDA會被拉低;

若沒有應答信號NACK,則SDA會輸出為高電平,這過程會引起主設備發(fā)生重啟或者停止;

數(shù)據(jù)塊

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

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

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

停止條件

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

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

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

具體如下圖所示;

實際上如何工作?

第一步:起始條件

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

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

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

第三步:接收應答

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

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

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

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

第五步:接收應答

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

第六步:停止通信

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

單個主設備連接多個從機

I2C總線上的主設備使用7位地址對從設備進行尋址,可以使用128()個從機地址。

請使用4.7K上拉電阻將SDA和SCL線連接到Vcc;

多個主設備連接多個從機

多個主設備可以連接到一個或多個從機;

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

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

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

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

要將多個主設備連接到多個從機,請使用下圖,其中4.7K上拉電阻將SDA和SCL線連接到Vcc:

總結(jié)

本文主要介紹I2C的入門基礎知識,從I2C協(xié)議的硬件層,協(xié)議層進行了簡單介紹;作者能力有限,難免存在錯誤和紕漏,請大佬不吝賜教。

責任編輯:xj

原文標題:I2C基礎知識入門

文章出處:【微信公眾號:玩轉(zhuǎn)單片機】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

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

    關注

    9

    文章

    1792

    瀏覽量

    64411
  • 總線
    +關注

    關注

    10

    文章

    2858

    瀏覽量

    87912
  • I2C
    I2C
    +關注

    關注

    28

    文章

    1477

    瀏覽量

    123055

原文標題:I2C基礎知識入門

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

收藏 人收藏

    評論

    相關推薦

    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信號的處理
    的頭像 發(fā)表于 11-01 11:06 ?90次閱讀

    I2C協(xié)議的基礎知識

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

    了解I2C總線

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

    I2C基本指南

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

    簡單認識I2C通信協(xié)議

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

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

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

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

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

    詳解I2C接口協(xié)議

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

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

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

    簡單的總線通訊!I2C通訊總線的原理原來這么好懂

    通訊I2C
    安泰儀器維修
    發(fā)布于 :2024年01月02日 11:16:31

    i2c工作原理及使用方法

    的標準。 I2C協(xié)議具有以下特點: 簡單I2C使用兩根線(數(shù)據(jù)線SDA和時鐘線SCL)進行通信,極大地簡化了連接的線路。 多主機:支持多個主機設備同時連接到總線上,可以進行多路復用和地址選擇。 高速:
    的頭像 發(fā)表于 12-19 16:17 ?1159次閱讀

    I2C地址跳變問題的調(diào)試案例

    引言:I2C作為使用最為廣泛的通訊接口,調(diào)試各類I2C器件,大家應該都很輕車熟路。一般對于外掛電阻配置器件的I2C地址,例如電阻上拉之后,器件的地址就會固定下來不再變動,但是今天給大家分享一個自己的調(diào)試案例,即
    的頭像 發(fā)表于 11-22 10:51 ?1448次閱讀
    <b class='flag-5'>I2C</b>地址跳變問題的調(diào)試案例

    I2C總線信號與測試案例(一)

    I2C bus是Inter-IC bus的縮寫,意思是IC器件之間的通訊總線;I2C 總線的特點如下
    的頭像 發(fā)表于 11-20 15:45 ?1796次閱讀
    <b class='flag-5'>I2C</b>總線信號與測試案例(一)

    分享I2C總線規(guī)范

    電子發(fā)燒友網(wǎng)站提供《分享I2C總線規(guī)范.pdf》資料免費下載
    發(fā)表于 11-18 10:49 ?0次下載
    分享<b class='flag-5'>I2C</b>總線規(guī)范