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

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

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

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

I2C總線信號(hào)與測(cè)試案例(一)

冬至子 ? 來(lái)源:羊駝犀牛的測(cè)試隨筆 ? 作者:羊駝犀牛 ? 2023-11-20 15:45 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1、I2C 總線介紹

I2C bus是Inter-IC bus的縮寫(xiě),意思是IC器件之間的通訊總線;I2C 總線的特點(diǎn)如下:

  • 只需要兩個(gè)線路,serial data line(SDA)和serial clock line(SCL)
  • I2C總線可以支持一主多從或者多主多從的架構(gòu);
  • I2C總線上的從器件是通過(guò)地址來(lái)唯一確定的;
  • I2C總線是串行,8-bit,雙向傳輸?shù)?,支持standard-mode(100Kbits/s)、fast-mode(400kbit/s)、fast-mode plus(1Mbit/s)、high-speed mode(3.4Mbit/s)
  • I2C總線上可以掛載的器件數(shù)量只受最大總線電容影響;

2、I2C總線的電氣設(shè)計(jì)

圖片

上圖展示了I2C的電氣連接架構(gòu)

  • 所有I2C器件通過(guò)SDA和SCL連接到總線上
  • I2C總線不同電平總線要分別接電阻上拉至當(dāng)前電平值
  • 不同總線電平的I2C器件通過(guò)雙向電平轉(zhuǎn)換器(Switches)作為電平轉(zhuǎn)換

2.1 電平轉(zhuǎn)換的基本邏輯和原理

圖片

如上圖所示,主要有3種狀態(tài):

  • 雙邊器件均不下拉總線(輸入輸出為高)。3V3部分線路上拉,這樣的話MOS的G和S極都是3V3,Vgs小于導(dǎo)通電壓,MOS不導(dǎo)通;如此一來(lái),雙邊器件均保持其對(duì)應(yīng)電平值的高電平。
  • 3V3器件下拉總線到低電平。MOSFET的S極變低,而MOS的G極電平是3V3,Vgs大于閾值MOS導(dǎo)通;5V器件總線電平通過(guò)MOS被拉至低電平,最終實(shí)現(xiàn)低電平的輸出輸入。
  • 5V器件下拉總線至低電平。MOS的D極電壓降低直至比S極電壓低的時(shí)候,MOS內(nèi)置的漏極-基底二極管導(dǎo)通,MOS管的S極也就是3V3總線電平開(kāi)始下降,當(dāng)S極電平下降到Vgs大于閾值電平時(shí),MOS管導(dǎo)通,S極電平和D極電平一致被拉到低電平;從而實(shí)現(xiàn)了高電平器件輸出到低電平器件輸入。

2.2 上拉電阻

  • I2C端口為開(kāi)漏輸出(區(qū)別于常見(jiàn)IO的推挽輸出),即其IO口輸出是通過(guò)控制MOS管打開(kāi)與關(guān)斷來(lái)將漏極上的電平進(jìn)行輸出,所以沒(méi)有高電平輸出能力,必須將總線上拉至總線電平來(lái)實(shí)現(xiàn)高電平輸出。
    圖片
  • 開(kāi)漏輸出低電平的實(shí)現(xiàn)如下圖所示:

圖片

  • 開(kāi)漏輸出高電平的實(shí)現(xiàn)如下圖所示:

圖片

2.2.1 上拉電阻的阻值如何選擇

  • 眾所周知,電阻是能耗器件,所以肯定是盡可能使得電阻上的功率損耗越小越好,即電阻在此條件下是個(gè)最小值
    Rp(min)=(Vcc-Vol(max))/Iol
    Vcc:上拉電平 ,Volmax):總線輸出為低電平的最大電壓值 ,Iol:總線的驅(qū)動(dòng)電流(Vol狀態(tài)下)
  • 上拉電阻Rp還會(huì)受信號(hào)上升時(shí)間約束,一般datasheet上有明確的最大上升時(shí)間要求,若超過(guò)這個(gè)值,有可能信號(hào)還沒(méi)上升至高電平就開(kāi)始下降,導(dǎo)致信號(hào)采樣出錯(cuò);
    Rp(max)=tr/(0.8473 Cb)
    tr:上升時(shí)間,Cb:總線電容(線路、連接和管腳的總電容)
    推導(dǎo)公式如下:
    參考一階電路的電壓隨時(shí)間的變化公式 V(t)=Vcc
    (1-e^(-t/RC))
    上升下降時(shí)間一般波形的30% - 70%,這是因?yàn)檩斎氲碗娖阶畲笾甸T限一般0.3Vcc,輸入高電平門限一般0.7Vcc(不是絕對(duì),參考芯片Datasheet)
    當(dāng)Vih=0.7*Vcc時(shí),Vih=0.7*Vcc=Vcc*(1-e^(-t1/Rp*Cb))
    當(dāng)Vih=0.3*Vcc時(shí),Vih=0.3*Vcc=Vcc*(1-e^(-t2/Rp*Cb))
    上升時(shí)間即為:tr=t2-t1=0.8473Rp8Cb
  • 最終根據(jù)計(jì)算出來(lái)的Rp范圍內(nèi)選擇一個(gè)合適阻值
    注意:
    實(shí)際電路設(shè)計(jì)中,總線上會(huì)掛載不止一個(gè)器件,這就要綜合多個(gè)器件的參數(shù)進(jìn)行計(jì)算,進(jìn)而選擇一個(gè)適合所有器件的值
  • 除了上拉電阻Rp,有時(shí)在器件連接到總線上時(shí)會(huì)串入一個(gè)電阻Rs,這個(gè)電阻主要作用是消除高壓毛刺;Rs跟Rp的關(guān)系如下圖所示,Rs的值可以參考,若實(shí)測(cè)總線上沒(méi)有高壓毛刺,那Rs可以去掉;

圖片

圖片

圖片

3、I2C的數(shù)據(jù)幀結(jié)構(gòu)

圖片

起始位:開(kāi)始狀態(tài)位,1bit,SCL為高時(shí)SDA由高至低的過(guò)程稱作起始位;還有一種重復(fù)起始條件,指的是主機(jī)對(duì)于同一個(gè)從器件進(jìn)行同一操作的時(shí)候,不需要先發(fā)送停止條件結(jié)束總線,再開(kāi)始;

地址位:7bit,是當(dāng)前總線需要訪問(wèn)的器件地址;特殊的情況是10bit,一般不用。7bit地址里一般前四位是由器件類型定死,我們自己可以配置的是低三位,也就意味著,同類型的器件在同一根總線上最多可以掛載8個(gè);

讀寫(xiě)操作位:1bit,0代表寫(xiě),1代表讀;

應(yīng)答位:1bit,低電平,每8bit之后跟一位應(yīng)答位,表示接收端接收成功;還有一種非應(yīng)答位(NCK)高電平,表示終止傳輸。

數(shù)據(jù)位:8bit,一個(gè)字節(jié)后面必須跟著一個(gè)應(yīng)答位;一般數(shù)據(jù)的第一個(gè)字節(jié)傳輸?shù)氖且僮鞯?a href="http://www.www27dydycom.cn/tags/寄存器/" target="_blank">寄存器地址,后面字節(jié)是要寫(xiě)入或者讀出的數(shù)據(jù)。

停止位:當(dāng)SCL為高電平時(shí),SDA總線由低電平向高電平切換表示停止條件

  • 起始和停止條件一般由主機(jī)產(chǎn)生??偩€在起始條件之后被認(rèn)為是忙碌的狀態(tài);在停止條件的某段時(shí)間之后,總線被認(rèn)為再次處于空閑狀態(tài)。重復(fù)起始條件跟起始條件一樣,后續(xù)總線會(huì)處于忙碌狀態(tài);
  • SDA線上數(shù)據(jù)必須在SCL高電平周期保持穩(wěn)定,也就是說(shuō)SDA數(shù)據(jù)高低狀態(tài)變化只能發(fā)生在SCL低電平的時(shí)候;

4、I2C的時(shí)鐘同步與仲裁

  • 同步:所有主機(jī)在SCL上產(chǎn)生他們自己的時(shí)鐘來(lái)傳輸I2C總線上的報(bào)文。數(shù)據(jù)只有在SCL高電平周期有效,因此需要一個(gè)確定的時(shí)鐘進(jìn)行逐位仲裁。
  • 如下圖所示,多個(gè)主機(jī)在同一個(gè)總線上產(chǎn)生自己的時(shí)鐘信號(hào);SCL線被有最長(zhǎng)低電平周期的器件保持低電平,此時(shí)低電平周期短的器件會(huì)進(jìn)入高電平的等待狀態(tài);所以,低電平周期由低電平時(shí)鐘周期最長(zhǎng)的器件決定,高電平周期由高電平周期最短的器件決定。

圖片

  • 仲裁:

主機(jī)只能在總線空閑的時(shí)候啟動(dòng)傳輸。兩個(gè)或多個(gè)主機(jī)在起始條件的最小持續(xù)時(shí)間內(nèi)產(chǎn)生一個(gè)起始條件;

當(dāng)SCL為高電平時(shí),仲裁在SDA線上發(fā)生;在其他主機(jī)發(fā)送低電平時(shí),發(fā)送高電平的主機(jī)將斷開(kāi)他的輸出,因?yàn)榭偩€上電平與自己電平不一致。

圖片

5、I2C與CBUS的兼容

C-BUS接收器可以連接到標(biāo)準(zhǔn)的I2C總線。但是必須連接第三條叫DLEN的線,而且要省略響應(yīng)位。通常I2C的傳輸是8位的字節(jié)傳輸,兼容C-BUS的器件有不同的格式。在混合總線中,想要訪問(wèn)操作C-BUS器件,需要發(fā)送特定的C-BUS地址(0x0000001x);發(fā)送C-BUS地址后,DLEN線被激活,發(fā)送C-BUS格式的報(bào)文,如下圖所示:

圖片

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

    關(guān)注

    148

    文章

    10093

    瀏覽量

    171395
  • MOSFET
    +關(guān)注

    關(guān)注

    150

    文章

    8541

    瀏覽量

    220100
  • 上拉電阻
    +關(guān)注

    關(guān)注

    5

    文章

    366

    瀏覽量

    31146
  • 電平轉(zhuǎn)換器
    +關(guān)注

    關(guān)注

    1

    文章

    220

    瀏覽量

    20121
  • I2C總線
    +關(guān)注

    關(guān)注

    8

    文章

    408

    瀏覽量

    62126
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    文讀懂i2c總線信號(hào)傳輸

    總線空閑狀態(tài)   I2C總線總線的SDA和SCL兩條信號(hào)線同時(shí)處于高電平時(shí),規(guī)定為總線的空閑狀態(tài)
    的頭像 發(fā)表于 11-21 15:09 ?2.5w次閱讀
    <b class='flag-5'>一</b>文讀懂<b class='flag-5'>i2c</b>的<b class='flag-5'>總線</b><b class='flag-5'>信號(hào)</b>傳輸

    I2C總線原理詳解

    I2C兩線式串行總線通訊協(xié)議,它是由飛利浦開(kāi)發(fā)的,主要用于連接微控制器及其外圍設(shè)備之間,它是由數(shù)據(jù)線SDA和信號(hào)線SCL構(gòu)成的,可發(fā)送和接收數(shù)據(jù)即在MUC和I2C設(shè)備之間,
    發(fā)表于 10-18 17:20 ?3122次閱讀
    <b class='flag-5'>I2C</b><b class='flag-5'>總線</b>原理詳解

    I2C總線信號(hào)測(cè)試案例(二)

    前面章講解了I2C總線的基本原理,那么在電路設(shè)計(jì)完成打板回來(lái),肯定要做信號(hào)測(cè)試來(lái)驗(yàn)證設(shè)計(jì)
    的頭像 發(fā)表于 11-20 15:49 ?6198次閱讀
    <b class='flag-5'>I2C</b><b class='flag-5'>總線</b><b class='flag-5'>信號(hào)</b>與<b class='flag-5'>測(cè)試</b>案例(二)

    i2c總線ppt(I2C總線器件應(yīng)用)

    I2C總線器件應(yīng)用第節(jié) I2C總線器件應(yīng)用概述I2C總線
    發(fā)表于 08-13 17:34 ?0次下載

    i2c總線的特點(diǎn)

    i2c總線的特點(diǎn):2 I2C 總線使設(shè)計(jì)人員和廠商都得益.. 3 2.1 設(shè)計(jì)人員的得益.. 4 2.2 廠商的得益. 5
    發(fā)表于 08-05 09:05 ?26次下載

    什么是i2c總線

    什么是i2c總線  下載請(qǐng)點(diǎn)擊: i2c總線協(xié)議中文版 
    發(fā)表于 11-05 09:26 ?3060次閱讀

    并口模擬I2C總線的設(shè)計(jì)

    并口模擬I2C總線的設(shè)計(jì) 試驗(yàn)?zāi)康模赫J(rèn)識(shí)計(jì)算機(jī)并口和I2C總線,用計(jì)算
    發(fā)表于 09-11 10:31 ?4376次閱讀
    并口模擬<b class='flag-5'>I2C</b><b class='flag-5'>總線</b>的設(shè)計(jì)

    I2C總線的工作原理與應(yīng)用

    I2C總線的工作原理與應(yīng)用     I2C(Inter-Integrated Circuit)總線
    發(fā)表于 03-02 01:20 ?5112次閱讀
    <b class='flag-5'>I2C</b><b class='flag-5'>總線</b>的工作原理與應(yīng)用

    I2C總線詳解

    I2C總線定義  I2C(Inter-Integrated Circuit)總線種由PHILIPS公司開(kāi)發(fā)的兩線式串行
    發(fā)表于 06-30 11:09 ?4012次閱讀

    基于CPLD的I2C總線接口設(shè)計(jì)

    在電路設(shè)計(jì)中,I2C總線是比較常用的兩線式串行通信方式,大多數(shù)的CPU都擅長(zhǎng)于并口操作,不具備直接操作I2C總線接口的能力。為了使不具備I2C
    發(fā)表于 02-12 16:11 ?95次下載
    基于CPLD的<b class='flag-5'>I2C</b><b class='flag-5'>總線</b>接口設(shè)計(jì)

    基于51的I2c總線

    I2c總線,基于51的I2c總線,程序?qū)W習(xí)??靵?lái)下載學(xué)習(xí)吧
    發(fā)表于 01-13 11:49 ?34次下載

    i2c

    單片機(jī)i2c總線操作;單片機(jī)i2c總線操作;單片機(jī)i2c總線操作;
    發(fā)表于 05-17 11:09 ?35次下載

    I2C總線的基本通信總結(jié)

    在電子設(shè)計(jì)開(kāi)發(fā)中I2C大家已經(jīng)很熟悉了,每種電子產(chǎn)品小到電子開(kāi)關(guān),大到衛(wèi)星通信都會(huì)利用的I2C總線。據(jù)統(tǒng)計(jì)I2C在電子產(chǎn)品中占據(jù)了93%的
    的頭像 發(fā)表于 08-26 14:08 ?1.9w次閱讀
    <b class='flag-5'>I2C</b><b class='flag-5'>總線</b>的基本通信總結(jié)

    I2C串行總線協(xié)議是什么?I2C總線有哪些優(yōu)點(diǎn)?

    I2C串行總線協(xié)議是什么?I2C總線有哪些優(yōu)點(diǎn)? I2C(Inter-Integrated Circuit)是
    的頭像 發(fā)表于 09-12 11:18 ?2353次閱讀

    I2C總線通信原理 如何設(shè)計(jì)I2C總線電路

    I2C總線通信原理 I2C(Inter-Integrated Circuit)總線種用于集成電路之間進(jìn)行通信的串行通信協(xié)議。它最早由飛利
    的頭像 發(fā)表于 01-31 15:01 ?1107次閱讀