色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

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

簡談 IIC總線

FPGA學習交流 ? 2018-08-17 09:52 ? 次閱讀

大家好,又到了每日學習的時間了,今天咱們來聊一聊 IIC 總線設計。



一、概述:
IIC 是Inter-Integrated Circuit的縮寫,發(fā)音為"eye-squared cee" or "eye-two-cee" , 它是一種兩線接口。
IIC 只是用兩條雙向的線,一條 Serial Data Line (SDA) ,另一條Serial Clock (SCL)。
SCL:上升沿將數(shù)據(jù)輸入到每個EEPROM器件中;下降沿驅(qū)動EEPROM器件輸出數(shù)據(jù)。(邊沿觸發(fā))
SDA:雙向數(shù)據(jù)線,為OD門,與其它任意數(shù)量的OD與OC門成"線與"關(guān)系。

二、輸出級

112519piicokk1x5k2kcxs.png


每一個I2C總線器件內(nèi)部的SDA、SCL引腳電路結(jié)構(gòu)都是一樣的,引腳的輸出驅(qū)動與輸入緩沖連在一起。其中輸出為漏極開路的場效應管,輸入緩沖為一只高輸入阻抗的同相器,這種電路具有兩個特點:
1)由于SDA、SCL為漏極開路結(jié)構(gòu)(OD),因此它們必須接有上拉電阻,阻值的大小常為 1k8, 4k7 and 10k ,但1k8 時性能最好;當總線空閑時,兩根線均為高電平。連到總線上的任一器件輸出的低電平,都將使總線的信號變低,即各器件的SDA及SCL都是線"與"關(guān)系。
2)引腳在輸出信號的同時還將引腳上的電平進行檢測,檢測是否與剛才輸出一致,為"時鐘同步"和"總線仲裁"提供了硬件基礎。

三、主設備與從設備

系統(tǒng)中的所有外圍器件都具有一個7位的"從器件專用地址碼",其中高4位為器件類型,由生產(chǎn)廠家制定,低3位為器件引腳定義地址,由使用者定義。主控器件通過地址碼建立多機通信的機制,因此I2C總線省去了外圍器件的片選線,這樣無論總線上掛接多少個器件,其系統(tǒng)仍然為簡約的二線結(jié)構(gòu)。終端掛載在總線上,有主端和從端之分,主端必須是帶有CPU的邏輯模塊,在同一總線上同一時刻使能有一個主端,可以有多個從端,從端的數(shù)量受地址空間和總線的最大電容 400pF的限制。

* 主端主要用來驅(qū)動SCL line;
* 從設備對主設備產(chǎn)生響應;

二者都可以傳輸數(shù)據(jù),但是從設備不能發(fā)起傳輸,且傳輸是受到主設備控制的。
112520lr2xkjcx2o6s92la.png



四、速率:

普通模式:100kHz;
快速模式:400kHz;
高速模式:3.4MHz;
沒有任何必要使用高速SCL,將SCL保持在100k或以下,然后忘了它吧。



時序部分:

1.空閑狀態(tài)

I2C總線總線的SDA和SCL兩條信號線同時處于高電平時,規(guī)定為總線的空閑狀態(tài)。此時各個器件的輸出級場效應管均處在截止狀態(tài),即釋放總線,由兩條信號線各自的上拉電阻把電平拉高。

2.起始位與停止位的定義:

* 起始信號:當SCL為高期間,SDA由高到低的跳變;啟動信號是一種電平跳變時序信號,而不是一個電平信號。
* 停止信號:當SCL為高期間,SDA由低到高的跳變;停止信號也是一種電平跳變時序信號,而不是一個電平信號。

113412kv2dc8e9ee85pgp0.png




3.ACK
發(fā)送器每發(fā)送一個字節(jié),就在時鐘脈沖9期間釋放數(shù)據(jù)線,由接收器反饋一個應答信號。 應答信號為低電平時,規(guī)定為有效應答位(ACK簡稱應答位),表示接收器已經(jīng)成功地接收了該字節(jié);應答信號為高電平時,規(guī)定為非應答位(NACK),一般表示接收器接收該字節(jié)沒有成功。 對于反饋有效應答位ACK的要求是,接收器在第9個時鐘脈沖之前的低電平期間將SDA線拉低,并且確保在該時鐘的高電平期間為穩(wěn)定的低電平。 如果接收器是主控器,則在它收到最后一個字節(jié)后,發(fā)送一個NACK信號,以通知被控發(fā)送器結(jié)束數(shù)據(jù)發(fā)送,并釋放SDA線,以便主控接收器發(fā)送一個停止信號P。
113412jugvzny1gsvsgeui.png


如下圖邏輯分析儀的采樣結(jié)果:釋放總線后,如果沒有應答信號,sda應該一直持續(xù)為高電平,但是如圖中藍色虛線部分所示,它被拉低為低電平,證明收到了應答信號。

這里面給我們的兩個信息是:
1)接收器在SCL的上升沿到來之前的低電平期間拉低SDA;
2)應答信號一直保持到SCL的下降沿結(jié)束;正如前文紅色標識所指出的那樣。
113412g4q241qaatmohxd1.png


4.數(shù)據(jù)的有效性:
IIC總線進行數(shù)據(jù)傳送時,時鐘信號為高電平期間,數(shù)據(jù)線上的數(shù)據(jù)必須保持穩(wěn)定,只有在時鐘線上的信號為低電平期間,數(shù)據(jù)線上的高電平或低電平狀態(tài)才允許變化。

我的理解:雖然只要求在高電平期間保持穩(wěn)定,但是要有一個提前量,也就是數(shù)據(jù)在SCL的上升沿到來之前就需準備好,因為在前面I2C總線之(一)---概述一文中已經(jīng)指出,數(shù)據(jù)是在SCL的上升沿打入到器件(EEPROM)中的。
113413ud9fl666z1gl19l9.png


5.數(shù)據(jù)的傳送:
在I2C總線上傳送的每一位數(shù)據(jù)都有一個時鐘脈沖相對應(或同步控制),即在SCL串行時鐘的配合下,在SDA上逐位地串行傳送每一位數(shù)據(jù)。數(shù)據(jù)位的傳輸是邊沿觸發(fā)。



工作過程

總線上的所有通信都是由主控器引發(fā)的。在一次通信中,主控器與被控器總是在扮演著兩種不同的角色。

1.主設備向從設備發(fā)送數(shù)據(jù)

主設備發(fā)送起始位,這會通知總線上的所有設備傳輸開始了,接下來主機發(fā)送設備地址,與這一地址匹配的slave將繼續(xù)這一傳輸過程,而其它slave將會忽略接下來的傳輸并等待下一次傳輸?shù)拈_始。主設備尋址到從設備后,發(fā)送它所要讀取或?qū)懭氲膹脑O備的內(nèi)部寄存器地址; 之后,發(fā)送數(shù)據(jù)。數(shù)據(jù)發(fā)送完畢后,發(fā)送停止位:

寫入過程如下:

發(fā)送起始位
* 發(fā)送從設備的地址和讀/寫選擇位;釋放總線,等到EEPROM拉低總線進行應答;如果EEPROM接收成功,則進行應答;若沒有握手成功或者發(fā)送的數(shù)據(jù)錯誤時EEPROM不產(chǎn)生應答,此時要求重發(fā)或者終止。
* 發(fā)送想要寫入的內(nèi)部寄存器地址;EEPROM對其發(fā)出應答;
* 發(fā)送數(shù)據(jù)
* 發(fā)送停止位.
* EEPROM收到停止信號后,進入到一個內(nèi)部的寫入周期,大概需要10ms,此間任何操作都不會被EEPROM響應;(因此以這種方式的兩次寫入之間要插入一個延時,否則會導致失敗)
113413fw4338hlcao874hd.png


詳細:
113413n9q4f3qfwgz2d5qd.png




需要說明的是:①主控器通過發(fā)送地址碼與對應的被控器建立了通信關(guān)系,而掛接在總線上的其它被控器雖然同時也收到了地址碼,但因為與其自身的地址不相符合,因此提前退出與主控器的通信;

2.主控器讀取數(shù)據(jù)的過程:
讀的過程比較復雜,在從slave讀出數(shù)據(jù)前,你必須先要告訴它哪個內(nèi)部寄存器是你想要讀取的,因此必須先對其進行寫入(dummy write):

發(fā)送起始位;
* 發(fā)送slave地址+write bit set;
* 發(fā)送內(nèi)部寄存器地址;
* 重新發(fā)送起始位,即restart;
* 重新發(fā)送slave地址+read bit set;
* 讀取數(shù)據(jù)
* 主機接收器在接收到最后一個字節(jié)后,也不會發(fā)出ACK信號。于是,從機發(fā)送器釋放SDA線,以允許主機發(fā)出P信號結(jié)束傳輸。
* 發(fā)送停止位
113414vha4orleob3i4art.png




詳細:



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

    關(guān)注

    1630

    文章

    21796

    瀏覽量

    605301
收藏 人收藏

    評論

    相關(guān)推薦

    IIC信號線需要增加上拉電阻,是因為IIC的IO是什么

    IIC(Inter-Integrated Circuit,即集成電路總線)信號線需要增加上拉電阻,這主要是因為IIC的IO(輸入輸出)設計采用了開漏(Open-Drain)輸出方式。開漏輸出方式在
    的頭像 發(fā)表于 10-06 15:50 ?999次閱讀

    IIC通訊協(xié)議解析

    概述 IIC(Inter-Integrated Circuit)其實是IICBus簡稱,所以中文應該叫集成電路總線,它是一種串行通信總線,使用多主從架構(gòu),由飛利浦公司在1980年代為了讓主板、嵌入式
    發(fā)表于 09-12 16:09

    【龍芯2K0300蜂鳥板試用】+IIC設備讀取陀螺儀數(shù)據(jù)

    總線在數(shù)據(jù)傳輸?shù)臅r候要保證在 SCL 高電平期間,SDA 上的數(shù)據(jù)穩(wěn)定,因此 SDA 上 的數(shù)據(jù)變化只能在 SCL 低電平期間發(fā)生。 IIC寫時序:首先是給一個起始信號,發(fā)送IIC設備地址,讀寫位,從
    發(fā)表于 08-17 21:02

    iic通訊的ardunio的文件下載

    里面很多iic通訊的ardunio的文件
    發(fā)表于 07-05 10:55 ?1次下載

    IIC總線一直忙是怎么回事?

    我用IIC寫東西,僅僅是寫,讀都不要,初始化的時候直接寫,卻一開始就總線忙(風馳里面的IIC代碼),具體如下: <1>main /*************/(大概就是這
    發(fā)表于 05-11 07:13

    Xilinx Zynq-7000嵌入式系統(tǒng)設計與實現(xiàn)

    今天給大俠帶來Xilinx Zynq-7000嵌入式系統(tǒng)設計與實現(xiàn),話不多說,上貨。 Xilinx的ZYNQ系列FPGA是二種看上去對立面的思想的融合,ARM處理器的串行執(zhí)行+FPGA
    發(fā)表于 05-08 16:23

    STM32F767IGTB使用IIC的過程中遇到讀超時及總線忙的問題怎么解決?

    這兩天測試過程中發(fā)現(xiàn)讀取eeprom偶爾會報錯,定位過程發(fā)現(xiàn)IIC總線上經(jīng)常會有時鐘總線為低的情況,開始不解,經(jīng)查閱資料發(fā)現(xiàn)這是正常現(xiàn)象,從MCU手冊上得知,當移位寄存器里8位數(shù)據(jù)接收完成后,如果
    發(fā)表于 04-19 07:28

    Xilinx Zynq-7000嵌入式系統(tǒng)設計與實現(xiàn)

    今天給大俠帶來Xilinx Zynq-7000嵌入式系統(tǒng)設計與實現(xiàn),話不多說,上貨。 Xilinx的ZYNQ系列FPGA是二種看上去對立面的思想的融合,ARM處理器的串行執(zhí)行+FPGA
    發(fā)表于 04-10 16:00

    儀同步水聲及振動采集系統(tǒng)解決方案

    儀提供的解決方案是為客戶開發(fā)一個基于PXIe總線的同步高速采集分析系統(tǒng)。這個系統(tǒng)采用了高速流盤技術(shù)和聲音與振動分析算法,可以準確實時獲取水下水聲與振動信號特征。
    的頭像 發(fā)表于 04-10 14:24 ?807次閱讀
    <b class='flag-5'>簡</b>儀同步水聲及振動采集系統(tǒng)解決方案

    單片機一個IIC連接兩個MPU9250如何設置讀取磁力計的模式?

    直接讀取磁力計的數(shù)據(jù)嘛,兩塊磁力計的IIC地址都一樣,在一個iic總線上不會產(chǎn)生沖突嘛?非常困惑,請各位前輩能幫助指點一下,感激不盡{:23:}
    發(fā)表于 04-10 07:14

    RS485總線出現(xiàn)不確定的狀態(tài)

    RS-485總線上的驅(qū)動器必須能夠提供足夠的電流來驅(qū)動連接的所有設備。如果總線上的設備數(shù)量過多或驅(qū)動器電流能力不足,可能導致信號衰減和通信錯誤。
    的頭像 發(fā)表于 03-06 17:28 ?1057次閱讀
    <b class='flag-5'>談</b>RS485<b class='flag-5'>總線</b>出現(xiàn)不確定的狀態(tài)

    FPGA實現(xiàn)IIC協(xié)議的設計

    今天給大家?guī)淼氖?b class='flag-5'>IIC通信,IIC協(xié)議應用非常廣泛,例如與MPU6050進行通信,配置OV5640攝像頭、驅(qū)動OLED屏幕等等,都需要使用到IIC協(xié)議,所以掌握它是非常必要的,廢話不多說,接著往下看。
    的頭像 發(fā)表于 03-04 10:49 ?1336次閱讀
    FPGA實現(xiàn)<b class='flag-5'>IIC</b>協(xié)議的設計

    GD32 MCU碰到IIC總線卡死怎么辦?

    大家在使用MCU IIC通信時,若碰到設備復位或者總線干擾等情況,可能會導致IIC總線卡死,表現(xiàn)上總線上SDA或者SCL其中一根線為低電平,
    的頭像 發(fā)表于 02-24 09:46 ?3986次閱讀
    GD32 MCU碰到<b class='flag-5'>IIC</b><b class='flag-5'>總線</b>卡死怎么辦?

    CY8CMBR3102可以通過IIC總線讀取proximity值嗎?

    想問下CY8CMBR3102可以通過IIC總線讀取proximity值嗎?如果可以的話,一個IIC總線上掛多個CY8CMBR3102,如何區(qū)分它們的設備地址(slave address
    發(fā)表于 02-21 07:12

    IIC總線為什么是半雙工?

    IIC(Inter-Integrated Circuit)總線是一種半雙工的串行通信接口。在I2C總線上,主設備和從設備之間的數(shù)據(jù)傳輸是采用半雙工模式進行的。這意味著主設備和從設備在不同的時間段內(nèi)交替發(fā)送和接收數(shù)據(jù)。
    的頭像 發(fā)表于 02-02 16:37 ?4768次閱讀
    <b class='flag-5'>IIC</b><b class='flag-5'>總線</b>為什么是半雙工?
    主站蜘蛛池模板: 无罩看奶禁18 | 成人天堂资源WWW在线 | 打扑克床上视频不用下载免费观看 | 免费国产久久啪在线 | 在线观看精品视频看看播放 | 俄罗斯9一14 young处 | 伊人影院综合网 | 亚欧免费观看在线观看更新 | 99久久免费国产精精品 | 好吊妞国产欧美日韩视频 | 芒果影院网站在线观看 | 亚洲国产成人精品久久久久 | 亚洲 欧美 国产 视频二区 | 国产精品无码久久av | 亚洲欧美中文日韩v在线 | 香港成人社区 | 年轻的朋友4在线看中文字幕 | 性夜影院午夜看片 | 狠狠国产欧美在线视频 | 男女亲吻摸下面吃奶视频 | 天天拍拍国产在线视频 | 精品性影院一区二区三区内射 | 小SB几天没做SAO死了H | 国产精品视频yy9099 | 蜜臀AV99无码精品国产专区 | 亚洲精品www久久久久久久软件 | 把内衣脱了把奶露出来 | 中文字幕精品视频在线 | 青青草原在线免费 | 无码专区aaaaaa免费视频 | 被黑人掹躁10次高潮 | YELLOW在线观看高清视频免费 | 伊人久久影院大香线蕉 | 国产在线精品亚洲观看不卡欧美 | 尤蜜网站在线进入免费 | 性欧美videosex18嫩 | 日韩免费一区二区三区在线 | 日日摸夜夜嗷嗷叫日日拍 | 大胸美女被c | 岳打开双腿开始配合日韩视频 | 国产精品成人啪精品视频免费观看 |