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

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

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

嵌入式開發(fā)中I2C協(xié)議詳解

FPGA之家 ? 來源:FPGA之家 ? 2023-12-05 09:16 ? 次閱讀

I2C協(xié)議中最重要的一點是I2C地址。這個地址有7位和10位兩種形式。7位能夠表示127個地址,而在實際使用中基本上不會掛載如此多的設(shè)置,所以很多設(shè)備的地址都采用7位,所以本文接下來的說明都是基于此。I2C還有一個很重要的概念,就是“主—從”。對于從設(shè)備來說,它是啥都不干的,更不會自動發(fā)送數(shù)據(jù);而主設(shè)備,則是起到控制作用,一切都是從它開始。

除了GND以外,I2C有兩根線,分別是SDA和SCL,所有的設(shè)備都是接到這兩根線上。那么,這些設(shè)備如何知道數(shù)據(jù)是發(fā)送給它們呢?這就得依靠前面所說到的地址了。設(shè)備I2C的地址是固定的,比如0x50,0x60等等。因為只能有127個地址,地址沖突是很常見的,所以一般設(shè)備都會有一個地址選擇PIN,比如拉高時候為0x50,接地為0x60。如果無論拉高還是接地,都和別的芯片有沖突,那該怎么辦呢?答案是:涼拌,沒辦法。遇到這種情況,只能換芯片了。

我們來看I2C協(xié)議中的數(shù)據(jù)傳輸時序圖:

9c76a2fc-9306-11ee-939d-92fbcf53809c.png

SCL是時鐘,SDA承載的是數(shù)據(jù)。當SDA從1變動到0,而SCL還是1時,表示開始數(shù)據(jù)傳輸。接下來的7位,就是設(shè)備的地址。緊接著的是讀寫標志,其為1時是讀取,為0則是寫。

如果I2C總線上存在著和請求的地址相對應的設(shè)備,則從設(shè)備會發(fā)送一個ACK信號通知主設(shè)備,可以發(fā)送數(shù)據(jù)了。接到ACK信號后,主設(shè)備則發(fā)送一個8位的數(shù)據(jù)。當傳輸完畢之后,SCL保持為1,SDA從0變換到1時,標明傳輸結(jié)束。

從這個時序圖中可以看到,SCL很重要,并且哪個時鐘沿是干嘛的,都是確定好的。比如,前面7個必定是地址,第8個是讀寫標志,數(shù)據(jù)傳輸必須是8位,必須接個ACK信號等等。

前面的時序圖并沒有標明數(shù)據(jù)傳輸?shù)姆较?,我們現(xiàn)在看看寫操作的數(shù)據(jù)流向:

9c86d74e-9306-11ee-939d-92fbcf53809c.png

網(wǎng)格的是主設(shè)備發(fā)送的,白色格子是從設(shè)備發(fā)送的。從圖示中可以看到,對于寫操作,從設(shè)備都只是發(fā)送ACK進行確認而已。而讀操作的數(shù)據(jù)流向,就有所不同,如圖:

9c95077e-9306-11ee-939d-92fbcf53809c.png

這時候,從設(shè)備除了發(fā)送ACK以外,緊跟著的還有數(shù)據(jù)。

我們用示波器來查看波形圖,以便于理解。

將示波器的X和Y分別接到SDA和SCL,得到波形并分析如圖:

9c9ea4dc-9306-11ee-939d-92fbcf53809c.jpg

從圖中可知時序如下:

由主機發(fā)起,在SCL為高電平時,SDA由高到低切變,形成開始信號;

接著是7位地址和一位讀寫標志,這里7位地址為0111100,即0x3c,正是我們代碼中設(shè)置的地址ID;最后一位為0表示寫操作;

接著在下一個時鐘,主機以高電平狀態(tài)釋放SDA,這時從機響應,將SDA拉低了;

接著是兩個8位數(shù)據(jù)00101110與響應,即0x2E,正是“.”號的ASCII碼,符合預期輸出;

還有其它數(shù)據(jù)和最后的停止位,圖中被截掉了。

從圖中可知,縱向一格是200mV,則SDA和SCL的電平大概就是350mV;由于信號筆上設(shè)置了信號x10,因此實際電平應該大概是3.5V(理論上應該是3.3V)。橫向一格是25us,10個時鐘周期大概用了4格,即4x25us=100us,平均每個時鐘周期是10us,可算出傳輸頻率為1/10us=100,000/s,即100k bps。

既有讀又有寫的波形圖:

9cb345f4-9306-11ee-939d-92fbcf53809c.jpg

I2C是由2根線進行操作的,一個是主控時序SCL,另一根主控數(shù)據(jù)SDA

對于操作主要分成讀寫,讀寫的兩個操作有部分是相似的

而時序的操作主要分為:START,DATA,ACK,STOP,NOACK






審核編輯:劉清

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

    關(guān)注

    113

    文章

    6164

    瀏覽量

    184313
  • ACK
    ACK
    +關(guān)注

    關(guān)注

    0

    文章

    28

    瀏覽量

    11129
  • SCL
    SCL
    +關(guān)注

    關(guān)注

    1

    文章

    239

    瀏覽量

    17025
  • GND
    GND
    +關(guān)注

    關(guān)注

    2

    文章

    528

    瀏覽量

    38632
  • I2C協(xié)議
    +關(guān)注

    關(guān)注

    0

    文章

    26

    瀏覽量

    8449

原文標題:一文了解嵌入式開發(fā)中I2C協(xié)議

文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    利用數(shù)字示波器調(diào)試嵌入式I2C總線

    本內(nèi)容提供了利用數(shù)字示波器調(diào)試嵌入式I2C總線,本文闡述了在實際開發(fā)中所遇到的I2C通信問題及使用示波器分析問題和解決問題的方法。嵌入式系統(tǒng)
    發(fā)表于 11-04 17:30 ?5813次閱讀

    I2C總線介紹 I2C讀寫時序介紹

    作為嵌入式開發(fā)人員,無論是硬件還是軟件工程師,或多或少都會接觸過I2C接口的外設(shè)。諸如常用的存儲器EEPROM等皆是I2C接口進行通信。
    發(fā)表于 10-01 16:57 ?2637次閱讀
    <b class='flag-5'>I2C</b>總線介紹 <b class='flag-5'>I2C</b>讀寫時序介紹

    嵌入式開發(fā)

    嵌入式開發(fā)就是指在嵌入式操作系統(tǒng)下進行開發(fā),嵌入式Linux是以Linux為基礎(chǔ)的嵌入式作業(yè)系統(tǒng)。這里提供了
    發(fā)表于 12-20 13:21
    <b class='flag-5'>嵌入式開發(fā)</b>

    基于嵌入式Linux演示I2C設(shè)備調(diào)試

      I2C嵌入式設(shè)備最為常用的接口之一,常用于如下面這些應用場景,因此本文就基于嵌入式Linux演示在User Space進行I2C設(shè)備調(diào)試。
    發(fā)表于 09-18 15:21 ?3次下載

    I2C標準協(xié)議的時序時鐘問題詳解

    對于嵌入式開發(fā)的朋友來說,I2C協(xié)議實在是再熟悉不過了,有太多的器件,采用的都是通過I2C來進行相應的設(shè)置。今天,我們就隨便聊聊這個I2C
    發(fā)表于 11-15 15:08 ?2.8w次閱讀
    <b class='flag-5'>I2C</b>標準<b class='flag-5'>協(xié)議</b>的時序時鐘問題<b class='flag-5'>詳解</b>

    如何玩轉(zhuǎn)嵌入式開發(fā)i2c協(xié)議

    對于嵌入式開發(fā)的朋友來說,I2C協(xié)議實在是再熟悉不過了,有太多的器件,采用的都是通過I2C來進行相應的設(shè)置。
    的頭像 發(fā)表于 01-09 15:28 ?4223次閱讀
    如何玩轉(zhuǎn)<b class='flag-5'>嵌入式開發(fā)</b><b class='flag-5'>中</b><b class='flag-5'>i2c</b><b class='flag-5'>協(xié)議</b>

    I2C系列的合集,可以系統(tǒng)學習I2C協(xié)議

    這篇文章給大家?guī)砹?b class='flag-5'>I2C系列的合集,可以系統(tǒng)學習I2C協(xié)議。大家趕緊看看吧! 1、I2C總線:何時使用I2C緩沖器 本文討論了使用
    的頭像 發(fā)表于 09-23 15:28 ?3100次閱讀

    嵌入式詳解

    嵌入式詳解(stm32嵌入式開發(fā)實例)-嵌入式詳解,有需要的可以參考!
    發(fā)表于 07-30 16:07 ?64次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>詳解</b>

    嵌入式linux應用讀寫i2c示例

    這里分享一個嵌入式linux讀寫24c02的i2c程序ioctl函數(shù)的使用:原型:struct ioctl(struct file *file,unsigned int cmd,unsigned
    發(fā)表于 11-01 16:57 ?12次下載
    <b class='flag-5'>嵌入式</b>linux應用讀寫<b class='flag-5'>i2c</b>示例

    嵌入式Linux開發(fā)——I2C總線接口

    嵌入式Linux開發(fā)——I2C總線接口
    發(fā)表于 11-02 11:06 ?15次下載
    <b class='flag-5'>嵌入式</b>Linux<b class='flag-5'>開發(fā)</b>——<b class='flag-5'>I2C</b>總線接口

    嵌入式工程師培訓技能 嵌入式開發(fā)學什么?

      想知道嵌入式軟件開發(fā)編程學的是什么?我們得先知道什么是嵌入式開發(fā),今天就來整理整理嵌入式工程師培訓技能?! ∫话銇碚f它負責上層應用軟件,主要要用:  (1)CPU:51/MSP43
    發(fā)表于 11-02 20:51 ?13次下載
    <b class='flag-5'>嵌入式</b>工程師培訓技能  <b class='flag-5'>嵌入式開發(fā)</b>學什么?

    嵌入式開發(fā)I2C協(xié)議

    I2C協(xié)議中最重要的一點是I2C地址。這個地址有7位和10位兩種形式。7位能夠表示127個地址,而在實際使用基本上不會掛載如此多的設(shè)置,所以很多設(shè)備的地址都采用7位,所以本文接下來的
    的頭像 發(fā)表于 03-11 10:18 ?1417次閱讀

    嵌入式開發(fā)為什么選擇C語言?它有哪些特點?

    眾所周知,C語言在嵌入式開發(fā)占據(jù)著十分重要的地位,為什么嵌入式開發(fā)要選擇C語言?嵌入式開發(fā)的方
    的頭像 發(fā)表于 01-04 09:56 ?1180次閱讀
    <b class='flag-5'>嵌入式開發(fā)</b><b class='flag-5'>中</b>為什么選擇<b class='flag-5'>C</b>語言?它有哪些特點?

    c語言嵌入式開發(fā)

    電子發(fā)燒友網(wǎng)站提供《c語言嵌入式開發(fā).zip》資料免費下載
    發(fā)表于 11-17 14:11 ?2次下載
    <b class='flag-5'>c</b>語言<b class='flag-5'>嵌入式開發(fā)</b>

    物聯(lián)網(wǎng)嵌入式軟件I2C總線設(shè)計詳解

    I2C(Inter-Integrated Circuit)通信總線,作為嵌入式系統(tǒng)設(shè)計的一個關(guān)鍵組成部分,其靈活性和高效率使其在高級應用備受青睞。本文旨在提供關(guān)于
    的頭像 發(fā)表于 09-29 16:21 ?230次閱讀
    物聯(lián)網(wǎng)<b class='flag-5'>嵌入式</b>軟件<b class='flag-5'>中</b>的<b class='flag-5'>I2C</b>總線設(shè)計<b class='flag-5'>詳解</b>