一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲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)不再提示

簡(jiǎn)談 IIC總線

FPGA學(xué)習(xí)交流 ? 2018-08-17 09:52 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

大家好,又到了每日學(xué)習(xí)的時(shí)間了,今天咱們來(lái)聊一聊 IIC 總線設(shè)計(jì)。



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

二、輸出級(jí)

112519piicokk1x5k2kcxs.png


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

三、主設(shè)備與從設(shè)備

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

* 主端主要用來(lái)驅(qū)動(dòng)SCL line;
* 從設(shè)備對(duì)主設(shè)備產(chǎn)生響應(yīng);

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



四、速率:

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



時(shí)序部分:

1.空閑狀態(tài)

I2C總線總線的SDA和SCL兩條信號(hào)線同時(shí)處于高電平時(shí),規(guī)定為總線的空閑狀態(tài)。此時(shí)各個(gè)器件的輸出級(jí)場(chǎng)效應(yīng)管均處在截止?fàn)顟B(tài),即釋放總線,由兩條信號(hào)線各自的上拉電阻把電平拉高。

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

* 起始信號(hào):當(dāng)SCL為高期間,SDA由高到低的跳變;啟動(dòng)信號(hào)是一種電平跳變時(shí)序信號(hào),而不是一個(gè)電平信號(hào)。
* 停止信號(hào):當(dāng)SCL為高期間,SDA由低到高的跳變;停止信號(hào)也是一種電平跳變時(shí)序信號(hào),而不是一個(gè)電平信號(hào)。

113412kv2dc8e9ee85pgp0.png




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


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

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


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

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


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



工作過(guò)程

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

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

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

寫入過(guò)程如下:

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


詳細(xì):
113413n9q4f3qfwgz2d5qd.png




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

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

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




詳細(xì):



今天就聊到這里,各位,加油。
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(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)投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1645

    文章

    22050

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    簡(jiǎn)析Modbus與MQTT的區(qū)別

    Modbus和MQTT是工業(yè)領(lǐng)域中兩種不同的通信協(xié)議,在設(shè)計(jì)目標(biāo)、應(yīng)用場(chǎng)景、通信模式等方面存在顯著差異,以下從多個(gè)維度簡(jiǎn)析兩者的區(qū)別: 1.設(shè)計(jì)目標(biāo)與起源 Modbus 誕生于1979年,由施耐德
    的頭像 發(fā)表于 07-10 14:10 ?152次閱讀

    1553B總線常見(jiàn)三種組網(wǎng)方式

    其技術(shù)特點(diǎn)與選型策略。 一、單總線結(jié)構(gòu):基礎(chǔ)架構(gòu)與成本優(yōu)勢(shì) 單總線是1553B系統(tǒng)最簡(jiǎn)單的組網(wǎng)形式,由一條主干總線連接所有終端設(shè)備(最多31個(gè)遠(yuǎn)程終端RT),通過(guò)總線控制器(BC)集中
    的頭像 發(fā)表于 06-21 17:39 ?329次閱讀
    1553B<b class='flag-5'>總線</b>常見(jiàn)三種組網(wǎng)方式

    IIC接口的IIC_SCL和IIC_SDA引腳做普通GPIO,程序啟動(dòng)不起來(lái)怎么解決?

    想用IIC接口的IIC_SCL和IIC_SDA引腳做普通GPIO,兩個(gè)引腳對(duì)應(yīng)的是GPIO58和GPIO59,更改代碼將設(shè)置為普通GPIO引腳模式后,程序啟動(dòng)不起來(lái)。問(wèn):這種情況如何解決,官方支持這種應(yīng)用嗎?
    發(fā)表于 05-06 08:59

    ZYNQ FPGA的PS端IIC設(shè)備接口使用

    zynq系列中的FPGA,都會(huì)自帶兩個(gè)iic設(shè)備,我們直接調(diào)用其接口函數(shù)即可運(yùn)用。使用xilinx官方提供的庫(kù)函數(shù),開(kāi)發(fā)起來(lái)方便快捷。
    的頭像 發(fā)表于 04-17 11:26 ?1094次閱讀
    ZYNQ FPGA的PS端<b class='flag-5'>IIC</b>設(shè)備接口使用

    巨霖科技IIC Shanghai 2025精彩回顧

    近日,全球半導(dǎo)體行業(yè)矚目的國(guó)際集成電路展覽會(huì)暨研討會(huì)(IIC Shanghai 2025)在上海金茂君悅大酒店盛大開(kāi)幕。
    的頭像 發(fā)表于 03-28 11:27 ?552次閱讀

    為什么IIC總線會(huì)難住這么多人?

    為什么 IIC 總線讓很多人頭疼?其實(shí)可以把它想象成一場(chǎng)復(fù)雜的 "設(shè)備對(duì)話游戲",新手容易在這些地方栽跟頭:
    的頭像 發(fā)表于 03-12 10:14 ?520次閱讀
    為什么<b class='flag-5'>IIC</b><b class='flag-5'>總線</b>會(huì)難住這么多人?

    DLPC3435 IIC通信時(shí)候會(huì)干擾到DLPC3435正常工作,導(dǎo)致顯示花屏或者畫(huà)面不動(dòng)怎么解決?

    0x43,畫(huà)面即可恢復(fù)正常。 原因排查: 目前產(chǎn)品IIC總線上掛了一個(gè)Gsensor和DLPC3435,Gsensor采用輪詢方式每30ms會(huì)讀一次數(shù)據(jù)。 實(shí)驗(yàn)一:將IIC總線上掛
    發(fā)表于 02-21 09:53

    iic協(xié)議與其他總線協(xié)議比較

    在現(xiàn)代電子系統(tǒng)中,總線協(xié)議扮演著至關(guān)重要的角色,它們?cè)试S不同的電子組件之間進(jìn)行通信和數(shù)據(jù)交換。I2C協(xié)議是其中一種流行的總線協(xié)議,以其簡(jiǎn)單性和高效性而聞名。 1. I2C協(xié)議概述 I2C協(xié)議是一種
    的頭像 發(fā)表于 02-05 13:36 ?764次閱讀

    EE-116:SHARC簡(jiǎn)詞DMA

    電子發(fā)燒友網(wǎng)站提供《EE-116:SHARC簡(jiǎn)詞DMA.pdf》資料免費(fèi)下載
    發(fā)表于 01-05 09:56 ?0次下載
    EE-116:SHARC<b class='flag-5'>簡(jiǎn)</b>詞DMA

    愛(ài)芯元智亮相IIC Shenzhen 2024

    近日,國(guó)際集成電路展覽會(huì)暨研討會(huì)(IIC Shenzhen 2024)在深圳福田會(huì)展中心拉開(kāi)帷幕。作為業(yè)界最具影響力的系統(tǒng)設(shè)計(jì)盛會(huì)之一,IIC匯聚了國(guó)內(nèi)外電子產(chǎn)業(yè)領(lǐng)袖、管理人員、設(shè)計(jì)精英及決策者。在
    的頭像 發(fā)表于 11-07 15:41 ?752次閱讀

    MCU通過(guò)IIC口控制TLV320AIC3204,請(qǐng)問(wèn)MCU的IIC接口和TLV320AIC3204的IIC接口對(duì)接時(shí)需要電平轉(zhuǎn)換嗎?

    MCU通過(guò)IIC口控制TLV320AIC3204,該芯片的IOVDD接1.8V,MCU的IIC上拉電平是3.3V,請(qǐng)問(wèn)MCU的IIC接口和TLV320AIC3204的IIC接口對(duì)接時(shí)
    發(fā)表于 10-30 06:02

    前端總線是屬于什么總線

    前端總線(Front-Side Bus,簡(jiǎn)稱FSB)在計(jì)算機(jī)體系結(jié)構(gòu)中扮演著至關(guān)重要的角色,它屬于系統(tǒng)總線的一種,是連接CPU與主板北橋芯片(或稱為內(nèi)存控制器集線器)之間的高速數(shù)據(jù)通道。以下是對(duì)前端
    的頭像 發(fā)表于 10-10 17:11 ?1373次閱讀

    IIC信號(hào)線需要增加上拉電阻,是因?yàn)?b class='flag-5'>IIC的IO是什么

    IIC(Inter-Integrated Circuit,即集成電路總線)信號(hào)線需要增加上拉電阻,這主要是因?yàn)?b class='flag-5'>IIC的IO(輸入輸出)設(shè)計(jì)采用了開(kāi)漏(Open-Drain)輸出方式。開(kāi)漏輸出方式在
    的頭像 發(fā)表于 10-06 15:50 ?2088次閱讀

    IIC通訊協(xié)議解析

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

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

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