一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

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

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

對(duì)于嵌入式開發(fā)的朋友來說,I2C協(xié)議實(shí)在是再熟悉不過了,有太多的器件,采用的都是通過I2C來進(jìn)行相應(yīng)的設(shè)置。今天,我們就隨便聊聊這個(gè)I2C協(xié)議。I2C協(xié)議中最重要的一點(diǎn)是I2C地址。這個(gè)地址有7位和10位兩種形式。7位能夠表示127個(gè)地址,而在實(shí)際使用中基本上不會(huì)掛載如此多的設(shè)置,所以很多設(shè)備的地址都采用7位,所以本文接下來的說明都是基于此。I2C還有一個(gè)很重要的概念,就是“主—從”。對(duì)于從設(shè)備來說,它是啥都不干的,更不會(huì)自動(dòng)發(fā)送數(shù)據(jù);而主設(shè)備,則是起到控制作用,一切都是從它開始。除了GND以外,I2C有兩根線,分別是SDA和SCL,所有的設(shè)備都是接到這兩根線上。那么,這些設(shè)備如何知道數(shù)據(jù)是發(fā)送給它們呢?這就得依靠前面所說到的地址了。設(shè)備I2C的地址是固定的,比如0x50,0x60等等。因?yàn)橹荒苡?27個(gè)地址,地址沖突是很常見的,所以一般設(shè)備都會(huì)有一個(gè)地址選擇PIN,比如拉高時(shí)候?yàn)?x50,接地為0x60。如果無論拉高還是接地,都和別的芯片有沖突,那該怎么辦呢?答案是:涼拌,沒辦法。遇到這種情況,只能換芯片了。我們來看I2C協(xié)議中的數(shù)據(jù)傳輸時(shí)序圖:

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

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

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

從圖中可知時(shí)序如下:

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

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

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

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

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

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

I2C是由2根線進(jìn)行操作的,一個(gè)是主控時(shí)序SCL,另一根主控?cái)?shù)據(jù)SDA

對(duì)于操作主要分成讀寫,讀寫的兩個(gè)操作有部分是相似的

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

聲明:本文內(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)投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5125

    文章

    19438

    瀏覽量

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

    關(guān)注

    28

    文章

    1514

    瀏覽量

    126519

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

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

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    嵌入式學(xué)習(xí)-飛凌嵌入式ElfBoard ELF 1板卡-I2C設(shè)備驅(qū)動(dòng)之Linux下的I2C驅(qū)動(dòng)簡(jiǎn)介

    的通信協(xié)議,其中一個(gè)設(shè)備作為主設(shè)備控制總線,并與多個(gè)從設(shè)備通信。在Linux內(nèi)核,I2C驅(qū)動(dòng)主要由三部分組成:I2C核心、I2C總線驅(qū)動(dòng)和
    發(fā)表于 04-15 10:39

    嵌入式開發(fā):高門檻的系統(tǒng)性工程與 996 的行業(yè)困局

    嵌入式開發(fā)的門檻,往往被培訓(xùn)機(jī)構(gòu)和表象所掩蓋。許多人誤以為 “用 C 語言寫個(gè)跑在 ARM 上的程序” 就是嵌入式,實(shí)則連皮毛都未觸及。真正的嵌入式開發(fā)是硬件與軟件深度融合的系統(tǒng)性工程
    的頭像 發(fā)表于 04-09 11:06 ?172次閱讀
    <b class='flag-5'>嵌入式開發(fā)</b>:高門檻的系統(tǒng)性工程與 996 的行業(yè)困局

    如何成為嵌入式開發(fā)工程師?

    和使用方法。- 掌握接口標(biāo)準(zhǔn)和總線協(xié)議,如UART、SPI、I2C、CAN等。 3. 編程能力:- 精通至少一種編程語言,尤其是C/C++,因?yàn)樗鼈兪?/div>
    發(fā)表于 02-19 10:39

    iic協(xié)議嵌入式系統(tǒng)的功能

    在現(xiàn)代電子設(shè)備,嵌入式系統(tǒng)的設(shè)計(jì)越來越復(fù)雜,需要集成更多的功能和外設(shè)。I2C協(xié)議因其簡(jiǎn)單性、靈活性和高效性,在嵌入式系統(tǒng)
    的頭像 發(fā)表于 02-05 11:40 ?435次閱讀

    I2C總線在嵌入式系統(tǒng)的應(yīng)用

    在現(xiàn)代電子設(shè)計(jì)嵌入式系統(tǒng)扮演著越來越重要的角色。這些系統(tǒng)通常需要與多種外圍設(shè)備進(jìn)行通信,以實(shí)現(xiàn)數(shù)據(jù)的輸入和輸出。I2C總線作為一種多主機(jī)、多從機(jī)的串行通信協(xié)議,因其簡(jiǎn)單、靈活和高效
    的頭像 發(fā)表于 01-17 15:30 ?491次閱讀

    I2C總線協(xié)議詳細(xì)解析

    總線以其簡(jiǎn)單性、靈活性和低功耗而聞名,廣泛應(yīng)用于嵌入式系統(tǒng)2. I2C總線的基本組成 I2C總線由兩條線組成:數(shù)據(jù)線(SDA)和時(shí)鐘線
    的頭像 發(fā)表于 01-17 15:22 ?598次閱讀

    如何使用 RISC-V 進(jìn)行嵌入式開發(fā)

    、準(zhǔn)備開發(fā)環(huán)境 選擇開發(fā)板 :RISC-V架構(gòu)的嵌入式開發(fā)板有多種選擇,如GD32VF103R-START、飛凌嵌入式OK113i-S等。選
    的頭像 發(fā)表于 12-11 17:32 ?1459次閱讀

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

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

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

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

    嵌入式開發(fā)常見問題排查

    嵌入式開發(fā)問題排查很多人認(rèn)為嵌入式開發(fā)很難,主要是因?yàn)樵谶@個(gè)過程中常常會(huì)遇到各式各樣的問題。這些問題的復(fù)雜性和多樣性使得許多人感到困惑和無所適從。然而,如果將這些問題逐一拆解,實(shí)際上大部分都可以
    的頭像 發(fā)表于 09-22 08:04 ?626次閱讀
    <b class='flag-5'>嵌入式開發(fā)</b>常見問題排查

    嵌入式常用總線有哪些

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

    聚焦嵌入式開發(fā)的合規(guī)性工具、項(xiàng)目管理工具、版本迭代工具應(yīng)用

    ,就嵌入式開發(fā)與管理領(lǐng)域的最新趨勢(shì)、工具選擇以及DevSecOps實(shí)踐應(yīng)用等方面展開了深入探討。 本期對(duì)話龍智資深DevSecOps顧問徐晨暉, 分享嵌入式開發(fā)的合規(guī)性工具、項(xiàng)目管理和版本管理的工具選擇,以及DevSecOps
    的頭像 發(fā)表于 07-29 15:15 ?869次閱讀

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

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

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

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

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

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