新聞中心

        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 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 偃师市| 彰化县| 枣庄市| 浑源县| 巴林左旗| 鄂温| 江阴市| 清涧县| 顺昌县| 永福县| 肃南| 金乡县| 来宾市| 巴东县| 吉首市| 四会市| 广丰县| 民县| 长汀县| 淳安县| 依兰县| 鸡泽县| 蒲城县| 马山县| 稷山县| 岚皋县| 西峡县| 大港区| 罗平县| 上虞市| 陕西省| 郯城县| 夏河县| 石台县| 谢通门县| 五河县| 金堂县| 剑川县| 阿拉尔市| 余江县| 巫溪县|