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

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

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

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

GReq_mcu168 ? 來源:cc ? 2019-01-09 15:28 ? 次閱讀

對于嵌入式開發(fā)的朋友來說,I2C協(xié)議實在是再熟悉不過了,有太多的器件,采用的都是通過I2C來進(jìn)行相應(yīng)的設(shè)置。今天,我們就隨便聊聊這個I2C協(xié)議。I2C協(xié)議中最重要的一點(diǎn)是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ù)傳輸時序圖:

SCL是時鐘,SDA承載的是數(shù)據(jù)。當(dāng)SDA從1變動到0,而SCL還是1時,表示開始數(shù)據(jù)傳輸。接下來的7位,就是設(shè)備的地址。緊接著的是讀寫標(biāo)志,其為1時是讀取,為0則是寫。如果I2C總線上存在著和請求的地址相對應(yīng)的設(shè)備,則從設(shè)備會發(fā)送一個ACK信號通知主設(shè)備,可以發(fā)送數(shù)據(jù)了。接到ACK信號后,主設(shè)備則發(fā)送一個8位的數(shù)據(jù)。當(dāng)傳輸完畢之后,SCL保持為1,SDA從0變換到1時,標(biāo)明傳輸結(jié)束。從這個時序圖中可以看到,SCL很重要,并且哪個時鐘沿是干嘛的,都是確定好的。比如,前面7個必定是地址,第8個是讀寫標(biāo)志,數(shù)據(jù)傳輸必須是8位,必須接個ACK信號等等。前面的時序圖并沒有標(biāo)明數(shù)據(jù)傳輸?shù)姆较?,我們現(xiàn)在看看寫操作的數(shù)據(jù)流向:

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

這時候,從設(shè)備除了發(fā)送ACK以外,緊跟著的還有數(shù)據(jù)。我們用示波器來查看波形圖,以便于理解。將示波器的X和Y分別接到SDA和SCL,得到波形并分析如圖:

從圖中可知時序如下:

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

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

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

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

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

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

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

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

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

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

    關(guān)注

    5052

    文章

    18915

    瀏覽量

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

    關(guān)注

    28

    文章

    1468

    瀏覽量

    122791

原文標(biāo)題:嵌入式開發(fā)中i2c協(xié)議是怎么玩的?

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

收藏 人收藏

    評論

    相關(guān)推薦

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

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

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

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

    嵌入式常用總線有哪些

    嵌入式系統(tǒng)中常用的總線種類繁多,它們各自具有不同的特點(diǎn)和應(yīng)用場景。以下將詳細(xì)介紹幾種嵌入式開發(fā)中常用的總線,包括UART、I2C、SPI、RS-232、RS-485、CAN以及USB等,每種總線將從其定義、特點(diǎn)、工作原理、應(yīng)用場
    的頭像 發(fā)表于 09-10 11:34 ?347次閱讀

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

    I2C(Inter-Integrated Circuit)通信協(xié)議是由飛利浦公司(現(xiàn)為恩智浦半導(dǎo)體)開發(fā)的一種簡單、雙向二線制同步串行總線協(xié)議。自1982年發(fā)布以來,
    的頭像 發(fā)表于 07-25 18:06 ?1087次閱讀

    嵌入式開發(fā)前景怎么樣?

    嵌入式開發(fā)前景非常廣闊,這主要得益于物聯(lián)網(wǎng)、人工智能、大數(shù)據(jù)等技術(shù)的快速發(fā)展,以及嵌入式系統(tǒng)在各個領(lǐng)域的廣泛應(yīng)用。以下是對嵌入式開發(fā)前景的詳細(xì)分析
    的頭像 發(fā)表于 07-10 09:00 ?2075次閱讀
    <b class='flag-5'>嵌入式開發(fā)</b>前景怎么樣?

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

    等特點(diǎn),在嵌入式系統(tǒng)設(shè)計得到了廣泛應(yīng)用。本文將詳細(xì)介紹I2C總線協(xié)議的工作原理和尋址格式,幫助讀者深入理解該協(xié)議。
    的頭像 發(fā)表于 05-27 15:47 ?1395次閱讀

    SPI和I2C通信協(xié)議:應(yīng)用與區(qū)別

    /DAC芯片等場合。SPI和I2C在連接方式、傳輸速率和設(shè)備支持等方面有顯著差異,但隨著物聯(lián)網(wǎng)和智能設(shè)備的發(fā)展,它們都將在嵌入式系統(tǒng)中發(fā)揮重要作用。
    的頭像 發(fā)表于 04-22 16:45 ?1329次閱讀

    嵌入式開發(fā)常見的C語言技巧與方法分享

    嵌入式開發(fā),常常要操作寄存器,對寄存器進(jìn)行寫入,讀出等等操作。每個寄存器都有自己固有的地址,通過C語言訪問這些地址就變得尤為重要。
    的頭像 發(fā)表于 12-26 09:55 ?988次閱讀

    一文了解嵌入式開發(fā)I2C協(xié)議

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

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

    I2C協(xié)議中最重要的一點(diǎn)是I2C地址。這個地址有7位和10位兩種形式。
    的頭像 發(fā)表于 12-05 09:16 ?1099次閱讀
    <b class='flag-5'>嵌入式開發(fā)</b><b class='flag-5'>中</b><b class='flag-5'>I2C</b><b class='flag-5'>協(xié)議</b>詳解

    嵌入式C語言的結(jié)構(gòu)特點(diǎn)

    嵌入式開發(fā)既有底層硬件的開發(fā)又涉及上層應(yīng)用的開發(fā),即涉及系統(tǒng)的硬件和軟件,C語言既具有匯編語言操作底層的優(yōu)勢,又具有高級語言功能性強(qiáng)的特點(diǎn)
    的頭像 發(fā)表于 11-24 16:16 ?590次閱讀
    <b class='flag-5'>嵌入式</b><b class='flag-5'>C</b>語言的結(jié)構(gòu)特點(diǎn)

    一文徹底搞懂I2C總線

    I2C通信協(xié)議嵌入式IC應(yīng)用的特別廣泛,所以今天給大家詳細(xì)的講解一下,有解釋的不正確或不合理的地方歡迎大家提出意見。
    的頭像 發(fā)表于 11-24 10:24 ?4200次閱讀
    一文徹底搞懂<b class='flag-5'>I2C</b>總線

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

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

    嵌入式開發(fā)學(xué)習(xí)路線

    電子發(fā)燒友網(wǎng)站提供《嵌入式開發(fā)學(xué)習(xí)路線.doc》資料免費(fèi)下載
    發(fā)表于 11-17 10:13 ?13次下載
    <b class='flag-5'>嵌入式開發(fā)</b>學(xué)習(xí)路線

    嵌入式開發(fā)入門學(xué)習(xí)

    電子發(fā)燒友網(wǎng)站提供《嵌入式開發(fā)入門學(xué)習(xí).doc》資料免費(fèi)下載
    發(fā)表于 10-26 09:37 ?1次下載
    <b class='flag-5'>嵌入式開發(fā)</b>入門學(xué)習(xí)