NiosII的I2C控制IP及其在成像系統中的應用

發(fā)布時(shí)間:2010-12-27 20:18    發(fā)布者:designer
關(guān)鍵詞: NIOS , 成像系統
1 IP的硬件結構及寄存器

1.1 IP硬件結構

IP內部結構如圖1所示。主要由波特率時(shí)鐘寄存器、寄存器組控制器、并行I/O接口、I2C可編程接口、I2C接口引擎5個(gè)模塊組成。





波特率時(shí)鐘產(chǎn)生器用來(lái)產(chǎn)生I2C IP工作的基本時(shí)鐘頻率;寄存器組控制器用來(lái)對寄存器進(jìn)行設置,設置數據通過(guò)并行I/O接口傳送到該模塊中;并行I/O接口模塊用來(lái)處理可編程接口模塊傳送過(guò)來(lái)的命令;I2C可編程接口模塊用來(lái)設置IP各個(gè)寄存器的地址;I2C接口引擎模塊執行I2C總線(xiàn)上數據的傳輸。

1.2 寄存器結構

I2C控制IP主要由6個(gè)寄存器構成,如表1所列。通過(guò)對寄存器的讀寫(xiě)可以方便地控制I2C總線(xiàn)數據的傳輸,從而實(shí)現NiosII處理器與設備之間的通信。數據寄存器用來(lái)存放I2C總線(xiàn)上要傳送的數據;波特率產(chǎn)生模塊,波特率時(shí)鐘寄存器和時(shí)鐘寄存器共同決定I2C總線(xiàn)上SCL的頻率。SCL的計算公式為其中System_clk是系統時(shí)鐘;Value是時(shí)鐘寄存器的值;divider是波特率時(shí)鐘寄存器的值所對應的分頻數(寄存器的值與分頻數相差為1,如寄存器設置為0,則分頻數為1;寄存器設置為1,則分頻數值為2)。

本地地址寄存器、控制寄存器、狀態(tài)寄存器的詳細介紹略——編者注。

2 I2C控制lP在成像系統中的應用

在成像系統中,CMOS傳感器應用非常普遍。這些傳感器大多數都自帶I2C串行通信接口,本文以MT9M011為例介紹I2C控制IP在成像系統中的應用。MT9M011傳感器根據讀寫(xiě)位數可分為兩種方式:16位數據讀寫(xiě)方式和8位數據讀寫(xiě)方式。這里選用曝光寄存器,采用16位讀寫(xiě)方式進(jìn)行操作,時(shí)序如圖2所示。









從設備地址(寫(xiě)模式)與從設備地址(讀模式)高7位為從器件地址,第8位是讀寫(xiě)控制位(R/W),它控制數據的傳輸方向。

向曝光寄存器0x09寫(xiě)入數據:主器件啟動(dòng)傳輸,然后發(fā)送它所要尋址的從設備地址(寫(xiě)模式)。MT9M011監視總線(xiàn),當其地址與傳送的從器件地址相符時(shí),響應一位應答信號,接著(zhù)主器件發(fā)送曝光寄存器地址,MT9M011再次應答,在向曝光寄存器中寫(xiě)入16位數據后主器件停止寫(xiě)數據。每傳送8位數據,從器件MT9M011都會(huì )產(chǎn)生一位應答信號。









從曝光寄存器0x09讀出數據:開(kāi)始部分與寫(xiě)數據時(shí)序是相同的,當主器件發(fā)送完從設備地址(寫(xiě)模式)和寄存器地址后,需要重新啟動(dòng),并發(fā)送從設備地址(讀模式),然后才能從寄存器中讀出數據。每讀完1字節數據,主器件都會(huì )產(chǎn)生1位應答信號。當16位數據被讀出后,主器件發(fā)送1位非應答信號,傳輸結束。









3 IP應用實(shí)例

3.1 硬件設計

本文使用I2C控制IP對圖像傳感器MT9M011寄存器進(jìn)行并行配置。硬件設計基于SOPC技術(shù),將系統組件庫提供的32位Nios II軟核處理器、SDRAM接口模塊、TIMER定時(shí)器模塊(提供SignaltapII中對信號進(jìn)行采樣的頻率)、PIO模塊以及I2C控制IP(配置為主設備)集成在一塊FPGA內。QuartusII頂層原理略——編者注。

  3.2 軟件設計

軟件的編寫(xiě)有兩種方式:一種是對I2C控制IP應用程序編程接口(API)函數的操作;另一種是利用Altera提供的讀寫(xiě)函數對寄存器進(jìn)行操作。為了提高系統運行的速度,采用第二種方法。系統軟件部分是在NiosII IDE中,通過(guò)編寫(xiě)C代碼完成的。

對CMOS寄存器的并行配置程序主要包括以下兩個(gè)部分:

①I(mǎi)P初始化設置:包括設置波特率、設置本地址寄存器、設置時(shí)鐘寄存器值。

②選擇CMOS1,對其寄存器進(jìn)行讀寫(xiě);選擇CMOS2,對其寄存器進(jìn)行讀寫(xiě)。寄存器選擇曝光寄存器。


   



關(guān)鍵代碼如下:

















函數checkBus查詢(xún)狀態(tài)寄存器的麗來(lái)判斷I2C總線(xiàn)忙/閑狀態(tài),checkProgres函數查詢(xún)狀態(tài)寄存器的PIN來(lái)判斷總線(xiàn)數據是否傳輸完成。為了便于觀(guān)察讀出的數據和寫(xiě)入的數據是否一致,通常將程序包含在while語(yǔ)句中。

4 實(shí)驗驗證

將硬件系統生成的下載文件燒寫(xiě)到FPGA芯片上并運行C代碼程序,用QuartusII自帶的SignahapII邏輯分析儀對I2C總線(xiàn)上的數據進(jìn)行觀(guān)察。圖3為所得到的波形,信號由上至下分別為CMOS2/CMOS1上的I2C總線(xiàn)信號m_sclk_2、m_sda_2、m_sclk_1、m_sda_1。前半部分給CMOS1寫(xiě)入0x06、0x07,然后讀出;后半部分對CMOS2寫(xiě)入相同的數并讀出。此波形滿(mǎn)足MT9M011圖像傳感器時(shí)序讀寫(xiě)要求。

5 系統擴展

在需要多路CMOS配置的應用中,使用該I2C控制IP可以很容易地實(shí)現多路并行CMOS寄存器配置。例如,8路并行CMOS配置系統:在電路板上焊接8片CMOS傳感器芯片,通過(guò)對分配器3路信號的控制 將使能并行加載到8塊CMOS芯片,3路控制信號和使能信號通過(guò)對SOPC系統的PIO接口模塊的控制來(lái)實(shí)現,配置數據的傳輸則在I2C控制IP的控制下完成。電路板結構簡(jiǎn)單,系統容易實(shí)現。

結 語(yǔ)

本文所介紹的I2C IP可作為自定義組件加載到SOPC系統中,使系統的設計更為靈活,功能擴展上具有較大的潛力。在采用CMOS圖像傳感器的成像系統中,I2C接口應用普遍,本文通過(guò)給出該IP應用實(shí)例,說(shuō)明了該IP的使用具有廣闊的前景和較高的應用價(jià)值。
本文地址:http://selenalain.com/thread-48033-1-1.html     【打印本頁(yè)】

本站部分文章為轉載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀(guān)點(diǎn)和對其真實(shí)性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問(wèn)題,我們將根據著(zhù)作權人的要求,第一時(shí)間更正或刪除。
您需要登錄后才可以發(fā)表評論 登錄 | 立即注冊

關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點(diǎn)地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權所有   京ICP備16069177號 | 京公網(wǎng)安備11010502021702
快速回復 返回頂部 返回列表
午夜高清国产拍精品福利|亚洲色精品88色婷婷七月丁香|91久久精品无码一区|99久久国语露脸精品|动漫卡通亚洲综合专区48页