基于NiosII的I2C總線接口的實現(xiàn)-設(shè)計應(yīng)用_第1頁
基于NiosII的I2C總線接口的實現(xiàn)-設(shè)計應(yīng)用_第2頁
基于NiosII的I2C總線接口的實現(xiàn)-設(shè)計應(yīng)用_第3頁
基于NiosII的I2C總線接口的實現(xiàn)-設(shè)計應(yīng)用_第4頁
基于NiosII的I2C總線接口的實現(xiàn)-設(shè)計應(yīng)用_第5頁
已閱讀5頁,還剩3頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

精品文檔-下載后可編輯基于NiosII的I2C總線接口的實現(xiàn)-設(shè)計應(yīng)用

為了保護(hù)NiosⅡ嵌入式系統(tǒng)的運(yùn)行現(xiàn)場,在掉電之前,需要把系統(tǒng)的重要數(shù)據(jù)保存在非易失存貯器中。針對這種保存的數(shù)據(jù)量不大特點(diǎn),本文提出采用"NiosⅡ+AT24C02"設(shè)計方案,在介紹AT24C02A芯片主要特性和分析I2C通信協(xié)議原理基礎(chǔ)上,重點(diǎn)介紹NiosⅡ與AT24C02A之間接口電路的設(shè)計方法,包括接口電路的寄存器定義、邏輯功能模塊設(shè)計和驅(qū)動程序的編寫三個方而的內(nèi)容,利用嵌入式邏輯分析儀(SigalTapⅡLogicAnalyzer)來分析接口信號時序,分析結(jié)果表,本接口所產(chǎn)生的讀寫時序滿足I2C的通信協(xié)議要求,驗證了設(shè)計的正確性。

1AT24C02A芯片簡介

AT24C02A芯片,是由ATMEL公司生產(chǎn)的基于I2C總線型的串行電可擦除的可編程存儲器(EEPROM),內(nèi)部含有2Kbit的存儲單元,是通過二根線(SDL與SCL)與外部I2C控制器交換數(shù)據(jù)。

AT24C02A芯片的主要特性如下:

低電壓和標(biāo)準(zhǔn)電壓操作

-2.7(VCC=2.7V至5.5V)

-1.8(VCC=1.8V至5.5V)

片內(nèi)存儲容量為256×8bit(2K)

2線串行接口

施密特觸發(fā)器,過濾輸入的噪聲抑制

雙向數(shù)據(jù)傳輸協(xié)議

100kHz(1.8V、2.5V、2.7V)和400kHz(5V)兼容性

寫保護(hù)引腳的硬件數(shù)據(jù)保護(hù)。

2I2C通信協(xié)議

2.1I2C通信協(xié)議簡介

AT24C02A器件采用成本低廉的I2C(Interintegrat-edCircuit)總線通信協(xié)議,SDA和SCL均為雙向I/O線,通過上拉電阻接正電源。當(dāng)總線空閑時,兩根線都是高電平。連接總線的器件的輸出級必須是集電極或漏極開路的。I2C總線的數(shù)據(jù)傳送速率在標(biāo)準(zhǔn)工作方式下為100kbit/s,在快速方式下,傳送速率可達(dá)400kbit/s。

在數(shù)據(jù)傳送過程中,必須確認(rèn)數(shù)據(jù)傳送的開始和結(jié)束信號(也稱啟動和停止信號)。當(dāng)時鐘線SCL為高電平時,數(shù)據(jù)線SDA由高電平跳變?yōu)榈碗娖絼t定義為"開始"信號;當(dāng)SCL為高電平時,SDA由低電平跳變?yōu)楦唠娖絼t定義為"結(jié)束"信號。開始和結(jié)束信號都由主器件產(chǎn)生。在開始信號以后,總線即被認(rèn)為處于忙狀態(tài);在結(jié)束信號以后的一段時間內(nèi),總線被認(rèn)為是空閑狀態(tài)。

在I2C總線開始信號后,依次送出器件地址和數(shù)據(jù),I2C總線上每次傳送的數(shù)據(jù)字節(jié)數(shù)不限,但每一個字節(jié)必須為8位,而且每個傳送的字節(jié)后面必須跟一個認(rèn)可位(第9位),也叫應(yīng)答位(ACK)。從器件的響應(yīng)信號結(jié)束后,SDA線返回高電平,進(jìn)入下一個傳送周期。

2.2AT24C02A器件讀寫時序

一個寫功能要求一個8位數(shù)據(jù)字地址隨設(shè)備地址字和acknowledgement(承認(rèn))。在這個地址的收據(jù)之上,EEPROM將再響應(yīng)由一個0且時鐘在個8位數(shù)據(jù)字。隨著8位數(shù)據(jù)字的收據(jù),EEPROM將輸出一個0且尋址設(shè)備,例如一個微控制器,必須指定帶停止條件的寫時序。在這個時間EEPROM進(jìn)入一個internally-timed(內(nèi)部定時)寫時序,tWR,對于非易失性內(nèi)存。所有輸入關(guān)閉在這個鞋周期之間且EEPROM將不響應(yīng)直到寫完成(關(guān)系Figure2)。

讀功能被初始化與寫功能相同由外部的讀/寫選擇位在設(shè)備地址字被設(shè)置為1。有三個讀功能:當(dāng)前地址讀取,隨機(jī)地址讀取和順序讀取。

當(dāng)前地址讀取:內(nèi)部數(shù)據(jù)字地址計數(shù)器包含一個地址訪問在一個讀或?qū)懝δ芷陂g,以1遞增。這個地址保持有效在芯片電源提供工作期間。地址“折返”在讀來自于內(nèi)存頁到頁的個字節(jié)期間。這個地址“折返”在寫來自于當(dāng)前頁的一個字節(jié)到同樣頁的個字節(jié)期間。

圖2為寫(讀)AT24C02A器件中指定地址存儲單元的數(shù)據(jù)幀格式,圖2(a)為寫操作的幀格式,(b)為讀操作幀格式。要想把一個字節(jié)數(shù)據(jù)發(fā)送到器件中(或從器件中讀取一個字節(jié)數(shù)據(jù))除了給出具體的地址信息之外,還要給出該器件的控制信息:首先由控制器發(fā)出“啟動”信號,啟動I2C總線的通信,然后發(fā)送一個控制字節(jié),前7位為器件的片選地址,1位為讀寫控制位,“0”表示寫,“1”表示讀。當(dāng)傳完控制字節(jié)之后,掛在I2C總線的所有的器件比較控制字節(jié)片選地址(前7位)是否與自已的物理地址一致,如一致,則發(fā)一個應(yīng)答信號??刂破鹘邮盏綉?yīng)答信號之后,再發(fā)器件內(nèi)部存儲單元地址和其他的信息。

3AT24C02A讀寫控制接口設(shè)計

3.1寄存器組定義

為了實現(xiàn)NiosⅡI能與外部設(shè)備進(jìn)行交換數(shù)據(jù),首先要在AT24C08讀寫控制接口中定義寄存器,包括數(shù)據(jù)寄存器、狀態(tài)寄存器和控制寄存器。表4-1AT24C02A讀寫控制器內(nèi)部寄存器定義的情況:State_Re為此接口電路的狀態(tài)寄存器,位有效,用來表示接口電路的狀態(tài),“1”表示接口處于“忙”狀態(tài)中,此時表示接口正處于讀寫外部設(shè)備(AT24C02A)中,不能對此控制接口進(jìn)行操作,只到接口處于“0”狀態(tài)時為止;Address_Re為數(shù)據(jù)寄存器,用于存放NiosⅡ要訪問AT24C02A器件內(nèi)部單元的地址數(shù)據(jù);Control_Re為控制寄存器,控制著接口電路啟動或停止,“1”為啟動,“0”停止;Data_Re為數(shù)據(jù)寄存器,用于存放傳輸?shù)臄?shù)據(jù);Con_r/w_Re為控制寄存器,控制數(shù)據(jù)的傳輸方向,高電平為讀(輸入),低電平為寫(輸出)。

3.2邏輯功能模塊設(shè)計

在接口電路中,除了定義接口電路的寄存器組之外,還要利用硬件描述語言來描述接口電路要實現(xiàn)的功能,即邏輯功能模塊的設(shè)計。接口電路要完成的主要功能是,用接口電路產(chǎn)生如圖3所示的時序,成功讀寫外部存儲器件。在本設(shè)計中,采用了有限狀態(tài)機(jī)來實現(xiàn)這一功能,圖3為本設(shè)計的各個狀態(tài)之間轉(zhuǎn)換狀態(tài)圖:當(dāng)NiosⅡ要交換數(shù)據(jù)時,首先要讀State_Re的值,并判定電路是否為“空閑”狀態(tài),只有狀態(tài)機(jī)處在空閑狀態(tài),才允許進(jìn)行讀寫操作,并修改狀態(tài)寄存器的值為“忙”狀態(tài);當(dāng)完成讀寫操作時,修改狀態(tài)寄存器的值為“閑”狀態(tài)。

4在NiosⅡIDE環(huán)境中軟件設(shè)計

打開NiosⅡEDS,并點(diǎn)擊new菜單建立工程文件,在IDE環(huán)境中完成接口電路驅(qū)動程序編寫。驅(qū)動程序主要的任務(wù),是判斷接口電路所處的狀態(tài),當(dāng)接口電路處于“閑”狀態(tài)時,設(shè)置好接口電路中的寄存器中的值,并啟動讀寫操作。圖4為驅(qū)動程序的算法流程圖。

5測試結(jié)果

為了驗證設(shè)計的正確性,對以上設(shè)計進(jìn)行測試。在測試的過程中,可以利用嵌入式邏輯分析儀(SigalTapⅡLogicAnalyzer)來分析信號時序,打開工程文件,點(diǎn)擊File菜單,為本設(shè)計新建一個矢量波形文件(VectorwaveformFile),把要測試的信號添加到此文件中來,并設(shè)置好相關(guān)參數(shù),保存并編譯系統(tǒng),然后把系統(tǒng)的配制文件到EP1C6Q240C8可編程器件中等待調(diào)試,,在:NiosⅡ的IDE中,把驅(qū)動程序到可編程器件中,并在QuartusⅡ軟件中打開矢量波形文件,觀察被測信號的時序,圖5為接口電路把數(shù)據(jù)為“11111111”寫到地址為“10101010”單元中的時序圖。從圖可以看出,啟動時序、數(shù)據(jù)傳輸時序和停止時序都滿足I2C通信協(xié)議要求,驗證了本接口電路的正確性。

6結(jié)束語

本文在討論了I2C通信協(xié)議的基礎(chǔ)上,重點(diǎn)介紹了AT24C02A讀寫接口電路設(shè)計方法,包括接口電路的寄存器定義、邏輯功能模塊設(shè)計和驅(qū)動程序的編寫,并利用嵌入式邏輯分析儀(SigalTapⅡLogicAnalyzer)對本接口電路進(jìn)行測試,測試結(jié)果表明,本設(shè)計滿足設(shè)計要求,并在實際電路中得到應(yīng)用。

參考文獻(xiàn):

[1].AT24C02datasheet/datasheet/AT

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論