• <li id="00i08"><input id="00i08"></input></li>
  • <sup id="00i08"><tbody id="00i08"></tbody></sup>
    <abbr id="00i08"></abbr>
  • 新聞中心

    EEPW首頁 > 嵌入式系統 > 設計應用 > I2C總線通訊接口器件的CPLD實現

    I2C總線通訊接口器件的CPLD實現

    作者: 時間:2012-10-29 來源:網絡 收藏

    I2C(IIC)總線是PHILIPS公司開發的一種簡單、雙向、二線制、同步串行總線。它只需兩根線(串行時鐘線和串行數據線)即可在連接于總線上的器件之間傳送信息。該總線是高性能串行總線,具備多主機系統所需要的裁決和高低速設備同步等功能,應用極為廣泛。目前市場上雖然有專用IIC總線接口芯片,但是地址可選范圍小、性能指標固定、功能單一、使用不方便。根據IIC總線的電氣特性及其通訊協議,采用ALTERA公司的FLEX10K系列器件EPF10K10LC84-3可以方便地實現I2C(IIC)總線的,且具有高速、易調試、可以靈活地實現地在線配置等優點,同時大大地減少了系統的開發周期。

    1 IIC總線的數據傳輸規范

    I2C(IIC)總線主從機之間的一次數據傳送稱為一幀,由啟動信號、地址碼、若干數據字節、應答位以及停止信號等組成。通訊啟動時,主動發送一個啟動信號(當SCL線上是高電平時,SDA線上產生一個下降沿)、從機的地址碼(8位)和讀寫信號;通訊停止時,主機發送一個停止信號(當SCL線上是高電平時,SDA線上產生一個上升沿)。在數據傳送過程中,當SCL線上是高電平時,必須保證SDA線上的數據穩定;傳送一個字節的數據,必須由接收機發一個應答信號??偩€的傳輸碼速率為100kbps(標準)~400kbps(高速)。采用+5V電源供電時,輸入電平規定為:VILmax=1.5V,VIHmin=3V;采用寬電源電壓時,電平規定為:VILmax=1.5VDD,VIHmin=3VDD。 IIC總線的通訊過程如圖1所示。

    2 ISP的邏輯實現

    基于IIC總線的數據傳輸規范,為完成IIC總線的數據發送與接收,采用ISP器件實現的邏輯功能框圖如圖2所示。通過頻選、控制、可控時鐘可獲得100kHz、200kHz、300kHz、400kHz的時鐘頻率。器件退出總線競爭后,時鐘線置高電平。

    2.1 通訊的啟動與停止

    在主機方式下,接收數據時,ISP器件必須通過啟動信號生成器送出一個啟動信號,然后發送從機的地址信號和讀寫信號。只有這樣,才能在總線上發送數據。該過程由控制寄存器啟動。VHDL描述如下: PROCESS(WR,CS) ――WR IS CPU WRITE SIGNAL ――CS IS THIS CHIP"S SELECT SIGNAL ADDRS:="0"; IF(Ctrreg(0)="1"AND Ctrreg(3)="1" AND SCL1="1")THEN ――Ctrreg 為控制寄存器 CLK1COUNT:="0"; SDA1:="1"; IF(CLK1 EVENT AND CLK="0")THEN IF(CLK1COUNT="3")THEN SDA1:="1"; ADDRS:="1"; Ctrreg(3):="0"; CSTA:="1"; ELSE CLK1COUNT:=CLK1COUNT+1; END IF; END IF; END IF; IF(ADDRS="1"AND SCL1 "EVENT AND SCL1="1")THEN %26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;――將數據寄存器中的數據 %26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;%26;#183;――及WR信號移位發出(略) END IF; END PROCESS;當一次通訊結束時,主機要發送停止信號。該過程同樣同控制寄存器控制;當控制字第二位為"1"時,ISP器件產生停止信號。VHDL描述與啟動類似。


    上一頁 1 2 下一頁

    評論


    相關推薦

    技術專區

    關閉
    主站蜘蛛池模板: 宣汉县| 平谷区| 津市市| 本溪市| 卫辉市| 从化市| 巴塘县| 沈阳市| 兖州市| 河曲县| 乡宁县| 通化市| 东乌珠穆沁旗| 满洲里市| 白银市| 定日县| 墨竹工卡县| 洪洞县| 稻城县| 富民县| 穆棱市| 孝昌县| 南华县| 磴口县| 绩溪县| 定南县| 宜阳县| 巫溪县| 咸阳市| 六盘水市| 出国| 临高县| 安图县| 汉沽区| 临沂市| 吉林市| 美姑县| 尖扎县| 山东省| 孝感市| 赤峰市|